:root{
  --deep: #3C1D4A;
  --mid:  #7E5A9B;
  --soft: #B59AC8;
  --cream:#F6F0E6;
  --sand: #D9C2A8;
  --gold: #D8B66A;

  --text: #1d1622;
  --muted:#6f6676;
  --white:#ffffff;

  --radius: 18px;
  --shadow: 0 12px 30px rgba(20, 10, 25, .12);
  --shadow2: 0 10px 22px rgba(20, 10, 25, .10);

  --max: 1120px;
}

*{
  box-sizing:border-box;
}

html,
body{
  margin:0;
  padding:0;
}

body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  overflow-x: hidden;
  background:
    radial-gradient(1200px 500px at 20% 5%, rgba(181,154,200,.25), transparent 60%),
    radial-gradient(900px 450px at 85% 20%, rgba(216,182,106,.18), transparent 60%),
    linear-gradient(180deg, #fff, #faf8fb 55%, #fff);
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

.container{
  max-width:var(--max);
  margin:0 auto;
  padding:0 20px;
}

/* Topbar */
.topbar{
  position:sticky;
  top:0;
  z-index:30;

  background: linear-gradient(135deg, #3C1D4A, #7E5A9B);
  color:#fff;

  box-shadow: 0 4px 14px rgba(0,0,0,0.15);
  border-bottom: none;
}

.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
  gap:16px;
}

.topbar__left{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;

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

  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);

  backdrop-filter: blur(8px);
  font-size:13px;
}

.topbar__right{
  display:flex;
  align-items:center;
  gap:10px;
}

.topbar__link{
  font-size:13px;
  opacity:.9;
}

.topbar__link:hover{
  opacity:1;
}

.topbar .btn{
  background: #fff;
  color: #3C1D4A;
  border: none;

  font-weight:600;
  padding:10px 16px;

  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.topbar .btn:hover{
  transform: translateY(-1px);
  background:#f6f0e6;
}


/* Header */
.header{
  position:sticky;
  top:46px;
  z-index:25;
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(60,29,74,.08);
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:14px;
}

@media (max-width: 760px){
  .topbar{
    position: static;
  }

  .header{
    position: sticky;
    top: 0;
    z-index: 40;
  }

  .nav__toggle{
    display: inline-block;
    position: relative;
    z-index: 41;
  }
}

/* Brand */
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:240px;
}

.brand__mark{
  width:58px;
  height:58px;
  flex:0 0 58px;
  border-radius:16px;
  box-shadow: var(--shadow2);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:8px;
}

.brand__mark img{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  max-height:100%;
  object-fit:contain;
}

.brand__text{
  line-height:1.05;
}

.brand__name{
  font-family: "Great Vibes", cursive;
  font-size:28px;
  color: var(--deep);
  margin:0;
}

.brand__tag{
  font-size:12px;
  letter-spacing:.2px;
  color: var(--muted);
  margin-top:2px;
}

/* Navigation */
.nav{
  display:flex;
  align-items:center;
  gap:14px;
  position:relative;
}

.nav__links{
  display:flex;
  align-items:center;
  gap:18px;
}

.nav__links a{
  font-size:14px;
  color: rgba(29,22,34,.86);
}

.nav__links a:hover{
  color: var(--deep);
}

.nav__toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(60,29,74,.15);
  background: rgba(255,255,255,.8);
  cursor:pointer;
}

.nav__toggle span{
  display:block;
  width:18px;
  height:2px;
  background: var(--deep);
  margin:4px auto;
  border-radius:2px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background: linear-gradient(135deg, var(--deep), var(--mid));
  color: var(--white);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow2);
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:transform .2s ease;
}

.btn:hover{
  transform: translateY(-1px);
}

.btn:active{
  transform: translateY(0);
}

.btn--ghost{
  background: rgba(255,255,255,.7);
  color: var(--deep);
  border:1px solid rgba(60,29,74,.18);
  box-shadow:none;
}

.btn--small{
  padding:10px 14px;
  font-size:13px;
}

.btn--wide{
  width:100%;
}

