:root {
  --navy: #050b1a;
  --navy2: #070e1c;
  --navy3: #0c1525;
  --gold: #c9a84c;
  --gold-light: #e8c97a;
  --gold-dark: #b89050;
  --cream: #f5efe0;
  --white: #ffffff;
  --gray: #c4b89a;
  --gray-light: #d9cfb5;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:103%; }

body {
  background-color: #050b1a;
  background-image: linear-gradient(rgba(5,11,26,0.35), rgba(5,11,26,0.35)), url("hero-bg.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center top;
  background-attachment: fixed;
  color: var(--cream);
  font-family: "Montserrat", sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}

/* STARS */



/* NAVBAR */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 60px; transition:all 0.4s;
}
nav.scrolled {
  background:rgba(5,11,26,0.95); backdrop-filter:blur(20px);
  padding:8px 60px; border-bottom:1px solid rgba(201,168,76,0.15);
}
.nav-logo { cursor:pointer; display:flex; align-items:center; }
.nav-logo img { height:42px; width:auto; display:block; transition:height 0.4s; }
nav.scrolled .nav-logo img { height:36px; }
.nav-links { display:flex; align-items:center; gap:40px; list-style:none; }
.nav-links a {
  font-size:0.8rem; letter-spacing:0.25em; text-transform:uppercase;
  color:var(--gray-light); text-decoration:none; cursor:pointer; transition:color 0.3s; position:relative;
}
.nav-links a::after { content:""; position:absolute; bottom:-4px; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transition:transform 0.3s; }
.nav-links a:hover, .nav-links a.active { color:var(--gold); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.lang-switch { display:flex; gap:6px; align-items:center; }
.lang-btn { font-size:0.58rem; letter-spacing:0.2em; color:var(--gray); cursor:pointer; padding:4px 8px; border:1px solid transparent; transition:all 0.3s; text-transform:uppercase; background:none; font-family:"Montserrat",sans-serif; }
.lang-btn.active, .lang-btn:hover { color:var(--gold); border-color:rgba(201,168,76,0.4); }
.lang-sep { color:var(--gold-dark); font-size:0.6rem; }
.mobile-menu-btn { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.mobile-menu-btn span { display:block; width:22px; height:1px; background:var(--gold); transition:transform 0.3s, opacity 0.3s; transform-origin:center; }
body.nav-open nav { background:rgba(5,11,26,0.98); backdrop-filter:blur(20px); }
body.nav-open .mobile-menu-btn span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
body.nav-open .mobile-menu-btn span:nth-child(2){ opacity:0; }
body.nav-open .mobile-menu-btn span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

/* MOBILE NAV */
.mobile-nav { display:none; position:fixed; inset:0; background:rgba(5,11,26,0.98); z-index:999; flex-direction:column; align-items:center; justify-content:flex-start; gap:22px; overflow-y:auto; padding:96px 20px 72px; -webkit-overflow-scrolling:touch; }
.mobile-nav.open { display:flex; }
.mobile-nav a { font-family:"Cormorant Garant",serif; font-size:2.4rem; font-weight:300; color:var(--cream); text-decoration:none; cursor:pointer; transition:color 0.3s; }
.mobile-nav a:hover { color:var(--gold); }
.mobile-nav-close { display:none; }

/* PAGES */
.page { display:none; }
.page.active { display:block; }

/* HERO */
.hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:80px 40px 40px; position:relative; z-index:2;
}
.hero-logo {
  width:clamp(240px, 34vw, 420px); margin-bottom:20px;
  animation:heroFade 1.4s ease both;
  border-radius: 2px;
}
@keyframes heroFade { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
.hero-divider { width:80px; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); margin:0 auto 18px; animation:fadeUp 1s 0.6s both; }
.hero-tagline { font-family:"Cormorant Garant",serif; font-size:clamp(1.2rem,2.6vw,2rem); font-weight:300; font-style:italic; color:var(--cream); text-align:center; line-height:1.35; margin-bottom:12px; animation:fadeUp 1s 0.7s both; }
.hero-tagline em { color:var(--gold); }
.hero-sub { font-family:"Playfair Display",serif; font-style:italic; font-size:0.82rem; font-weight:400; letter-spacing:0.04em; color:var(--gray-light); text-align:center; line-height:1.8; margin-bottom:28px; animation:fadeUp 1s 0.9s both; }
.hero-cta { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; animation:fadeUp 1s 1.05s both; }
.scroll-indicator { display:flex; flex-direction:column; align-items:center; gap:6px; margin-top:30px; animation:fadeUp 1s 1.3s both; }
.scroll-line { width:1px; height:32px; background:linear-gradient(180deg,var(--gold),transparent); animation:scrollPulse 2s ease-in-out infinite; }
.scroll-text { font-size:0.46rem; letter-spacing:0.4em; text-transform:uppercase; color:var(--gray); }
@keyframes scrollPulse { 0%,100%{opacity:0.3} 50%{opacity:1} }

/* BUTTONS */
.btn-gold { display:inline-block; text-align:center; text-decoration:none; font-size:0.6rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--navy); background:linear-gradient(135deg,var(--gold-light),var(--gold)); padding:16px 44px; cursor:pointer; transition:all 0.3s; border:none; font-family:"Montserrat",sans-serif; font-weight:500; }
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 12px 40px rgba(201,168,76,0.35); }
.btn-outline { display:inline-block; text-align:center; text-decoration:none; font-size:0.6rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); background:transparent; padding:15px 44px; cursor:pointer; transition:all 0.3s; border:1px solid rgba(201,168,76,0.45); font-family:"Montserrat",sans-serif; font-weight:400; }
.btn-outline:hover { background:rgba(201,168,76,0.08); border-color:var(--gold); transform:translateY(-2px); }

