/* RESET */

*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
}

:root{
--black:#050505;
--dark:#0b0b0b;
--nav:#2f2f2f;
--gold:#d4af37;
--light:#f5d77a;
--white:#ffffff;
}

body{
background:var(--black);
color:var(--white);
line-height:1.7;
overflow-x:hidden;
}

/* CONTAINER */

.container{
width:92%;
max-width:1300px;
margin:0 auto;
}

/* NAVBAR */

.navbar{
position:sticky;
top:0;
z-index:999;
background:var(--nav);
border-bottom:1px solid rgba(212,175,55,.4);
}

.nav-content{
display:flex;
align-items:center;
justify-content:space-between;
height:90px;

position:relative;
z-index:10000;
}

/* LOGO */

.logo{
display:flex;
align-items:center;
margin-top:-6px;
}

.logo img{
height:135px;
filter:
drop-shadow(0 0 6px rgba(212,175,55,.9))
drop-shadow(0 0 15px rgba(212,175,55,.6));
}

/* MENU */

nav{
flex:1;
display:flex;
justify-content:center;
}

nav ul{
display:flex;
gap:32px;
list-style:none;
align-items:center;
}

nav a{
color:#fff;
text-decoration:none;
font-weight:500;
transition:.2s;
}

nav a:hover{
color:var(--gold);
}

.mobile-only{
display:none;
}

/* BUTTONS */

.btn-gold{
background:linear-gradient(135deg,var(--gold),var(--light));
color:#000;
padding:12px 26px;
border-radius:6px;
font-weight:600;
border:none;
cursor:pointer;
text-decoration:none;
}

.btn-outline{
border:1px solid var(--gold);
color:var(--gold);
padding:12px 26px;
border-radius:6px;
text-decoration:none;
}

/* HERO */

.hero{
min-height:100vh;
display:flex;
align-items:center;
justify-content:center;

background:
linear-gradient(rgba(0,0,0,.65),rgba(0,0,0,.65)),
url("detail2.webp") center/cover no-repeat;

animation:heroZoom 12s ease-in-out infinite alternate;
}

.hero-content{
max-width:900px;
padding:0 20px;
text-align:center;
}

.hero-content h1{
font-size:64px;
font-weight:700;
line-height:1.1;
color:#fff;

margin-bottom:25px;

text-shadow:
0 4px 15px rgba(0,0,0,.4);
}

.hero-content p{
font-size:22px;
color:#fff;
opacity:.95;

margin-bottom:40px;
}

.hero-buttons{
display:flex;
justify-content:center;
gap:20px;
flex-wrap:wrap;
}

/* SECTIONS */

section{
padding:110px 0;
}

h2{
text-align:center;
font-size:38px;
margin-bottom:15px;
}

.subtitle{
text-align:center;
color:var(--gold);
margin-bottom:50px;
}

/* ABOUT */

.about{
background:
linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.75)),
url("detail4.webp") center/cover no-repeat;
}

.about-box{
max-width:900px;
margin:auto;
background:rgba(11,11,11,.9);
border-radius:18px;
padding:45px;
}

/* SERVICES */

.services{
background:
linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.75)),
url("detail1.webp") center/cover no-repeat;
}

.service-category{
margin:60px 0 25px;
text-align:center;
color:var(--gold);
font-size:26px;
cursor:pointer;
user-select:none;
}

.service-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
gap:25px;
max-width:1000px;
margin:auto;
display:none;
}

.service-grid.open{
display:grid;
}

.service-card{
background:#0b0b0b;
border:1px solid rgba(212,175,55,.25);
border-radius:14px;
padding:26px;
cursor:pointer;
transition:.3s;
}

.service-card:hover{
transform:translateY(-6px);
border-color:var(--gold);
}

.service-card.selected{
border:2px solid var(--gold);
box-shadow:0 0 20px rgba(212,175,55,.6);
}

/* PACKAGES */

.packages{
background:
linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.75)),
url("detail3.webp") center/cover no-repeat;
}

.package-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
gap:40px;
max-width:1000px;
margin:auto;
align-items:stretch;
}

.package-wrapper{
position:relative;
text-align:center;
}

