/* ===================================================
   ZENDA HIKING v2 — Frontend CSS
   Exact match to design screenshots
=================================================== */
:root {
  --zg: #2d5a27;        /* primary green */
  --zgl: #4a8f42;       /* light green */
  --zgd: #1a3a16;       /* dark green */
  --zga: #6ab04c;       /* accent green */
  --zt: #1a1a1a;        /* text dark */
  --ztm: #6b7280;       /* text muted */
  --zbg: #f8f9f6;       /* bg */
  --zbr: #e5e7eb;       /* border */
  --zw: #ffffff;
  --zr: 10px;
  --zshadow: 0 2px 12px rgba(0,0,0,.07);
  --zshadow-lg: 0 8px 32px rgba(0,0,0,.13);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
.zh-wrap{font-family:-apple-system,'Inter','Segoe UI',Arial,sans-serif;color:var(--zt);background:var(--zw);}
.zh-container{max-width:1160px;margin:0 auto;padding:0 20px;}
.zh-narrow{max-width:860px;}
.zh-section{padding:56px 0;}
.zh-bg-alt{background:var(--zbg);}
img{max-width:100%;height:auto;}
a{text-decoration:none;}

/* ======================== BUTTONS ======================== */
.zh-btn-sm{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;background:var(--zg);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;}
.zh-btn-sm:hover{background:var(--zgl);}
.zh-btn-book{display:block;width:100%;padding:13px;background:var(--zg);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;text-align:center;transition:background .2s;margin-bottom:8px;}
.zh-btn-book:hover{background:var(--zgl);}
.zh-btn-alldates{display:block;width:100%;padding:11px;background:transparent;color:var(--zg);border:2px solid var(--zg);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;margin-bottom:8px;}
.zh-btn-alldates:hover{background:var(--zg);color:#fff;}
.zh-btn-full{display:block;width:100%;padding:13px;background:var(--zg);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;text-align:center;transition:background .2s;}
.zh-btn-full:hover{background:var(--zgl);}

/* ======================== HERO ======================== */
.zh-hero{position:relative;min-height:500px;display:flex;align-items:center;background:linear-gradient(160deg,#1e3f19 0%,#3d7236 60%,#5a9e50 100%);background-size:cover;background-position:center;}
.zh-hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(20,40,16,.75) 0%,rgba(40,80,35,.5) 100%);}
.zh-hero-inner{position:relative;z-index:2;width:100%;max-width:1160px;margin:0 auto;padding:70px 20px 60px;text-align:center;}
.zh-hero-inner h1{font-size:clamp(28px,5vw,58px);font-weight:900;color:#fff;line-height:1.1;margin-bottom:10px;text-shadow:0 2px 8px rgba(0,0,0,.25);}
.zh-hero-inner>p{font-size:clamp(14px,2vw,18px);color:rgba(255,255,255,.85);margin-bottom:36px;}

/* Search box */
.zh-search-box{display:flex;align-items:center;background:#fff;border-radius:14px;padding:12px 14px;gap:0;box-shadow:0 8px 40px rgba(0,0,0,.18);max-width:860px;margin:0 auto;flex-wrap:wrap;}
.zh-s-field{display:flex;align-items:center;gap:10px;flex:1;min-width:150px;padding:4px 10px;}
.zh-s-icon{font-size:18px;}
.zh-s-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--ztm);letter-spacing:.5px;margin-bottom:2px;}
.zh-s-input{border:none;outline:none;font-size:14px;font-weight:500;color:var(--zt);background:transparent;width:100%;}
.zh-s-input option{color:var(--zt);}
.zh-s-divider{width:1px;height:36px;background:var(--zbr);margin:0 4px;flex-shrink:0;}
.zh-search-btn{display:flex;align-items:center;gap:8px;padding:11px 24px;background:var(--zg);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s;flex-shrink:0;}
.zh-search-btn:hover{background:var(--zgl);}

/* ======================== SECTION HEADER ======================== */
.zh-sec-head{text-align:center;margin-bottom:32px;}
.zh-sec-head h2{font-size:clamp(20px,3vw,34px);font-weight:800;color:var(--zt);margin-bottom:8px;}
.zh-sec-head p{font-size:15px;color:var(--ztm);margin-bottom:18px;}
.zh-see-all-wrap{text-align:right;margin-top:12px;}
.zh-see-all{font-size:14px;font-weight:700;color:var(--zg);}
.zh-see-all:hover{text-decoration:underline;}

/* ======================== TABS ======================== */
.zh-tabs{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;}
.zh-tab{padding:7px 16px;border-radius:100px;border:1.5px solid var(--zbr);background:#fff;font-size:13px;font-weight:600;color:var(--ztm);cursor:pointer;transition:all .15s;}
.zh-tab:hover,.zh-tab.active{background:var(--zg);color:#fff;border-color:var(--zg);}

/* ======================== CARDS ======================== */
.zh-card{background:#fff;border-radius:var(--zr);overflow:hidden;box-shadow:var(--zshadow);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;}
.zh-card:hover{transform:translateY(-3px);box-shadow:var(--zshadow-lg);}
.zh-card-img-wrap{display:block;position:relative;aspect-ratio:4/3;overflow:hidden;}
.zh-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block;}
.zh-card:hover .zh-card-img-wrap img{transform:scale(1.04);}
.zh-card-no-img{width:100%;height:100%;background:linear-gradient(135deg,var(--zgd),var(--zgl));}
.zh-badge{position:absolute;top:10px;left:10px;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:700;background:rgba(0,0,0,.5);color:#fff;backdrop-filter:blur(4px);}
.zh-badge-advanced,.zh-badge-avanzado{background:rgba(220,38,38,.82);}
.zh-badge-beginner,.zh-badge-principiante{background:rgba(45,90,39,.85);}
.zh-badge-intermediate,.zh-badge-intermedio{background:rgba(234,179,8,.9);color:#000;}
.zh-badge-hot{position:absolute;top:10px;right:10px;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:700;background:#ef4444;color:#fff;}
.zh-card-body{padding:14px;display:flex;flex-direction:column;flex:1;}
.zh-card-cat{font-size:11px;font-weight:700;color:var(--zg);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.zh-card-body h3,.zh-card-body h4{font-size:14px;font-weight:700;line-height:1.35;margin-bottom:8px;}
.zh-card-body h3 a,.zh-card-body h4 a{color:var(--zt);}
.zh-card-body h3 a:hover,.zh-card-body h4 a:hover{color:var(--zg);}
.zh-card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--ztm);margin-bottom:10px;}
.zh-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:auto;}
.zh-price{font-size:17px;font-weight:900;color:var(--zg);}
.zh-price small{font-size:11px;font-weight:500;color:var(--ztm);}
.zh-price span{font-size:12px;font-weight:600;color:var(--ztm);}

/* ======================== SLIDERS ======================== */
.zh-slider .slick-slide{padding:0 8px;}
.zh-slider .slick-list{margin:0 -8px;padding-bottom:4px;}
.zh-related-slider .slick-slide{padding:0 8px;}
.zh-related-slider .slick-list{margin:0 -8px;}
.slick-prev::before,.slick-next::before{color:var(--zg);}
.slick-dots li button::before{color:var(--zg);}

/* ======================== GRIDS ======================== */
.zh-grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;}
.zh-grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;}

/* ======================== BANNER ======================== */
.zh-banner{background:linear-gradient(135deg,#1a3a16 0%,#3d7236 100%);padding:60px 20px;}
.zh-banner-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.zh-banner-text h2{font-size:clamp(22px,3.5vw,40px);font-weight:900;color:#fff;margin-bottom:14px;}
.zh-banner-text p{font-size:15px;color:rgba(255,255,255,.82);line-height:1.7;}
.zh-banner-photos{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.zh-banner-photo{border-radius:8px;overflow:hidden;aspect-ratio:1;}
.zh-banner-photo img{width:100%;height:100%;object-fit:cover;}

/* ======================== REVIEWS GRID ======================== */
.zh-reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;}
.zh-review-card{background:#fff;border:1px solid var(--zbr);border-radius:var(--zr);padding:18px;}
.zh-review-top{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.zh-review-avatar{width:40px;height:40px;border-radius:50%;background:var(--zg);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex-shrink:0;}
.zh-review-author{font-weight:700;font-size:14px;}
.zh-review-stars{color:#f59e0b;font-size:13px;}
.zh-review-tour-img{width:44px;height:44px;border-radius:6px;object-fit:cover;margin-left:auto;flex-shrink:0;}
.zh-review-text{font-size:13px;color:var(--ztm);line-height:1.6;margin-bottom:8px;}
.zh-review-tour-name{font-size:11px;font-weight:700;color:var(--zg);}

/* ======================== PAGINATION ======================== */
.zh-pagination{display:flex;justify-content:center;gap:8px;margin-top:36px;flex-wrap:wrap;}
.zh-pag-btn{padding:8px 14px;border-radius:8px;border:1.5px solid var(--zbr);color:var(--zt);font-size:13px;font-weight:600;background:#fff;transition:all .15s;}
.zh-pag-btn:hover,.zh-pag-btn.active{background:var(--zg);color:#fff;border-color:var(--zg);}

/* ======================== SINGLE TOUR ======================== */
.zh-single-topbar{border-bottom:1px solid var(--zbr);padding:12px 0;margin-bottom:28px;}
.zh-rating-bar{display:flex;align-items:center;gap:10px;}
.zh-stars{display:flex;gap:2px;}
.zh-star{font-size:17px;color:#d1d5db;}
.zh-star.filled{color:#f59e0b;}
.zh-rating-num{font-weight:800;font-size:16px;}
.zh-rating-link{font-size:13px;color:var(--zg);text-decoration:underline;}

.zh-single-layout{display:grid;grid-template-columns:1fr 340px;gap:36px;align-items:start;padding:0 0 60px;}

/* Feature image */
.zh-feat-img{border-radius:var(--zr);overflow:hidden;margin-bottom:10px;aspect-ratio:16/9;}
.zh-feat-img img{width:100%;height:100%;object-fit:cover;}

/* Gallery row */
.zh-gallery-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:24px;}
.zh-gthumb{border-radius:8px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative;}
.zh-gthumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.zh-gthumb:hover img{transform:scale(1.05);}
.zh-gmore{position:relative;}
.zh-gmore-count{position:absolute;inset:0;background:rgba(0,0,0,.52);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:900;}

/* About */
.zh-about{margin-bottom:24px;}
.zh-about h2{font-size:20px;font-weight:800;margin-bottom:12px;}
.zh-about-content{font-size:15px;line-height:1.75;color:#374151;}

/* Stats */
.zh-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;background:#f4f7f3;border-radius:var(--zr);padding:20px;margin-bottom:24px;}
.zh-stat{display:flex;align-items:flex-start;gap:10px;}
.zh-stat-icon{font-size:20px;flex-shrink:0;margin-top:2px;}
.zh-stat-val{font-size:15px;font-weight:800;color:var(--zt);}
.zh-stat-lbl{font-size:11px;color:var(--ztm);margin-top:1px;}

/* Inc/Exc */
.zh-inc-exc{margin-bottom:20px;}
.zh-includes h4,.zh-excludes h4{font-size:15px;font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.zh-check{color:var(--zg);font-size:18px;}
.zh-x-icon{color:#ef4444;font-size:18px;}
.zh-includes ul,.zh-excludes ul{list-style:none;padding:0;}
.zh-includes li,.zh-excludes li{font-size:14px;padding:5px 0;border-bottom:1px solid var(--zbr);color:#374151;}
.zh-includes li::before{content:'• ';color:var(--zg);}
.zh-excludes li::before{content:'• ';color:#ef4444;}

/* FAQ */
.zh-faq-block{margin-bottom:28px;}
.zh-faq-block h4{font-size:17px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.zh-faq-item{border:1.5px solid var(--zbr);border-radius:8px;margin-bottom:6px;overflow:hidden;}
.zh-faq-q{width:100%;text-align:left;padding:13px 16px;background:#fff;border:none;cursor:pointer;font-size:14px;font-weight:600;display:flex;justify-content:space-between;color:var(--zt);}
.zh-faq-q:hover{background:#f9fbf8;}
.zh-faq-arr{transition:transform .2s;}
.zh-faq-item.open .zh-faq-arr{transform:rotate(180deg);}
.zh-faq-a{padding:12px 16px;font-size:14px;color:var(--ztm);line-height:1.65;background:#fafcfa;display:none;}

/* Reviews */
.zh-reviews-section{margin-bottom:32px;}
.zh-reviews-section h3{font-size:20px;font-weight:800;margin-bottom:16px;}
.zh-rev-item{padding:16px;border:1.5px solid var(--zbr);border-radius:8px;margin-bottom:10px;}
.zh-rev-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.zh-rev-avatar{width:36px;height:36px;border-radius:50%;background:var(--zg);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex-shrink:0;}
.zh-stars-sm{color:#f59e0b;font-size:12px;}

/* Related */
.zh-related{margin-bottom:40px;}
.zh-related h3{font-size:20px;font-weight:800;margin-bottom:16px;}

/* ======================== BOOKING WIDGET (right sidebar) ======================== */
.zh-booking-widget{background:#fff;border-radius:var(--zr);box-shadow:var(--zshadow-lg);padding:22px;position:sticky;top:24px;}
.zh-bw-price{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--zbr);}
.zh-bw-price-big{font-size:30px;font-weight:900;color:var(--zg);}
.zh-bw-cur{font-size:14px;font-weight:600;color:var(--ztm);}
.zh-bw-price-note{font-size:12px;color:var(--ztm);}
.zh-bw-row{display:flex;align-items:center;gap:10px;background:#f8f9f6;border:1.5px solid var(--zbr);border-radius:8px;padding:10px 12px;margin-bottom:10px;}
.zh-bw-row label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ztm);white-space:nowrap;flex-shrink:0;}
.zh-bw-select{border:none;background:transparent;font-size:14px;font-weight:600;color:var(--zt);outline:none;flex:1;cursor:pointer;}

/* Sidebar dates */
.zh-bw-dates-head{font-size:13px;font-weight:800;color:var(--zt);display:flex;align-items:center;gap:6px;margin:16px 0 10px;padding-top:16px;border-top:1px solid var(--zbr);}
.zh-bw-date-row{padding:12px 0;border-bottom:1px solid var(--zbr);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.zh-bw-date-row.zh-sold{opacity:.5;}
.zh-bw-date-times{display:flex;align-items:center;gap:6px;}
.zh-bw-dt{text-align:center;}
.zh-bw-dt-lbl{font-size:10px;color:var(--ztm);font-weight:700;text-transform:uppercase;}
.zh-bw-dt-time{font-size:13px;font-weight:700;color:var(--zt);}
.zh-bw-dt-date{font-size:11px;color:var(--ztm);}
.zh-bw-dt-arrow{color:var(--ztm);font-size:16px;margin:0 4px;}
.zh-bw-date-action{display:flex;align-items:center;flex-direction:column;gap:4px;}
.zh-sold-badge{background:#f3f4f6;color:#6b7280;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;}
.zh-last-badge{background:#fef2f2;color:#ef4444;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;}
.zh-avail-badge{background:#f0fdf4;color:#16a34a;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;}
.zh-btn-book-sm{padding:6px 12px;background:var(--zg);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;}

/* Departure widget */
.zh-bw-departure{display:flex;align-items:flex-start;gap:10px;background:#f4f7f3;border-radius:8px;padding:12px;margin:14px 0;}
.zh-bw-dep-icon{font-size:22px;flex-shrink:0;}
.zh-bw-dep-label{font-size:11px;font-weight:700;color:var(--ztm);text-transform:uppercase;margin-bottom:2px;}
.zh-bw-dep-link{font-size:13px;font-weight:600;color:var(--zg);line-height:1.4;}
.zh-bw-dep-link small{color:var(--ztm);font-weight:400;}
.zh-bw-dep-name{font-size:13px;font-weight:600;}

/* Custom tour cta */
.zh-bw-custom{text-align:center;padding:16px;background:#f8f9f6;border-radius:8px;margin-top:14px;}
.zh-bw-custom-icon{font-size:32px;margin-bottom:8px;}
.zh-bw-custom p{font-size:13px;color:var(--zt);font-weight:600;margin-bottom:4px;}
.zh-bw-custom-sub{font-size:12px;color:var(--ztm) !important;margin-bottom:10px;}

/* ======================== ALL DATES MODAL ======================== */
.zh-ad-pax-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px;padding-bottom:14px;border-bottom:1px solid var(--zbr);}
.zh-ad-pax{background:#f8f9f6;border-radius:8px;padding:12px;}
.zh-ad-pax>span{font-size:13px;font-weight:700;display:block;margin-bottom:8px;}
.zh-ad-pax-ctrl{display:flex;align-items:center;gap:12px;}
.zh-pax-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--zbr);background:#fff;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;}
.zh-pax-btn:hover{background:var(--zg);color:#fff;border-color:var(--zg);}
.zh-ad-pax small{font-size:11px;color:var(--ztm);display:block;margin-top:4px;}
.zh-ad-pax-note{font-size:12px;color:var(--ztm);margin-bottom:14px;}
.zh-ad-pax-note a{color:var(--zg);}

.zh-ad-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--zbr);flex-wrap:wrap;}
.zh-ad-row.zh-ad-sold{opacity:.5;}
.zh-ad-dayname{font-size:14px;font-weight:800;color:var(--zt);margin-bottom:8px;}
.zh-ad-times{display:flex;align-items:center;gap:10px;}
.zh-ad-time-col{text-align:center;}
.zh-ad-t-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--ztm);}
.zh-ad-t-time{font-size:13px;font-weight:700;}
.zh-ad-t-date{font-size:11px;color:var(--ztm);}
.zh-ad-arr{color:var(--ztm);font-size:20px;margin:0 6px;}
.zh-ad-action{display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
.zh-ad-book-btn{padding:8px 16px;background:var(--zg);color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:700;cursor:pointer;}
.zh-ad-book-btn:hover{background:var(--zgl);}
.zh-ad-footer{margin-top:16px;padding-top:14px;border-top:1px solid var(--zbr);}

/* ======================== MODALS ======================== */
.zh-modal{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;}
.zh-modal-bg{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(3px);}
.zh-modal-box{position:relative;background:#fff;border-radius:14px;padding:28px;max-width:500px;width:calc(100% - 32px);max-height:92vh;overflow-y:auto;box-shadow:var(--zshadow-lg);}
.zh-modal-alldates{max-width:680px;}
.zh-modal-box h3{font-size:19px;font-weight:800;margin-bottom:16px;}
.zh-modal-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;border:none;background:#f3f4f6;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;font-weight:700;}

/* ======================== SEAT MAP ======================== */
.zh-bm-seats-wrap{margin:16px 0;}
.zh-bm-seats-wrap h4{font-size:15px;font-weight:800;margin-bottom:12px;}
#zh-seat-map{display:inline-block;background:#f4f7f3;border-radius:10px;padding:14px;margin-bottom:10px;}
.zh-smap-driver-row{display:flex;align-items:center;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:2px dashed var(--zbr);}
.zh-smap-driver{background:#555;color:#fff;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;}
.zh-smap-spacer{flex:1;}
.zh-smap-row{display:flex;gap:4px;margin-bottom:4px;align-items:center;}
.zh-smap-aisle{width:14px;}
.zh-seat{width:42px;height:42px;border-radius:8px 8px 4px 4px;border:2px solid;font-size:9px;font-weight:700;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center;line-height:1.1;text-align:center;}
.zh-seat.zh-avail{background:#f0fdf4;border-color:#16a34a;color:#16a34a;}
.zh-seat.zh-avail:hover{background:#dcfce7;}
.zh-seat.zh-selc{background:var(--zg);border-color:var(--zgd);color:#fff;}
.zh-seat.zh-taken{background:#f3f4f6;border-color:#d1d5db;color:#9ca3af;cursor:not-allowed;}
.zh-seat-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--ztm);margin-bottom:8px;}
.zh-seat-legend span{display:flex;align-items:center;gap:5px;}
.sl-available{color:#16a34a;font-size:15px;}
.sl-selected{color:var(--zg);font-size:15px;}
.sl-taken{color:#9ca3af;font-size:15px;}
.zh-selected-info{font-size:13px;color:var(--ztm);margin-bottom:10px;}

/* ======================== BOOKING FORM ======================== */
.zh-field{position:relative;margin-bottom:0;}
.zh-field input,.zh-field select,.zh-field textarea{width:100%;border:1.5px solid var(--zbr);border-radius:8px;padding:10px 13px;font-size:14px;color:var(--zt);outline:none;background:#fff;transition:border-color .2s;}
.zh-field input:focus,.zh-field select:focus,.zh-field textarea:focus{border-color:var(--zg);}
.zh-field input[readonly]{background:#f8f9f6;color:var(--ztm);}
.zh-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.zh-gender-field{display:flex;align-items:center;gap:12px;border:1.5px solid var(--zbr);border-radius:8px;padding:10px 13px;}
.zh-gender-field label{display:flex;align-items:center;gap:5px;font-size:13px;cursor:pointer;}
.zh-bm-form h4{font-size:15px;font-weight:800;margin-bottom:12px;}
.zh-bm-summary{background:#f4f7f3;border-radius:8px;padding:14px;margin-bottom:16px;font-size:14px;}
.zh-bm-summary strong{font-weight:800;}

/* ======================== CONFIRM PAGE (booking.php) ======================== */
.zh-booking-page{padding:40px 0;}
.zh-back-link{display:inline-flex;align-items:center;gap:4px;font-size:14px;color:var(--zg);margin-bottom:16px;}
.zh-confirm-title{font-size:28px;font-weight:900;margin-bottom:28px;}
.zh-confirm-layout{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start;}
.zh-confirm-card{background:#fff;border:1.5px solid var(--zbr);border-radius:var(--zr);padding:24px;margin-bottom:16px;}
.zh-confirm-card h3{font-size:18px;font-weight:800;margin-bottom:4px;}
.zh-confirm-note{font-size:13px;color:var(--ztm);margin-bottom:18px;}
.zh-confirm-p-label{font-size:13px;font-weight:700;color:var(--ztm);margin-bottom:12px;}
.zh-confirm-status{padding:10px 14px;border-radius:8px;font-size:14px;margin-top:14px;background:#fff3cd;color:#856404;}
.zh-status-confirmed{background:#d4edda;color:#155724;}
.zh-status-cancelled,.zh-status-failed{background:#f8d7da;color:#721c24;}
.zh-confirm-seats{margin-top:12px;padding-top:12px;border-top:1px solid var(--zbr);font-size:13px;}
.zh-gender-display{display:flex;align-items:center;gap:12px;border:1.5px solid var(--zbr);border-radius:8px;padding:10px 13px;}
.zh-gender-display label{display:flex;align-items:center;gap:4px;font-size:13px;}

/* Summary card */
.zh-confirm-summary{background:#fff;border:1.5px solid var(--zbr);border-radius:var(--zr);padding:20px;position:sticky;top:24px;}
.zh-cs-top{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--ztm);letter-spacing:.5px;margin-bottom:10px;}
.zh-cs-img{width:100%;border-radius:8px;aspect-ratio:16/9;object-fit:cover;margin-bottom:10px;}
.zh-cs-name{font-size:16px;font-weight:800;margin-bottom:14px;}
.zh-cs-section{font-size:12px;font-weight:700;color:var(--ztm);text-transform:uppercase;margin-top:14px;margin-bottom:6px;}
.zh-cs-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#374151;padding:4px 0;}
.zh-cs-row a{color:var(--zg);}
.zh-cs-edit{font-size:12px;color:var(--zg);}
.zh-cs-map-link{font-size:12px;color:var(--zg);text-decoration:underline;}
.zh-cs-divider{border:none;border-top:1px solid var(--zbr);margin:10px 0;}
.zh-cs-total{display:flex;justify-content:space-between;font-size:15px;font-weight:800;padding-top:8px;}

/* ======================== FORMS ======================== */
.zh-field{margin-bottom:0;}
.zh-field input,.zh-field select,.zh-field textarea{width:100%;border:1.5px solid var(--zbr);border-radius:8px;padding:10px 13px;font-size:14px;color:var(--zt);outline:none;background:#fff;transition:border-color .2s;}
.zh-field input:focus,.zh-field select:focus,.zh-field textarea:focus{border-color:var(--zg);}

/* ======================== RESPONSIVE ======================== */
@media(max-width:900px){
  .zh-single-layout{grid-template-columns:1fr;}
  .zh-booking-widget{position:static;}
  .zh-banner-inner{grid-template-columns:1fr;}
  .zh-confirm-layout{grid-template-columns:1fr;}
}
@media(max-width:700px){
  .zh-hero{min-height:380px;}
  .zh-search-box{flex-direction:column;gap:8px;padding:16px;}
  .zh-s-field{min-width:100%;}
  .zh-s-divider{display:none;}
  .zh-stats{grid-template-columns:1fr 1fr;}
  .zh-gallery-row{grid-template-columns:repeat(2,1fr);}
  .zh-row2{grid-template-columns:1fr;}
  .zh-ad-pax-row{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .zh-grid-3,.zh-grid-4{grid-template-columns:1fr;}
  .zh-stats{grid-template-columns:1fr;}
  .zh-modal-box{padding:18px;}
}