/* MARQUEE */
.marquee-wrap { border-top:1px solid rgba(201,168,76,0.12); border-bottom:1px solid rgba(201,168,76,0.12); height:46px; display:flex; align-items:center; overflow:hidden; background:rgba(5,11,26,0.7); position:relative; z-index:2; }
.marquee-track { display:flex; align-items:center; white-space:nowrap; animation:marquee 60s linear infinite; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.marquee-item { font-family:"Playfair Display",serif; font-style:italic; font-size:0.95rem; font-weight:400; letter-spacing:0.02em; color:var(--gray-light); padding:0 36px; line-height:1; }
.marquee-dot { color:var(--gold); font-size:0.7rem; padding:0 14px; line-height:1; }

/* ABOUT */
.about-section { padding:100px 60px; max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; position:relative; z-index:2; }
.section-label { font-size:0.55rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.section-heading { font-family:"Playfair Display",serif; font-size:clamp(2rem,3.5vw,3.2rem); font-weight:400; color:var(--white); line-height:1.2; letter-spacing:-0.01em; margin-bottom:24px; }
.section-heading em { font-style:italic; color:var(--gold); }
.section-text { font-size:0.88rem; line-height:2.1; color:var(--gray); letter-spacing:0.04em; }
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.stat-box { background:rgba(7,14,32,0.85); border:1px solid rgba(201,168,76,0.08); padding:36px 28px; position:relative; transition:border-color 0.3s; }
.stat-box::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); }
.stat-box:hover { border-color:rgba(201,168,76,0.25); }
.stat-num { font-family:"Cormorant Garant",serif; font-size:2.8rem; font-weight:300; color:var(--gold); line-height:1; margin-bottom:8px; }
.stat-lbl { font-size:0.56rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gray); }
.stat-langs { font-size:1.6rem !important; letter-spacing:0.04em; }

/* GALLERY (Featured Moments) */
.gallery-section { padding:100px 60px 80px; max-width:1400px; margin:0 auto; position:relative; z-index:2; }
.gallery-header { text-align:center; margin-bottom:60px; }
.gallery-eyebrow { font-size:0.55rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.gallery-heading { font-family:"Playfair Display",serif; font-size:clamp(2rem,3.5vw,3rem); font-weight:400; color:var(--white); line-height:1.2; letter-spacing:-0.01em; margin-bottom:20px; }
.gallery-heading em { font-style:italic; color:var(--gold); }
.gallery-intro { font-family:"Cormorant Garant",serif; font-style:italic; font-size:1rem; line-height:1.7; color:var(--gray-light); max-width:680px; margin:0 auto; letter-spacing:0.03em; padding:0 20px; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery-item { aspect-ratio:4/3; overflow:hidden; position:relative; cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease, filter 0.4s ease; filter:saturate(85%) brightness(0.9) contrast(1.05); }
.gallery-item:hover img { transform:scale(1.06); filter:saturate(110%) brightness(1) contrast(1); }
.gallery-item::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 50%,rgba(5,11,26,0.85)); pointer-events:none; }
.gallery-caption { position:absolute; bottom:20px; left:22px; right:22px; z-index:2; color:var(--cream); font-family:"Playfair Display",serif; font-style:italic; font-size:1.2rem; text-shadow:0 2px 12px rgba(5,11,26,0.85), 0 1px 4px rgba(5,11,26,0.6); }
.gallery-sub { display:none; }

/* TESTIMONIALS */
.testimonials-section { padding:100px 60px; max-width:1400px; margin:0 auto; position:relative; z-index:2; }
.testimonials-header { text-align:center; margin-bottom:70px; }
.testimonial-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.testimonial-card { background:rgba(7,14,32,0.7); border:1px solid rgba(201,168,76,0.1); padding:42px 32px; position:relative; transition:border-color 0.4s; }
.testimonial-card:hover { border-color:rgba(201,168,76,0.3); }
.testimonial-card::before { content:"\201C"; position:absolute; top:8px; left:20px; font-family:"Playfair Display",serif; font-size:5rem; color:var(--gold); opacity:0.25; line-height:1; }
.testimonial-text { font-family:"Playfair Display",serif; font-style:italic; font-size:1rem; line-height:1.7; color:var(--cream); margin-bottom:24px; position:relative; z-index:1; }
.testimonial-author { font-size:0.62rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gold); }
.testimonial-author-loc { font-size:0.6rem; letter-spacing:0.15em; color:var(--gray); margin-top:4px; }