/* Hero */
.hero{
  padding:54px 0 24px;
}

.hero__grid{
  display:grid;
  grid-template-columns: 1.25fr .9fr;
  gap:26px;
  align-items:stretch;
}

.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color: rgba(60,29,74,.9);
  background: rgba(181,154,200,.25);
  border:1px solid rgba(126,90,155,.22);
  padding:8px 12px;
  border-radius:999px;
}

.hero h1{
  margin:16px 0 10px;
  font-size:52px;
  line-height:1.02;
  letter-spacing:-.8px;
  color: var(--deep);
}

.hero .accent{
  background: linear-gradient(135deg, var(--mid), var(--gold));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.lead{
  font-size:16px;
  color: rgba(29,22,34,.76);
  line-height:1.6;
  max-width:52ch;
}

.hero__cta{
  display:flex;
  gap:12px;
  margin-top:18px;
  flex-wrap:wrap;
}

.hero__badges{
  display:flex;
  gap:10px;
  margin-top:18px;
  flex-wrap:wrap;
}

.badge{
  font-size:13px;
  padding:10px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.75);
  border:1px solid rgba(60,29,74,.12);
}

.hero__card{
  position:relative;
}

.card{
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.card--glass{
  background: rgba(255,255,255,.75);
  border:1px solid rgba(60,29,74,.12);
  backdrop-filter: blur(14px);
}

.card__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  padding:18px 18px 0 18px;
}

.card__title{
  font-weight:700;
  color:var(--deep);
}

.card__subtitle{
  font-size:13px;
  color:var(--muted);
  margin-top:3px;
}

.chip{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(216,182,106,.22);
  border: 1px solid rgba(216,182,106,.35);
  color: rgba(60,29,74,.95);
  font-weight:600;
}

.card__body{
  padding:16px 18px 18px;
}

.info{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}

.info li{
  display:grid;
  grid-template-columns:18px auto;
  gap:10px;
  align-items:start;
  font-size:14px;
}

.info a{
  color: var(--deep);
  text-decoration:underline;
  text-decoration-color: rgba(60,29,74,.25);
}

.divider{
  height:1px;
  background: rgba(60,29,74,.10);
  margin:14px 0;
}

.mini-form label,
.form label{
  display:block;
  font-size:13px;
  color: rgba(29,22,34,.76);
}

input,select,textarea{
  width:100%;
  margin-top:6px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(60,29,74,.16);
  background: rgba(255,255,255,.9);
  outline:none;
  font:inherit;
}

input:focus,select:focus,textarea:focus{
  border-color: rgba(126,90,155,.55);
  box-shadow: 0 0 0 4px rgba(181,154,200,.25);
}

.mini-form__row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

.tiny{
  font-size:12px;
  color:var(--muted);
  margin:10px 0 0;
}

.hero__decor{
  position:absolute;
  right:0;
  bottom:0;
  width:140px;
  height:140px;
  background:
    radial-gradient(circle at 30% 30%, rgba(216,182,106,.45), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(126,90,155,.45), transparent 55%);
  border-radius:40px;
  filter: blur(.2px);
  transform: rotate(12deg);
  pointer-events:none;
}

/* Sections */
.section{
  padding:56px 0;
}

.section--alt{
  background: linear-gradient(180deg, rgba(60,29,74,.04), rgba(181,154,200,.10), rgba(60,29,74,.04));
  border-top:1px solid rgba(60,29,74,.06);
  border-bottom:1px solid rgba(60,29,74,.06);
}

.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:22px;
  flex-wrap:wrap;
}

.section__head h2{
  margin:0;
  font-size:34px;
  color: var(--deep);
  letter-spacing:-.4px;
}

.section__head p{
  margin:0;
  color:rgba(29,22,34,.72);
  max-width:60ch;
}

/* ===== DIENSTEN ===== */
.services-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(320px, 520px));
  justify-content:center;
  gap:28px;
  align-items:stretch;
}

