/* ===== Base ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
    --c1:#2b4c2e;--c1l:#3d6b42;--c1d:#1a2f1c;
    --c2:#bf8a54;--c2l:#d4a87a;
    --txt:#1e1e1e;--txt2:#555;--txt3:#999;
    --bg:#faf9f6;--bg2:#f2efe9;--white:#fff;
    --border:#e2dfd8;
    --radius:14px;--radius-sm:8px;
    --shadow:0 2px 16px rgba(0,0,0,.06);
    --shadow-lg:0 8px 32px rgba(0,0,0,.1);
    --font:'DM Sans',sans-serif;
    --font-head:'DM Serif Display',serif;
    --max:1100px;
    --transition:all .25s ease;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--txt);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--font)}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}
.nav{max-width:var(--max);margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:1.2rem;color:var(--c1)}
.brand-icon{font-size:1.1rem;color:var(--c2)}
.nav-links{display:flex;list-style:none;gap:24px}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--txt2);transition:var(--transition);padding-bottom:2px;border-bottom:2px solid transparent}
.nav-links a:hover{color:var(--c1);border-color:var(--c2)}
.btn-cta{background:var(--c1);color:var(--white);padding:9px 22px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;transition:var(--transition);border:none}
.btn-cta:hover{background:var(--c1l)}
.mobile-toggle{display:none;background:none;border:none;font-size:1.2rem;color:var(--txt)}

/* ===== Hero ===== */
.hero{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 8s ease}
.hero:hover .hero-bg{transform:scale(1.03)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,30,30,.25) 0%,rgba(30,30,30,.55) 100%)}
.hero-body{position:relative;z-index:1;text-align:center;color:var(--white);max-width:680px;padding:40px 24px}
.hero-location{font-size:.85rem;letter-spacing:1px;text-transform:uppercase;opacity:.9;margin-bottom:12px}
.hero-title{font-family:var(--font-head);font-size:clamp(2.4rem,5.5vw,3.8rem);margin-bottom:8px}
.hero-tagline{font-size:1.1rem;font-weight:300;opacity:.9;margin-bottom:28px}
.hero-stats{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:32px}
.stat{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);padding:8px 18px;border-radius:50px;font-size:.85rem}
.btn-hero{display:inline-block;background:var(--c2);color:var(--white);padding:14px 36px;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;transition:var(--transition);border:none}
.btn-hero:hover{background:var(--c2l);transform:translateY(-2px);box-shadow:0 4px 16px rgba(191,138,84,.4)}

/* ===== Sections ===== */
.section{padding:80px 0}
.section-alt{background:var(--bg2)}
.section-head{text-align:center;margin-bottom:48px}
.section-head h2{font-family:var(--font-head);font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:8px;color:var(--c1d)}
.section-head p{color:var(--txt2);font-size:.95rem}

/* ===== Photo Grid ===== */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.photo-grid .photo-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative}
.photo-grid .photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.photo-grid .photo-item:hover img{transform:scale(1.06)}
.photo-grid .photo-item:first-child{grid-column:1/3;grid-row:1/3;aspect-ratio:auto}
.btn-outline{display:block;margin:0 auto;padding:12px 28px;border:2px solid var(--c1);color:var(--c1);border-radius:var(--radius-sm);background:transparent;font-weight:600;font-size:.9rem;transition:var(--transition)}
.btn-outline:hover{background:var(--c1);color:var(--white)}

/* ===== About Two-Col ===== */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.col-text h2{font-family:var(--font-head);font-size:1.7rem;margin-bottom:16px;color:var(--c1d)}
.col-text p{color:var(--txt2);margin-bottom:14px;line-height:1.75;font-size:.95rem}
.col-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.col-img img{width:100%;height:420px;object-fit:cover}
.price-box{margin-top:24px;display:inline-flex;align-items:baseline;gap:6px;background:var(--c1);padding:16px 28px;border-radius:var(--radius-sm);color:var(--white)}
.price-label{font-size:.8rem;opacity:.8}
.price-value{font-family:var(--font-head);font-size:2rem}
.price-unit{font-size:.85rem;opacity:.8}