@media (max-width:780px) {
}

/* CUSTOM BANNER - Beyond the Six */
.custom-banner { max-width:1100px; margin:30px auto 80px; padding:65px 60px; text-align:center; position:relative; z-index:2; border-top:1px solid rgba(201,168,76,0.18); border-bottom:1px solid rgba(201,168,76,0.18); background:linear-gradient(180deg,transparent,rgba(201,168,76,0.025),transparent); }
.custom-banner::before { content:"◆"; position:absolute; top:-8px; left:50%; transform:translateX(-50%); color:var(--gold); font-size:0.7rem; background:var(--navy); padding:0 14px; }
.custom-eyebrow { font-size:0.55rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.custom-heading { font-family:"Playfair Display",serif; font-size:clamp(1.7rem,3vw,2.6rem); font-weight:400; color:var(--white); line-height:1.2; letter-spacing:-0.01em; margin-bottom:20px; }
.custom-heading em { font-style:italic; color:var(--gold); }
.custom-text { font-family:"Playfair Display",serif; font-style:italic; font-size:1rem; line-height:1.8; color:var(--gray-light); max-width:580px; margin:0 auto 36px; }
@media (max-width:780px) {
  .custom-banner { padding:50px 24px; margin:20px 22px 50px; }
}

/* FAQ — What to Expect */
.faq-section { padding:100px 60px; max-width:1000px; margin:0 auto; position:relative; z-index:2; }
.faq-header { text-align:center; margin-bottom:60px; }
.faq-grid { display:grid; gap:2px; }
.faq-item { background:rgba(7,14,32,0.6); border:1px solid rgba(201,168,76,0.08); padding:30px 36px; transition:all 0.4s; cursor:pointer; }
.faq-item:hover { background:rgba(12,22,42,0.85); border-color:rgba(201,168,76,0.22); }
.faq-question { display:flex; justify-content:space-between; align-items:center; gap:20px; }
.faq-q-text { font-family:"Playfair Display",serif; font-style:italic; font-size:1.1rem; color:var(--cream); line-height:1.4; }
.faq-toggle { width:28px; height:28px; border:1px solid rgba(201,168,76,0.4); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:1rem; flex-shrink:0; transition:all 0.3s; }
.faq-item.open .faq-toggle { background:var(--gold); color:var(--navy); transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s ease, padding-top 0.4s ease; }
.faq-item.open .faq-answer { max-height:300px; padding-top:18px; }
.faq-answer p { font-size:0.88rem; line-height:1.95; color:var(--gray-light); }
@media (max-width:780px) {
  .faq-section { padding:60px 22px; }
  .faq-item { padding:24px 22px; }
  .faq-q-text { font-size:0.95rem; }
}

/* FINAL CTA */
.final-cta { padding:120px 60px; text-align:center; position:relative; z-index:2; background:linear-gradient(180deg,transparent,rgba(201,168,76,0.04),transparent); }
.final-cta-eyebrow { font-size:0.55rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.final-cta-heading { font-family:"Playfair Display",serif; font-size:clamp(2.4rem,5vw,4rem); font-weight:400; color:var(--white); line-height:1.15; letter-spacing:-0.01em; margin-bottom:24px; max-width:800px; margin-left:auto; margin-right:auto; }
.final-cta-heading em { font-style:italic; color:var(--gold); }
.final-cta-text { font-size:0.95rem; line-height:1.9; color:var(--gray-light); max-width:580px; margin:0 auto 44px; font-family:"Playfair Display",serif; font-style:italic; }
.final-cta-buttons { display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }

/* RESPONSIVE for new sections */
@media (max-width:780px) {
  .gallery-section, .testimonials-section { padding:60px 22px; }
  .testimonial-grid { grid-template-columns:1fr; gap:18px; }
  .testimonial-card { padding:34px 26px; }
  .final-cta { padding:80px 22px; }
  .stat-langs { font-size:1.2rem !important; }
}

/* PAGE HERO */
.page-hero { min-height:42vh; display:flex; align-items:flex-end; padding:100px 60px 52px; position:relative; z-index:2; }
.page-hero::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.page-title-wrap { max-width:1200px; width:100%; margin:0 auto; }
.page-eyebrow { font-size:0.54rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.page-title { font-family:"Playfair Display",serif; font-size:clamp(2.8rem,6vw,5rem); font-weight:400; color:var(--white); line-height:1.05; letter-spacing:-0.01em; animation:fadeUp 0.8s ease both; }
.page-title em { font-style:italic; color:var(--gold); }

/* SERVICES */
.services-section { padding:70px 60px 110px; max-width:1200px; margin:0 auto; position:relative; z-index:2; }
.services-intro { max-width:680px; margin-bottom:70px; }
.services-intro-title { font-family:"Playfair Display",serif; font-size:clamp(1.6rem,3vw,2.4rem); font-weight:400; color:var(--white); line-height:1.2; letter-spacing:-0.01em; margin-bottom:22px; }
.services-intro-title em { font-style:italic; color:var(--gold); }
.services-intro p { font-size:0.95rem; line-height:2; color:var(--gray-light); font-family:"Playfair Display",serif; font-style:italic; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.service-card { background:linear-gradient(180deg,rgba(7,14,32,0.78) 0%,rgba(7,14,32,0.62) 40%,rgba(7,14,32,0.95) 100%),var(--service-bg) center/cover no-repeat,rgba(7,14,32,0.8); padding:44px 32px 64px; position:relative; overflow:hidden; cursor:pointer; transition:all 0.4s; border:1px solid rgba(201,168,76,0.06); }
.service-card:hover { background:linear-gradient(180deg,rgba(7,14,32,0.55) 0%,rgba(7,14,32,0.38) 40%,rgba(7,14,32,0.88) 100%),var(--service-bg) center/cover no-repeat,rgba(12,22,42,0.95); border-color:rgba(201,168,76,0.4); }
.service-card::before { content:""; position:absolute; bottom:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); transform:scaleX(0); transform-origin:left; transition:transform 0.4s; z-index:2; }
.service-card:hover::before { transform:scaleX(1); }
.service-card.featured { background:linear-gradient(145deg,rgba(20,28,12,0.82),rgba(15,22,8,0.92)),var(--service-bg) center/cover no-repeat,rgba(15,22,8,0.9); border-color:rgba(201,168,76,0.22); }
.service-card.featured:hover { background:linear-gradient(145deg,rgba(20,28,12,0.6),rgba(15,22,8,0.78)),var(--service-bg) center/cover no-repeat,rgba(15,22,8,0.9); border-color:rgba(201,168,76,0.45); }
.service-bachelor { --service-bg:url('bachelor-hero.webp'); }
.service-boat { --service-bg:url('boat-hero.webp'); }
.service-birthday { --service-bg:url('birthday-hero.webp'); }
.service-gender { --service-bg:url('gender-hero.webp'); }
.service-private { --service-bg:url('private-hero.webp'); }
.service-private-celebration { --service-bg:url('private-hero.webp'); }
.service-vip { --service-bg:url('vip-hero.webp'); }
.service-card.featured::after { content:"SIGNATURE"; position:absolute; top:18px; right:18px; font-size:0.48rem; letter-spacing:0.35em; color:var(--gold); border:1px solid rgba(201,168,76,0.4); padding:5px 12px; background:rgba(201,168,76,0.05); }
.service-num { font-family:"Cormorant Garant",serif; font-size:3.2rem; font-weight:300; color:rgba(201,168,76,0.1); line-height:1; margin-bottom:20px; transition:color 0.3s; }
.service-card:hover .service-num { color:rgba(201,168,76,0.22); }
.service-icon { width:42px; height:42px; margin-bottom:22px; display:block; color:var(--gold); transition:transform 0.4s ease; }
.service-card:hover .service-icon { transform:scale(1.08); }
.service-name { font-family:"Cormorant Garant",serif; font-size:2rem; font-weight:600; color:var(--white); margin-bottom:8px; }
.service-fr { font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:20px; }
body.lang-en .service-fr { display:none; }
.service-desc { font-size:0.82rem; line-height:2; color:var(--gray); }
.service-arrow { position:absolute; bottom:28px; right:28px; width:30px; height:30px; border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:0.75rem; transition:all 0.3s; }
.service-card:hover .service-arrow { background:var(--gold); color:var(--navy); border-color:var(--gold); }

/* PROCESS */
.process-section { padding:80px 60px; background:rgba(5,11,26,0.6); position:relative; z-index:2; }
.process-inner { max-width:1200px; margin:0 auto; }
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
.process-steps::before { content:""; position:absolute; top:28px; left:8%; right:8%; height:1px; background:linear-gradient(90deg,transparent,rgba(201,168,76,0.3),transparent); }
.step { padding:0 24px 0 0; }
.step-num { width:56px; height:56px; border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; font-family:"Cormorant Garant",serif; font-size:1.2rem; color:var(--gold); margin-bottom:28px; background:var(--navy2); position:relative; z-index:2; }
.step-title { font-family:"Playfair Display",serif; font-size:1.15rem; font-weight:500; color:var(--white); margin-bottom:14px; letter-spacing:-0.01em; }
.step-desc { font-size:0.78rem; line-height:2; color:var(--gray); }

/* CONTACT */
.contact-section { padding:80px 60px 110px; max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:90px; align-items:start; position:relative; z-index:2; }
.contact-title { font-family:"Cormorant Garant",serif; font-size:clamp(1.8rem,3.5vw,3rem); font-weight:300; color:var(--white); line-height:1.2; margin-bottom:24px; }
.contact-title em { font-style:italic; color:var(--gold); }
.contact-text { font-size:0.85rem; line-height:2.1; color:var(--gray); margin-bottom:44px; }
.contact-detail { display:flex; gap:18px; margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid rgba(201,168,76,0.06); align-items:flex-start; }
.contact-detail:last-child { border-bottom:none; }
.c-icon { width:40px; height:40px; border:1px solid rgba(201,168,76,0.22); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:0.9rem; flex-shrink:0; }
.c-lbl { font-size:0.5rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:4px; }
.c-val { font-size:0.88rem; color:var(--cream); letter-spacing:0.05em; }
.form-wrap { background:rgba(7,14,32,0.85); padding:48px 42px; border:1px solid rgba(201,168,76,0.12); position:relative; }
.form-wrap::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); }
.form-title { font-family:"Cormorant Garant",serif; font-size:1.75rem; font-weight:300; color:var(--white); margin-bottom:4px; }
.form-sub { font-size:0.57rem; letter-spacing:0.15em; color:var(--gray); margin-bottom:34px; text-transform:uppercase; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { margin-bottom:18px; }
.form-label { font-size:0.5rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gold-dark); display:block; margin-bottom:7px; }
.form-input, .form-select, .form-textarea { width:100%; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07); padding:14px 16px; color:var(--cream); font-family:"Montserrat",sans-serif; font-size:0.85rem; font-weight:300; letter-spacing:0.04em; outline:none; transition:border-color 0.3s; border-radius:0; -webkit-appearance:none; }
.form-select { cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23c9a84c'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }
.form-select option { background:var(--navy2); color:var(--cream); }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:rgba(201,168,76,0.45); }
.form-input::placeholder, .form-textarea::placeholder { color:rgba(255,255,255,0.18); }
.form-textarea { resize:vertical; min-height:96px; }
.form-submit { width:100%; margin-top:6px; }
.success-msg { display:none; background:rgba(201,168,76,0.08); border:1px solid rgba(201,168,76,0.3); padding:18px; margin-top:14px; font-size:0.63rem; letter-spacing:0.1em; color:var(--gold); text-align:center; }