.service-card{
  height:100%; 
  position:relative;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(60,29,74,.08);
  border-radius:24px;
  padding:26px 22px;
  display:flex;
  flex-direction:column;
  gap:16px;
  box-shadow:0 10px 30px rgba(20,10,25,.06);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(20,10,25,.10);
}

.service-card--featured{
  border:1px solid rgba(216,182,106,.35);
  box-shadow:0 14px 34px rgba(216,182,106,.10);
}

.service-card__price--stacked {
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* links uitlijnen */
  gap: 6px;
}

.service-card__price--stacked span {
  font-weight: 600;
  line-height: 1.2;
  display: block;
}


/* BADGE */
.service-card__badge{
  position:absolute;
  top:32px;
  right:32px;
  background:rgba(216,182,106,.16);
  border:1px solid rgba(216,182,106,.30);
  padding:6px 10px;
  border-radius:999px;
  font-size:21px;
  font-weight:800;
  animation: float 2s ease-in-out infinite;
}

@keyframes float {
  0% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
  100% { transform: translateY(0); }
}

/* ICON */
.service-card__icon{
  width:55px;
  height:55px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(181,154,200,.18);
  color:#6d3d7a;
  flex-shrink:0;
  transition:transform .2s ease, box-shadow .2s ease;
  font-size:40px;
}


/* ICON SVG */
.service-card__icon svg{
  width:48px;
  height:48px;
  stroke-width:1.8;
}

/* ICON HOVER */
.service-card:hover .service-card__icon{
  transform:scale(1.25);
}

/* TOP ROW  */
.service-card__top{
  display:flex;
  justify-content:space-between;
  align-items:center; 
  gap:16px;
}

/* ICON + TITLE */
.service-card__left{
  display:flex;
  align-items:center;
  gap:14px;
}

.service-card__top h3{
  margin:0;
  font-size:20px;
  line-height:1.25;
}

/* PRICE */
.service-card__price{
  font-size:34px;
  font-weight:800;
  white-space:nowrap;
  margin-left:auto;
  background:linear-gradient(135deg,var(--mid),var(--gold));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* LIST */
.service-card__list{
  padding-left:20px;
  margin:0;
  font-size:15px;
  line-height:1.7;
}

/* TEXT */
.service-card__text{
  margin-top:auto;
  font-size:15px;
  line-height:1.8;
  color:var(--muted);
}

/* NOTE */
.services-note{
  text-align:center;
  margin-top:18px;
  font-size:13px;
  color:var(--muted);
}

/* RESPONSIVE */
@media(max-width:1100px){
  .services-grid{
    grid-template-columns:repeat(2, minmax(280px, 1fr));
    gap:22px;
  }
}

@media(max-width:700px){
  .services-grid{
    grid-template-columns:1fr;
  }

  .service-card__top{
    align-items:flex-start;
  }

  .service-card__left{
    align-items:flex-start;
  }
}

/* Gallery */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.gallery__item {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  box-shadow: var(--shadow2);
  aspect-ratio: 4 / 3;
  background: #eee;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.gallery__item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.gallery__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* Tablet */
@media (max-width: 900px) {
  .gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobiel */
@media (max-width: 600px) {
  .gallery {
    grid-template-columns: 1fr;
  }
}

/* Reviews */
.reviews{
  position:relative;
  border-radius: var(--radius);
  background: rgba(255,255,255,.82);
  border:1px solid rgba(60,29,74,.12);
  box-shadow: var(--shadow2);
  padding:22px 18px;
  overflow:hidden;
}

.review{
  display:none;
}

.review.active{
  display:block;
}

.review p{
  margin:0;
  font-size:18px;
  line-height:1.6;
  color: rgba(29,22,34,.80);
}

.review__meta{
  margin-top:10px;
  color: var(--muted);
  font-size:13px;
}

.review__controls{
  position: static; 
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.iconbtn{
  width:40px;
  height:40px;
  border-radius:14px;
  border:1px solid rgba(60,29,74,.14);
  background: rgba(255,255,255,.9);
  cursor:pointer;
  font-size:20px;
  line-height:1;
  color: var(--deep);
}

.iconbtn:hover{
  transform: translateY(-1px);
}

/* Booking */
.booking{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:16px;
  align-items:start;
}

.form{
  border-radius: var(--radius);
  background: rgba(255,255,255,.82);
  border:1px solid rgba(60,29,74,.12);
  box-shadow: var(--shadow2);
  padding:18px;
}

.form__row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:12px;
}

.form__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}

.contact-card{
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(60,29,74,.92), rgba(126,90,155,.86));
  color: rgba(255,255,255,.92);
  box-shadow: var(--shadow);
  padding:18px;
  border:1px solid rgba(255,255,255,.12);
}

.contact-card h3{
  margin:0 0 6px;
  font-size:18px;
}

.contact-card p{
  margin:0 0 14px;
  opacity:.9;
}

.contact-card__items{
  display:grid;
  gap:10px;
  font-size:14px;
  margin-bottom:14px;
}

.contact-card a{
  color: rgba(255,255,255,.95);
  text-decoration:underline;
  text-decoration-color: rgba(255,255,255,.35);
}

/* Footer */
.footer{
  padding:40px 0;
  background: linear-gradient(135deg, var(--deep), #4b285c);
  color: rgba(255,255,255,.92);
  margin-top:40px;
  position:relative;
}

.footer::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:70px;
  height:2px;
  background: var(--gold);
  opacity:.75;
}

.footer__inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:18px;
}

