:root{--gold:#C9A065;--gold-light:#E8D5B0;--gold-dark:#8B6C3E;--gold-bright:#D4AF72;--dark:#0F0D0A;--dark2:#1A1713;--dark3:#252018;--cream:#FAF7F2;--cream2:#F3EDE3;--text:#1A1713;--text-muted:#6B5E4E;--text-light:#9B8E7E;--white:#FFFFFF;--error:#C0392B;--success:#27AE60;--font-display:'Cormorant Garamond',Georgia,serif;--font-body:'DM Sans',sans-serif;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--radius-xl:32px;--shadow-sm:0 2px 8px rgba(15,13,10,.08);--shadow-md:0 8px 32px rgba(15,13,10,.12);--shadow-lg:0 20px 60px rgba(15,13,10,.18);--shadow-gold:0 8px 32px rgba(201,160,101,.25);--transition:.3s cubic-bezier(.4,0,.2,1);--transition-slow:.6s cubic-bezier(.4,0,.2,1);--max-width:1240px;--nav-height:80px;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-body);color:var(--text);background:var(--cream);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,select,textarea{font-family:inherit;}
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:600;line-height:1.15;}
.display-xl{font-size:clamp(3rem,7vw,6rem);font-weight:300;letter-spacing:-0.02em;line-height:1.05;}
.display-lg{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:400;line-height:1.1;}
.display-md{font-size:clamp(1.8rem,3.5vw,3rem);font-weight:500;}
.display-sm{font-size:clamp(1.4rem,2.5vw,2rem);font-weight:500;}
.eyebrow{font-family:var(--font-body);font-size:0.72rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);}
.body-lg{font-size:1.125rem;line-height:1.75;}
.body-md{font-size:1rem;line-height:1.7;}
.body-sm{font-size:0.875rem;line-height:1.6;}
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px;}
.section{padding:100px 0;}
.section-sm{padding:60px 0;}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;border-radius:60px;font-family:var(--font-body);font-size:0.9rem;font-weight:600;letter-spacing:0.04em;transition:var(--transition);white-space:nowrap;}
.btn-primary{background:var(--gold);color:var(--dark);box-shadow:var(--shadow-gold);}
.btn-primary:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,160,101,.35);}
.btn-dark{background:var(--dark);color:var(--gold-light);}
.btn-dark:hover{background:var(--dark2);transform:translateY(-2px);}
.btn-outline{border:1.5px solid var(--gold);color:var(--gold);background:transparent;}
.btn-outline:hover{background:var(--gold);color:var(--dark);}
.btn-outline-light{border:1.5px solid rgba(255,255,255,.4);color:var(--white);background:transparent;}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.8);}
.btn-secondary{background:rgba(255,255,255,.08);color:var(--white);border:1.5px solid rgba(201,160,101,.45);backdrop-filter:blur(8px);}
.btn-secondary:hover{background:rgba(201,160,101,.18);border-color:var(--gold);color:var(--gold-light);transform:translateY(-2px);}
.bg-cream .btn-secondary,.bg-cream2 .btn-secondary,section[class*="cream"] .btn-secondary{background:white;color:var(--dark);border-color:rgba(201,160,101,.4);backdrop-filter:none;}
.bg-cream .btn-secondary:hover,.bg-cream2 .btn-secondary:hover,section[class*="cream"] .btn-secondary:hover{background:var(--gold);color:var(--dark);border-color:var(--gold);}
.btn-lg{padding:20px 48px;font-size:1rem;}
.btn-sm{padding:10px 22px;font-size:0.82rem;}
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);display:flex;align-items:center;transition:var(--transition);}
#nav.scrolled{background:rgba(10,9,7,.95);backdrop-filter:blur(20px);border-bottom:1px solid rgba(201,160,101,.15);box-shadow:0 4px 30px rgba(0,0,0,.3);}
#nav.light-nav{background:rgba(250,247,242,.97);backdrop-filter:blur(20px);border-bottom:1px solid rgba(201,160,101,.15);}
#nav.light-nav .nav-logo-text{color:var(--dark);}
#nav.light-nav .nav-links a{color:var(--text);}
#nav.light-nav .nav-links a:hover{color:var(--gold);}
#nav.light-nav .nav-cta{background:var(--gold);color:var(--dark);}
.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px;width:100%;display:flex;align-items:center;justify-content:space-between;gap:32px;}
.nav-logo{display:flex;align-items:center;gap:12px;}
.nav-logo img{height:38px;width:auto;filter:brightness(0) invert(1);}
#nav.light-nav .nav-logo img{filter:none;}
.nav-links{display:flex;align-items:center;gap:36px;}
.nav-links a{color:rgba(255,255,255,.85);font-size:0.88rem;font-weight:500;letter-spacing:0.03em;transition:var(--transition);position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--gold);transition:var(--transition);}
.nav-links a:hover{color:var(--gold);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--gold);}
.nav-cta{background:var(--gold);color:var(--dark);padding:10px 24px;border-radius:50px;font-size:0.85rem;font-weight:700;letter-spacing:0.04em;transition:var(--transition);}
.nav-cta:hover{background:var(--gold-bright);transform:translateY(-1px);}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;}
.nav-hamburger span{display:block;width:24px;height:2px;background:white;border-radius:2px;transition:var(--transition);}
#nav.light-nav .nav-hamburger span{background:var(--dark);}
.nav-mobile{display:none;position:fixed;top:var(--nav-height);left:0;right:0;background:var(--dark);padding:24px;border-bottom:1px solid rgba(201,160,101,.2);z-index:999;flex-direction:column;gap:8px;}
.nav-mobile.open{display:flex;}
.nav-mobile a{color:rgba(255,255,255,.85);font-size:1rem;font-weight:500;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);display:block;}
.nav-mobile a:last-child{border:none;}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:var(--dark);}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.45;}
.hero-bg video{width:100%;height:100%;object-fit:cover;opacity:.4;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,13,10,.85) 0%,rgba(15,13,10,.4) 60%,rgba(139,108,62,.2) 100%);}
.hero-content{position:relative;z-index:2;max-width:var(--max-width);margin:0 auto;padding:0 24px;width:100%;padding-top:var(--nav-height);}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,160,101,.15);border:1px solid rgba(201,160,101,.3);border-radius:50px;padding:8px 18px;margin-bottom:32px;backdrop-filter:blur(10px);}
.hero-badge span{font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold-light);}
.hero-badge .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse-dot 2s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);}
50%{opacity:.5;transform:scale(1.3);}
}
.hero h1{color:white;margin-bottom:24px;}
.hero h1 em{font-style:italic;color:var(--gold-light);}
.hero-sub{color:rgba(255,255,255,.75);max-width:540px;margin-bottom:48px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;}
.hero-scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scroll-line 2s ease-in-out infinite;}
@keyframes scroll-line{0%{transform:scaleY(0);transform-origin:top;}
50%{transform:scaleY(1);transform-origin:top;}
51%{transform:scaleY(1);transform-origin:bottom;}
100%{transform:scaleY(0);transform-origin:bottom;}
}
.stats-bar{background:var(--dark2);border-top:1px solid rgba(201,160,101,.15);border-bottom:1px solid rgba(201,160,101,.15);padding:32px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.stat-item{text-align:center;padding:8px 24px;border-right:1px solid rgba(201,160,101,.15);}
.stat-item:last-child{border:none;}
.stat-num{font-family:var(--font-display);font-size:2.5rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:4px;}
.stat-label{font-size:0.78rem;font-weight:500;color:rgba(255,255,255,.78);letter-spacing:0.05em;text-transform:uppercase;}
.section-header{margin-bottom:64px;}
.section-header.center{text-align:center;}
.section-header .eyebrow{margin-bottom:12px;display:block;}
.section-header h2{margin-bottom:20px;}
.section-header p{color:var(--text-muted);max-width:560px;}
.section-header.center p{margin:0 auto;}
.gold-line{width:60px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);margin:20px 0 0;}
.section-header.center .gold-line{margin:20px auto 0;}
.card{background:white;border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-sm);}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.card-img{width:100%;height:240px;object-fit:cover;transition:var(--transition-slow);}
.card:hover .card-img{transform:scale(1.04);}
.card-body{padding:28px;}
.card-badge{display:inline-block;padding:5px 14px;border-radius:50px;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:12px;}
.card-badge-gold{background:rgba(201,160,101,.12);color:var(--gold-dark);}
.card-badge-dark{background:var(--dark);color:var(--gold-light);}
.card-badge-blue{background:rgba(52,110,235,.1);color:#3466eb;}
.pakket-card{background:white;border-radius:var(--radius-lg);overflow:hidden;border:1.5px solid rgba(201,160,101,.15);transition:var(--transition);display:flex;flex-direction:column;}
.pakket-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:var(--shadow-gold);}
.pakket-card.featured{border-color:var(--gold);box-shadow:var(--shadow-gold);}
.pakket-card-header{padding:24px 28px 20px;background:linear-gradient(135deg,var(--dark2),var(--dark3));position:relative;overflow:hidden;}
.pakket-card-header::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(201,160,101,.08);}
.pakket-naam{font-family:var(--font-display);font-size:1.6rem;font-weight:500;color:white;margin-bottom:4px;}
.pakket-badge-pill{display:inline-block;padding:4px 12px;border-radius:50px;background:var(--gold);color:var(--dark);font-size:0.7rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:16px;}
.pakket-prijs-block{display:flex;align-items:baseline;gap:8px;margin-top:4px;}
.prijs-vanaf{font-size:0.75rem;color:rgba(255,255,255,.5);}
.prijs-bedrag{font-family:var(--font-display);font-size:2.2rem;font-weight:600;color:var(--gold-light);}
.prijs-pp{font-size:0.75rem;color:rgba(255,255,255,.5);}
.prijs-kamer-info{font-size:0.72rem;color:rgba(255,255,255,.4);margin-top:2px;}
.pakket-card-body{padding:24px 28px;flex:1;}
.pakket-info-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--cream2);font-size:0.88rem;color:var(--text-muted);}
.pakket-info-row:last-child{border:none;}
.pakket-info-row svg{color:var(--gold);flex-shrink:0;}
.pakket-info-row strong{color:var(--text);font-weight:600;}
.pakket-card-footer{padding:20px 28px 28px;display:flex;gap:12px;}
.pakket-card-footer .btn{flex:1;text-align:center;justify-content:center;}
.maand-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;cursor:pointer;display:block;}
.maand-card-img{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow);}
.maand-card:hover .maand-card-img{transform:scale(1.08);}
.maand-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,13,10,.9) 0%,rgba(15,13,10,.3) 60%,transparent 100%);}
.maand-card-content{position:absolute;bottom:0;left:0;right:0;padding:28px;}
.maand-card-label{display:inline-block;padding:4px 12px;border-radius:50px;font-size:0.65rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:8px;background:var(--gold);color:var(--dark);}
.maand-card-naam{font-family:var(--font-display);font-size:1.8rem;font-weight:600;color:white;margin-bottom:4px;}
.maand-card-periode{font-size:0.82rem;color:rgba(255,255,255,.65);}
.maand-card-pakketten{margin-top:12px;font-size:0.78rem;color:var(--gold-light);font-weight:600;}
.usp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.usp-item{background:var(--dark2);padding:48px 36px;transition:var(--transition);position:relative;overflow:hidden;}
.usp-item::before{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:var(--transition);}
.usp-item:hover{background:var(--dark3);}
.usp-item:hover::before{transform:scaleX(1);}
.usp-icon{width:52px;height:52px;background:rgba(201,160,101,.1);border:1px solid rgba(201,160,101,.2);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--gold);}
.usp-item h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:white;margin-bottom:12px;}
.usp-item p{font-size:0.88rem;color:rgba(255,255,255,.55);line-height:1.7;}
.testimonial-card{background:white;border-radius:var(--radius-lg);padding:36px;border:1px solid rgba(201,160,101,.1);box-shadow:var(--shadow-sm);position:relative;display:flex;flex-direction:column;}
.testimonial-stars{display:flex;gap:4px;color:var(--gold);margin-bottom:20px;}
.testimonial-text{font-family:var(--font-display);font-size:1.15rem;font-style:italic;color:var(--text);line-height:1.7;margin-bottom:14px;flex:1;}
.review-card .testimonial-text{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:8;line-clamp:8;overflow:hidden;}
.review-readmore{background:rgba(201,160,101,.1);border:1px solid rgba(201,160,101,.3);color:var(--gold-dark);font-family:var(--font-body);font-size:.78rem;font-weight:600;cursor:pointer;padding:7px 14px;margin:0 0 16px;display:inline-flex;align-items:center;gap:6px;border-radius:20px;transition:all .2s;align-self:flex-start;letter-spacing:.02em;}
.review-readmore:hover{background:var(--gold-dark);border-color:var(--gold-dark);color:white;}
.review-readmore::after{content:"\2192";transition:transform .2s}
.review-readmore:hover::after{transform:translateX(2px)}
.review-card .testimonial-author{margin-top:auto;}
.reviews-grid-snap{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:880px){
  .reviews-grid-snap{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:16px;padding-bottom:16px;margin:0 -20px;padding-left:20px;padding-right:20px;-webkit-overflow-scrolling:touch;}
  .reviews-grid-snap::-webkit-scrollbar{height:6px;}
  .reviews-grid-snap::-webkit-scrollbar-track{background:rgba(201,160,101,.08);border-radius:3px;}
  .reviews-grid-snap::-webkit-scrollbar-thumb{background:rgba(201,160,101,.4);border-radius:3px;}
  .reviews-grid-snap>*{flex:0 0 calc(100% - 40px);scroll-snap-align:center;min-width:0;}
}
.review-modal{position:fixed;inset:0;background:rgba(15,13,10,.6);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;opacity:0;transition:opacity .2s;}
.review-modal.open{opacity:1;}
.review-modal-content{background:white;border-radius:var(--radius-lg);max-width:640px;width:100%;max-height:90vh;overflow:auto;padding:36px;position:relative;transform:translateY(20px);transition:transform .2s;}
.review-modal.open .review-modal-content{transform:translateY(0);}
.review-modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(15,13,10,.05);border:0;font-size:1.4rem;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;line-height:1;}
.review-modal-close:hover{background:rgba(15,13,10,.1);}
@media (max-width:600px){.review-modal-content{padding:28px 22px;}}
.testimonial-author{display:flex;align-items:center;gap:14px;}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--dark);flex-shrink:0;}
.testimonial-name{font-weight:600;font-size:0.9rem;color:var(--text);}
.testimonial-meta{font-size:0.78rem;color:var(--text-muted);}
.booking-widget{background:white;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;}
.booking-steps{display:flex;background:var(--dark2);padding:0;}
.booking-step{flex:1;padding:20px 16px;text-align:center;position:relative;cursor:pointer;}
.booking-step::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transition:var(--transition);}
.booking-step.active::after{transform:scaleX(1);}
.booking-step.completed::after{transform:scaleX(1);background:var(--success);}
.step-num{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:0.8rem;font-weight:700;color:rgba(255,255,255,.8);transition:var(--transition);}
.booking-step.active .step-num{background:var(--gold);border-color:var(--gold);color:var(--dark);}
.booking-step.completed .step-num{background:var(--success);border-color:var(--success);color:white;}
.step-label{font-size:0.72rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:rgba(255,255,255,.72);}
.booking-step.active .step-label{color:var(--gold-light);}
.booking-body{padding:40px;}
.booking-panel{display:none;}
.booking-panel.active{display:block;}
.form-group{margin-bottom:24px;}
.form-label{display:block;font-size:0.82rem;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:0.02em;}
.form-label span{color:var(--gold);}
.form-input,.form-select,.form-textarea{width:100%;padding:14px 18px;border:1.5px solid rgba(201,160,101,.25);border-radius:var(--radius-md);font-size:0.95rem;color:var(--text);background:var(--cream);transition:var(--transition);outline:none;appearance:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold);background:white;box-shadow:0 0 0 4px rgba(201,160,101,.1);}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23C9A065' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:44px;cursor:pointer;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-error{display:none;font-size:0.78rem;color:var(--error);margin-top:6px;}
.kamer-options{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;}
.kamer-option{border:2px solid rgba(201,160,101,.2);border-radius:var(--radius-md);padding:20px 12px;text-align:center;cursor:pointer;transition:var(--transition);position:relative;}
.kamer-option:hover{border-color:var(--gold);background:rgba(201,160,101,.04);}
.kamer-option.selected{border-color:var(--gold);background:rgba(201,160,101,.08);}
.kamer-option.selected::before{content:'✓';position:absolute;top:8px;right:10px;width:20px;height:20px;background:var(--gold);border-radius:50%;font-size:0.7rem;font-weight:700;color:var(--dark);display:flex;align-items:center;justify-content:center;}
.kamer-personen{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--gold);line-height:1;margin-bottom:4px;}
.kamer-label{font-size:0.8rem;color:var(--text-muted);font-weight:500;}
.kamer-prijs{font-size:0.78rem;color:var(--text);font-weight:700;margin-top:8px;}
.kamer-besparing{font-size:0.65rem;color:var(--success);font-weight:600;margin-top:2px;}
.prijs-summary{background:var(--dark2);border-radius:var(--radius-md);padding:24px;margin-bottom:28px;}
.prijs-summary-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;font-size:0.88rem;color:rgba(255,255,255,.65);}
.prijs-summary-row:last-child{margin:0;}
.prijs-summary-row.total{padding-top:16px;border-top:1px solid rgba(201,160,101,.2);font-size:1rem;font-weight:700;color:white;}
.prijs-summary-row.total .amount{font-family:var(--font-display);font-size:1.8rem;color:var(--gold-light);}
.betaling-opties{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px;}
.betaling-optie{border:2px solid rgba(201,160,101,.2);border-radius:var(--radius-md);padding:20px;cursor:pointer;transition:var(--transition);}
.betaling-optie:hover{border-color:var(--gold);}
.betaling-optie.selected{border-color:var(--gold);background:rgba(201,160,101,.06);}
.betaling-optie-title{font-weight:700;font-size:0.95rem;color:var(--text);margin-bottom:4px;}
.betaling-optie-bedrag{font-family:var(--font-display);font-size:1.5rem;color:var(--gold-dark);font-weight:600;margin-bottom:4px;}
.betaling-optie-desc{font-size:0.78rem;color:var(--text-muted);}
.cta-banner{background:linear-gradient(135deg,var(--dark2) 0%,var(--dark3) 100%);position:relative;overflow:hidden;padding:100px 0;}
.cta-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C9A065' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.cta-content{position:relative;z-index:1;text-align:center;}
.cta-content h2{color:white;margin-bottom:16px;}
.cta-content p{color:rgba(255,255,255,.65);max-width:500px;margin:0 auto 40px;}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
footer{background:var(--dark);border-top:1px solid rgba(201,160,101,.1);padding-top:80px;}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.06);}
.footer-logo img{height:36px;width:auto;filter:brightness(0) invert(1);margin-bottom:20px;}
.footer-desc{font-size:0.88rem;color:rgba(255,255,255,.45);line-height:1.8;max-width:280px;margin-bottom:24px;}
.footer-social{display:flex;gap:12px;}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.78);transition:var(--transition);}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--dark);}
.footer-col h4{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:white;margin-bottom:20px;}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:0.875rem;color:rgba(255,255,255,.45);transition:var(--transition);display:flex;align-items:center;gap:6px;}
.footer-links a:hover{color:var(--gold);}
.footer-contact-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;transition:opacity 0.2s;}
a.footer-contact-item:hover{opacity:0.7;}
a.footer-contact-item:hover .footer-contact-icon{background:rgba(201,160,101,.2);border-color:rgba(201,160,101,.4);}
.footer-contact-icon{width:32px;height:32px;background:rgba(201,160,101,.1);border:1px solid rgba(201,160,101,.15);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--gold);flex-shrink:0;}
.footer-contact-text{font-size:0.85rem;color:rgba(255,255,255,.78);line-height:1.6;}
.footer-contact-text strong{display:block;color:rgba(255,255,255,.8);font-size:0.78rem;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:2px;}
.footer-bottom{padding:24px 0;display:flex;align-items:center;justify-content:space-between;font-size:0.78rem;color:rgba(255,255,255,.25);}
.footer-bottom a{color:rgba(255,255,255,.35);transition:var(--transition);}
.footer-bottom a:hover{color:var(--gold);}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:rgba(255,255,255,.72);margin-bottom:24px;}
.breadcrumb a{color:rgba(255,255,255,.8);transition:var(--transition);}
.breadcrumb a:hover{color:var(--gold);}
.breadcrumb-sep{color:rgba(255,255,255,.3);}
.page-hero{background:var(--dark2);padding:140px 0 80px;position:relative;overflow:hidden;}
.page-hero-bg{position:absolute;inset:0;opacity:.25;}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,var(--dark2) 0%,rgba(15,13,10,.6) 100%);}
.page-hero-content{position:relative;z-index:1;}
.page-hero h1{color:white;margin-bottom:16px;}
.page-hero p{color:rgba(255,255,255,.65);max-width:560px;}
.whatsapp-float{position:fixed;bottom:32px;right:32px;z-index:900;height:48px;padding:0 20px 0 16px;background:#25D366;border-radius:100px;display:flex;align-items:center;gap:10px;color:white;text-decoration:none;box-shadow:0 8px 32px rgba(37,211,102,.4);transition:var(--transition);animation:float-bounce 3s ease-in-out infinite;}
.whatsapp-float:hover{transform:scale(1.05);box-shadow:0 12px 40px rgba(37,211,102,.5);color:white;}
@keyframes float-bounce{0%,100%{transform:translateY(0);}
50%{transform:translateY(-6px);}
}
.whatsapp-float:hover{animation:none;}
#page-loader{position:fixed;inset:0;background:var(--dark);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transition:opacity .5s ease,visibility .5s ease;}
#page-loader.hidden{opacity:0;visibility:hidden;}
.loader-logo img{height:48px;filter:brightness(0) invert(1);}
.loader-bar{width:160px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;}
.loader-bar-fill{height:100%;background:var(--gold);border-radius:2px;animation:loader-fill 1.2s ease forwards;}
@keyframes loader-fill{from{width:0;}
to{width:100%;}
}
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease;}
.fade-up.visible{opacity:1;transform:none;}
.fade-up-delay-1{transition-delay:.1s;}
.fade-up-delay-2{transition-delay:.2s;}
.fade-up-delay-3{transition-delay:.3s;}
.fade-up-delay-4{transition-delay:.4s;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;}
.text-gold{color:var(--gold);}
.text-white{color:white;}
.text-muted{color:var(--text-muted);}
.bg-dark{background:var(--dark);}
.bg-dark2{background:var(--dark2);}
.bg-cream{background:var(--cream);}
.bg-cream2{background:var(--cream2);}
.mt-8{margin-top:8px;}
.mt-16{margin-top:16px;}
.mt-24{margin-top:24px;}
.mt-32{margin-top:32px;}
.mt-48{margin-top:48px;}
.mb-8{margin-bottom:8px;}
.mb-16{margin-bottom:16px;}
.mb-24{margin-bottom:24px;}
.mb-32{margin-bottom:32px;}
.mb-48{margin-bottom:48px;}
.d-flex{display:flex;}
.align-center{align-items:center;}
.justify-between{justify-content:space-between;}
.gap-16{gap:16px;}
.gap-24{gap:24px;}
.gap-32{gap:32px;}
.text-center{text-align:center;}
.w-full{width:100%;}
.pattern-divider{width:100%;height:40px;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C9A065' fill-opacity='0.15' fill-rule='evenodd'%3E%3Cpath d='M20 20c0-5.5-4.5-10-10-10s-10 4.5-10 10 4.5 10 10 10 10-4.5 10-10zm10 0c0 5.5 4.5 10 10 10s10-4.5 10-10-4.5-10-10-10-10 4.5-10 10z'/%3E%3C/g%3E%3C/svg%3E");opacity:.6;}
.stars{display:flex;gap:2px;}
.star{color:var(--gold);font-size:0.9rem;}
.star-empty{color:var(--cream2);}
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--dark2);color:white;padding:16px 32px;border-radius:60px;font-size:0.9rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:9998;border:1px solid rgba(201,160,101,.2);transition:transform .4s cubic-bezier(.34,1.56,.64,1);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast.success{border-color:var(--success);}
.toast.error{border-color:var(--error);}
@media (max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
.usp-grid{grid-template-columns:repeat(2,1fr);}
.stats-grid{grid-template-columns:repeat(2,1fr);}
.stat-item{border-right:none;border-bottom:1px solid rgba(201,160,101,.15);}
.stat-item:last-child{border:none;}
}
@media (max-width:900px){.nav-links,.nav-cta{display:none;}
.nav-hamburger{display:flex;}
.grid-3{grid-template-columns:repeat(2,1fr);}
.grid-4{grid-template-columns:repeat(2,1fr);}
.form-grid{grid-template-columns:1fr;}
.kamer-options{grid-template-columns:repeat(3,1fr);}
.betaling-opties{grid-template-columns:1fr;}
}
@media (max-width:640px){:root{--nav-height:68px;}
.section{padding:70px 0;}
.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
.usp-grid{grid-template-columns:1fr;}
.stats-grid{grid-template-columns:repeat(2,1fr);}
.footer-grid{grid-template-columns:1fr;gap:32px;}
.hero-actions{flex-direction:column;}
.hero-actions .btn{width:100%;justify-content:center;}
.display-xl{font-size:2.8rem;}
.booking-body{padding:24px;}
.kamer-options{grid-template-columns:1fr;gap:10px;}
.kamer-option{display:flex;align-items:center;gap:16px;text-align:left;padding:16px;}
.kamer-personen{font-size:1.5rem;}
.section-header{margin-bottom:40px;}
.whatsapp-float{bottom:20px;right:20px;}
body.has-sticky-cta .whatsapp-float{display:none;}
.pakket-card-footer{flex-direction:column;}
.cta-actions{flex-direction:column;align-items:center;}
.cta-actions .btn{width:100%;max-width:360px;justify-content:center;}
.booking-steps{overflow-x:auto;}
.step-label{display:none;}
}
.reis-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;color:white;overflow:hidden;padding:120px 0 60px;}
.reis-hero-bg{position:absolute;inset:0;z-index:0;}
.reis-hero-bg img{width:100%;height:100%;object-fit:cover;}
.reis-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,13,10,.6) 0%,rgba(15,13,10,.85) 100%);}
.reis-hero-content{position:relative;z-index:2;width:100%;}
.reis-hero-breadcrumb{display:inline-flex;align-items:center;gap:8px;color:var(--gold-light);font-size:.85rem;margin-bottom:16px;opacity:.85;}
.reis-hero-breadcrumb a{color:inherit;opacity:.7;}
.reis-hero-breadcrumb a:hover{opacity:1;color:var(--gold);}
.reis-hero h1{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:600;line-height:1.1;margin:0 0 12px;}
.reis-hero-sub{font-size:1.05rem;color:rgba(255,255,255,.75);margin-bottom:28px;max-width:640px;}
.reis-hero-pills{display:flex;flex-wrap:wrap;gap:10px;}
.reis-hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);border-radius:50px;padding:9px 16px;font-size:.85rem;color:rgba(255,255,255,.9);}
.reis-hero-pill svg{color:var(--gold);flex-shrink:0;}
.reis-hero-pill.gold{background:rgba(201,160,101,.15);border-color:rgba(201,160,101,.3);color:var(--gold-light);}
.momenten-featured{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:16/8;margin-bottom:24px;box-shadow:0 20px 50px rgba(0,0,0,.4);}
.momenten-featured img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s;}
.momenten-featured:hover img{transform:scale(1.03);}
.momenten-featured-overlay{position:absolute;bottom:0;left:0;right:0;padding:60px 40px 36px;background:linear-gradient(to top,rgba(15,13,10,.95) 0%,rgba(15,13,10,.55) 70%,transparent 100%);color:white;}
.momenten-featured-overlay h3{font-family:var(--font-display);font-size:1.8rem;font-weight:600;margin:6px 0 8px;color:white;}
.momenten-featured-overlay p{margin:0;max-width:560px;color:rgba(255,255,255,.78);font-size:.95rem;line-height:1.6;}
@media (max-width:700px){.momenten-featured{aspect-ratio:4/5;}
.momenten-featured-overlay{padding:40px 22px 22px;}
.momenten-featured-overlay h3{font-size:1.3rem;}
.momenten-featured-overlay p{font-size:.85rem;}
}
.momenten-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.moment-card{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:3/4;margin:0;cursor:default;}
.moment-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.moment-card:hover img{transform:scale(1.05);}
.moment-card figcaption{position:absolute;bottom:0;left:0;right:0;padding:30px 18px 16px;background:linear-gradient(to top,rgba(15,13,10,.92) 0%,transparent 100%);color:white;font-size:.85rem;font-weight:500;letter-spacing:.01em;}
@media (max-width:800px){.momenten-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
.moment-card figcaption{font-size:.78rem;padding:24px 14px 12px;}
}
@media (max-width:480px){.momenten-grid{grid-template-columns:1fr;}
.moment-card{aspect-ratio:4/3;}
}
.familie-strip{margin-top:32px;padding:24px 28px;background:linear-gradient(135deg,rgba(201,160,101,.12) 0%,rgba(201,160,101,.04) 100%);border:1px solid rgba(201,160,101,.2);border-radius:14px;display:flex;gap:18px;align-items:flex-start;color:rgba(255,255,255,.85);}
.familie-strip-icon{width:44px;height:44px;border-radius:50%;background:rgba(201,160,101,.18);display:flex;align-items:center;justify-content:center;color:var(--gold-light);flex-shrink:0;}
.familie-strip strong{display:block;color:var(--gold-light);font-size:1rem;margin-bottom:4px;}
.familie-strip p{margin:0;font-size:.88rem;line-height:1.6;}
@media (max-width:600px){.familie-strip{flex-direction:column;gap:12px;padding:20px;}
}
.ibadah-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.ibadah-photo{margin:0;position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;cursor:default;}
.ibadah-photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s;}
.ibadah-photo:hover img{transform:scale(1.04);}
.ibadah-photo figcaption{position:absolute;bottom:0;left:0;right:0;padding:26px 16px 12px;background:linear-gradient(to top,rgba(15,13,10,.92) 0%,transparent 100%);color:white;font-size:.8rem;font-style:italic;letter-spacing:.02em;}
@media (max-width:700px){.ibadah-strip{grid-template-columns:1fr;}
}
.kortingen-blok{margin-top:14px;padding-top:14px;border-top:1px solid rgba(15,13,10,.08);}
.kortingen-titel{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--text-muted);margin-bottom:8px;}
.kortingen-list{list-style:none;padding:0;margin:0 0 8px;display:flex;flex-direction:column;gap:5px;}
.kortingen-list li{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text);padding:4px 0;border-bottom:1px dashed rgba(15,13,10,.06);}
.kortingen-list li:last-child{border-bottom:0;}
.kortingen-list .bedrag{font-weight:600;color:var(--gold-dark);}
.kortingen-list .bedrag.korting{color:#2E7D32;}
.kortingen-info{margin:8px 0 0;font-size:.72rem;color:var(--text-muted);line-height:1.5;font-style:italic;}
.auto-detect-badge{display:flex;align-items:center;gap:8px;font-size:.82rem;padding:8px 12px;border-radius:8px;margin-bottom:6px;line-height:1.45;}
.auto-detect-badge.kind{background:rgba(201,160,101,.12);color:#6b4d22;border:1px solid rgba(201,160,101,.3);}
.auto-detect-badge.baby{background:#FFF3E0;color:#8B5A00;border:1px solid #FFD89A;}
.auto-detect-badge.niet-eu{background:#FFF8E1;color:#7E6300;border:1px solid #F5D472;}
.kind-zonder-bed-check{display:flex;align-items:flex-start;gap:9px;background:white;padding:10px 12px;border-radius:8px;border:1px solid rgba(15,13,10,.08);font-size:.85rem;line-height:1.5;cursor:pointer;margin:4px 0 0;}
.kind-zonder-bed-check input[type="checkbox"]{margin-top:2px;flex-shrink:0;accent-color:var(--gold-dark);width:16px;height:16px;}
.sticky-cta{position:fixed;bottom:0;left:0;right:0;background:var(--dark);border-top:1px solid var(--border);padding:12px 16px;display:none;align-items:center;justify-content:space-between;gap:12px;z-index:800;box-shadow:0 -8px 24px rgba(0,0,0,.15);}
.sticky-cta-prijs{color:white;}
.sticky-cta-prijs .label{font-size:.7rem;color:rgba(255,255,255,.55);display:block;}
.sticky-cta-prijs .bedrag{font-size:1.25rem;font-weight:700;color:var(--gold);}
.sticky-cta .btn{flex-shrink:0;}
@media (max-width:968px){.sticky-cta{display:flex;}
body.has-sticky-cta{padding-bottom:80px;}
}
.reis-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;padding:60px 0;align-items:flex-start;}
@media (max-width:968px){.reis-layout{grid-template-columns:1fr;gap:24px;padding:32px 0 100px;}
}
.reis-section{background:white;border-radius:16px;padding:32px;margin-bottom:24px;border:1px solid var(--border);}
.reis-section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;margin:0 0 4px;color:var(--dark);}
.reis-section-sub{color:var(--text-muted);font-size:.9rem;margin:0 0 24px;}
@media (max-width:600px){.reis-section{padding:20px;}
}
.hotel-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:600px){.hotel-grid{grid-template-columns:1fr;}
}
.hotel-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--cream);transition:var(--transition);}
.hotel-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.06);}
.hotel-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.hotel-card-body{padding:16px;}
.hotel-card-city{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--gold-dark);margin-bottom:4px;font-weight:600;}
.hotel-card-name{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--dark);margin-bottom:6px;}
.hotel-card-stars{color:var(--gold);font-size:.85rem;margin-bottom:8px;}
.hotel-card-meta{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;gap:6px;}
.programma-timeline{position:relative;padding-left:28px;}
.programma-timeline::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--gold) 0%,var(--gold) 50%,transparent 100%);}
.programma-dag{position:relative;padding-bottom:24px;}
.programma-dag::before{content:"";position:absolute;left:-28px;top:4px;width:24px;height:24px;background:white;border:2px solid var(--gold);border-radius:50%;}
.programma-dag::after{content:attr(data-dag);position:absolute;left:-28px;top:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--gold-dark);}
.programma-dag-titel{font-weight:600;color:var(--dark);margin-bottom:4px;}
.programma-dag-beschrijving{color:var(--text-muted);font-size:.9rem;line-height:1.5;}
.programma-toggle{background:none;border:none;color:var(--gold-dark);font-weight:600;cursor:pointer;padding:8px 0;display:inline-flex;align-items:center;gap:6px;}
.programma-toggle:hover{color:var(--gold);}
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;}
@media (max-width:600px){.incl-grid{grid-template-columns:1fr;gap:20px;}
}
.incl-titel{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:12px;color:var(--dark);}
.incl-titel.ja{color:#2d7a4f;}
.incl-titel.nee{color:#a83838;}
.incl-list{list-style:none;padding:0;margin:0;}
.incl-list-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 32px;}
@media (max-width:600px){.incl-list-grid{grid-template-columns:1fr;}
}
.incl-list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.9rem;color:var(--dark);}
.incl-list li:last-child{border-bottom:none;}
.incl-list svg{flex-shrink:0;margin-top:3px;}
.hotel-card-desc{font-size:.85rem;color:var(--text-muted);margin:10px 0 0;line-height:1.55;}
.hotel-gallery{display:flex;gap:6px;padding:8px;background:rgba(15,13,10,.04);overflow-x:auto;scrollbar-width:thin;}
.hotel-gallery-thumb{flex:0 0 80px;height:60px;border-radius:6px;background-size:cover;background-position:center;cursor:pointer;transition:all 0.2s;border:2px solid transparent;opacity:0.65;}
.hotel-gallery-thumb:hover{opacity:0.9;}
.hotel-gallery-thumb.actief{opacity:1;border-color:var(--gold);}
.vlucht-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
@media (max-width:700px){.vlucht-grid{grid-template-columns:1fr;}
}
.vlucht-card{background:var(--cream);border-radius:12px;padding:18px 20px;border:1px solid var(--border);}
.vlucht-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-weight:600;color:var(--dark);font-size:.9rem;}
.vlucht-card-header svg{color:var(--gold-dark);flex-shrink:0;}
.vlucht-datum{margin-left:auto;font-weight:500;color:var(--text-muted);font-size:.82rem;}
.vlucht-card-body{display:flex;flex-direction:column;gap:6px;}
.vlucht-leg{font-size:.85rem;color:var(--text);padding:6px 10px;background:white;border-radius:6px;border-left:2px solid var(--gold);}
.vlucht-info-row{display:flex;gap:8px;flex-wrap:wrap;}
.vlucht-info-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:rgba(201,160,101,.08);border:1px solid rgba(201,160,101,.2);border-radius:50px;font-size:.8rem;color:var(--dark);}
.vlucht-info-pill svg{color:var(--gold-dark);}
.suggestie-pills,.suggestie-pill{display:none !important;}
.boeking-sidebar{position:sticky;top:100px;background:white;border-radius:16px;padding:28px;border:1px solid var(--border);box-shadow:0 4px 24px rgba(0,0,0,.04);}
@media (max-width:968px){.boeking-sidebar{position:static;}
}
.boeking-prijs-blok{padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:20px;}
.boeking-vanaf{font-size:.8rem;color:var(--text-muted);}
.boeking-bedrag{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--dark);line-height:1;}
.boeking-bedrag-pp{font-size:.9rem;color:var(--text-muted);margin-left:6px;}
.boeking-prijs-tabel{width:100%;border-collapse:collapse;margin-top:12px;}
.boeking-prijs-tabel td{padding:6px 0;font-size:.85rem;color:var(--text-muted);}
.boeking-prijs-tabel td.bedrag{text-align:right;color:var(--dark);font-weight:600;}
.beschikbaarheid{display:flex;align-items:center;gap:10px;background:rgba(45,122,79,.08);border:1px solid rgba(45,122,79,.2);border-radius:8px;padding:10px 12px;margin-bottom:16px;font-size:.8rem;color:#2d7a4f;}
.beschikbaarheid svg{flex-shrink:0;}
.beschikbaarheid.weinig{background:rgba(204,99,0,.08);border-color:rgba(204,99,0,.2);color:#cc6300;}
.trust-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-top:1px solid var(--border);font-size:.82rem;color:var(--text-muted);}
.trust-row svg{color:var(--gold);flex-shrink:0;}
.boeking-modal{position:fixed;inset:0;background:rgba(15,13,10,.6);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;}
.boeking-modal.open{display:flex;}
.boeking-modal-content{background:white;border-radius:16px;width:100%;max-width:720px;position:relative;box-shadow:0 24px 64px rgba(0,0,0,.3);}
.boeking-modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:var(--cream2);border:none;border-radius:50%;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.boeking-modal-close:hover{background:var(--dark);color:white;}
.boeking-steps{display:flex;padding:24px 32px 0;gap:4px;}
.boeking-step-dot{flex:1;height:4px;background:var(--border);border-radius:4px;transition:var(--transition);}
.boeking-step-dot.active{background:var(--gold);}
.boeking-step-dot.done{background:var(--gold-dark);}
.boeking-step-label{padding:12px 32px 0;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:600;}
.boeking-step{padding:20px 32px 32px;display:none;}
.boeking-step.active{display:block;}
@media (max-width:600px){.boeking-step,.boeking-steps,.boeking-step-label{padding-left:20px;padding-right:20px;}
}
.boeking-step h2{font-family:var(--font-display);font-size:1.6rem;font-weight:600;margin:8px 0 6px;color:var(--dark);}
.boeking-step .step-sub{color:var(--text-muted);font-size:.9rem;margin-bottom:24px;}
.stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:50px;background:white;overflow:hidden;}
.stepper button{width:40px;height:40px;background:white;border:none;font-size:1.4rem;cursor:pointer;color:var(--dark);transition:var(--transition);}
.stepper button:hover:not(:disabled){background:var(--cream2);color:var(--gold-dark);}
.stepper button:disabled{color:var(--border);cursor:not-allowed;}
.stepper-value{min-width:48px;text-align:center;font-weight:700;font-size:1.05rem;color:var(--dark);}
.personen-selector{display:flex;align-items:center;justify-content:space-between;padding:20px;background:var(--cream);border-radius:12px;margin-bottom:24px;}
.personen-selector-info strong{display:block;color:var(--dark);font-size:1.05rem;margin-bottom:4px;}
.personen-selector-info span{color:var(--text-muted);font-size:.85rem;}
.kamer-rij{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:20px;border:1px solid var(--border);border-radius:12px;margin-bottom:12px;transition:var(--transition);}
.kamer-rij.actief{border-color:var(--gold);background:rgba(201,160,101,.04);}
.kamer-icon{width:48px;height:48px;background:var(--cream);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--gold-dark);flex-shrink:0;}
.kamer-info strong{display:block;color:var(--dark);margin-bottom:2px;}
.kamer-info .prijs-pp{color:var(--gold-dark);font-weight:600;font-size:.9rem;}
.kamer-info .max-info{color:var(--text-muted);font-size:.75rem;margin-top:2px;}
@media (max-width:600px){.kamer-rij{grid-template-columns:auto 1fr;}
.kamer-rij .stepper{grid-column:1 / -1;justify-self:end;}
}
.verdeling-status{margin:16px 0;padding:14px 18px;border-radius:10px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:10px;}
.verdeling-status.ok{background:rgba(45,122,79,.1);color:#2d7a4f;}
.verdeling-status.fout{background:rgba(168,56,56,.08);color:#a83838;}
.verdeling-status.wacht{background:var(--cream);color:var(--text-muted);}
.totaal-card{background:var(--dark);color:white;border-radius:12px;padding:20px;margin-top:16px;}
.totaal-card-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem;color:rgba(255,255,255,.7);}
.totaal-card-row.eindtotaal{border-top:1px solid rgba(255,255,255,.15);margin-top:8px;padding-top:12px;font-size:1.15rem;color:white;font-weight:700;}
.totaal-card-row.eindtotaal .bedrag{color:var(--gold);font-family:var(--font-display);font-size:1.5rem;}
.suggestie-pills{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 20px;}
.suggestie-pill{background:white;border:1px solid var(--border);border-radius:50px;padding:8px 14px;font-size:.8rem;color:var(--text-muted);cursor:pointer;transition:var(--transition);}
.suggestie-pill:hover{border-color:var(--gold);color:var(--gold-dark);}
.suggestie-pill.actief{background:var(--gold);color:white;border-color:var(--gold);}
.persoon-form{border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px;background:var(--cream);}
.persoon-form-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.persoon-nummer{width:32px;height:32px;background:var(--gold);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;}
.persoon-form-header strong{color:var(--dark);}
.persoon-kamer-tag{font-size:.75rem;color:var(--text-muted);margin-left:auto;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media (max-width:600px){.form-grid{grid-template-columns:1fr;}
}
.form-grid.full{grid-template-columns:1fr;}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--dark);margin-bottom:4px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-family:inherit;background:white;transition:var(--transition);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,160,101,.15);}
.betaling-keuze{display:grid;gap:12px;margin-bottom:24px;}
.betaling-card{display:flex;align-items:center;gap:16px;padding:18px;border:2px solid var(--border);border-radius:12px;cursor:pointer;background:white;transition:var(--transition);}
.betaling-card.actief{border-color:var(--gold);background:rgba(201,160,101,.04);}
.betaling-card-radio{width:22px;height:22px;border:2px solid var(--border);border-radius:50%;flex-shrink:0;position:relative;}
.betaling-card.actief .betaling-card-radio{border-color:var(--gold);}
.betaling-card.actief .betaling-card-radio::after{content:"";position:absolute;inset:3px;background:var(--gold);border-radius:50%;}
.betaling-card-info{flex:1;}
.betaling-card-info strong{display:block;color:var(--dark);margin-bottom:2px;}
.betaling-card-info span{color:var(--text-muted);font-size:.85rem;}
.betaling-card-bedrag{color:var(--gold-dark);font-weight:700;font-size:1.05rem;}
.bevestiging-icon{width:80px;height:80px;background:rgba(45,122,79,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#2d7a4f;}
.bevestiging-id{background:var(--cream);border-radius:12px;padding:16px;text-align:center;margin:16px 0 24px;}
.bevestiging-id-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);}
.bevestiging-id-num{font-family:var(--font-display);font-size:1.6rem;color:var(--gold-dark);margin-top:4px;}
.step-buttons{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);flex-wrap:wrap;}
.step-buttons .btn{flex:1 1 0;min-width:0;justify-content:center;white-space:nowrap;padding-left:18px;padding-right:18px;}
.step-buttons .btn.secondary{flex:0 0 auto;min-width:90px;}
@media (max-width:480px){.step-buttons .btn{font-size:.85rem;padding-left:14px;padding-right:14px;}
}