/* FOOTER */
footer { background:rgba(2,5,10,0.95); border-top:1px solid rgba(201,168,76,0.1); padding:60px 60px 38px; position:relative; z-index:2; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-logo { height:58px; width:auto; margin-bottom:16px; }
.footer-tagline { font-size:0.78rem; line-height:1.9; color:var(--gray); max-width:280px; }
.footer-col-title { font-size:0.53rem; letter-spacing:0.35em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer-links li span, .footer-links li a { font-size:0.78rem; color:var(--gray); text-decoration:none; letter-spacing:0.06em; transition:color 0.3s; }
.footer-links li a { cursor:pointer; }
.footer-links li a:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.04); padding-top:26px; display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:0.53rem; letter-spacing:0.14em; color:var(--gray); text-transform:uppercase; }
.footer-copy-wrap { display:flex; align-items:center; flex-wrap:wrap; gap:8px 18px; }
.footer-copy-wrap a { font-size:0.53rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--gray); }
.footer-socials { display:flex; gap:18px; }
.social-btn { width:58px; height:58px; --soc:30px; border:1px solid rgba(201,168,76,0.2); display:flex; align-items:center; justify-content:center; color:var(--gray); font-size:0.65rem; cursor:pointer; transition:all 0.3s; text-decoration:none; flex:0 0 auto; }
.social-btn svg { width:var(--soc); height:var(--soc); }
.social-btn[aria-label="WhatsApp"] svg, .social-btn[aria-label="LINE"] svg { width:calc(var(--soc) * 0.78); height:calc(var(--soc) * 0.78); }
.social-btn[aria-label="Facebook"] svg { width:calc(var(--soc) * 1.18); height:calc(var(--soc) * 1.18); }
.social-btn[aria-label="TikTok"] svg { width:calc(var(--soc) * 1.06); height:calc(var(--soc) * 1.06); }
.social-btn:hover { border-color:var(--gold); color:var(--gold); }