.footer__top{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
}

.footer__brand{
  font-family: "Great Vibes", cursive;
  font-size:30px;
  color:#fff;
  line-height:1;
}

.footer__tag{
  font-size:13px;
  color: rgba(255,255,255,.78);
}

.footer__links{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:14px 18px;
}

.footer__links a{
  font-size:13px;
  color: rgba(255,255,255,.88);
  transition:opacity .2s ease, color .2s ease;
}

.footer__links a:hover{
  color: var(--gold);
}

.footer__bottom{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}

.footer__copy{
  font-size:13px;
  color: rgba(255,255,255,.82);
  line-height:1.6;
}

.footer__credit{
  font-size:13px;
  color: rgba(255,255,255,.82);
}

.footer__credit a{
  color: var(--gold);
  font-weight:600;
  text-decoration:none;
}

.footer__credit a:hover{
  text-decoration:underline;
}

@media (max-width: 760px){
  .footer{
    padding:32px 0;
  }

  .footer__brand{
    font-size:26px;
  }

  .footer__links{
    gap:10px 14px;
  }

  .footer__copy,
  .footer__credit,
  .footer__tag,
  .footer__links a{
    font-size:12px;
  }
}

/* Modal */
.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:100;
}

.modal.open{
  display:block;
}

.modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(20,10,25,.55);
  backdrop-filter: blur(3px);
}

.modal__panel{
  position:relative;
  max-width:820px;
  margin:8vh auto 0;
  padding:14px;
}

.modal__content{
  border-radius: var(--radius);
  background: rgba(255,255,255,.92);
  border:1px solid rgba(60,29,74,.12);
  box-shadow: var(--shadow);
  padding:18px;
  min-height:260px;
  display:grid;
  place-items:center;
  text-align:center;
}

.modal__close{
  position:absolute;
  top:0;
  right:0;
  transform: translate(-6px, 6px);
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.92);
  cursor:pointer;
}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .hero h1{
    font-size: 42px;
    line-height: 1.05;
    text-align: center;
  }

  .hero h1 .accent{
    display: block;
  }


  .pricing{
    grid-template-columns:1fr;
    gap:12px;
  }

  .price-card--featured{
    transform:none;
  }

  .gallery{
    grid-template-columns:repeat(2, 1fr);
  }

  .booking{
    grid-template-columns:1fr;
  }
}