.featured-badge{
position:absolute;
top:-20px;
left:50%;
transform:translateX(-50%);
background:linear-gradient(135deg,#d4af37,#f5d77a);
color:#000;
padding:10px 22px;
border-radius:30px;
font-size:14px;
font-weight:700;
letter-spacing:.5px;
box-shadow:0 6px 18px rgba(212,175,55,.5);
z-index:10;
}

.package-card{
background:#0b0b0b;
border:1px solid rgba(212,175,55,.25);
border-radius:14px;
padding:40px 32px;
text-align:center;
cursor:pointer;
transition:.3s;
min-height:260px;
display:flex;
flex-direction:column;
justify-content:center;
}

.package-card:hover{
transform:translateY(-6px);
border-color:var(--gold);
}

.package-card[data-package*="Silver"].selected{
border:3px solid #cfd2d6;
box-shadow:0 0 25px rgba(200,200,200,.6);
}

.package-card[data-package*="Gold"].selected{
border:3px solid #d4af37;
box-shadow:0 0 30px rgba(212,175,55,.8);
}

.package-card[data-package*="Platinum"].selected{
border:3px solid #e5e4e2;
box-shadow:0 0 30px rgba(230,230,230,.8);
}

/* CONTACT */

.contact-info{
background:
linear-gradient(
rgba(0,0,0,.72),
rgba(0,0,0,.72)
),
url("detail5.webp");

background-size:cover;
background-position:center;
background-repeat:no-repeat;
}

.contact-info .container{
max-width:700px;

background:rgba(0,0,0,.45);

backdrop-filter:blur(8px);

padding:50px;

border-radius:20px;

border:1px solid rgba(212,175,55,.25);
}

.contact-form{
max-width:900px;
margin:auto;
}

.form-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:15px;
margin-bottom:25px;
}

.contact-form input{
padding:12px;
border-radius:6px;
border:none;
width:100%;
}

.selection-summary{
margin-top:25px;
padding:15px;
background:#111;
border:1px solid rgba(212,175,55,.3);
border-radius:10px;
font-size:14px;
min-height:60px;
}

/* FOOTER */

footer{
background:#000;
padding:40px;
text-align:center;
}

/* WHATSAPP */

.whatsapp-btn{
position:fixed;
bottom:25px;
right:25px;
width:60px;
height:60px;
background:#25D366;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 6px 18px rgba(0,0,0,.45);
z-index:100000;
transition:.3s;
}

.whatsapp-btn:hover{
transform:scale(1.1);
background:#1ebe5d;
}

.whatsapp-icon{
width:32px;
height:32px;
display:block;
filter:none;
}

/* INSTAGRAM */

.instagram-btn{
position:fixed;
bottom:110px;
right:25px;
width:60px;
height:60px;
background:linear-gradient(45deg,#f9ce34,#ee2a7b,#6228d7);
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
box-shadow:0 6px 18px rgba(0,0,0,.45);
z-index:100001;
transition:.3s;
}

.instagram-btn:hover{
transform:scale(1.1);
}

.instagram-icon{
width:32px;
height:32px;
display:block;
}

/* HAMBURGER */

.hamburger{
display:none;
flex-direction:column;
gap:6px;
cursor:pointer;

position:relative;
z-index:10000;
}

.hamburger span{
width:28px;
height:3px;
background:#fff;
border-radius:3px;
transition:.3s;
}

/* MOBILE */

@media(max-width:768px){

.desktop-cta{display:none;}
.mobile-only{display:block;}
.hamburger{display:flex;}

nav{
position:fixed;
top:90px;
left:0;
width:100%;
background:#111;

max-height:0;
overflow:hidden;

visibility:hidden;
opacity:0;

transition:
max-height .3s ease,
opacity .2s ease;

pointer-events:auto;
z-index:9999;
}

nav.open{
max-height:400px;
visibility:visible;
opacity:1;
}

nav ul{
flex-direction:column;
padding:20px;
gap:15px;
}

.logo img{height:110px;}
section{padding:80px 0;}

.service-grid,
.package-grid{
grid-template-columns:1fr;
}

.hero-content h1{
font-size:34px;
}

.form-grid{
grid-template-columns:1fr;
}

.whatsapp-btn{
bottom:90px;
right:20px;
}

.instagram-btn{
bottom:170px;
right:20px;
}

}
/* =====================================
   FINAL FIX: Badge in Gold kaart (Mobile)
===================================== */

@media(max-width:768px){

/* Gold kaart als referentie */
.package-card.featured{
position:relative;
padding-top:70px;
}

/* Badge in kaart */
.package-card.featured .featured-badge{
position:absolute;

top:15px;
left:50%;
transform:translateX(-50%);

padding:8px 22px;
border-radius:25px;

z-index:50;
}

}
/* =====================================
   MOBILE: Meest gekozen perfect gecentreerd
===================================== */

@media (max-width:768px){

/* Gold kaart referentie */
.package-card.featured{
position:relative;
padding-top:65px;
}

/* Badge exact in midden */
.package-card.featured .featured-badge{
position:absolute;

top:18px;
left:50%;
transform:translate(-50%, 0);

margin:0 auto;

display:flex;
align-items:center;
justify-content:center;

min-width:160px;

padding:8px 24px;
border-radius:25px;

text-align:center;

z-index:20;
}

}
/* ======================
   OFFERT KEUZE
====================== */

.offerte-start{
background:
linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.75)),
url("detail3.webp") center/cover no-repeat;
text-align:center;
}