@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

@media (max-width:900px) {
  nav { padding:16px 22px; } nav.scrolled { padding:10px 22px; }
  .nav-links { display:none; } .mobile-menu-btn { display:flex !important; }
  .hero { padding:100px 24px 60px; }
  .about-section { grid-template-columns:1fr; padding:60px 24px; gap:50px; }
  .services-grid { grid-template-columns:1fr; } .services-section { padding:60px 24px; }
  .process-section { padding:60px 24px; } .process-steps { grid-template-columns:1fr 1fr; gap:36px; } .process-steps::before { display:none; }
  .page-hero { padding:90px 22px 40px; }
  .contact-section { grid-template-columns:1fr; padding:60px 22px 80px; gap:48px; }
  .form-row { grid-template-columns:1fr; } .form-wrap { padding:28px 20px; }
  footer { padding:48px 22px 104px; } .footer-top { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:14px; }
  .footer-socials { flex-wrap:nowrap; gap:10px; }
  .social-btn { width:46px; height:46px; --soc:24px; }
}

/* SERVICE DETAIL PAGES */
.back-link { display:inline-flex; align-items:center; gap:10px; font-size:0.58rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); cursor:pointer; margin-bottom:28px; transition:all 0.3s; text-decoration:none; background:none; border:none; font-family:"Montserrat",sans-serif; }
.back-link:hover { gap:14px; }
.back-link .arr { font-size:0.9rem; }