@media (max-width: 760px){
  .nav__toggle{
    display:inline-block;
  }

  .nav__links{
    display:none;
    position:absolute;
    right:20px;
    top:62px;
    background: rgba(255,255,255,.92);
    border:1px solid rgba(60,29,74,.12);
    border-radius:18px;
    box-shadow: var(--shadow);
    padding:12px;
    flex-direction:column;
    gap:10px;
    min-width:220px;
  }

  .nav__links.open{
    display:flex;
  }

  .grid3{
    grid-template-columns:1fr;
  }

  .mini-form__row{
    grid-template-columns:1fr;
  }

  .form__row{
    grid-template-columns:1fr;
  }

  .footer__inner{
    grid-template-columns:1fr;
    text-align:center;
  }

  .footer__copy{
    text-align:center;
  }

  .footer__links{
    justify-content:center;
  }

  .brand__mark{
    width:50px;
    height:50px;
    flex:0 0 50px;
    padding:7px;
  }

  .brand__name{
    font-size:24px;
  }

  .brand__tag{
    font-size:11px;
  }
}

   /* ===== Belleauisa unieke stijl overmij: baelleaframe ===== */

        .baelleaframe-wrap {
            max-width: 1000px;
            margin: 40px auto;
            padding: 35px;
            background: linear-gradient(135deg, #fffaf8, #f8f0ec);
            border-radius: 22px;
            box-shadow: 0 12px 35px rgba(0, 0, 0, 0.08);
            font-family: 'Segoe UI', Tahoma, Arial, sans-serif;
            color: #3d302d;
        }

        .baelleaframe-wrap h1 {
            text-align: center;
            font-size: 2.3rem;
            margin-bottom: 25px;
            color: #8a5c5c;
            line-height: 1.3;
        }

        .baelleaframe-wrap h2 {
            font-size: 1.5rem;
            color: #a56d6d;
            margin-top: 28px;
            margin-bottom: 14px;
            padding-left: 12px;
            border-left: 5px solid #d8b3a7;
        }

        .baelleaframe-wrap h3 {
            font-size: 1.15rem;
            color: #7c5a5a;
            margin-top: 18px;
            margin-bottom: 8px;
        }

        .baelleaframe-wrap p {
            font-size: 1rem;
            line-height: 1.8;
            margin-bottom: 14px;
        }

        .baelleaframe-wrap strong {
            color: #b56f6f;
        }

        .baelleaframe-wrap em {
            color: #8b6f6f;
        }

        /* blok met foto naast tekst */
        .baelleaframe-sideblock {
            display: flex;
            align-items: center;
            gap: 30px;
            margin: 30px 0;
            padding: 20px;
            background: rgba(255, 255, 255, 0.55);
            border-radius: 18px;
        }

        .baelleaframe-sideblock.reverse {
            flex-direction: row-reverse;
        }

        .baelleaframe-sideblock img {
            width: 320px;
            max-width: 100%;
            height: auto;
            display: block;
            border-radius: 16px;
            box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
            object-fit: cover;
        }

        .baelleaframe-sidecontent {
            flex: 1;
            min-width: 0;
        }

        .baelleaframe-closing {
            margin-top: 25px;
            padding: 18px 20px;
            background: rgba(255, 255, 255, 0.45);
            border-radius: 16px;
        }

        /* mobiel */
        @media (max-width: 768px) {
            .baelleaframe-wrap {
                margin: 20px;
                padding: 22px;
            }

            .baelleaframe-wrap h1 {
                font-size: 1.8rem;
            }

            .baelleaframe-sideblock,
            .baelleaframe-sideblock.reverse {
                flex-direction: column;
                text-align: left;
            }

            .baelleaframe-sideblock img {
                width: 100%;
            }
        }

/* MOBILE  TOPBAR*/
@media (max-width: 760px){

  .topbar{
    padding: 8px 0;
  }

  .topbar__inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
  }

  .topbar__left{
    flex:1;
    min-width:0;
  }

  .topbar__right{
    flex-shrink:0;
  }

  .topbar__left .pill{
    max-width:100%;
    font-size:12px;
    line-height:1.25;
    padding:8px 12px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .topbar__left .pill:last-child{
    display:none;
  }

  .topbar__link{
    display:none;
  }

  .topbar .btn{
    padding:10px 14px;
    font-size:14px;
    border-radius:999px;
  }
}