/* ===== Features ===== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.feature-card{background:var(--white);padding:28px 24px;border-radius:var(--radius);text-align:center;transition:var(--transition);border:1px solid var(--border)}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--c2)}
.feature-card i{font-size:1.6rem;color:var(--c2);margin-bottom:14px}
.feature-card h4{font-size:1rem;margin-bottom:6px;color:var(--c1d)}
.feature-card p{font-size:.85rem;color:var(--txt2)}
.info-box{display:flex;gap:16px;align-items:flex-start;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}
.info-icon{flex-shrink:0;color:var(--c2);font-size:1.4rem;margin-top:2px}
.info-box strong{color:var(--c1d);font-size:.95rem}
.info-box p{color:var(--txt2);font-size:.85rem;line-height:1.7;margin-top:4px}

/* ===== Calendar ===== */
.calendar-wrapper{display:flex;justify-content:center;margin-bottom:16px}
#inlineCalendar .flatpickr-calendar{box-shadow:none!important;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font)}
.flatpickr-day.booked-date{background:#ffe0e0!important;color:#cc0000!important;text-decoration:line-through;pointer-events:none}

/* Range selection styles */
.flatpickr-day.in-range-preview{background:rgba(43,76,46,.12)!important;border-color:transparent!important}
.flatpickr-day.range-start{background:var(--c1)!important;color:#fff!important;border-radius:50%!important}
.flatpickr-day.range-end{background:var(--c1)!important;color:#fff!important;border-radius:50%!important}
.flatpickr-day.selected.startRange{background:var(--c1)!important;border-color:var(--c1)!important}
.flatpickr-day.selected.endRange{background:var(--c1)!important;border-color:var(--c1)!important}
.flatpickr-day.inRange{background:rgba(43,76,46,.12)!important;border-color:transparent!important;box-shadow:-5px 0 0 rgba(43,76,46,.12),5px 0 0 rgba(43,76,46,.12)!important}
.flatpickr-day.selected{background:var(--c1)!important;border-color:var(--c1)!important}
.flatpickr-day.today{border-color:var(--c2)!important}
.flatpickr-day:hover{background:rgba(43,76,46,.08)!important}

.calendar-legend{display:flex;gap:20px;justify-content:center;font-size:.85rem;color:var(--txt2)}
.dot-green,.dot-red{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot-green{background:#d4edda;border:2px solid #28a745}
.dot-red{background:#ffe0e0;border:2px solid #cc0000}

/* ===== Booking ===== */
.booking-layout{display:grid;grid-template-columns:1.4fr .6fr;gap:40px;align-items:start}
.booking-form{background:var(--white);padding:32px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.field{display:flex;flex-direction:column}
.field.full{margin-bottom:16px}
.field label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;color:var(--txt)}
.opt{font-weight:400;color:var(--txt3);text-transform:none;letter-spacing:0}
.field input,.field select,.field textarea{padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--font);transition:var(--transition);background:var(--bg);color:var(--txt)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--c1);box-shadow:0 0 0 3px rgba(43,76,46,.1)}
.field textarea{resize:vertical}
.conflict-alert{background:#fff0f0;border:1px solid #ffcccc;border-radius:var(--radius-sm);padding:12px 16px;display:flex;align-items:center;gap:10px;font-size:.85rem;color:#c00;margin-bottom:16px}
.booking-summary{background:var(--bg2);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:16px}
.sum-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--txt2);margin-bottom:8px}
.sum-total{display:flex;justify-content:space-between;font-weight:700;font-size:1rem;padding-top:10px;border-top:2px solid var(--c1)}
.discount-row{color:#28a745;font-weight:500}
.discount-row i{margin-right:4px}

.pricing-detail{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.pricing-detail summary{padding:10px 14px;font-size:.82rem;font-weight:500;color:var(--c1);cursor:pointer;background:var(--bg);list-style:none;display:flex;align-items:center;gap:6px}
.pricing-detail summary::-webkit-details-marker{display:none}
.pricing-detail[open] summary{border-bottom:1px solid var(--border)}
.detail-list{max-height:200px;overflow-y:auto;padding:4px 0}
.detail-item{display:flex;justify-content:space-between;align-items:center;padding:6px 14px;font-size:.8rem;border-bottom:1px solid var(--bg2)}
.detail-item:last-child{border-bottom:none}
.detail-label{color:var(--txt3);font-size:.75rem;padding:2px 8px;background:var(--bg2);border-radius:50px}

.btn-submit{width:100%;padding:14px;border:none;border-radius:var(--radius-sm);background:var(--c1);color:var(--white);font-size:1rem;font-weight:600;transition:var(--transition)}
.btn-submit:hover{background:var(--c1l)}
.btn-submit.loading{opacity:.7;pointer-events:none}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
.shake{animation:shake .4s ease}

.side-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.side-card img{width:100%;height:180px;object-fit:cover}
.side-body{padding:20px}
.side-body h3{font-family:var(--font-head);font-size:1.2rem;margin-bottom:6px;color:var(--c1d)}
.side-loc{font-size:.8rem;color:var(--txt2);margin-bottom:12px}
.side-tags{display:flex;flex-wrap:wrap;gap:6px}
.side-tags span{background:var(--bg2);padding:4px 12px;border-radius:50px;font-size:.75rem;color:var(--txt2)}
.btn-wpp{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:var(--radius-sm);border:2px solid #25d366;color:#25d366;font-weight:600;font-size:.9rem;transition:var(--transition)}
.btn-wpp:hover{background:#25d366;color:var(--white)}
.btn-wpp i{font-size:1.15rem}

/* ===== Map ===== */
.map-box{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

/* ===== Reviews ===== */
.reviews-avg{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:1.1rem}
.reviews-avg .avg-num{font-family:var(--font-head);font-size:2rem;color:var(--c1d)}
.reviews-avg .avg-stars{color:var(--c2);font-size:1.1rem}
.reviews-avg .avg-count{color:var(--txt2);font-size:.85rem}

/* Reviews toolbar */
.reviews-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:14px 20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);gap:12px;flex-wrap:wrap}
.reviews-toolbar-left{display:flex;align-items:center;gap:8px}
.reviews-count{font-size:.85rem;color:var(--txt2);font-weight:500}
.reviews-toolbar-right{display:flex;align-items:center;gap:8px}
.reviews-sort-label{font-size:.78rem;color:var(--txt3);white-space:nowrap;display:flex;align-items:center;gap:4px}
.reviews-sort-select{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--font);background:var(--white);cursor:pointer;color:var(--txt);appearance:auto}
.reviews-sort-select:focus{outline:none;border-color:var(--c1)}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:var(--transition)}
.review-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.review-avatar{width:42px;height:42px;border-radius:50%;background:var(--c1);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}
.review-meta{flex:1;min-width:0}
.review-meta h4{font-size:.9rem;margin-bottom:2px;color:var(--c1d)}
.review-meta .review-date{font-size:.75rem;color:var(--txt3)}
.review-nota{margin-left:auto;background:var(--c1);color:var(--white);padding:4px 10px;border-radius:var(--radius-sm);font-weight:700;font-size:.85rem;flex-shrink:0}
.review-nota-stars{display:flex;gap:2px;margin-top:4px;color:var(--c2);font-size:.7rem}
.review-text{font-size:.88rem;color:var(--txt2);line-height:1.7}

/* Reviews pagination */
.reviews-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:28px;flex-wrap:wrap}
.reviews-pagination button{min-width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--txt);font-size:.85rem;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}
.reviews-pagination button:hover{border-color:var(--c1);color:var(--c1)}
.reviews-pagination button.active{background:var(--c1);color:var(--white);border-color:var(--c1)}
.reviews-pagination button:disabled{opacity:.4;cursor:not-allowed}
.reviews-pagination .page-info{font-size:.78rem;color:var(--txt3);margin:0 8px}

.review-form-wrap{margin-top:40px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;max-width:700px;margin-left:auto;margin-right:auto}
.review-form-wrap h3{font-family:var(--font-head);font-size:1.1rem;color:var(--c1d);margin-bottom:16px;text-align:center}

/* ===== Gallery Modal ===== */
.gallery-modal{position:fixed;inset:0;background:var(--white);z-index:200;display:none;flex-direction:column;overflow-y:auto}
.gallery-modal.active{display:flex}
.gm-header{position:sticky;top:0;background:var(--white);padding:14px 24px;border-bottom:1px solid var(--border);z-index:1}
.gm-close{background:none;border:none;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:8px;color:var(--txt);padding:8px 16px;border-radius:var(--radius-sm);transition:var(--transition)}
.gm-close:hover{background:var(--bg2)}
.gm-body{max-width:800px;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:12px}
.gm-body img{width:100%;border-radius:var(--radius-sm)}

/* ===== Success Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.active{display:flex}
.modal-box{background:var(--white);border-radius:var(--radius);padding:40px;max-width:420px;width:100%;text-align:center}
.modal-icon{font-size:3rem;color:var(--c1);margin-bottom:16px}
.modal-box h3{font-family:var(--font-head);font-size:1.3rem;margin-bottom:10px}
.modal-box p{color:var(--txt2);font-size:.9rem;line-height:1.65;margin-bottom:24px}
.btn-modal{background:var(--c1);color:var(--white);border:none;padding:12px 32px;border-radius:var(--radius-sm);font-weight:600;transition:var(--transition)}
.btn-modal:hover{background:var(--c1l)}

/* ===== Footer ===== */
.footer{background:var(--c1d);color:rgba(255,255,255,.8);padding-top:48px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:32px;padding-bottom:32px}
.footer h4{color:var(--white);font-size:.9rem;margin-bottom:12px;font-family:var(--font-head);font-size:1rem}
.footer p{font-size:.85rem;line-height:2}
.footer a{color:rgba(255,255,255,.7);transition:var(--transition)}
.footer a:hover{color:var(--white)}
.footer i{margin-right:6px;width:16px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 24px;text-align:center;font-size:.78rem;color:rgba(255,255,255,.5)}

/* ===== Responsive ===== */
@media(max-width:960px){
    .booking-layout{grid-template-columns:1fr}
    .two-col{grid-template-columns:1fr;gap:32px}
    .col-img img{height:300px}
    .features-grid{grid-template-columns:1fr 1fr}
    .reviews-grid{grid-template-columns:1fr 1fr}
    .reviews-toolbar{flex-direction:column;align-items:stretch}
    .reviews-toolbar-right{justify-content:flex-end}
    .nav-links,.btn-cta{display:none}
    .mobile-toggle{display:block}
    .nav-links.active{display:flex;flex-direction:column;position:absolute;top:60px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:16px 24px;gap:12px;box-shadow:var(--shadow)}
}
@media(max-width:640px){
    .photo-grid{grid-template-columns:1fr 1fr;gap:8px}
    .photo-grid .photo-item:first-child{grid-column:1/-1;grid-row:auto}
    .form-row{grid-template-columns:1fr}
    .hero{min-height:420px}
    .hero-stats{gap:8px}
    .stat{padding:6px 12px;font-size:.78rem}
    .section{padding:56px 0}
    .features-grid{grid-template-columns:1fr}
    .reviews-grid{grid-template-columns:1fr}
    .review-form-wrap{padding:20px 16px}
    .reviews-toolbar{padding:10px 14px}
    .reviews-sort-select{width:100%}
    .reviews-pagination button{min-width:36px;height:36px;font-size:.78rem}
    .footer-grid{grid-template-columns:1fr;gap:24px}
    .map-box iframe{height:260px}
}