.detail-section { padding:30px 60px 80px; max-width:1200px; margin:0 auto; position:relative; z-index:2; }
.detail-grid { display:grid; grid-template-columns:1.3fr 1fr; gap:80px; align-items:start; margin-bottom:80px; }
.detail-heading { font-family:"Cormorant Garant",serif; font-size:clamp(1.6rem,2.6vw,2.2rem); font-weight:400; color:var(--white); margin-bottom:22px; line-height:1.3; }
.detail-heading em { font-style:italic; color:var(--gold); }
.detail-para { font-size:0.9rem; line-height:2; color:var(--gray); margin-bottom:18px; letter-spacing:0.03em; }
.includes-box { background:rgba(7,14,32,0.7); border:1px solid rgba(201,168,76,0.15); padding:36px 32px; position:relative; }
.includes-box::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); }
.includes-title { font-size:0.55rem; letter-spacing:0.35em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.includes-intro { font-family:"Playfair Display",serif; font-style:italic; font-size:0.82rem; line-height:1.6; color:var(--gray-light); margin-bottom:26px; }
.includes-list { list-style:none; display:flex; flex-direction:column; gap:14px; }
.includes-list li { font-size:0.85rem; line-height:1.7; color:var(--cream); padding-left:22px; position:relative; letter-spacing:0.02em; }
.includes-list li::before { content:"◆"; position:absolute; left:0; top:1px; color:var(--gold); font-size:0.55rem; }

/* SIGNATURE EXPERIENCES SECTION (Bachelor page) */
.signature-experiences { margin-bottom:80px; position:relative; }
.signature-experiences-header { text-align:center; margin-bottom:50px; }
.signature-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; margin-top:50px; margin-bottom:45px; }
.signature-theme { background:rgba(7,14,32,0.7); border:1px solid rgba(201,168,76,0.15); padding:30px 28px; position:relative; }
.signature-theme::before { content:""; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--gold),transparent); }
.signature-theme-title { font-family:"Cormorant Garant",serif; font-size:1.4rem; font-weight:400; color:var(--gold); text-align:center; padding-bottom:14px; margin-bottom:18px; border-bottom:1px solid rgba(201,168,76,0.2); letter-spacing:0.08em; }
.signature-tier { display:flex; justify-content:space-between; align-items:center; gap:24px; padding:14px 16px; margin-bottom:10px; background:rgba(201,168,76,0.04); border:1px solid rgba(201,168,76,0.1); transition:all 0.3s ease; }
.signature-tier:hover { background:rgba(201,168,76,0.08); border-color:rgba(201,168,76,0.28); transform:translateY(-1px); }
.signature-tier:last-child { margin-bottom:0; }
.signature-tier-info { display:flex; align-items:center; gap:12px; flex:1; min-width:0; }
.signature-tier-icon { font-size:1rem; }
.signature-tier-name { font-family:"Cormorant Garant",serif; font-size:1rem; color:var(--cream); letter-spacing:0.03em; }
.signature-tier-price { font-family:"Montserrat",sans-serif; font-weight:500; color:var(--gold); font-size:0.85rem; letter-spacing:0.05em; flex-shrink:0; white-space:nowrap; text-align:right; }
.signature-cta { text-align:center; padding:35px 30px; background:rgba(7,14,32,0.5); border:1px solid rgba(201,168,76,0.12); }
.signature-cta-text { font-family:"Playfair Display",serif; font-style:italic; font-size:0.95rem; line-height:1.7; color:var(--gray-light); margin-bottom:24px; max-width:600px; margin-left:auto; margin-right:auto; }
.signature-cta-text em { color:var(--gold); font-style:italic; }
.signature-download-btn { display:inline-block; text-decoration:none; }
/* Bilingual download links - show/hide by lang */
.signature-link-fr { display:none; }
body.lang-fr .signature-link-fr { display:inline-block; }
body.lang-fr .signature-link-en { display:none; }

