
:root{
  --bg:#f5f7fa;
  --surface:#ffffff;
  --surface-soft:#f8fafc;
  --surface-muted:#f1f5f9;
  --line:#e4e7ec;
  --line-strong:#d0d5dd;
  --text:#101828;
  --muted:#667085;
  --primary:#0f766e;
  --primary-dark:#115e59;
  --primary-soft:rgba(15,118,110,.08);
  --accent:#d97706;
  --danger:#b42318;
  --success:#027a48;
  --shadow:0 12px 30px rgba(16,24,40,.08);
  --shadow-sm:0 6px 16px rgba(16,24,40,.06);
  --radius:24px;
  --radius-lg:30px;
  --radius-sm:16px;
  --container:1180px;
  --sidebar:270px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font:400 15px/1.65 Inter,Arial,Helvetica,sans-serif}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;color:var(--text);padding:13px 14px;border-radius:14px;outline:none}
input:focus,select:focus,textarea:focus{border-color:rgba(15,118,110,.45);box-shadow:0 0 0 4px rgba(15,118,110,.08)}
textarea{resize:vertical}
.container{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.narrow{width:min(980px,calc(100% - 32px));margin:0 auto}
.site-main{padding:0 0 42px}
.section{padding:36px 0}
.section-soft{background:linear-gradient(180deg,#f7f8fa 0%,#f3f5f8 100%)}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.stack-list,.accordion-list,.timeline,.payment-options,.check-list,.amenity-grid,.permission-grid,.icon-list,.payment-info-boxes{display:grid;gap:14px}
.actions-row,.section-head,.results-topbar,.summary-line,.flex-between,.header-row,.detail-badges,.card-head,.filter-head,.access-role-head,.booking-card-head{display:flex;align-items:center;justify-content:space-between;gap:14px}
.section-head.left{justify-content:flex-start}
.section-head{margin-bottom:18px}
.section-head h2,.page-hero-compact h1,.detail-hero-head h1,.admin-page-head h1,.hero-copy h1,.destination-hero-copy h1{margin:0 0 10px}
.section-head p,.page-hero-compact p,.admin-page-head p,.hero-copy p,.destination-hero-copy p,.muted,.footer-copy p,.card p,.product-card p,small{color:var(--muted)}
.section-link{font-weight:700;color:var(--primary)}
.section-kicker,.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#0f766e;font-weight:800}
.eyebrow:before,.section-kicker:before{content:"";width:24px;height:2px;border-radius:999px;background:currentColor;opacity:.5}
.card{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow-sm)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:12px 18px;border:1px solid transparent;font-weight:700;cursor:pointer;transition:.2s ease}
.btn:hover{transform:translateY(-1px)}
.btn-small{padding:9px 14px;font-size:.88rem}
.btn-block{width:100%}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:#fff;border-color:var(--line);color:var(--text)}
.btn-danger{background:#fff;border-color:#f1b7b3;color:var(--danger)}
.alert{margin:14px auto 0;border-radius:16px;padding:14px 16px;border:1px solid var(--line)}
.alert-success{background:#ecfdf3;border-color:#abefc6;color:#027a48}
.alert-danger{background:#fef3f2;border-color:#fecdca;color:#b42318}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(228,231,236,.75)}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#0f766e,#1c8d84);display:grid;place-items:center;color:#fff;font-weight:800}
.brand-copy{display:grid}
.brand-copy strong{font-size:1rem}
.brand-copy small{font-size:.78rem;color:var(--muted)}
.main-nav{display:flex;align-items:center;gap:20px}
.main-nav>a{font-weight:600;color:#344054}
.main-nav>a.active,.main-nav>a:hover{color:var(--primary)}
.language-switcher{display:inline-flex;align-items:center;padding:4px;border-radius:999px;background:var(--surface-muted);gap:4px}
.language-switcher a{padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:700;color:var(--muted)}
.language-switcher a.active{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}
.nav-cta{margin-left:4px}
.admin-entry{font-size:.88rem;color:var(--muted)}
.menu-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 12px}

/* Hero */
.hero{padding:30px 0 22px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:stretch}
.hero-copy{padding:18px 0}
.hero-copy h1{font-size:clamp(2rem,4vw,3.4rem);line-height:1.04;max-width:11ch}
.hero-copy p{max-width:640px;font-size:1.02rem}
.hero-highlights{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0 22px}
.hero-highlights span,.destination-hero-stats span,.detail-badges span{display:inline-flex;align-items:center;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:600;color:#344054}
.hero-visual img{width:100%;height:100%;min-height:560px;object-fit:cover;border-radius:32px;box-shadow:var(--shadow)}
.hero-search{padding:16px}
.tabs{display:flex;gap:10px;padding-bottom:12px}
.tab{border:none;background:var(--surface-muted);color:#344054;padding:10px 16px;border-radius:999px;font-weight:700;cursor:pointer}
.tab.active{background:var(--primary);color:#fff}
.tab-panel{display:none}
.tab-panel.active{display:block}
.search-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr .8fr auto;gap:12px}
.hero .search-grid input,.hero .search-grid select{height:48px}
.search-grid button{height:48px}

/* Home */
.destination-grid{align-items:stretch}
.destination-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s ease}
.destination-card:hover{transform:translateY(-4px)}
.destination-card img{width:100%;height:210px;object-fit:cover}
.destination-card-body{padding:18px}
.destination-card-body h3{margin:0 0 6px;font-size:1.15rem}
.destination-card-body p{margin:0 0 14px;color:var(--muted)}
.destination-stats{display:flex;flex-wrap:wrap;gap:8px}
.destination-stats span{padding:8px 10px;border:1px solid var(--line);border-radius:999px;font-size:.82rem;font-weight:700;color:#344054;background:#fff}
.why-grid .card{height:100%}
.payment-info-boxes .info-box,.home-cta-box,.info-box{background:var(--surface-soft);border:1px solid var(--line);border-radius:18px;padding:16px}
.review-card{padding:18px}
.rating-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#fff7ed;color:#b54708;font-weight:800;font-size:.82rem;border:1px solid #fed7aa}

/* Product cards */
.product-card{padding:0;overflow:hidden}
.card-image{display:block;position:relative}
.card-image img{width:100%;height:250px;object-fit:cover}
.tag{position:absolute;top:14px;left:14px;padding:8px 12px;border-radius:999px;background:rgba(16,24,40,.72);color:#fff;font-size:.76rem;font-weight:700;backdrop-filter:blur(7px)}
.card-body{padding:18px}
.card-topline{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}
.card-location{font-size:.84rem;color:#667085;font-weight:700}
.product-card h3{margin:0 0 8px;font-size:1.08rem}
.product-card p{margin:0 0 14px;min-height:48px}
.card-specs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.card-specs span{padding:7px 10px;border-radius:999px;background:var(--surface-muted);font-size:.78rem;color:#344054;font-weight:600}
.card-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:14px}
.card-price{display:grid;gap:2px}
.card-price strong{font-size:1.08rem}
.card-price span{color:var(--muted);font-size:.85rem}
.card-price small{font-size:.78rem}
.card-actions{display:flex;gap:8px;flex-wrap:wrap}

/* Compact page heroes */
.page-hero-compact,.detail-hero-head{padding:34px 0 12px}
.page-hero-compact h1,.detail-hero-head h1{font-size:clamp(1.8rem,3vw,2.6rem)}
.listing-category-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.listing-category-tabs a{padding:10px 16px;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:700;color:#344054}
.listing-category-tabs a.active{background:var(--primary);border-color:var(--primary);color:#fff}
.listing-layout{display:grid;grid-template-columns:320px 1fr;gap:24px}
.filter-sidebar{position:sticky;top:88px;height:fit-content}
.filter-sidebar h3{margin:0}
.listing-results{display:grid;gap:20px}
.listing-view-pill{display:inline-flex;gap:6px;padding:5px;border-radius:999px;background:var(--surface-muted)}
.listing-view-pill span{padding:7px 12px;border-radius:999px;font-size:.8rem;font-weight:700;color:var(--muted)}
.listing-view-pill .active{background:#fff;box-shadow:var(--shadow-sm);color:#101828}
.empty-state{text-align:center;padding:42px 24px}

/* Detail */
.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:start}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
.gallery-grid img{width:100%;height:176px;object-fit:cover;border-radius:20px}
.gallery-main{grid-column:span 2;grid-row:span 2;height:364px!important}
.detail-hero{width:100%;height:420px;object-fit:cover;border-radius:28px;box-shadow:var(--shadow);margin-bottom:22px}
.detail-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:20px}
.detail-section h2,.detail-section h3{margin:8px 0 10px}
.amenity-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.amenity-chip{display:flex;align-items:center;justify-content:center;padding:12px 14px;border-radius:16px;background:var(--surface-muted);border:1px solid var(--line);font-weight:700;color:#344054;text-align:center}
.sticky-booking{position:sticky;top:96px}
.booking-sidebar-card{padding:22px}
.price-block{display:flex;align-items:flex-end;gap:8px;margin-bottom:10px}
.price-block strong{font-size:1.9rem}
.price-block span{font-size:.94rem;color:var(--muted)}
.mini-booking-form{display:grid;gap:12px;margin-top:16px}
.review-item{padding:16px;border:1px solid var(--line);border-radius:18px;background:var(--surface-soft)}
.stars{color:#f59e0b}
.timeline-item{padding:14px;border-radius:18px;border:1px solid var(--line);background:#fff}
.timeline-item p{margin:6px 0 4px}

/* Availability */
.interactive-calendar{overflow:hidden}
.calendar-shell{display:grid;gap:14px}
.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px}
.calendar-toolbar small{display:block;margin-top:4px}
.calendar-weekdays,.calendar-board{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.calendar-weekdays span{font-size:.82rem;font-weight:700;color:#667085;text-align:center;padding:6px 0}
.calendar-day{min-height:110px;border:1px solid var(--line);background:#fff;border-radius:18px;padding:10px;display:grid;gap:6px;align-content:start;text-align:left}
.calendar-day strong{font-size:1rem}
.calendar-day small,.calendar-day span,.calendar-day em{font-size:.72rem;color:#667085;font-style:normal}
.calendar-day.status-available{background:#fff}
.calendar-day.status-low{background:#fff8eb;border-color:#fed7aa}
.calendar-day.status-blocked{background:#fff3f2;border-color:#fecdca}
.calendar-day.is-disabled{opacity:.55;cursor:not-allowed}
.calendar-day.is-empty{visibility:hidden}
.calendar-legend{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.legend{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;color:#475467}
.legend:before{content:"";width:10px;height:10px;border-radius:999px;background:currentColor}
.legend.available{color:#027a48}
.legend.low{color:#b54708}
.legend.blocked{color:#b42318}

/* Booking flow */
.booking-steps{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.booking-step{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#fff}
.booking-step span{width:26px;height:26px;border-radius:999px;background:var(--surface-muted);display:grid;place-items:center;font-size:.82rem;font-weight:800}
.booking-step.is-current{border-color:rgba(15,118,110,.3);background:rgba(15,118,110,.06)}
.booking-step.is-current span,.booking-step.is-done span{background:var(--primary);color:#fff}
.booking-card{display:grid;gap:20px}
.booking-card-price{font-size:1.25rem;font-weight:800}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.payment-option{display:flex;gap:14px;border:1px solid var(--line);border-radius:20px;padding:16px;background:#fff}
.payment-option input{width:auto;margin-top:4px}
.qris-box{padding:16px;border-radius:18px;border:1px dashed var(--line-strong);background:var(--surface-soft)}

/* Content/blog/pages */
.article-card{overflow:hidden}
.article-card img{width:100%;height:220px;object-fit:cover}
.article-card h3{margin:8px 0}
.article-content{line-height:1.8}
.rich-text{color:#344054}
.destination-hero{position:relative;padding:78px 0;background-size:cover;background-position:center}
.destination-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,24,40,.68),rgba(16,24,40,.28))}
.destination-hero-inner{position:relative}
.destination-hero-copy{max-width:690px;color:#fff}
.destination-hero-copy p,.destination-hero-copy .eyebrow{color:#fff}
.destination-hero-stats{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}

/* Footer */
.site-footer{background:#fff;border-top:1px solid var(--line);padding-top:28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:24px;padding-bottom:24px}
.footer-brand{display:flex;gap:12px}
.footer-brand p{margin:8px 0 0}
.footer-list{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:10px}
.footer-list a{color:#475467}
.footer-list a:hover{color:var(--primary)}
.footer-wa{display:inline-flex;margin-top:16px;padding:11px 16px;border-radius:999px;background:rgba(37,211,102,.12);color:#067647;font-weight:700}
.footer-copy{padding:18px 0 28px;border-top:1px solid var(--line)}

/* Admin */
.admin-body{background:#f4f6f9}
.admin-shell{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.admin-sidebar{background:#fff;border-right:1px solid var(--line);padding:22px 18px;display:flex;flex-direction:column;gap:20px;position:sticky;top:0;height:100vh}
.admin-brand a{font-weight:800;font-size:1.08rem}
.admin-brand small{display:block;color:#667085;margin-top:4px}
.admin-nav,.admin-sidebar-foot{display:grid;gap:6px}
.admin-nav-link{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:14px;color:#344054;font-weight:600}
.admin-nav-link:hover,.admin-nav-link.is-active{background:var(--surface-muted);color:#101828}
.admin-nav-dot{width:9px;height:9px;border-radius:999px;background:#cbd5e1}
.admin-nav-link.is-active .admin-nav-dot{background:var(--primary)}
.admin-content{min-width:0}
.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.88);backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}
.admin-topbar strong{display:block}
.admin-topbar span{color:#667085;font-size:.92rem}
.admin-user-pill{display:flex;flex-direction:column;align-items:flex-end;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:#fff}
.admin-user-pill small{font-size:.78rem}
.admin-main{padding:24px}
.admin-page-head{margin-bottom:18px}
.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}
.stats-grid-6{grid-template-columns:repeat(6,minmax(0,1fr))}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow-sm);display:grid;gap:8px}
.stat-card span{color:#667085}
.stat-card strong{font-size:1.3rem}
.admin-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;margin-bottom:18px}
.table-wrap{overflow:auto}
.data-table{width:100%;border-collapse:separate;border-spacing:0}
.data-table th,.data-table td{padding:14px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.data-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:#667085}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.status-pill{display:inline-flex;padding:7px 10px;border-radius:999px;font-size:.78rem;font-weight:800;background:#eef2f6;color:#344054}
.status-pending,.status-pending_payment,.status-awaiting_verification,.status-awaiting_review{background:#fffaeb;color:#b54708}
.status-confirmed,.status-paid_in_full,.status-active,.status-verified,.status-completed,.status-sent{background:#ecfdf3;color:#027a48}
.status-cancelled,.status-failed,.status-rejected{background:#fef3f2;color:#b42318}
.toolbar-card{margin-bottom:18px}
.search-inline{display:flex;gap:12px}
.search-inline input{max-width:360px}
.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-form-grid .full{grid-column:1/-1}
.form-card{display:grid;gap:20px}
.metric-row{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.access-role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.access-role-card{display:grid;gap:16px}
.permission-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.permission-chip{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:16px;background:var(--surface-soft);border:1px solid var(--line)}
.permission-chip input{width:auto;margin-top:3px}
.tab-bar{display:flex;gap:10px;margin-bottom:18px}
.tab-link{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:700;color:#344054}
.tab-link.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.admin-login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.admin-login-panel{width:min(1080px,100%);display:grid;grid-template-columns:1.08fr .92fr;gap:20px}
.admin-login-aside{padding:44px;border-radius:32px;background:linear-gradient(135deg,#0f766e,#115e59);color:#fff}
.admin-login-aside .section-kicker,.admin-login-aside p,.admin-login-aside li{color:#fff}
.admin-login-card{padding:34px}
.compact-list li{display:grid;gap:4px;padding:10px 0;border-bottom:1px solid var(--line)}
.compact-list{list-style:none;padding:0;margin:0}
.booking-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}

/* Misc */
.check-list{list-style:none;padding:0;margin:0}
.check-list li{position:relative;padding-left:24px}
.check-list li:before{content:"✓";position:absolute;left:0;top:0;color:var(--primary);font-weight:900}
.accordion-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px}
.accordion-item summary{cursor:pointer;font-weight:700}
.floating-wa{position:fixed;right:18px;bottom:18px;z-index:70;background:#25d366;color:#fff;border-radius:999px;padding:14px 18px;box-shadow:var(--shadow);display:grid}
.floating-wa small{color:#eafff0}
.info-card{height:100%}

/* Responsive */
@media (max-width: 1100px){
  .hero-grid,.detail-layout,.admin-grid,.footer-grid,.admin-login-panel{grid-template-columns:1fr}
  .listing-layout{grid-template-columns:1fr}
  .sticky-booking,.filter-sidebar,.admin-sidebar,.admin-topbar{position:static}
  .admin-shell{grid-template-columns:1fr}
  .admin-sidebar{height:auto;border-right:none;border-bottom:1px solid var(--line)}
  .stats-grid-6{grid-template-columns:repeat(3,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 860px){
  .menu-toggle{display:block}
  .main-nav{position:absolute;left:16px;right:16px;top:74px;padding:16px;border:1px solid var(--line);background:#fff;border-radius:22px;box-shadow:var(--shadow);display:none;flex-direction:column;align-items:stretch}
  .main-nav.open{display:flex}
  .hero-visual img{min-height:360px}
  .search-grid,.form-grid,.detail-card-grid,.amenity-grid,.access-role-grid,.permission-grid,.admin-form-grid,.stats-grid,.grid-2,.grid-3{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-main{grid-column:span 2;height:280px!important}
  .calendar-weekdays,.calendar-board{gap:6px}
  .calendar-day{min-height:92px;padding:8px}
}
@media (max-width: 640px){
  .container,.narrow{width:min(100%,calc(100% - 24px))}
  .hero-copy h1{font-size:2.15rem}
  .tabs{flex-wrap:wrap}
  .search-grid{grid-template-columns:1fr}
  .actions-row,.section-head,.results-topbar,.summary-line,.flex-between,.card-footer,.card-topline,.header-row,.detail-badges,.filter-head,.booking-card-head,.calendar-toolbar{flex-direction:column;align-items:flex-start}
  .hero-highlights,.destination-stats,.destination-hero-stats,.detail-badges,.card-actions,.calendar-legend,.listing-category-tabs,.tab-bar{flex-wrap:wrap}
  .stats-grid-6{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}


/* Compatibility for legacy views still in use */
.site-body{background:var(--bg)}
.soft-bg{background:linear-gradient(180deg,#f7f8fa 0%,#f3f5f8 100%)}
.page-head,.page-head-compact,.page-head-detail{padding:34px 0 12px}
.page-head h1,.page-head-compact h1,.page-head-detail h1{margin:0 0 10px;font-size:clamp(1.8rem,3vw,2.4rem)}
.page-head p,.page-head-compact p,.page-head-detail p{max-width:760px;color:var(--muted)}
.subhero{padding:74px 0;background-size:cover;background-position:center;position:relative}
.subhero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,24,40,.62),rgba(16,24,40,.2))}
.subhero .container{position:relative}
.subhero-copy{max-width:700px;color:#fff}
.subhero-copy p,.subhero-copy .eyebrow{color:#fff}
.payment-card{padding:16px;border:1px solid var(--line);border-radius:18px;background:var(--surface-soft)}
.payment-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.verify-form{margin-top:12px}
.mini-note{padding:16px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--line)}
.article-card-large img{height:240px}
.booking-sidebar-card .summary-line{padding:8px 0;border-bottom:1px solid var(--line)}
.booking-sidebar-card .summary-line.total{border-bottom:none;padding-top:14px}
.home-cta-box{margin-top:18px}
.payment-info-boxes{margin-top:14px}
.toolbar-card .search-inline{align-items:center}


/* ===== Frontend redesign 2026 ===== */
.site-body{
  --site-bg:#f8f7f3;
  --site-sand:#f3eee4;
  --site-mist:#edf6f4;
  --site-sky:#e8f1f8;
  --site-card:#ffffff;
  --site-line:rgba(54,36,29,.10);
  --site-line-strong:rgba(54,36,29,.16);
  --site-heading:#2f1d15;
  --site-text:#5b5148;
  --site-muted:#8b7c70;
  --site-teal:#258777;
  --site-blue:#2c90c7;
  --site-orange:#e07b2d;
  --site-brown:#2d201a;
  background:#fff;
  color:var(--site-text);
  font-family:"Inter",Arial,Helvetica,sans-serif;
}
.site-body *{box-sizing:border-box}
.site-body img{display:block;max-width:100%}
.site-body a{text-decoration:none;color:inherit}
.site-body .site-main{padding:0}
.site-body .container{width:min(1240px,calc(100% - 48px));margin:0 auto}
.site-body .narrow{width:min(920px,calc(100% - 48px));margin:0 auto}
.site-body .narrow-centered{width:min(900px,calc(100% - 48px));margin:0 auto;text-align:center}
.site-body h1,.site-body h2,.site-body h3,.site-body h4,.site-body h5,.site-body h6{
  font-family:"Cormorant Garamond",Georgia,serif;
  color:var(--site-heading);
  line-height:.95;
  letter-spacing:-.02em;
}
.site-body h1{font-size:clamp(3rem,5vw,5.35rem)}
.site-body h2{font-size:clamp(2.35rem,4vw,3.45rem)}
.site-body h3{font-size:clamp(1.7rem,2.4vw,2.3rem)}
.site-body p,.site-body li,.site-body small,.site-body span,.site-body label,.site-body input,.site-body select,.site-body textarea{
  font-family:"Inter",Arial,Helvetica,sans-serif;
}
.site-body p{color:var(--site-text)}
.site-body input,.site-body select,.site-body textarea{
  border:1px solid rgba(54,36,29,.12);
  border-radius:16px;
  background:#fff;
  color:var(--site-heading);
  padding:13px 14px;
}
.site-body input:focus,.site-body select:focus,.site-body textarea:focus{
  border-color:rgba(37,135,119,.45);
  box-shadow:0 0 0 4px rgba(37,135,119,.10);
  outline:none;
}
.site-body .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:14px;
  padding:12px 20px;
  font-weight:700;
  border:1px solid transparent;
  transition:.22s ease;
}
.site-body .btn:hover{transform:translateY(-1px)}
.site-body .btn-small{padding:11px 16px;border-radius:12px}
.site-body .btn-large{padding:14px 28px}
.site-body .btn-gradient{
  background:linear-gradient(90deg,var(--site-teal) 0%,var(--site-blue) 100%);
  color:#fff;
  box-shadow:0 12px 28px rgba(44,144,199,.20);
}
.site-body .btn-ghost{
  background:#fff;
  border-color:var(--site-line-strong);
  color:var(--site-heading);
}
.site-body .btn-light{
  background:#fff;
  color:var(--site-heading);
}
.site-body .btn-light-outline{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.35);
  color:#fff;
}
.site-body .section-link{
  color:var(--site-teal);
  font-weight:700;
  font-size:1.05rem;
}
.site-body .section-kicker,
.site-body .eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.84rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--site-orange);
}
.site-body .section-kicker:before,
.site-body .eyebrow:before{
  content:"";
  width:26px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  opacity:.45;
}
.site-body .site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(54,36,29,.08);
}
.site-body .site-header-bar{
  display:flex;
  align-items:center;
  gap:26px;
  min-height:76px;
}
.site-body .site-brand{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
.site-body .site-brand-primary{
  color:#257b6b;
  font:700 clamp(2rem,2.5vw,2.5rem)/1 "Cormorant Garamond",Georgia,serif;
}
.site-body .site-brand-secondary{
  color:var(--site-orange);
  font-weight:700;
  font-size:1.45rem;
}
.site-body .main-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex:1;
}
.site-body .nav-links{
  display:flex;
  align-items:center;
  gap:4px;
  flex-wrap:wrap;
}
.site-body .nav-links a{
  padding:12px 16px;
  border-radius:14px;
  color:var(--site-text);
  font-weight:600;
}
.site-body .nav-links a:hover,
.site-body .nav-links a.active{
  background:#eef6f3;
  color:var(--site-teal);
}
.site-body .nav-actions{
  display:flex;
  align-items:center;
  gap:12px;
}
.site-body .lang-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  color:var(--site-heading);
  font-weight:600;
}
.site-body .menu-toggle{
  display:none;
  border:1px solid var(--site-line-strong);
  background:#fff;
  color:var(--site-heading);
  border-radius:12px;
  padding:10px 12px;
}
.site-body .home-hero{
  min-height:820px;
  padding:120px 0 110px;
  background-size:cover;
  background-position:center;
  color:#fff;
}
.site-body .hero-copy{max-width:780px}
.site-body .hero-title{
  margin:0;
  max-width:760px;
  color:#fff;
  font-size:clamp(4rem,7vw,6.1rem);
  line-height:.88;
}
.site-body .hero-subtitle{
  margin:20px 0 0;
  max-width:740px;
  font-size:clamp(1.15rem,2vw,1.6rem);
  line-height:1.45;
  color:rgba(255,255,255,.92);
}
.site-body .hero-search-panel{
  margin-top:46px;
  max-width:1100px;
  background:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 28px 60px rgba(18,22,34,.22);
}
.site-body .tabs{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  background:#fff;
}
.site-body .tab{
  border:0;
  background:transparent;
  padding:20px 16px;
  font-size:1.05rem;
  font-weight:800;
  color:var(--site-muted);
  cursor:pointer;
}
.site-body .tab.active{
  color:var(--site-teal);
  background:#eef4f2;
  box-shadow:inset 0 -3px 0 var(--site-teal);
}
.site-body .tab-panel{
  display:none;
  padding:24px 28px 28px;
}
.site-body .tab-panel.active{display:block}
.site-body .hero-search-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  align-items:end;
}
.site-body .search-field{display:block}
.site-body .search-field span{
  display:block;
  margin:0 0 8px 4px;
  color:var(--site-muted);
  font-size:.92rem;
  font-weight:700;
}
.site-body .search-field input,
.site-body .search-field select{height:50px}
.site-body .btn-search{
  width:100%;
  min-height:50px;
  border-radius:14px;
}
.site-body .section-stack{padding:88px 0}
.site-body .section-stack--plain{background:#fff}
.site-body .section-stack--sand{background:var(--site-sand)}
.site-body .section-stack--mist{background:#eaf3f1}
.site-body .section-stack--sky{background:#e8f2f8}
.site-body .section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:34px;
}
.site-body .section-head h1,
.site-body .section-head h2{
  margin:0;
}
.site-body .section-head p{
  margin:10px 0 0;
  font-size:1.1rem;
  color:var(--site-muted);
}
.site-body .section-head--center{
  justify-content:center;
  text-align:center;
}
.site-body .destination-strip{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:18px;
}
.site-body .destination-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.site-body .destination-grid--page{
  margin-top:10px;
}
.site-body .destination-tile{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:24px;
  min-height:272px;
  box-shadow:0 14px 30px rgba(32,25,20,.10);
}
.site-body .destination-tile--large{
  min-height:276px;
}
.site-body .destination-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s ease;
}
.site-body .destination-tile:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(15,17,20,.02) 24%,rgba(9,10,12,.76) 100%);
  z-index:1;
}
.site-body .destination-tile__content{
  position:absolute;
  left:24px;
  right:24px;
  bottom:20px;
  z-index:2;
  color:#fff;
}
.site-body .destination-tile__content h3{
  margin:0 0 6px;
  color:#fff;
}
.site-body .destination-tile__content p,
.site-body .destination-tile__content small{
  color:rgba(255,255,255,.88);
}
.site-body .destination-tile:hover img{transform:scale(1.05)}
.site-body .product-grid{
  display:grid;
  gap:24px;
}
.site-body .product-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.site-body .product-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.site-body .product-card{
  margin:0;
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(54,36,29,.10);
  box-shadow:0 12px 30px rgba(30,24,19,.08);
  transition:.24s ease;
}
.site-body .product-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 36px rgba(30,24,19,.12);
}
.site-body .product-card__media{
  display:block;
  position:relative;
  aspect-ratio:1.26 / 1;
  overflow:hidden;
}
.site-body .product-card--tour .product-card__media{
  aspect-ratio:1.42 / 1;
}
.site-body .product-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.site-body .product-card__badges{
  position:absolute;
  left:18px;
  top:14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  z-index:2;
}
.site-body .pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-size:.9rem;
  font-weight:700;
  line-height:1;
}
.site-body .pill--light{
  background:rgba(255,255,255,.92);
  color:var(--site-heading);
}
.site-body .pill--brand{
  background:var(--site-teal);
  color:#fff;
}
.site-body .product-card__body{
  padding:18px 20px 20px;
}
.site-body .product-card__location{
  color:#aa7d58;
  font-size:1rem;
  margin-bottom:8px;
}
.site-body .product-card__title{
  margin:0 0 12px;
  font-size:2.05rem;
}
.site-body .product-card__title a{color:var(--site-heading)}
.site-body .product-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(54,36,29,.10);
  color:var(--site-muted);
  font-size:1rem;
}
.site-body .product-card__price-row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding-top:16px;
}
.site-body .product-card__price{
  display:flex;
  align-items:baseline;
  gap:4px;
  flex-wrap:wrap;
}
.site-body .product-card__price strong{
  color:var(--site-heading);
  font-size:1.9rem;
  line-height:1;
}
.site-body .product-card__price span,
.site-body .product-card__deposit{
  color:var(--site-muted);
  font-size:1rem;
}
.site-body .feature-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.site-body .feature-card,
.site-body .info-card,
.site-body .testimonial-card{
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  border-radius:24px;
  padding:28px 24px;
  box-shadow:0 10px 26px rgba(30,24,19,.05);
}
.site-body .feature-card{
  text-align:center;
}
.site-body .feature-card__icon,
.site-body .payment-showcase__icon{
  width:56px;
  height:56px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 20px;
  background:linear-gradient(180deg,var(--site-teal),var(--site-blue));
  color:#fff;
  font-size:1.9rem;
}
.site-body .feature-card h3,
.site-body .info-card h2{
  margin:0 0 12px;
}
.site-body .feature-card p{margin:0;color:var(--site-muted);font-size:1.04rem}
.site-body .payment-showcase{text-align:center}
.site-body .payment-showcase h2{margin:0 0 16px}
.site-body .payment-showcase p{
  margin:0 auto;
  max-width:860px;
  font-size:1.1rem;
  color:var(--site-muted);
}
.site-body .payment-pill-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:34px;
}
.site-body .payment-pill{
  padding:18px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  font-weight:800;
  color:var(--site-heading);
  box-shadow:0 10px 22px rgba(30,24,19,.04);
}
.site-body .testimonial-grid,
.site-body .guide-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.site-body .testimonial-card__stars{
  color:var(--site-orange);
  font-size:1.1rem;
  letter-spacing:.1em;
  margin-bottom:18px;
}
.site-body .testimonial-card p{
  margin:0 0 18px;
  color:var(--site-text);
  font-style:italic;
  line-height:1.6;
}
.site-body .testimonial-card__author{
  display:grid;
  gap:2px;
}
.site-body .testimonial-card__author strong{color:var(--site-heading)}
.site-body .testimonial-card__author span{color:var(--site-muted)}
.site-body .faq-shell{max-width:940px}
.site-body .faq-list{
  display:grid;
  gap:16px;
}
.site-body .accordion-item{
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  border-radius:18px;
  padding:0 20px;
}
.site-body .accordion-item summary{
  list-style:none;
  cursor:pointer;
  padding:20px 4px;
  font-weight:700;
  color:var(--site-heading);
  position:relative;
}
.site-body .accordion-item summary::-webkit-details-marker{display:none}
.site-body .accordion-item summary:after{
  content:"›";
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  color:var(--site-muted);
  font-size:1.5rem;
  transition:.2s ease;
}
.site-body .accordion-item[open] summary:after{
  transform:translateY(-50%) rotate(90deg);
}
.site-body .accordion-item p{
  margin:0;
  padding:0 4px 20px;
  color:var(--site-muted);
}
.site-body .guide-card{
  overflow:hidden;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  box-shadow:0 10px 26px rgba(30,24,19,.05);
}
.site-body .guide-card__media{
  display:block;
  aspect-ratio:1.28 / 1;
}
.site-body .guide-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.site-body .guide-card__body{
  padding:18px 16px 16px;
}
.site-body .guide-card__destination{
  color:var(--site-orange);
  font-size:.95rem;
  font-weight:700;
}
.site-body .guide-card h3{
  margin:10px 0 12px;
  font-size:1.95rem;
}
.site-body .guide-card p{
  margin:0;
  color:var(--site-muted);
}
.site-body .page-banner{
  padding:72px 0 44px;
}
.site-body .page-banner--soft{
  background:#edf5f3;
}
.site-body .page-banner--plain{
  background:#fff;
}
.site-body .page-banner h1,
.site-body .page-banner h2{
  margin:0;
}
.site-body .page-banner p{
  margin:12px 0 0;
  color:var(--site-muted);
  font-size:1.12rem;
}
.site-body .destination-hero{
  min-height:520px;
  padding:96px 0;
  background-size:cover;
  background-position:center;
}
.site-body .destination-hero__inner{
  display:flex;
  align-items:center;
  min-height:320px;
}
.site-body .destination-hero__copy{
  max-width:700px;
}
.site-body .destination-hero__eyebrow{
  color:#fff;
  display:inline-block;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:.82rem;
}
.site-body .destination-hero__copy h1{
  margin:14px 0 12px;
  color:#fff;
}
.site-body .destination-hero__copy p{
  margin:0;
  color:rgba(255,255,255,.90);
  font-size:1.12rem;
  line-height:1.7;
}
.site-body .destination-hero__stats,
.site-body .destination-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:26px;
}
.site-body .destination-hero__stats span{
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:#fff;
  font-weight:700;
}
.site-body .two-col-copy{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}
.site-body .info-card__eyebrow{
  display:inline-flex;
  color:var(--site-orange);
  font-weight:800;
  text-transform:uppercase;
  font-size:.84rem;
  letter-spacing:.1em;
}
.site-body .info-card p{
  margin:0;
  color:var(--site-text);
  line-height:1.8;
}
.site-body .listing-section{padding-top:26px}
.site-body .listing-pills{
  display:flex;
  gap:12px;
  margin-bottom:22px;
}
.site-body .listing-pills a{
  padding:10px 18px;
  border-radius:999px;
  background:#efede8;
  color:var(--site-text);
  font-weight:700;
}
.site-body .listing-pills a.active{
  background:var(--site-teal);
  color:#fff;
}
.site-body .listing-toolbar{
  display:grid;
  grid-template-columns:1.2fr 1.6fr .8fr .9fr auto;
  gap:14px;
  align-items:end;
  margin-bottom:20px;
}
.site-body .listing-toolbar label span{
  display:block;
  margin:0 0 8px 4px;
  color:var(--site-muted);
  font-size:.92rem;
  font-weight:700;
}
.site-body .listing-toolbar .btn{
  min-height:50px;
}
.site-body .listing-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:0 0 24px;
  color:var(--site-muted);
}
.site-body .empty-state-card{
  padding:32px 28px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
}
.site-body .empty-state-card h3{margin:0 0 10px}
.site-body .empty-state-card p{margin:0;color:var(--site-muted)}
.site-body .detail-hero{
  width:100%;
  border-radius:24px;
  object-fit:cover;
}
.site-body .footer-cta{
  background:linear-gradient(90deg,var(--site-teal) 0%,var(--site-blue) 100%);
  padding:88px 0;
}
.site-body .footer-cta-inner{
  display:grid;
  gap:28px;
  justify-items:center;
  text-align:center;
}
.site-body .footer-cta-copy h2{
  margin:0;
  color:#fff;
}
.site-body .footer-cta-copy p{
  margin:14px auto 0;
  max-width:760px;
  color:rgba(255,255,255,.88);
  font-size:1.12rem;
}
.site-body .footer-cta-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
}
.site-body .footer-main{
  background:var(--site-brown);
  color:rgba(255,255,255,.86);
  padding:54px 0 22px;
}
.site-body .footer-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:34px;
}
.site-body .site-brand--footer .site-brand-primary,
.site-body .site-brand--footer .site-brand-secondary{
  color:#fff;
}
.site-body .site-brand--footer .site-brand-secondary{
  color:var(--site-orange);
}
.site-body .footer-brand-block p,
.site-body .footer-list a,
.site-body .footer-list li,
.site-body .footer-location,
.site-body .footer-bottom p{
  color:rgba(255,255,255,.82);
}
.site-body .footer-main h4{
  margin:4px 0 18px;
  color:#fff;
  font-size:1.8rem;
}
.site-body .footer-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.site-body .footer-socials{
  display:flex;
  gap:12px;
  margin-top:24px;
}
.site-body .footer-socials a{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fff;
}
.site-body .footer-bottom{
  margin-top:28px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
}
.site-body .floating-wa{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:70;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 20px;
  border-radius:999px;
  background:#25d366;
  color:#fff;
  font-weight:800;
  box-shadow:0 18px 36px rgba(37,211,102,.28);
}
.site-body .floating-wa__dot{font-size:1.1rem}
.site-body .article-content{line-height:1.9}
.site-body .stack-list{display:grid;gap:18px}
.site-body .rich-text{white-space:pre-line}
.site-body .page-hero-compact,
.site-body .page-head,
.site-body .page-head-compact{
  background:#edf5f3;
  padding:64px 0 30px;
}
.site-body .page-hero-compact h1,
.site-body .page-head h1{margin:10px 0 0}
.site-body .card{border-radius:24px}
.site-body .grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.site-body .grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.site-body .detail-layout{display:grid;grid-template-columns:minmax(0,1.6fr) 360px;gap:24px}
.site-body .detail-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:24px}
.site-body .detail-section{
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  border-radius:24px;
  padding:24px;
  box-shadow:0 8px 20px rgba(30,24,19,.04);
}
.site-body .detail-hero-head{
  padding:72px 0 36px;
  background:#edf5f3;
}
.site-body .detail-hero-head h1{margin:12px 0 12px}
.site-body .detail-hero-head p{max-width:840px;color:var(--site-muted)}
.site-body .detail-badges{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.site-body .detail-badges span{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  color:var(--site-heading);
  font-weight:700;
}
.site-body .gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.site-body .gallery-grid img{
  width:100%;
  height:220px;
  object-fit:cover;
  border-radius:18px;
}
.site-body .gallery-grid .gallery-main{
  grid-column:span 2;
  grid-row:span 2;
  height:452px;
}
.site-body .sticky-booking{position:sticky;top:110px}
.site-body .booking-sidebar-card{
  background:#fff;
  border:1px solid rgba(54,36,29,.08);
  border-radius:24px;
  padding:22px;
  box-shadow:0 14px 26px rgba(30,24,19,.05);
}
.site-body .price-block strong{
  color:var(--site-heading);
  font-size:2rem;
}
.site-body .review-item{
  padding:18px 0;
  border-bottom:1px solid rgba(54,36,29,.08);
}
.site-body .review-item:last-child{border-bottom:0;padding-bottom:0}
.site-body .stars{color:var(--site-orange);margin-bottom:8px}
.site-body .booking-card,
.site-body .booking-step,
.site-body .home-cta-box,
.site-body .filter-sidebar,
.site-body .results-topbar{
  border-radius:24px;
}
@media (max-width:1180px){
  .site-body .destination-strip{grid-template-columns:repeat(3,minmax(0,1fr))}
  .site-body .feature-grid,
  .site-body .testimonial-grid,
  .site-body .guide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-body .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:980px){
  .site-body .menu-toggle{display:inline-flex}
  .site-body .main-nav{
    position:absolute;
    top:76px;
    left:0;
    right:0;
    background:#fff;
    border-bottom:1px solid rgba(54,36,29,.08);
    padding:16px 24px 22px;
    display:none;
    flex-direction:column;
    align-items:stretch;
  }
  .site-body .main-nav.open{display:flex}
  .site-body .nav-links,
  .site-body .nav-actions{flex-direction:column;align-items:stretch}
  .site-body .nav-links a,
  .site-body .lang-pill,
  .site-body .nav-actions .btn{justify-content:center}
  .site-body .hero-search-grid,
  .site-body .listing-toolbar,
  .site-body .detail-layout,
  .site-body .product-grid--2,
  .site-body .product-grid--3,
  .site-body .destination-grid,
  .site-body .two-col-copy{grid-template-columns:1fr}
  .site-body .gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-body .gallery-grid .gallery-main{grid-column:span 2}
}
@media (max-width:760px){
  .site-body .container{width:min(100% - 24px,1240px)}
  .site-body .site-header-bar{min-height:70px}
  .site-body .site-brand-primary{font-size:1.8rem}
  .site-body .site-brand-secondary{font-size:1.1rem}
  .site-body .home-hero{min-height:auto;padding:96px 0 64px}
  .site-body .hero-title{font-size:3.3rem}
  .site-body .hero-subtitle{font-size:1.05rem}
  .site-body .tabs{grid-template-columns:1fr}
  .site-body .destination-strip,
  .site-body .feature-grid,
  .site-body .payment-pill-row,
  .site-body .testimonial-grid,
  .site-body .guide-grid,
  .site-body .footer-grid{grid-template-columns:1fr}
  .site-body .section-stack{padding:64px 0}
  .site-body .footer-cta{padding:68px 0}
  .site-body .floating-wa{
    right:12px;
    bottom:12px;
    padding:14px 16px;
  }
}


/* --- Frontend refresh stage 2 --- */
.site-body{
  background:#f7f5f1;
  color:#2e2724;
  font:400 15px/1.65 Inter,Arial,Helvetica,sans-serif;
}
.site-body .site-main{padding:0 0 0}
.site-body .container{width:min(1240px,calc(100% - 32px))}
.site-body .narrow{width:min(980px,calc(100% - 32px));margin:0 auto}
.site-body .narrow-centered{width:min(820px,calc(100% - 32px));margin:0 auto;text-align:center}
.site-body h1,.site-body h2,.site-body h3,.site-body h4{
  font-family:"Cormorant Garamond", Georgia, serif;
  line-height:1.05;
  color:#241b14;
  letter-spacing:-.02em;
}
.site-body h1{font-size:clamp(2.7rem,5vw,4.6rem)}
.site-body h2{font-size:clamp(2rem,3.8vw,3.3rem)}
.site-body h3{font-size:clamp(1.25rem,2vw,1.8rem)}
.site-body p,.site-body li,.site-body label,.site-body small{color:#8c7769}
.site-body .section-stack{padding:64px 0}
.site-body .section-stack--plain{background:#f7f5f1}
.site-body .section-stack--sand{background:#f1ebe2}
.site-body .section-stack--mist{background:#edf5f2}
.site-body .section-stack--sky{background:#e8f4f7}
.site-body .section-head{margin-bottom:28px}
.site-body .section-head h2{margin:0}
.site-body .section-head p{margin:10px 0 0}
.site-body .section-head--center{justify-content:center;text-align:center}
.site-body .section-link{
  color:#0f8076;
  font-weight:700;
  font-size:1.1rem;
}
.site-body .section-kicker{
  color:#0f8076;
  font-size:.85rem;
  font-weight:700;
}
.site-body .btn{
  border-radius:14px;
  font-weight:700;
  padding:14px 20px;
  transition:.2s ease;
}
.site-body .btn-small{padding:11px 16px}
.site-body .btn:hover{transform:translateY(-1px)}
.site-body .btn-gradient,
.site-body .btn-primary{
  color:#fff;
  border:none;
  background:linear-gradient(90deg,#23886f 0%, #2d93c7 100%);
  box-shadow:none;
}
.site-body .btn-gradient:hover,
.site-body .btn-primary:hover{filter:brightness(.98)}
.site-body .btn-ghost,
.site-body .btn-secondary{
  background:#fff;
  color:#3b332d;
  border:1px solid #ddd1c4;
}
.site-body .btn-light{
  background:#fff;
  color:#201814;
  border:none;
}
.site-body .btn-light-outline{
  background:rgba(255,255,255,.15);
  color:#fff;
  border:1px solid rgba(255,255,255,.35);
}
.site-body .btn-block{width:100%}
.site-body input,
.site-body select,
.site-body textarea{
  width:100%;
  border:1px solid #ddd3ca;
  background:#fff;
  color:#342a23;
  border-radius:14px;
  padding:14px 16px;
  outline:none;
  box-shadow:none;
}
.site-body input:focus,
.site-body select:focus,
.site-body textarea:focus{
  border-color:rgba(45,147,199,.45);
  box-shadow:0 0 0 4px rgba(45,147,199,.08);
}
.site-body label{display:block;font-weight:600;color:#9b806e}
.site-body label span{display:block;margin-bottom:8px}
.site-body .card,
.site-body .info-card,
.site-body .product-card,
.site-body .guide-card,
.site-body .booking-panel,
.site-body .booking-summary-card,
.site-body .contact-card,
.site-body .detail-section-box{
  background:#fff;
  border:1px solid #e7ddd4;
  box-shadow:0 8px 24px rgba(39,25,16,.04);
}
.site-body .product-grid{display:grid;gap:24px}
.site-body .product-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.site-body .product-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.site-body .guide-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}
.site-body .guide-grid--compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.site-body .floating-wa{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:72;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 18px;
  border-radius:999px;
  background:#25D366;
  color:#fff;
  box-shadow:0 18px 26px rgba(37,211,102,.28);
}
.site-body .floating-wa__dot{font-size:1.1rem}
.site-body .floating-wa__label{font-weight:700}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid #ece3d9;
  backdrop-filter:blur(10px);
}
.site-header-bar{
  min-height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.site-brand{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:"Cormorant Garamond", Georgia, serif;
  font-weight:700;
  font-size:2rem;
  line-height:1;
}
.site-brand-primary{color:#1f7b70}
.site-brand-secondary{
  color:#de7d2f;
  font-family:Inter,Arial,sans-serif;
  font-size:1.3rem;
  font-weight:700;
}
.menu-toggle{
  display:none;
  border:none;
  background:#eff5f2;
  width:44px;height:44px;border-radius:12px;
}
.main-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex:1;
}
.nav-links{display:flex;align-items:center;justify-content:center;gap:6px;flex:1}
.nav-links a{
  color:#6f6660;
  font-weight:600;
  padding:12px 14px;
  border-radius:14px;
}
.nav-links a.active{
  background:#edf5f2;
  color:#187e74;
}
.nav-actions{display:flex;align-items:center;gap:12px}
.lang-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#5a5350;
  font-weight:600;
  padding:0 8px;
}
.lang-pill span{font-size:.9rem}
.site-body .btn-ghost.btn-small{padding:11px 16px}
.site-body .btn-gradient.btn-small{padding:11px 18px}

/* Home hero polish */
.site-body .home-hero{
  min-height:840px;
  padding:130px 0 70px;
  background-size:cover;
  background-position:center;
}
.site-body .hero-copy{
  max-width:760px;
  padding-top:90px;
}
.site-body .hero-copy h1,
.site-body .hero-title{
  font-family:"Cormorant Garamond", Georgia, serif;
  color:#fff;
  font-size:clamp(3.6rem,6vw,5.8rem);
  line-height:.95;
  max-width:740px;
  margin-bottom:14px;
}
.site-body .hero-subtitle{
  color:#fff;
  max-width:680px;
  font-size:1rem;
}
.site-body .hero-search-panel{
  margin-top:42px;
  max-width:1100px;
  background:#fff;
  border-radius:24px;
  box-shadow:0 20px 45px rgba(34,25,20,.18);
  overflow:hidden;
}
.site-body .tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  background:#fff;
}
.site-body .tab{
  appearance:none;
  border:none;
  background:#fff;
  padding:18px 20px;
  font-weight:700;
  color:#8b7567;
  border-bottom:1px solid #eadfd5;
}
.site-body .tab.active{
  background:#eef5f3;
  color:#177f75;
  box-shadow:inset 0 -3px 0 #177f75;
}
.site-body .tab-panel{display:none;padding:24px 24px 20px}
.site-body .tab-panel.active{display:block}
.site-body .hero-search-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr auto;
  gap:14px;
  align-items:end;
}
.site-body .search-field{display:block}
.site-body .search-field span{
  display:block;
  margin:0 0 8px;
  font-size:.95rem;
  font-weight:700;
  color:#9d8570;
}
.site-body .btn-hero-search{
  min-width:245px;
  height:54px;
  border-radius:14px;
}

/* Page heroes */
.page-hero-soft{
  background:#edf6f4;
  padding:42px 0 120px;
  border-bottom:1px solid #e8e1d7;
}
.page-hero-soft h1{margin:0 0 10px}
.page-hero-soft p{margin:0 auto;max-width:760px;font-size:1.05rem}

/* Lists / cards */
.destination-strip{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}
.destination-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.destination-grid--page{margin-top:-82px}
.destination-tile{
  position:relative;
  overflow:hidden;
  min-height:272px;
  border-radius:22px;
  background:#e4ddd5;
  box-shadow:0 10px 28px rgba(28,18,10,.07);
}
.destination-tile img{
  width:100%;height:100%;object-fit:cover;
}
.destination-tile:after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(9,9,9,0) 20%,rgba(9,9,9,.6) 100%);
}
.destination-tile__content{
  position:absolute;left:20px;right:20px;bottom:18px;z-index:1;color:#fff;
}
.destination-tile__content h3{margin:0;color:#fff;font-size:1.6rem}
.destination-tile__content p,
.destination-tile__content small{color:rgba(255,255,255,.92)}
.destination-tile--wide{min-height:275px}
.destination-tile--compact{min-height:270px}
.listing-section{padding-top:14px}
.listing-pills{
  display:flex;gap:12px;flex-wrap:wrap;
  margin:10px 0 22px;
}
.listing-pills a{
  padding:10px 16px;border-radius:999px;
  background:#f1ede8;color:#826d5e;font-weight:700;
}
.listing-pills a.active{
  background:#1f8970;color:#fff;
}
.listing-toolbar{
  display:grid;
  grid-template-columns:1.05fr 1.2fr .7fr .75fr auto;
  gap:14px;
  align-items:end;
  margin-bottom:26px;
}
.listing-toolbar--compact{
  background:#fff;
  border:1px solid #e7ddd4;
  border-radius:20px;
  padding:18px;
}
.empty-state-card{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:22px;
  padding:26px;
  text-align:center;
}

.product-card{
  overflow:hidden;
  border-radius:20px;
}
.product-card__media{
  position:relative;
  display:block;
  height:320px;
}
.product-card__media img{
  width:100%;height:100%;object-fit:cover;
}
.product-card__badges{
  position:absolute;top:12px;left:12px;
  display:flex;gap:8px;flex-wrap:wrap;
}
.pill{
  display:inline-flex;align-items:center;
  padding:7px 12px;border-radius:999px;
  font-size:.92rem;font-weight:700;
}
.pill--light{background:rgba(255,255,255,.95);color:#534740}
.pill--brand{background:#188777;color:#fff}
.product-card__body{padding:16px 20px 18px}
.product-card__location{
  color:#c96e28;
  font-weight:700;
  margin-bottom:4px;
}
.product-card__title{
  margin:0 0 10px;
  font-size:1.15rem;
}
.product-card__title a{color:#281d15}
.product-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  color:#8e7765;
  padding-bottom:16px;
  border-bottom:1px solid #efe6dd;
}
.product-card__price-row{
  margin-top:16px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
}
.product-card__price strong{
  display:inline-block;
  font-size:1.12rem;
  color:#1f1a17;
  margin-right:2px;
}
.product-card__price span,
.product-card__deposit{color:#9b8575}

/* Guide cards */
.guide-card{
  overflow:hidden;
  border-radius:18px;
}
.guide-card__media{display:block;height:160px}
.guide-card__media img{width:100%;height:100%;object-fit:cover}
.guide-card__body{padding:16px 18px 18px}
.guide-card__destination{
  color:#dd7d2c;
  font-weight:700;
}
.guide-card__meta-line{
  display:flex;flex-wrap:wrap;gap:10px;
  font-size:.92rem;
  margin-bottom:8px;
}
.guide-card h3{
  font-size:1rem;
  line-height:1.18;
  margin:8px 0 8px;
}
.guide-card p{margin:0}

/* Footer */
.site-footer{margin-top:0}
.footer-cta{
  background:linear-gradient(90deg,#22836d 0%,#2f95c8 100%);
  padding:72px 0;
}
.footer-cta-inner{
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;text-align:center;gap:18px;
}
.footer-cta-copy h2{
  color:#fff;
  margin:0 0 10px;
}
.footer-cta-copy p{
  color:rgba(255,255,255,.92);
  margin:0 auto;
  max-width:700px;
  font-size:1.15rem;
}
.footer-cta-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.footer-main{
  background:#2c1f18;
  color:#fff;
  padding:60px 0 34px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr repeat(3,1fr);
  gap:40px;
}
.footer-main h4{
  color:#fff;
  margin:6px 0 14px;
  font-size:1.2rem;
}
.footer-brand-block p,
.footer-list li,
.footer-bottom p,
.footer-location{color:rgba(255,255,255,.85)}
.footer-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-socials{display:flex;gap:12px;margin-top:20px}
.footer-socials a{
  width:40px;height:40px;border-radius:999px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.12);
  color:#fff;
}
.footer-bottom{
  margin-top:32px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.12);
  text-align:center;
}

/* Generic info / content pages */
.contact-layout{
  margin-top:-82px;
  display:grid;
  grid-template-columns:.9fr 1fr;
  gap:46px;
  align-items:start;
}
.contact-info-stack{padding:8px 0 0}
.contact-info-item{
  display:flex;gap:14px;align-items:flex-start;
  margin-bottom:28px;
}
.mini-icon{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(90deg,#23886f 0%, #2d93c7 100%);
  color:#fff;
  font-weight:700;
  flex:none;
}
.btn-contact{display:inline-flex;margin-top:8px;min-width:270px}
.contact-card{
  border-radius:22px;
  padding:28px;
}
.contact-card h2{margin:0 0 18px}
.contact-card label{margin-bottom:16px}
.page-text-shell{padding-top:46px}
.article-content{
  font-size:1.05rem;
  line-height:1.72;
}
.article-content--plain{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
}
.article-content--large{
  background:#fff;
  border-radius:22px;
  padding:28px;
  border:1px solid #eadfd5;
  margin-top:20px;
}
.article-content h1{font-size:3.25rem;margin:0 0 18px}
.article-content h2{font-size:2.1rem;margin:26px 0 12px}
.article-content h3{font-size:1.4rem;margin:0 0 12px}
.article-content p{color:#6f5f55}
.article-content ul{padding-left:22px}
.article-content li{margin:6px 0}

/* Destination detail */
.destination-hero{
  min-height:360px;
  background-size:cover;
  background-position:center;
}
.destination-hero__inner{
  min-height:360px;
  display:flex;
  align-items:flex-end;
}
.destination-hero__inner--tall{min-height:370px}
.destination-hero__copy{
  padding:0 0 48px;
  max-width:760px;
}
.destination-hero__copy--left h1,
.destination-hero__copy--left p{color:#fff}
.destination-hero__copy--left h1{margin:0 0 12px}
.destination-hero__eyebrow{color:rgba(255,255,255,.92);margin-bottom:10px}
.chip-row{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0 34px}
.soft-chip{
  display:inline-flex;align-items:center;justify-content:center;
  background:#edf6f4;color:#1d7e73;
  padding:10px 16px;border-radius:999px;font-weight:700;
}
.destination-facts{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;
}
.info-card{
  border-radius:22px;padding:26px;
}
.info-card--soft{background:#faf7f2}
.info-card h3{margin:16px 0 6px;font-size:1.5rem}
.info-card p{margin:0;color:#7d6859}

/* Detail pages */
.detail-breadcrumb{
  background:#f3eddf;
  border-bottom:1px solid #ebe0d0;
}
.detail-breadcrumb .container{
  padding:14px 0;
  display:flex;
  gap:12px;
  align-items:center;
  color:#907a6b;
  font-weight:600;
}
.detail-page-shell{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  gap:38px;
  align-items:start;
}
.detail-main{min-width:0}
.detail-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 190px;
  grid-template-rows:260px 260px;
  gap:16px;
}
.detail-hero-main{
  width:100%;height:100%;object-fit:cover;
  grid-row:1/span 2;
  border-radius:26px;
}
.detail-hero-thumb,
.detail-hero--single{
  width:100%;height:100%;object-fit:cover;border-radius:26px;
}
.detail-hero--single{height:460px}
.detail-title-block{padding:24px 0 8px}
.detail-title-block h1{
  font-size:4rem;
  margin:8px 0 12px;
}
.detail-title-meta{
  display:flex;flex-wrap:wrap;gap:18px;
  color:#867362;font-weight:600;
}
.detail-copy-block{
  font-size:1.15rem;
  color:#6c5a50;
  padding-bottom:8px;
}
.detail-section-box{
  padding:24px;
  border-radius:22px;
  margin-top:22px;
}
.detail-section-box h2{font-size:2rem;margin:0 0 18px}
.facility-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px 20px;
}
.facility-item{font-weight:600;color:#1c7d72}
.stay-rule-list{margin:0 0 18px;padding-left:18px}
.policy-note{
  background:#f3ede5;
  border-radius:18px;
  padding:22px;
  border:1px solid #eadfd5;
}
.policy-note h3{
  font-size:1.8rem;
  margin:0 0 8px;
}
.policy-note p{margin:0}
.addon-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.addon-card{
  display:flex;justify-content:space-between;gap:16px;
  padding:14px 16px;border:1px solid #eadfd5;border-radius:16px;
  align-items:center;background:#fff;
}
.addon-card strong{display:block;color:#241b14}
.addon-card p{margin:2px 0 0;font-size:.92rem}
.addon-card span{font-weight:700;color:#2b211a}
.availability-legend{
  font-weight:700;
  color:#8f7b6c;
  margin-bottom:14px;
}
.availability-widget{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:18px;
  padding:16px;
}
.calendar-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  margin-bottom:18px;
}
.calendar-toolbar strong{display:block;color:#241b14}
.calendar-toolbar small{color:#8f7b6c}
.calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:8px;
}
.calendar-weekdays{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:8px;
  margin-bottom:8px;
}
.calendar-weekdays span{
  text-align:center;
  color:#8f7b6c;
  font-weight:700;
  padding:8px 0;
}
.calendar-day{
  min-height:48px;
  border:none;
  border-radius:12px;
  background:#edf6f4;
  color:#177a72;
}
.calendar-day.is-low{background:#fff6e7;color:#cc8a2d}
.calendar-day.is-blocked{background:#f3efea;color:#b8a89a}
.calendar-day.is-selected{outline:2px solid #2d93c7}
.calendar-legend{
  display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;color:#8d7a6e
}
.calendar-legend span{display:inline-flex;align-items:center;gap:8px}
.calendar-legend span:before{
  content:"";width:12px;height:12px;border-radius:4px;background:#edf6f4;display:inline-block;
}
.calendar-legend span:nth-child(2):before{background:#fff6e7}
.calendar-legend span:nth-child(3):before{background:#f3efea}
.sticky-booking--detail{position:sticky;top:98px}
.booking-sidebar-card--detail{
  border-radius:24px;
  padding:28px;
}
.detail-price-title{
  font-size:1.55rem;
  font-weight:800;
  color:#2a221c;
  margin-bottom:18px;
}
.detail-price-title span{
  font-size:1rem;
  font-weight:600;
  color:#9d8a7c;
  margin-left:2px;
}
.detail-booking-form label{margin-bottom:16px}
.booking-date-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.booking-summary-lines{
  display:grid;
  gap:10px;
}
.booking-summary-lines--detail{
  border-top:1px solid #efe4db;
  border-bottom:1px solid #efe4db;
  padding:16px 0;
  margin:18px 0;
}
.summary-line{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.summary-line span{color:#8a7667}
.summary-line strong{color:#2c211c}
.summary-line--total{
  padding-top:10px;
  font-size:1.1rem;
}
.summary-line--total span,
.summary-line--total strong{font-weight:800;color:#231a14}
.deposit-note{
  background:#eef8f5;
  color:#147a70;
  border-radius:18px;
  padding:16px 18px;
  display:grid;
  gap:6px;
  margin-bottom:18px;
}
.deposit-note strong{font-size:1.05rem}
.deposit-note span{color:#5f8078}
.similar-section{
  margin-top:30px;
  padding:24px;
  border-radius:24px;
}
.similar-section .section-head{margin-bottom:22px}

/* Booking flow */
.booking-page{
  background:#f4efe6;
  padding:46px 0 72px;
}
.booking-shell{width:min(1060px,calc(100% - 32px));margin:0 auto}
.booking-shell--success{width:min(1120px,calc(100% - 32px))}
.booking-page-head h1{
  font-size:3rem;
  margin:0 0 22px;
}
.booking-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 290px;
  gap:32px;
  align-items:start;
}
.booking-layout--single{grid-template-columns:minmax(0,1fr)}
.booking-panel{
  border-radius:22px;
  padding:24px;
}
.booking-panel h2{
  font-size:2rem;
  margin:0 0 18px;
}
.booking-summary{position:sticky;top:100px}
.booking-summary-card{
  border-radius:22px;
  padding:22px;
}
.booking-summary-card h3{font-size:1.8rem;margin:0 0 14px}
.booking-summary-title{font-weight:800;color:#2a221c;font-size:1.2rem;margin-bottom:4px}
.booking-summary-card p{margin:0 0 18px}
.booking-steps{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
  margin-bottom:28px;
}
.booking-step{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  color:#9c8a79;
  font-weight:700;
}
.booking-step:after{
  content:"";
  position:absolute;
  left:52px;
  right:-7px;
  top:17px;
  height:2px;
  background:#e0d5c9;
}
.booking-step:last-child:after{display:none}
.booking-step span{
  width:32px;height:32px;border-radius:999px;
  display:grid;place-items:center;
  background:#efe8df;
  color:#8e7b6d;
  flex:none;
}
.booking-step.is-current span,
.booking-step.is-done span{
  background:linear-gradient(90deg,#23886f 0%, #2d93c7 100%);
  color:#fff;
}
.booking-step.is-current{color:#2a2019}
.booking-step.is-done{color:#2a2019}
.actions-row--booking{
  margin-top:22px;
  justify-content:space-between;
}
.addon-list{
  display:grid;
  gap:14px;
}
.addon-choice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border:1px solid #eadfd5;
  border-radius:16px;
  padding:16px 18px;
}
.addon-choice__main{
  display:flex;
  align-items:center;
  gap:14px;
}
.addon-choice input{
  width:18px;height:18px;flex:none;
}
.addon-choice__main strong{display:block;color:#2a221b}
.addon-choice__main small{display:block;color:#8a7769}
.addon-choice__price{font-weight:800;color:#2a221b}
.review-block{
  padding:18px 0;
  border-bottom:1px solid #efe4db;
}
.review-block:last-of-type{border-bottom:none}
.review-block h3{font-size:1.5rem;margin:0 0 8px}
.booking-page-head--success{text-align:center;margin-bottom:26px}
.booking-page-head--success p{font-size:1.05rem;margin:0}

/* Utility */
.info-box{background:#fff;border:1px solid #eadfd5;border-radius:18px;padding:18px}
.faq-shell{max-width:780px}
.faq-list{gap:14px}
.accordion-item{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:16px;
  padding:0 20px;
}
.accordion-item summary{
  list-style:none;
  cursor:pointer;
  padding:18px 0;
  font-weight:700;
  color:#2c231d;
}
.accordion-item summary::-webkit-details-marker{display:none}
.accordion-item p{padding:0 0 18px;margin:0}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.feature-card{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:22px;
  padding:26px;
  text-align:center;
}
.feature-card__icon{
  width:56px;height:56px;margin:0 auto 18px;
  border-radius:18px;
  display:grid;place-items:center;
  background:linear-gradient(90deg,#23886f 0%, #2d93c7 100%);
  color:#fff;
  font-weight:800;
}
.feature-card h3{font-size:1.8rem;margin:0 0 10px}
.payment-showcase{
  text-align:center;
}
.payment-showcase__icon{
  width:64px;height:64px;border-radius:20px;
  display:grid;place-items:center;
  background:linear-gradient(90deg,#23886f 0%, #2d93c7 100%);
  color:#fff;
  margin:0 auto 18px;
}
.payment-pill-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:26px;
}
.payment-pill{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:16px;
  padding:16px 18px;
  font-weight:700;
}
.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.testimonial-card{
  background:#fff;
  border:1px solid #eadfd5;
  border-radius:20px;
  padding:22px;
}
.testimonial-card__stars{color:#d9822b;margin-bottom:10px}
.testimonial-card__author{
  display:flex;flex-direction:column;gap:2px;margin-top:16px;
}
.results-topbar,.filter-head,.card-head,.header-row{gap:10px}

/* Responsive */
@media (max-width:1100px){
  .site-body .destination-strip{grid-template-columns:repeat(3,minmax(0,1fr))}
  .site-body .guide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-body .feature-grid,
  .site-body .testimonial-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-page-shell,
  .booking-layout,
  .contact-layout,
  .footer-grid{grid-template-columns:1fr}
  .booking-summary,
  .sticky-booking--detail{position:static}
}
@media (max-width:900px){
  .menu-toggle{display:grid;place-items:center}
  .main-nav{
    position:absolute;
    left:16px;right:16px;top:76px;
    display:none;
    background:#fff;
    border:1px solid #e9dfd5;
    border-radius:20px;
    padding:16px;
    box-shadow:0 18px 36px rgba(39,25,16,.12);
  }
  .main-nav.open{display:block}
  .nav-links,.nav-actions{display:grid;justify-content:stretch}
  .nav-links a,.nav-actions a{width:100%}
  .site-body .hero-search-grid,
  .listing-toolbar,
  .booking-date-grid,
  .payment-pill-row{grid-template-columns:1fr}
  .detail-hero-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  .detail-hero-main{grid-row:auto;height:420px}
  .detail-hero-thumb{height:220px}
  .facility-grid,
  .addon-grid,
  .destination-facts,
  .site-body .product-grid--3,
  .site-body .product-grid--2,
  .site-body .destination-grid,
  .site-body .booking-steps,
  .site-body .guide-grid--compact{grid-template-columns:1fr}
  .booking-step:after{display:none}
}
@media (max-width:640px){
  .site-body .hero-copy{padding-top:26px}
  .site-body .home-hero{min-height:auto;padding-top:102px}
  .site-body .hero-copy h1{font-size:3rem}
  .page-hero-soft{padding-bottom:76px}
  .destination-grid--page,.contact-layout{margin-top:-44px}
  .site-body .destination-strip{grid-template-columns:1fr 1fr}
  .site-body .guide-grid,
  .site-body .feature-grid,
  .site-body .testimonial-grid{grid-template-columns:1fr}
  .site-body .product-card__media{height:250px}
  .footer-cta{padding:52px 0}
  .floating-wa{right:12px;bottom:12px;padding:12px 15px}
}



/* ===== Final UI refresh: frontend + backend consistency ===== */
:root{
  --site-bg:#f7f4ee;
  --site-bg-soft:#edf6f4;
  --site-sand:#f3eee4;
  --site-surface:#ffffff;
  --site-line:#e7ded2;
  --site-line-soft:#efe7dc;
  --site-text:#241b16;
  --site-muted:#8a7466;
  --site-green:#1a8478;
  --site-green-dark:#14665d;
  --site-blue:#2a90c6;
  --site-orange:#d87923;
  --site-shadow:0 18px 38px rgba(40,30,22,.08);
  --site-shadow-soft:0 10px 22px rgba(33,24,18,.06);
}
html,body{background:var(--site-bg)}
body,.site-body,.admin-body{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--site-text);
}
h1,h2,h3,h4,.hero-title,.section-head h2,.page-hero-soft h1,.detail-title-block h1,.booking-page h1,.booking-panel h2,.admin-page-head h1,.admin-card-head h2{
  font-family:"Cormorant Garamond",Georgia,serif;
  letter-spacing:-.02em;
  color:var(--site-text);
}
.container{width:min(1240px,calc(100% - 30px))}
.narrow{width:min(960px,calc(100% - 30px))}
.site-main{padding-bottom:0}
.card,.info-card,.guide-card,.booking-panel,.booking-summary-card,.admin-surface-card,.admin-toolbar-card,.admin-mini-card,.admin-metric-card,.admin-status-card{
  background:var(--site-surface);
  border:1px solid var(--site-line);
  box-shadow:var(--site-shadow-soft);
}

/* Frontend base */
.site-body{background:#f8f7f4}
.site-header{
  background:rgba(255,255,255,.9);
  border-bottom:1px solid rgba(219,211,201,.6);
  backdrop-filter:blur(18px);
}
.site-header-bar{min-height:76px;display:flex;align-items:center;gap:24px}
.site-brand{display:flex;align-items:flex-end;gap:10px;font-weight:800;white-space:nowrap}
.site-brand-primary{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:2rem;
  color:#1d7a6c;
  line-height:1;
}
.site-brand-secondary{font-size:1.28rem;color:var(--site-orange);line-height:1.1}
.main-nav{display:flex;align-items:center;justify-content:space-between;gap:24px;flex:1}
.nav-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nav-links a{
  padding:12px 16px;
  border-radius:14px;
  color:#6c655e;
  font-weight:600;
  transition:.25s ease;
}
.nav-links a:hover,.nav-links a.active{background:#edf4f0;color:#1f8a7c}
.nav-actions{display:flex;align-items:center;gap:12px}
.lang-pill,.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 16px;border-radius:14px;
  border:1px solid rgba(212,202,191,.9);
  background:#fff;color:#4f4339;font-weight:700
}
.btn,.btn-light,.btn-light-outline,.btn-gradient{
  border-radius:14px;
  font-weight:700;
}
.btn-gradient,.btn-primary{
  background:linear-gradient(90deg,var(--site-green) 0%, var(--site-blue) 100%);
  color:#fff;
  box-shadow:none;
}
.btn-gradient:hover,.btn-primary:hover{background:linear-gradient(90deg,var(--site-green-dark) 0%, #247ead 100%)}
.btn-secondary{background:#fff;border-color:#d9cec0;color:var(--site-text)}
.btn-secondary:hover{border-color:#c2b19f}
.btn-light{background:#fff;color:#1f221f}
.btn-light-outline{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22);color:#fff}
.menu-toggle{border-radius:14px}

/* Hero and sections */
.home-hero{
  min-height:820px;
  display:flex;
  align-items:flex-end;
  padding:120px 0 70px;
  background-size:cover;
  background-position:center;
}
.hero-copy{max-width:760px;margin-bottom:32px}
.hero-title{
  color:#fff;
  font-size:clamp(3.2rem,6vw,5.8rem);
  line-height:.94;
  margin:0 0 12px;
}
.hero-subtitle{
  color:rgba(255,255,255,.92);
  font-size:clamp(1.02rem,1.8vw,1.18rem);
  max-width:720px;
}
.hero-search-panel{
  background:#fff;
  border:1px solid rgba(225,215,205,.92);
  border-radius:28px;
  box-shadow:0 18px 40px rgba(30,20,12,.16);
  overflow:hidden;
  max-width:1100px;
}
.tabs{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--site-line)}
.tab{
  background:#fff;border:0;padding:20px 14px;font-size:1.08rem;font-weight:700;color:#7c7165;cursor:pointer
}
.tab.active{color:#1d877a;box-shadow:inset 0 -3px 0 #1d877a;background:#f4faf8}
.hero-search-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:22px}
.search-field{display:grid;gap:8px;font-weight:700;color:#7b6758}
.search-field span{font-size:.95rem}
.search-field input,.search-field select{
  min-height:50px;border-radius:15px;border:1px solid #ddd2c5;background:#fff;color:var(--site-text)
}
.btn-search{min-height:50px;align-self:end}
.section-stack{padding:66px 0}
.section-stack--plain{background:#fbfaf8}
.section-stack--sand{background:#f4efe6}
.section-stack--soft{background:#eff7f4}
.section-head{margin-bottom:26px}
.section-head--center{text-align:center;justify-content:center}
.section-head h2{font-size:clamp(2.6rem,4vw,3.6rem);margin:0}
.section-head p{font-size:1.05rem;color:var(--site-muted)}
.section-link{color:#1a8478;font-weight:700}

.destination-strip,.destination-grid,.product-grid,.guide-grid{gap:22px}
.destination-tile,.product-card,.guide-card{
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--site-shadow);
  border:1px solid rgba(224,214,202,.9);
}
.destination-tile__content h3{font-size:2.2rem}
.destination-tile__content p{font-size:1rem}
.product-card{background:#fff}
.product-card__body{padding:16px 18px 18px}
.product-card__title{font-size:2rem;line-height:1.05;margin:8px 0 10px}
.product-card__title a{color:var(--site-text)}
.product-card__location,.guide-card__destination{color:var(--site-orange);font-weight:700}
.product-card__meta{
  display:flex;flex-wrap:wrap;gap:14px;
  color:var(--site-muted);padding-bottom:14px;margin-bottom:14px;
  border-bottom:1px solid var(--site-line-soft)
}
.product-card__price-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.product-card__price strong{font-size:1.9rem}
.product-card__deposit{color:#9a7e6d}
.pill{border-radius:999px;padding:6px 12px;font-size:.86rem;font-weight:700}
.pill--light{background:rgba(255,255,255,.92);color:#5e4f42}
.pill--brand{background:#1f8a7c;color:#fff}
.page-hero-soft{
  background:#edf6f4;
  padding:54px 0 150px;
}
.page-hero-soft .narrow-centered{text-align:center}
.page-hero-soft h1{font-size:clamp(3rem,4.8vw,4.6rem)}
.page-hero-soft p{font-size:1.08rem;color:var(--site-muted)}
.destination-hero{min-height:520px}
.destination-hero__copy h1{font-size:clamp(4rem,6vw,5.8rem)}
.destination-hero__copy p{font-size:1.2rem;color:rgba(255,255,255,.94)}
.chip-row{display:flex;flex-wrap:wrap;gap:14px}
.soft-chip{
  padding:12px 18px;border-radius:999px;background:#edf5f2;color:#1c887b;
  font-weight:700;border:1px solid rgba(28,136,123,.08)
}
.destination-facts,.contact-layout,.detail-page-shell,.guide-grid,.product-grid--2,.product-grid--3{align-items:start}
.info-card,.detail-section-box,.contact-card{
  border-radius:24px;background:#fff;border:1px solid var(--site-line);box-shadow:var(--site-shadow-soft)
}
.info-card--soft{background:#f8f3ea}
.mini-icon{
  width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--site-green),var(--site-blue));
  color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:16px
}
.detail-page-shell{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:38px}
.detail-main{display:grid;gap:26px}
.detail-hero{border-radius:28px;overflow:hidden;box-shadow:var(--site-shadow)}
.detail-title-block h1{font-size:clamp(3rem,4.2vw,4.4rem);margin:8px 0 14px}
.detail-title-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--site-muted)}
.detail-section-box{padding:28px}
.detail-section-box h2{font-size:2.35rem;margin:0 0 12px}
.sticky-booking{position:sticky;top:108px}
.booking-sidebar-card{
  border-radius:28px;padding:28px;background:#fff;border:1px solid var(--site-line);
  box-shadow:var(--site-shadow)
}
.detail-price-title{font-size:2.6rem;font-weight:800;margin-bottom:20px}
.detail-price-title span{font-size:1.1rem;color:var(--site-muted)}
.detail-booking-form{display:grid;gap:14px}
.deposit-note{
  padding:18px;border-radius:18px;background:#edf8f4;color:#3a7468;border:1px solid #d5ebe5;
  display:grid;gap:5px
}
.policy-note{
  padding:18px 20px;border-radius:18px;background:#f8f1e6;border:1px solid #eadbc8;color:#6a5547
}
.policy-note h3{margin:0 0 8px;font-size:1.55rem}
.policy-note--bank small{display:block;margin-top:10px;color:#836f60}
.guide-card__body h3{font-size:2rem;line-height:1.05}
.article-content,.article-content--plain{background:#fff;border:1px solid var(--site-line);border-radius:24px;padding:28px;box-shadow:var(--site-shadow-soft)}
.contact-card{padding:24px}

/* Footer */
.footer-cta{
  background:linear-gradient(90deg,var(--site-green) 0%, var(--site-blue) 100%);
  color:#fff;padding:88px 0;
}
.footer-cta-inner{display:grid;grid-template-columns:1.15fr auto;gap:26px;align-items:center}
.footer-cta-copy h2{font-size:clamp(3rem,4.8vw,4.8rem);color:#fff;margin:0 0 12px}
.footer-cta-copy p{max-width:720px;color:rgba(255,255,255,.92);font-size:1.15rem}
.footer-cta-actions{display:flex;gap:14px;flex-wrap:wrap}
.footer-main{background:#2d1f18;color:#fff;padding:64px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.25fr 1fr 1fr 1fr;gap:30px}
.footer-grid h4{
  color:#fff;font-family:"Cormorant Garamond",Georgia,serif;
  font-size:1.8rem;margin:6px 0 12px
}
.footer-copy p,.footer-brand-block p,.footer-list a,.footer-list li,.footer-location{color:rgba(255,255,255,.82)}
.footer-list{display:grid;gap:10px;padding:0;margin:0;list-style:none}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-socials a{
  width:42px;height:42px;border-radius:999px;display:grid;place-items:center;
  background:rgba(255,255,255,.12);color:#fff
}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:28px;padding-top:20px;text-align:center}
.floating-wa{
  position:fixed;right:24px;bottom:24px;z-index:70;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 18px;border-radius:999px;
  background:linear-gradient(90deg,#27c46b,#21d15d);
  color:#fff;box-shadow:0 18px 40px rgba(8,82,24,.22)
}
.floating-wa__dot{
  width:28px;height:28px;border-radius:999px;background:rgba(255,255,255,.18);
  display:grid;place-items:center
}

/* Booking flow */
.booking-page{
  background:#f4efe6;
  padding:50px 0 76px;
}
.booking-page-head{margin-bottom:28px}
.booking-page-head h1{font-size:3.6rem;margin:0 0 18px}
.booking-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:34px;
  align-items:start;
}
.booking-panel{
  padding:24px 24px 26px;
  border-radius:24px;
}
.booking-panel h2{font-size:2.4rem;margin:0 0 18px}
.booking-panel label{display:grid;gap:8px;color:#816c5d;font-weight:700}
.booking-panel input,.booking-panel select,.booking-panel textarea{
  border-radius:16px;border-color:#dccfbe;min-height:52px
}
.booking-panel textarea{min-height:132px}
.booking-summary{position:sticky;top:104px}
.booking-summary-card{padding:26px;border-radius:22px}
.booking-summary-card h3{font-size:2rem}
.booking-summary-lines{display:grid;gap:12px}
.summary-line{
  display:flex;align-items:flex-start;justify-content:space-between;gap:18px
}
.summary-line span{color:var(--site-muted)}
.summary-line strong{text-align:right}
.summary-line--total{
  padding-top:14px;border-top:1px solid var(--site-line-soft)
}
.booking-steps{
  display:flex;align-items:center;gap:0;flex-wrap:wrap
}
.booking-step{
  position:relative;display:flex;align-items:center;gap:12px;
  min-width:160px;padding-right:20px;background:none;border:0
}
.booking-step span{
  width:34px;height:34px;border-radius:999px;background:#ebebe5;color:#8f7d70;
  display:grid;place-items:center;font-weight:800
}
.booking-step:after{
  content:"";position:absolute;left:46px;right:0;top:17px;height:2px;background:#e0d9ce
}
.booking-step:last-child:after{display:none}
.booking-step.is-current span,.booking-step.is-done span{background:linear-gradient(90deg,var(--site-green),var(--site-blue));color:#fff}
.booking-step.is-done strong,.booking-step.is-current strong{color:var(--site-text)}
.payment-options{gap:14px}
.payment-option{
  border-radius:18px;
  padding:18px 18px;
  align-items:flex-start;
}
.payment-option input{width:18px;height:18px;margin-top:5px}
.payment-option strong{display:block;font-size:1.1rem}
.payment-option p{margin:4px 0 0;color:var(--site-muted)}
.payment-option:has(input:checked){
  border-color:#1d877a;
  background:#eef7f4;
  box-shadow:0 0 0 1px rgba(29,135,122,.12) inset;
}
.addon-choice{
  border-radius:18px;padding:18px;background:#fff;border:1px solid var(--site-line);box-shadow:none
}
.addon-choice__main{gap:14px}
.addon-choice__price{font-size:1.1rem;font-weight:800}
.review-block{padding:18px;border-radius:18px;background:#fbfaf8;border:1px solid var(--site-line)}
.booking-success-wrap{display:flex;justify-content:center}
.booking-success-card{
  width:min(100%, 560px);
  background:#fff;border:1px solid var(--site-line);
  border-radius:28px;padding:34px 32px;text-align:center;box-shadow:var(--site-shadow)
}
.booking-success-icon{
  width:64px;height:64px;border-radius:999px;margin:0 auto 16px;
  display:grid;place-items:center;background:linear-gradient(90deg,var(--site-green),var(--site-blue));color:#fff;font-size:2rem;font-weight:800
}
.booking-success-card h2{font-size:2.9rem;margin:0 0 8px}
.booking-success-summary{
  margin:22px 0;padding:18px;border-radius:18px;background:#faf6ee;border:1px solid var(--site-line-soft)
}
.booking-success-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:20px}
.booking-success-links{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.booking-success-links a{color:var(--site-green);font-weight:700}

/* Backend */
.admin-body{
  background:#f2f0ec;
}
.admin-shell{
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100vh;
}
.admin-sidebar{
  background:#fff;border-right:1px solid #dfd7cd;
  padding:18px 14px 22px;position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;gap:16px
}
.admin-brand-block{padding:4px 6px 18px;border-bottom:1px solid #e8dfd5}
.admin-brand{
  display:flex;align-items:center;gap:10px;font-weight:800
}
.admin-brand-name{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:2rem;color:#1c7b6d;line-height:1
}
.admin-brand-tag{
  display:inline-flex;align-items:center;justify-content:center;
  padding:6px 10px;border-radius:8px;background:#1a8478;color:#fff;font-size:.95rem
}
.admin-nav,.admin-sidebar-foot{display:grid;gap:6px}
.admin-sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid #e8dfd5}
.admin-nav-link{
  display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;
  color:#5a4c41;font-weight:600;transition:.2s ease
}
.admin-nav-link:hover{background:#f3f2ef}
.admin-nav-link.is-active{
  background:#1c8377;color:#fff;box-shadow:none
}
.admin-nav-icon{
  width:18px;text-align:center;flex:0 0 18px;font-size:1rem;opacity:.96
}
.admin-content{min-width:0}
.admin-topbar{
  position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid #dfd7cd;
  min-height:58px;padding:12px 22px;display:flex;align-items:center;justify-content:space-between
}
.admin-topbar-meta strong{display:block;font-size:1rem}
.admin-topbar-meta span{color:#8a7466;font-size:.92rem}
.admin-topbar-actions{display:flex;align-items:center;gap:14px}
.admin-bell{
  position:relative;border:0;background:transparent;padding:8px;border-radius:999px;cursor:pointer
}
.admin-bell-dot{
  position:absolute;right:7px;top:6px;width:9px;height:9px;border-radius:999px;background:#ec4a48;border:2px solid #fff
}
.admin-user{display:flex;align-items:center;gap:12px}
.admin-avatar{
  width:38px;height:38px;border-radius:999px;background:#1f89a0;color:#fff;
  display:grid;place-items:center;font-weight:800
}
.admin-user-meta strong{display:block}
.admin-user-meta small{color:#8a7466}
.admin-main{padding:26px 24px 34px}
.admin-page-head{margin-bottom:20px}
.admin-page-head h1{font-size:3rem;margin:0 0 6px}
.admin-page-head p{margin:0;color:#8a7466;font-size:1.02rem}
.admin-page-head-row,.admin-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}
.admin-link{color:#8a7466;font-weight:600}
.admin-toolbar-card{
  background:transparent;border:0;box-shadow:none;padding:0;margin-bottom:18px
}
.search-inline{display:flex;gap:12px;max-width:500px}
.search-inline input{background:#fff;border-radius:16px;min-height:52px}
.admin-surface-card{
  background:#fff;border:1px solid #e2d9cf;border-radius:20px;padding:16px 18px;margin-bottom:18px
}
.admin-card-head{margin-bottom:14px}
.admin-card-head h2{font-size:2rem;margin:0 0 4px}
.admin-card-head p{margin:0;color:#8a7466}
.admin-metric-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:22px
}
.admin-metric-grid--reports,.admin-metric-grid--payments{grid-template-columns:repeat(4,minmax(0,1fr))}
.admin-metric-card{
  padding:22px;border-radius:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px
}
.admin-metric-label{display:block;color:#8a7466;margin-bottom:10px}
.admin-metric-card strong{font-size:2rem;line-height:1.1}
.admin-metric-icon{
  width:40px;height:40px;border-radius:14px;display:grid;place-items:center;color:#fff;font-weight:800
}
.admin-metric-card--teal .admin-metric-icon{background:#228fa8}
.admin-metric-card--orange .admin-metric-icon{background:#e57a28}
.admin-metric-card--cyan .admin-metric-icon{background:#268ea2}
.admin-metric-card--gold .admin-metric-icon{background:#df7b2b}
.admin-metric-card--alert strong{color:#ff4b42}
.admin-dashboard-grid{
  display:grid;grid-template-columns:minmax(0,1.5fr) 300px;gap:18px;align-items:start;margin-bottom:18px
}
.admin-side-stack{display:grid;gap:18px}
.admin-mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.admin-mini-card{
  padding:20px 22px;border-radius:18px;display:flex;align-items:center;gap:16px
}
.admin-mini-icon{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-weight:800;background:#f7f0e7;color:#d17829
}
.admin-mini-card--alert .admin-mini-icon{background:#fde8e6;color:#ff4b42}
.admin-mini-card--soft .admin-mini-icon{background:#e7f4ef;color:#1a8478}
.admin-mini-card strong{font-size:2rem}
.admin-mini-card p{margin:4px 0 0;color:#8a7466}
.destination-stat-list{display:grid;gap:18px}
.destination-stat-item{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid #eee6db
}
.destination-stat-item:last-child{padding-bottom:0;border-bottom:0}
.destination-stat-item strong{display:block}
.destination-stat-item small{display:block;color:#8a7466}

.table-wrap{overflow:auto}
.data-table{
  width:100%;border-collapse:separate;border-spacing:0;font-size:.98rem
}
.data-table th{
  text-align:left;padding:14px 12px;color:#8a7466;font-weight:700;border-bottom:1px solid #eae1d7;background:#fff;position:sticky;top:0
}
.data-table td{
  padding:14px 12px;border-bottom:1px solid #eee7de;vertical-align:top
}
.data-table tbody tr:last-child td{border-bottom:0}
.data-table strong{display:block;color:var(--site-text)}
.data-table small{display:block;color:#8a7466}
.data-table .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.data-table--dense td,.data-table--dense th{padding:14px 10px}
.media-cell{display:flex;align-items:center;gap:12px}
.media-thumb{
  width:48px;height:36px;border-radius:14px;object-fit:cover;border:1px solid #ddd3c6
}
.soft-tag{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 10px;border-radius:999px;background:#f3efe8;color:#5d4d40;font-size:.9rem
}
.status-pill{
  display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.85rem;font-weight:700;border:0
}
.status-confirmed,.status-verified,.status-paid,.status-paid_in_full,.status-deposit_paid,.status-active,.status-completed{
  background:#e2f2eb;color:#267961
}
.status-pending,.status-pending_payment,.status-awaiting_review,.status-awaiting_verification{
  background:#fff1e2;color:#da7d20
}
.status-inquiry{background:#e2f0fb;color:#4383bb}
.status-rejected,.status-failed,.status-cancelled,.status-inactive,.status-expired{
  background:#fce9e8;color:#e0554e
}
.status-draft,.status-partially_paid{background:#f1ede8;color:#7f7062}
.actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.actions form{display:inline-flex}
.icon-action{
  width:34px;height:34px;border-radius:10px;border:1px solid #ddd5cb;background:#fff;color:#4f4339;
  display:grid;place-items:center;cursor:pointer
}
.icon-action--danger{color:#ff5448}
.icon-action:hover{border-color:#bba893}
.admin-addon-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-bottom:18px
}
.admin-addon-card{
  background:#fff;border:1px solid #e3dacf;border-radius:18px;padding:20px;
  display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:start;box-shadow:var(--site-shadow-soft)
}
.admin-addon-icon{
  width:44px;height:44px;border-radius:14px;background:#f7f0e7;display:grid;place-items:center;font-size:1.2rem
}
.admin-addon-body strong{display:block;font-size:1.1rem}
.admin-addon-price{margin-top:8px;color:#1a8478;font-size:1.5rem;font-weight:800}
.admin-addon-actions{display:flex;gap:8px}
.admin-content-stack,.admin-settings-stack{display:grid;gap:18px}
.admin-quick-links{display:flex;flex-wrap:wrap;gap:12px}
.admin-quick-link{
  padding:12px 16px;border-radius:14px;background:#f3f2ef;color:var(--site-text);font-weight:700;border:1px solid #e2d9cf
}
.admin-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-setting-item{
  padding:18px;border-radius:16px;background:#fbfaf8;border:1px solid #ebe2d6;display:grid;gap:10px
}
.admin-setting-item label{font-weight:700;color:#7b6859}
.admin-setting-value{
  min-height:56px;border-radius:14px;border:1px solid #e4dbcf;background:#fff;padding:12px 14px;color:var(--site-text)
}
.admin-form-card{padding:24px}
.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-field{display:grid;gap:8px}
.admin-field.full{grid-column:1/-1}
.admin-field label{font-weight:700;color:#7d695b}
.admin-form-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.report-bar-list{display:grid;gap:18px}
.report-bar-item{
  display:grid;grid-template-columns:110px minmax(0,1fr) 120px;gap:18px;align-items:center
}
.report-bar-track{height:24px;border-radius:999px;background:#ede9e3;overflow:hidden}
.report-bar-track span{
  display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--site-green),var(--site-blue))
}
.report-bar-meta{text-align:right}
.admin-status-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}
.admin-status-card{
  padding:20px;border-radius:18px;text-align:center
}
.admin-status-card strong{display:block;font-size:2rem;margin-bottom:6px}
.payment-card{
  padding:18px;border-radius:18px;border:1px solid #e6ddd1;background:#fff;display:grid;gap:14px
}
.verify-form{border-top:1px solid #efe7dc;padding-top:14px}
.admin-login-wrap{
  min-height:100vh;display:grid;place-items:center;padding:30px
}
.admin-login-panel{
  width:min(1120px,100%);
  display:grid;grid-template-columns:1.15fr .85fr;gap:22px;align-items:stretch
}
.admin-login-aside{
  background:linear-gradient(180deg,#1d877a,#2c90c6);color:#fff;border-radius:28px;padding:42px 38px
}
.admin-login-aside h1{color:#fff;font-size:3.6rem;margin:14px 0 10px}
.admin-login-aside p,.admin-login-aside li{color:rgba(255,255,255,.9)}
.admin-login-card{border-radius:28px;padding:30px}
.admin-login-card h2{font-size:2.4rem;margin:0 0 8px}

/* Reveal animation */
.reveal-on-scroll{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .7s ease, transform .7s ease;
  will-change:transform,opacity;
}
.reveal-on-scroll.is-revealed{
  opacity:1;
  transform:none;
}

/* Utilities */
.site-body .narrow-centered{width:min(980px,calc(100% - 30px));margin:0 auto;text-align:center}
.booking-sidebar-card--detail .btn{width:100%}
.booking-sidebar-card--detail .btn + .btn{margin-top:10px}

/* Responsive */
@media (max-width: 1180px){
  .destination-strip{grid-template-columns:repeat(3,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-metric-grid,.admin-status-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-dashboard-grid{grid-template-columns:1fr}
  .admin-addon-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 980px){
  .main-nav{
    position:absolute;left:15px;right:15px;top:76px;background:#fff;padding:18px;border:1px solid var(--site-line);
    border-radius:20px;box-shadow:var(--site-shadow);display:none;flex-direction:column;align-items:stretch
  }
  .main-nav.open{display:flex}
  .nav-links,.nav-actions{flex-direction:column;align-items:stretch}
  .menu-toggle{display:inline-flex}
  .site-header-bar{justify-content:space-between}
  .hero-search-grid{grid-template-columns:1fr}
  .destination-grid,.product-grid,.guide-grid,.detail-page-shell,.contact-layout,.booking-layout,.footer-cta-inner,.admin-login-panel,.admin-shell,.report-bar-item,.admin-settings-grid{grid-template-columns:1fr}
  .destination-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-sidebar{position:relative;height:auto}
  .admin-topbar{padding:12px 16px}
  .admin-main{padding:18px 16px 24px}
  .admin-mini-grid,.admin-addon-grid,.admin-form-grid{grid-template-columns:1fr}
  .booking-step{min-width:140px}
}
@media (max-width: 720px){
  .hero-title{font-size:3.1rem}
  .page-hero-soft{padding:40px 0 90px}
  .footer-grid{grid-template-columns:1fr}
  .destination-strip{grid-template-columns:1fr}
  .booking-step{min-width:unset;width:100%;padding:0 0 10px}
  .booking-step:after{left:17px;right:auto;top:34px;width:2px;height:18px}
  .booking-steps{display:grid;gap:12px}
  .admin-metric-grid,.admin-status-grid{grid-template-columns:1fr}
  .search-inline{flex-direction:column}
}


.upload-proof-preview{
  margin-top:12px;
  min-height:180px;
  border:1px dashed var(--site-line);
  border-radius:18px;
  background:#faf8f3;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  color:var(--site-muted);
  text-align:center;
}
.upload-proof-preview.has-image{
  display:block;
  padding:8px;
  background:#fff;
}
.upload-proof-preview img{
  display:block;
  width:100%;
  max-height:360px;
  object-fit:contain;
  border-radius:14px;
}



.demo-ribbon {
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 999;
    background: rgba(15, 23, 42, 0.92);
    color: #fff;
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.22);
}

.demo-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.22);
}

.site-brand .demo-chip--site {
    margin-left: 12px;
    vertical-align: middle;
}

@media (max-width: 768px) {
    .demo-ribbon {
        right: 12px;
        bottom: 12px;
        font-size: 11px;
        padding: 8px 12px;
    }

    .site-brand .demo-chip--site {
        display: none;
    }
}