.choice-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:40px;
max-width:900px;
margin:0 auto;
}

.choice-card{
background:#0b0b0b;
border:1px solid rgba(212,175,55,.3);
border-radius:16px;
padding:40px 30px;
transition:.3s;
}

.choice-card:hover{
transform:translateY(-8px);
border-color:var(--gold);
box-shadow:0 0 25px rgba(212,175,55,.4);
}

.choice-card h3{
margin-bottom:15px;
font-size:24px;
}
.packages-section{
  padding:100px 0;
  text-align:center;
}

.packages-container{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:40px;
  max-width:1100px;
  margin:50px auto 0;
}

.price{
  font-size:32px;
  font-weight:700;
  color:#d4af37;
  margin-top:20px;
}

.from-text{
  font-size:14px;
  color:#aaa;
  letter-spacing:1px;
}
/* ===============================
   PREMIUM PACKAGES DESIGN
================================ */

.packages-section{
  background:
    linear-gradient(rgba(0,0,0,.85),rgba(0,0,0,.85)),
    url("detail3.webp") center/cover no-repeat;
}

/* Container */

.packages-container{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:35px;
  max-width:1200px;
  margin:60px auto 0;
  padding:0 20px;
}

/* Card */

.package-card{
  background:rgba(5,5,5,0.95);
  border:1px solid rgba(212,175,55,.35);
  border-radius:18px;
  padding:45px 30px;

  display:flex;
  flex-direction:column;
  justify-content:space-between;

  min-height:520px;

  transition:.35s ease;
  position:relative;
}

.package-card:hover{
  transform:translateY(-12px);
  box-shadow:0 0 40px rgba(212,175,55,.4);
}

/* Title */

.package-card h3{
  font-size:28px;
  letter-spacing:2px;
  margin-bottom:25px;
  color:#fff;
}

/* List */

.package-card ul{
  list-style:none;
  padding:0;
  margin:0;
}

.package-card ul li{
  margin:12px 0;
  font-size:15px;
  opacity:.95;
}

/* Bullet */

.package-card ul li::before{
  content:"•";
  color:gold;
  margin-right:10px;
}

/* Price */

.price{
  font-size:38px;
  font-weight:700;
  color:#d4af37;
  margin-top:35px;
}

/* Vanaf */

.from-text{
  font-size:13px;
  color:#aaa;
  letter-spacing:2px;
  margin-top:4px;
  text-transform:uppercase;
}

/* GOLD */

.package-card.featured{
  border:2px solid gold;
  box-shadow:0 0 45px rgba(212,175,55,.6);
  transform:scale(1.06);
  z-index:2;
}

/* Badge */

.badge{
  position:absolute;
  top:-18px;
  left:50%;
  transform:translateX(-50%);

  background:linear-gradient(135deg,#d4af37,#f5d77a);
  color:#000;

  padding:7px 18px;
  border-radius:25px;

  font-size:12px;
  font-weight:700;
  letter-spacing:1px;
}

/* Mobile */

@media(max-width:900px){

  .package-card{
    min-height:auto;
    padding:35px 25px;
  }

  .package-card.featured{
    transform:none;
  }

}
.contact-info a{
  color: #fff;
  text-decoration: none;
  transition: .2s;
}

.contact-info a:hover{
  color: var(--gold);
}