.gallery-label { font-size:0.55rem; letter-spacing:0.45em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.gallery-title { font-family:"Cormorant Garant",serif; font-size:clamp(1.8rem,3vw,2.6rem); font-weight:300; color:var(--white); margin-bottom:40px; }
.gallery-title em { font-style:italic; color:var(--gold); }
.gallery-hero { width:100%; aspect-ratio:16/9; overflow:hidden; margin-bottom:14px; position:relative; cursor:pointer; background:rgba(7,14,32,0.9); }
.gallery-hero img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease, filter 0.4s ease; filter:saturate(88%) brightness(0.9) contrast(1.05); display:block; }
.gallery-hero:hover img { transform:scale(1.03); filter:saturate(110%) brightness(1) contrast(1); }
.gallery-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(5,11,26,0.5)); pointer-events:none; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:auto; gap:14px; margin-bottom:60px; height:auto; }
.gallery-item { position:relative; overflow:hidden; background:rgba(7,14,32,0.9); cursor:pointer; aspect-ratio:1/1; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; display:block; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-item::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(5,11,26,0.5) 70%,rgba(5,11,26,0.92) 100%); pointer-events:none; }
@media (max-width:780px) {
  .gallery-grid { grid-template-columns:1fr 1fr !important; gap:8px !important; margin-bottom:40px !important; }
  .gallery-hero { margin-bottom:8px !important; }
  /* Birthday hero on mobile: full image (keeps buffet + sea), just brighter */
  .birthday-hero-feature { aspect-ratio:16/9 !important; }
  .birthday-hero-feature img { object-position:center; filter:saturate(104%) brightness(1) contrast(1.02) !important; }
}

/* SCENARIO ROWS — alternating text/image storytelling */
.scenario-intro { max-width:720px; margin:0 auto 80px; text-align:center; padding:0 20px; }
.scenario-intro p { font-size:0.95rem; line-height:2; color:var(--gray-light); letter-spacing:0.04em; font-family:"Cormorant Garant",serif; font-style:italic; }
.scenario-row { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; margin-bottom:90px; }
.scenario-row.reverse .scenario-image { order:2; }
.scenario-image { aspect-ratio:3/2; overflow:hidden; position:relative; background:rgba(7,14,32,0.9); }
.scenario-image img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s ease, filter 0.4s ease; filter:saturate(88%) brightness(0.92) contrast(1.05); display:block; }
.scenario-image:hover img { transform:scale(1.04); filter:saturate(108%) brightness(1) contrast(1); }
.scenario-image::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 65%,rgba(5,11,26,0.4)); pointer-events:none; }
.scenario-eyebrow { font-size:0.55rem; letter-spacing:0.42em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.scenario-title { font-family:"Cormorant Garant",serif; font-size:clamp(1.5rem,2.4vw,2rem); font-weight:400; color:var(--white); margin-bottom:20px; line-height:1.3; }
.scenario-title em { font-style:italic; color:var(--gold); }
.scenario-text { font-size:0.88rem; line-height:1.95; color:var(--gray); letter-spacing:0.03em; }
.scenario-pair { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:80px; }
.scenario-pair .gallery-item { aspect-ratio:1/1; }
@media (max-width:900px) {
  .scenario-intro { margin-bottom:50px; }
  .scenario-row { grid-template-columns:1fr; gap:24px; margin-bottom:60px; }
  .scenario-row.reverse .scenario-image { order:0; }
  .scenario-image { aspect-ratio:3/2; }
  .scenario-pair { gap:8px; margin-bottom:50px; }
}

.cta-banner { background:linear-gradient(135deg,rgba(20,15,5,0.85),rgba(8,12,22,0.9)); border:1px solid rgba(201,168,76,0.25); padding:60px 50px; text-align:center; position:relative; overflow:hidden; }
.cta-banner::before { content:""; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.cta-banner-title { font-family:"Cormorant Garant",serif; font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:300; color:var(--white); margin-bottom:14px; line-height:1.2; }
.cta-banner-title em { font-style:italic; color:var(--gold); }
.cta-banner-text { font-size:0.85rem; letter-spacing:0.05em; color:var(--gray); margin-bottom:30px; line-height:1.9; max-width:560px; margin-left:auto; margin-right:auto; }

.service-card, .service-arrow { transition:all 0.4s; }

@media (max-width:900px) {
  .detail-section { padding:20px 24px 60px; }
  .detail-grid { grid-template-columns:1fr; gap:40px; margin-bottom:60px; }
  .cta-banner { padding:40px 28px; }
  .includes-box { padding:28px 22px; }
  .signature-grid { grid-template-columns:1fr; gap:24px; }
  .signature-theme { padding:24px 22px; }
  .signature-cta { padding:28px 22px; }
}


.legal-section { max-width:900px; margin:0 auto; padding:60px 60px 110px; position:relative; z-index:2; }
.legal-block { margin-bottom:80px; }
.legal-eyebrow { font-size:0.55rem; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.legal-heading { font-family:"Cormorant Garant",serif; font-size:clamp(1.8rem,3vw,2.4rem); font-weight:400; color:var(--white); margin-bottom:36px; line-height:1.2; padding-bottom:18px; border-bottom:1px solid rgba(201,168,76,0.18); }
.legal-subheading { font-family:"Playfair Display",serif; font-style:italic; font-size:1.1rem; font-weight:400; color:var(--gold); margin-top:32px; margin-bottom:14px; }
.legal-text { font-family:"Cormorant Garant",serif; font-size:1.05rem; line-height:1.75; color:var(--cream); margin-bottom:18px; font-weight:400; }
.legal-text a { color:var(--gold); text-decoration:none; border-bottom:1px solid rgba(201,168,76,0.3); transition:border-color 0.3s; }
.legal-text a:hover { border-bottom-color:var(--gold); }
.legal-update { font-family:"Montserrat",sans-serif; font-size:0.65rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--gray); text-align:center; margin-top:60px; }
@media (max-width:760px) {
  .legal-section { padding:40px 22px 80px; }
  .legal-block { margin-bottom:60px; }
}

/* ===== PACK DETAIL PAGES ===== */
.pack-price{font-family:'Cinzel',serif;color:#c9a84c;font-size:1.35rem;margin-top:14px;}
.pack-price .pack-pp{display:block;font-family:'Montserrat',sans-serif;color:#b7c0d0;font-size:.82rem;letter-spacing:.02em;margin-top:8px;font-weight:400;}
.pack-wrap{max-width:760px;margin:0 auto 30px;}
.pack-sec{margin:0 0 26px;}
.pack-sec-title{font-family:'Cinzel',serif;color:#c9a84c;font-size:1.08rem;letter-spacing:.03em;margin:0 0 12px;padding-bottom:9px;border-bottom:1px solid rgba(201,168,76,.28);}
.pack-list{list-style:none;padding:0;margin:0;}
.pack-list li{position:relative;padding:7px 0 7px 24px;color:#e7eaf0;line-height:1.55;font-size:.98rem;}
.pack-list li::before{content:"\203A";position:absolute;left:2px;top:7px;color:#c9a84c;font-weight:700;}
.pack-alc{margin-top:34px;background:rgba(201,168,76,.05);border:1px solid rgba(201,168,76,.22);border-radius:10px;padding:22px 26px;}
.pack-alc .pack-sec-title{border-bottom-color:rgba(201,168,76,.2);}
.pack-alc .pack-list li{color:#c4cdda;font-size:.92rem;}
/* clickable tiers */
.signature-tier.clickable{cursor:pointer;transition:background .2s ease,border-color .2s ease;}
.signature-tier.clickable:hover{background:rgba(201,168,76,.08);}
.signature-tier.clickable .signature-tier-price::after{content:"\203A";margin-left:12px;color:#c9a84c;font-weight:700;font-size:1.1em;vertical-align:-1px;}

.pack-intro{max-width:760px;margin:0 auto 26px;color:#c4cdda;font-style:italic;line-height:1.7;font-size:1rem;text-align:center;}
.wa-float{position:fixed;right:20px;bottom:20px;z-index:9999;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.3);transition:transform .2s,box-shadow .2s}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(0,0,0,.4)}
.wa-float svg{width:34px;height:34px}
@media(max-width:600px){.wa-float{right:16px;bottom:16px;width:56px;height:56px}}
/* --- multipage link overrides --- */
a.service-card{text-decoration:none;color:inherit;display:block;}
a.nav-logo{text-decoration:none;display:flex;align-items:center;cursor:pointer;}
.footer-links a[data-en],.footer-links a[href]{color:inherit;text-decoration:none;cursor:pointer;transition:color .3s;}
.footer-links a[data-en]:hover{color:var(--gold);}

a.signature-tier{text-decoration:none;color:inherit;}

/* --- Services dropdown (desktop) --- */
.nav-links .has-dropdown{position:relative;}
.nav-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:240px;background:#0b1428;border:1px solid rgba(201,168,76,0.18);box-shadow:0 18px 50px rgba(0,0,0,0.5);padding:10px 0;opacity:0;visibility:hidden;transition:opacity .25s ease,transform .25s ease;z-index:1200;}
.nav-links .has-dropdown:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-dropdown a{display:block;padding:11px 24px;color:rgba(245,239,224,0.82);font-family:"Montserrat",sans-serif;font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;text-decoration:none;white-space:nowrap;border-left:2px solid transparent;transition:color .2s ease,background .2s ease,border-color .2s ease,padding-left .2s ease;}
.nav-dropdown a.dd-all{color:var(--gold);font-weight:600;border-bottom:1px solid rgba(201,168,76,0.15);margin-bottom:6px;padding-bottom:13px;}
.nav-dropdown a::after{display:none !important;}
.nav-dropdown a:hover{color:var(--gold);background:rgba(201,168,76,0.06);border-left-color:var(--gold);padding-left:28px;}
/* --- Services sublist (mobile burger) --- */
.mobile-subnav{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:-16px;}
.mobile-subnav a{font-size:1.3rem !important;opacity:0.78;}
.mobile-subnav a:hover{opacity:1;}

/* Voile renforcé sur grand écran (desktop) — atténue les grosses étoiles, mobile inchangé */
@media (min-width:901px) {
  body { background-image: linear-gradient(rgba(5,11,26,0.5), rgba(5,11,26,0.5)), url("hero-bg.webp"); }
}
