/* Simply Umrah — Main CSS v3 */

/* ─── Google Font ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ─── Variables ──────────────────────────────────── */
:root{
  --primary:#016575;
  --primary-dark:#014d59;
  --secondary:#e9a23b;
  --secondary-dark:#c98520;
  --base-200:#f2f2f2;
  --neutral:#5a5a72;
  --white:#ffffff;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  --radius-xl:12px;
  --shadow:0 1px 4px rgba(0,0,0,.14);
  --shadow-hover:0 8px 24px rgba(0,0,0,.16);
}

/* ─── Reset ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:#1a1a2e;background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:var(--font);border:none;background:none}
ul{list-style:none}
input,select,textarea{font-family:var(--font)}

/* ─── Container ──────────────────────────────────── */
.su-container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem}
.bg-base-200{background:var(--base-200)}
.pb-8{padding-bottom:2rem}
.text-secondary{color:var(--secondary)}

/* ─── Buttons ────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:6px;font-weight:700;font-size:.9rem;transition:all .2s;white-space:nowrap;cursor:pointer;border:none;padding:10px 20px;font-family:var(--font)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark);color:#fff}
.btn-secondary{background:var(--secondary);color:#fff}
.btn-secondary:hover{background:var(--secondary-dark);color:#fff}
.btn-outline-primary{background:transparent;border:1px solid var(--primary);color:var(--primary)}
.btn-outline-primary:hover{background:var(--primary);color:#fff}
.btn-sm{padding:7px 14px;font-size:.82rem}

/* ══════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════ */
.site-header{position:sticky;top:0;left:0;z-index:999;width:100%;background:#fff;box-shadow:0 2px 8px rgba(32,33,36,.08)}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0;gap:16px;overflow:visible}
.navbar-logo a{display:flex;align-items:center}
.navbar-logo img{height:auto;width:160px;max-width:160px}
.site-logo-text{font-size:1.5rem;font-weight:800;display:inline-flex;align-items:center;gap:3px;letter-spacing:-0.02em;font-family:var(--font)}
.logo-word-1{color:var(--primary)}
.logo-word-2{color:var(--secondary)}

/* Desktop Nav */
.navbar-links{display:flex;align-items:center;gap:4px;font-size:1rem;font-weight:600;overflow:visible;position:relative}
.nav-link{padding:8px 12px;color:#1a1a2e;border-radius:4px;transition:color .15s;white-space:nowrap}
.nav-link:hover{color:var(--primary);text-decoration:none}
.nav-item{position:relative}
.nav-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:1rem;font-weight:600;color:#1a1a2e;border-radius:4px;transition:color .15s;white-space:nowrap}
.nav-btn:hover{color:var(--primary)}
.nav-btn svg{width:16px;height:16px}
.nav-dropdown{position:absolute;top:100%;left:0;min-width:180px;background:#fff;border-radius:6px;box-shadow:0 6px 24px rgba(0,0,0,.12);padding:6px 0;display:none;z-index:1000}
.nav-item.open .nav-dropdown{display:block}
.nav-dropdown a{display:block;padding:10px 16px;font-size:.95rem;font-weight:400;color:#1a1a2e;white-space:nowrap;transition:all .15s}
.nav-dropdown a:hover{background:var(--primary);color:#fff}
.navbar-end{display:flex;align-items:center;gap:12px;flex-shrink:0}

/* GBP currency selector */
.nav-currency{display:inline-flex;align-items:center;gap:4px;font-size:.875rem;font-weight:800;color:#1a1a2e;cursor:pointer;white-space:nowrap}
.nav-currency-code{font-size:.875rem;font-weight:700;margin-left:4px}
.nav-currency svg path{stroke:#1a1a2e}

/* User / Login button — rounded-full ring style like target */
.nav-user-btn{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:9999px;
  background:var(--secondary);color:#fff;
  border:none;cursor:pointer;font-size:1.4rem;
  box-shadow:0 0 0 2px var(--secondary),0 0 0 4px #fff,0 0 0 5px var(--secondary);
  transition:all .2s;flex-shrink:0;
}
.nav-user-btn:hover{background:var(--secondary-dark)}
.nav-user-btn svg{width:22px;height:22px}

/* Mobile currency row */
.mobile-currency-row{padding:12px 16px;border-bottom:1px solid #e2e8f0}
.mobile-currency{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:700;color:#1a1a2e;cursor:pointer}
.mobile-currency span{font-size:.9rem}

/* Hide on small screens */
.max-sm\:hidden{display:none}
@media(min-width:640px){.max-sm\:hidden{display:flex;align-items:center}}
.navbar-divider{height:32px;width:1px;background:var(--primary);margin:0 4px}
.nav-contact-icon{color:#1a1a2e;display:flex;align-items:center;transition:color .15s}
.nav-contact-icon:hover{color:var(--primary)}
.mobile-toggle-wrap{display:none}
.mobile-toggle-wrap button{font-size:1.5rem;color:#1a1a2e;display:flex;align-items:center}

/* ══════════════════════════════════════════════════
   MOBILE MENU
══════════════════════════════════════════════════ */
.mobile-menu-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1998}
.mobile-menu-overlay.active{display:block}
.mobile-menu{position:fixed;top:0;left:0;width:83.333%;max-width:420px;height:100vh;background:#fff;z-index:1999;transform:translateX(-100%);transition:transform .3s ease;overflow-y:auto;display:flex;flex-direction:column}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-top{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}
.mobile-menu-top img{height:32px;width:auto}
#mobileClose{font-size:1.8rem;color:#718096;display:flex;align-items:center;justify-content:center;width:36px;height:36px}
#mobileClose:hover{color:var(--primary)}
.mobile-nav-list{flex:1}
.mobile-nav-list>li{border-bottom:1px solid #e2e8f0}
.mobile-nav-list>li>a{display:block;padding:12px 16px;font-size:.9rem;color:#1a1a2e;transition:all .15s}
.mobile-nav-list>li>a:hover{background:var(--primary);color:#fff}
.mobile-dropdown-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;font-size:.9rem;font-weight:500;color:#1a1a2e;text-align:left;transition:all .15s}
.mobile-dropdown-toggle:hover{background:#f7fafc;color:var(--primary)}
.mobile-dropdown-toggle svg{width:16px;height:16px;transition:transform .2s}
.mobile-has-dropdown.open .mobile-dropdown-toggle svg{transform:rotate(180deg)}
.mobile-dropdown{display:none;background:#f7fafc}
.mobile-has-dropdown.open .mobile-dropdown{display:block}
.mobile-dropdown li{border-bottom:1px solid #e2e8f0}
.mobile-dropdown a{display:block;padding:10px 32px;font-size:.875rem;color:#4a5568;transition:all .15s}
.mobile-dropdown a:hover{background:var(--primary);color:#fff}

/* ══════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════ */
.hero-section{position:relative;min-height:calc(100vh - 76px);display:flex;align-items:center;overflow:visible}
.hero-section::before{content:'';position:absolute;inset:0;overflow:hidden;z-index:0;border-radius:0}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;clip-path:inset(0)}
.hero-gradient{position:absolute;top:0;left:0;width:100%;height:384px;z-index:1;background:linear-gradient(to bottom,var(--primary) 0%,rgba(1,101,117,.75) 50%,rgba(233,162,59,.1) 100%)}
.hero-body{position:relative;z-index:2;width:100%;padding:24px 0 40px}
.hero-text-wrap{max-width:780px;margin:0 auto;text-align:center;color:#fff;padding-bottom:24px}
.hero-text-wrap h1{font-size:1.5rem;font-weight:800;line-height:1.25;font-family:var(--font);letter-spacing:-0.01em;color:#fff;margin-bottom:16px}
.hero-text-wrap h1 span{color:#fff}
@media(min-width:640px){.hero-text-wrap h1{font-size:1.875rem}}
@media(min-width:768px){.hero-text-wrap h1{font-size:2.25rem}}
@media(min-width:1024px){.hero-text-wrap h1{font-size:3rem}}

/* ══════════════════════════════════════════════════
   SEARCH WIDGET
══════════════════════════════════════════════════ */
.search-widget-wrap{max-width:960px;margin:0 auto;position:relative;}

/* Tab row */
.search-tabs-bar{display:flex;justify-content:center;position:relative;z-index:6}
.search-tabs{display:flex;gap:0;background:#fff;border-radius:8px 8px 0 0;font-weight:500;max-width:max-content;padding:0 24px;box-shadow:0 3px 10px rgba(0,0,0,.2)}
.search-tab{display:flex;align-items:center;gap:6px;padding:14px 12px;font-size:.9rem;font-weight:400;white-space:nowrap;cursor:pointer;color:var(--secondary);border-bottom:2px solid var(--secondary)}
.search-tab svg{flex-shrink:0}

/* White card */
.search-form-card{position:relative;z-index:5;background:#fff;padding:16px;border-radius:8px;margin-top:-20px;box-shadow:0 4px 20px rgba(0,0,0,.12);overflow:visible}

/* ── Search fields in ONE row ─────────────────── */
.search-form-row{display:flex;align-items:stretch;gap:8px;flex-wrap:nowrap}

/* Each field box */
.sf-field{
  flex:1;
  min-width:0;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  background:#fff;
  border:1.5px solid #e2e8f0;
  border-radius:8px;
  cursor:pointer;
  transition:border-color .15s;
  position:relative;
  overflow:visible;
  min-height:60px;
}
.sf-field:focus-within{border-color:var(--primary)}
.sf-field.sf-dest{flex:1.4}
.sf-field.sf-nat{flex:1.1}

/* Icon inside field */
.sf-field svg.sf-icon{flex-shrink:0;color:#6b7280;width:28px;height:28px}

/* Label + input inside field */
.sf-inner{flex:1;min-width:0}
.sf-label{display:block;font-size:.7rem;font-weight:400;color:#6b7280;margin-bottom:2px;white-space:nowrap}
.sf-input{width:100%;border:none;outline:none;font-size:.9rem;font-weight:400;color:#1a1a2e;background:transparent;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font)}
.sf-input::placeholder{color:#d1d5db;font-weight:400}
.sf-input[type="date"]{cursor:pointer}
.sf-select{width:100%;border:none;outline:none;font-size:.9rem;font-weight:400;color:#1a1a2e;background:transparent;cursor:pointer;-webkit-appearance:none;appearance:none;font-family:var(--font)}

/* Search button */
.sf-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:0 28px;background:var(--secondary);color:#fff;border-radius:9999px;font-size:1rem;font-weight:700;min-height:60px;border:none;cursor:pointer;transition:background .2s;white-space:nowrap;font-family:var(--font)}
.sf-btn:hover{background:var(--secondary-dark)}

/* ── Destination dropdown ─────────────────────── */
.dest-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:100%;min-width:260px;background:var(--base-200);border:1px solid rgba(0,0,0,.06);border-radius:6px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:9999;display:none;overflow:hidden}
.dest-dropdown.open{display:block}
.dest-search-wrap{position:relative;padding:8px}
.dest-search-wrap svg{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:.85rem}
.dest-search-wrap input{width:100%;padding:8px 10px 8px 32px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;font-size:.875rem;outline:none;font-family:var(--font)}
.dest-search-wrap input:focus{border-color:var(--primary)}
.dest-dropdown hr{border:none;border-top:1px solid #e2e8f0}
#destList{max-height:220px;overflow-y:auto;padding:4px 0}
#destList li{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;transition:background .15s}
#destList li:hover{background:rgba(0,0,0,.04)}
#destList li.selected{background:var(--primary);color:#fff}
#destList li h6{font-weight:500;font-size:.9rem}

/* ── Travelers dropdown ───────────────────────── */
.trav-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.14);padding:16px;z-index:9999;display:none}
.trav-dropdown.open{display:block}
.room-header{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:14px;font-size:.9rem}
.room-header svg{color:#718096}
.guest-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}
.guest-info h6{font-size:.9rem;font-weight:600}
.guest-info p{font-size:.75rem;color:#718096}
.guest-counter{display:flex;align-items:center;gap:12px}
.counter-btn{width:28px;height:28px;border-radius:4px;background:var(--primary);color:#fff;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .15s;cursor:pointer;border:none}
.counter-btn:hover{background:var(--primary-dark)}
.guest-counter span{min-width:20px;text-align:center;font-weight:600}
.trav-dropdown hr{border:none;border-top:1px solid #e2e8f0;margin:8px 0}
.trav-actions{display:flex;gap:8px;padding-top:8px}
.trav-actions .btn{flex:1;height:40px;min-height:0;border-radius:6px}

/* ══════════════════════════════════════════════════
   HOTEL SECTIONS
══════════════════════════════════════════════════ */
.section-hotels{padding:48px 0}
.section-header-row{margin-bottom:24px}
.section-title{font-size:1.875rem;font-weight:600;letter-spacing:-0.02em}
@media(max-width:640px){.section-title{font-size:1.125rem}}
.section-header-row p{color:#4a5568;margin-top:4px}

/* 4-column grid */
.hotels-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* Hotel Card */
.hotel-card-link{display:block}
.hotel-card{position:relative;overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow);border-radius:var(--radius-xl)}
.hotel-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-8px)}

.hotel-card-img-wrap{position:relative;height:208px;overflow:hidden;display:block}
.hotel-card-img-wrap img{width:100%;height:208px;object-fit:cover;display:block}

/* Black 10% overlay */
.hotel-card-overlay{position:absolute;inset:0;background:rgba(0,0,0,.1)}

/* Hotel name pill — bottom left */
.hotel-card-name{position:absolute;left:0;bottom:16px;background:var(--primary);padding:4px 8px;border-radius:0 9999px 9999px 0;max-width:85%}
.hotel-card-name h6{font-size:.875rem;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Stars badge — top right */
.hotel-card-stars{position:absolute;top:16px;right:8px;background:var(--secondary);color:#fff;border-radius:9999px;padding:2px 5px;display:flex;align-items:center;justify-content:center;line-height:1;gap:1px}
.hotel-card-stars svg{width:10px;height:10px}

/* ══════════════════════════════════════════════════
   DESTINATIONS SLIDER
══════════════════════════════════════════════════ */
.section-destinations{padding:32px 0 48px}
.dest-header{margin-bottom:24px}
.dest-slider-outer{position:relative}
.dest-slider{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:10px 4px 20px;scrollbar-width:none}
.dest-slider::-webkit-scrollbar{display:none}
.dest-slide{flex-shrink:0;width:260px;scroll-snap-align:start}
.dest-card{background:#fff;padding:16px;border-radius:var(--radius-xl);box-shadow:0 3px 10px rgba(0,0,0,.1);transition:all .3s ease}
.dest-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-8px)}
.dest-card a{display:block}
.dest-card img{height:240px;width:100%;object-fit:cover;border-radius:var(--radius-xl)}
.dest-card-body{padding-top:16px}
.text-upper{font-weight:500;text-transform:uppercase;font-size:.85rem;margin-bottom:4px}
.dest-card-body h3{font-size:1rem;background:var(--primary);display:inline-block;border-radius:4px;padding:2px 8px;color:#fff;margin-bottom:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.btn-dest{height:40px;min-height:0;width:100%;border-radius:9999px;font-weight:400}
.dest-prev,.dest-next{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:9999px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;z-index:10;color:var(--secondary);font-size:1rem;transition:all .2s;border:none;cursor:pointer}
.dest-prev:hover,.dest-next:hover{background:var(--secondary);color:#fff}
.dest-prev{left:-4px}
.dest-next{right:-4px}

/* ══════════════════════════════════════════════════
   HOW TO BOOK
══════════════════════════════════════════════════ */
.section-how{padding:48px 0;position:relative;overflow:hidden}
.how-bg{position:absolute;inset:0;background-repeat:no-repeat;background-position:center;background-size:cover;opacity:.15;pointer-events:none}
.how-header{max-width:800px;margin:0 auto 32px;text-align:center}
.how-title{font-size:2.25rem;font-weight:600;margin-bottom:8px;letter-spacing:-0.02em}
.how-header p{font-size:1.125rem;color:#4a5568}
.how-steps-slider-wrap{position:relative}
.how-steps-slider{display:grid;grid-template-columns:repeat(5,1fr);overflow-x:auto;scrollbar-width:none}
.how-steps-slider::-webkit-scrollbar{display:none}
.how-step{display:flex;flex-direction:column;text-align:center}
.how-step.odd .how-img-cell{height:256px;border-bottom:2px solid #e2e8f0;display:flex;align-items:flex-end;justify-content:center;padding-bottom:24px}
.how-step.odd .how-dot{width:16px;height:16px;background:#fdba74;border-radius:50%;margin:-8px auto 0;flex-shrink:0}
.how-step.odd .how-text-cell{height:256px;padding:24px 4px 0}
.how-step.even .how-text-cell{height:256px;border-bottom:2px solid #e2e8f0;display:flex;flex-direction:column;justify-content:flex-end;padding:4px 4px 24px}
.how-step.even .how-dot{width:16px;height:16px;background:#fdba74;border-radius:50%;margin:-8px auto 0;flex-shrink:0}
.how-step.even .how-img-cell{height:256px;display:flex;align-items:flex-start;justify-content:center;padding-top:24px}
.how-step img{display:block;width:66%;height:auto;max-height:160px;object-fit:contain;border-radius:var(--radius-xl);margin:0 auto}
.how-step h6{font-size:1.25rem;font-weight:600;margin-bottom:8px}
.how-step p{font-size:.875rem;color:#4a5568;line-height:1.5}
.how-prev,.how-next{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fdba74;font-size:1.5rem;z-index:10;cursor:pointer;border:none;background:none}
.how-prev{left:-8px}
.how-next{right:-8px}

/* ══════════════════════════════════════════════════
   REVIEWS
══════════════════════════════════════════════════ */
.section-reviews{padding:48px 0}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px rgba(0,0,0,.07);border:1px solid #f0f0f0;transition:box-shadow .2s,transform .2s}
.review-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.12);transform:translateY(-4px)}
.review-stars{display:flex;gap:3px;margin-bottom:14px;color:var(--secondary);font-size:1rem}
.review-text{font-size:.9rem;color:#4a5568;line-height:1.65;margin-bottom:20px;font-style:italic}
.review-author{display:flex;align-items:center;gap:12px}
.review-avatar{width:42px;height:42px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}
.review-author strong{display:block;font-size:.9rem;font-weight:700;color:#1a1a2e}
.review-author span{display:block;font-size:.78rem;color:#718096;margin-top:2px}

/* ══════════════════════════════════════════════════
   FEATURES
══════════════════════════════════════════════════ */
.section-features{padding:0 0 48px}
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.feature-card{border:1px solid #e2e8f0;border-radius:var(--radius-xl);padding:16px;transition:border-color .2s}
.feature-card:hover{border-color:var(--secondary)}
.feature-icon-wrap{width:74px;height:74px;background:rgba(233,162,59,.15);color:var(--secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.feature-icon{font-size:3rem}
.feature-card h4{font-size:1.5rem;font-weight:700;color:#4b5563;margin-bottom:8px;letter-spacing:-0.015em}
.feature-card p{color:var(--neutral);font-size:.9rem;line-height:1.55}

/* ══════════════════════════════════════════════════
   UMRAH SERVICES + PARTNERS
══════════════════════════════════════════════════ */
.section-umrah-services{padding:48px 0 0}
.umrah-services-header{text-align:center}
.umrah-services-header h3{font-size:2.25rem;font-weight:600;margin-bottom:8px;letter-spacing:-0.02em}
.umrah-services-header p{font-size:1rem;color:#4a5568}
.section-partner-logos{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;align-items:center;padding:16px 0 48px}
.partner-logo{display:block;width:50%;height:auto;max-height:80px;object-fit:contain;margin:0 auto}
@media(min-width:1024px){.partner-logo{width:75%;max-height:100px}}

/* ══════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════ */
.site-footer{background:#fff;border-top:1px solid #e2e8f0;padding:32px 0 0}
.footer-grid{display:grid;grid-template-columns:auto 1fr 1fr 1fr;gap:48px;padding-bottom:24px;border-bottom:1px solid #e2e8f0}
.footer-brand p{font-size:.8rem;color:#4a5568;margin-top:6px;line-height:1.6}
.footer-brand a{color:var(--secondary)}
.footer-brand a:hover{text-decoration:underline}
.footer-socials{display:flex;align-items:center;gap:16px;margin-top:8px}
.social-btn{width:32px;height:32px;border-radius:50%;background:rgba(1,101,117,.1);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s}
.social-btn:hover{background:var(--primary);color:#fff}
.footer-col-title{font-size:1rem;font-weight:600;color:var(--primary);margin-bottom:16px;display:block;letter-spacing:-0.01em}
.footer-nav{display:flex;flex-direction:column}
.footer-nav a{color:var(--primary);font-size:.875rem;font-weight:400;padding:3px 0;transition:color .15s;display:block}
.footer-nav a:hover{color:var(--secondary)}
.footer-partner-logos{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.footer-partner-logos img{width:128px;height:64px;object-fit:contain;padding:8px;border-radius:4px}
.hotel-partner-logos{display:flex;flex-direction:column;gap:8px}
.hp-logo{background:#fff;border-radius:8px;overflow:hidden;padding:8px}
.hp-logo img{width:100%;height:48px;object-fit:contain;border-radius:4px}
.footer-bottom{padding:16px 0;text-align:center}
.footer-bottom p{font-size:.875rem;color:var(--primary)}

/* ══════════════════════════════════════════════════
   FLOATING BUTTONS — only WhatsApp + Phone
══════════════════════════════════════════════════ */
.floating-side{position:fixed;top:50%;transform:translateY(-50%);z-index:900;display:flex;flex-direction:column;gap:10px}
.floating-left{left:16px}
.floating-right{right:16px}
.float-btn{position:relative;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;box-shadow:0 2px 8px rgba(0,0,0,.2);transition:transform .2s}
.float-btn:hover{transform:scale(1.08)}
.float-wa{background:#25d366}
.float-phone{background:#27ae60}
.float-tooltip{position:absolute;background:rgba(0,0,0,.7);color:#fff;padding:4px 10px;border-radius:4px;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;right:calc(100% + 10px);top:50%;transform:translateY(-50%)}
.float-btn:hover .float-tooltip{opacity:1}
/* Remove left floating div */
.floating-left{display:none!important}

/* ══════════════════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:rgba(0,0,0,.8);color:#fff;padding:12px 0;display:none}
.cookie-banner.show{display:block}
.cookie-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cookie-inner p{font-size:.875rem;flex:1;opacity:.9}
.cookie-btns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
#cookieDecline{padding:8px 20px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;background:#64748b;color:#fff;transition:background .2s;font-family:var(--font)}
#cookieDecline:hover{background:#475569}
#cookieAccept{padding:8px 20px;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;background:#16a34a;color:#fff;transition:background .2s;font-family:var(--font)}
#cookieAccept:hover{background:#15803d}

/* ══════════════════════════════════════════════════
   HOTEL RESULTS PAGE
══════════════════════════════════════════════════ */
.results-header-section{background:var(--primary);padding:24px 0}
.results-form{width:100%}
.results-fields{display:flex;gap:8px;align-items:stretch;flex-wrap:wrap}
.rf-field{flex:1;min-width:140px}
.rf-input{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:rgba(255,255,255,.15);color:#fff;font-size:.9rem;font-family:var(--font);outline:none;transition:border-color .2s}
.rf-input::placeholder{color:rgba(255,255,255,.7)}
.rf-input:focus{border-color:#fff}
.rf-input option{color:#1a1a2e;background:#fff}
.rf-btn{padding:0 28px;min-height:48px;border-radius:8px;white-space:nowrap;flex-shrink:0}
.results-body{padding:32px 0 60px}
.results-count-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:8px}
.results-count-bar p{font-size:.95rem;color:#4a5568}
.results-dates{color:#718096;font-size:.875rem}
.no-results{text-align:center;padding:60px 20px;color:#4a5568}
.no-results h3{font-size:1.5rem;font-weight:700;margin-bottom:12px}
.no-results a{color:var(--primary);text-decoration:underline}
.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.result-card{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow);transition:all .3s ease;border:1px solid #e2e8f0}
.result-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}
.result-card-img{position:relative;height:200px;overflow:hidden}
.result-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.result-card:hover .result-card-img img{transform:scale(1.04)}
.result-card-stars{position:absolute;top:12px;right:10px;background:var(--secondary);color:#fff;border-radius:9999px;padding:3px 6px;font-size:11px;display:flex;align-items:center;gap:1px}
.result-card-stars svg{width:10px;height:10px}
.result-card-body{padding:16px}
.result-hotel-name{font-size:1rem;font-weight:700;color:#1a1a2e;margin-bottom:6px;line-height:1.35}
.result-hotel-dest{display:flex;align-items:center;gap:5px;font-size:.8rem;color:#718096;margin-bottom:4px}
.result-hotel-dest svg{color:var(--secondary);width:12px;height:14px;flex-shrink:0}
.result-hotel-distance{font-size:.78rem;color:#a0aec0;margin-bottom:14px}
.result-card-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.result-price{font-size:.85rem;color:#4a5568;white-space:nowrap}
.result-price strong{color:var(--primary);font-size:1rem}
.result-enquire-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;border-radius:6px;font-size:.82rem;font-weight:700;white-space:nowrap}

/* ══════════════════════════════════════════════════
   PAGE CONTENT
══════════════════════════════════════════════════ */
.page-content-body{color:#4a5568;line-height:1.75}
.page-content-body h2{font-size:1.4rem;font-weight:700;color:var(--primary);margin:24px 0 10px}
.page-content-body h3{font-size:1.15rem;font-weight:600;margin:18px 0 8px}
.page-content-body p{margin-bottom:14px}
.page-content-body a{color:var(--primary);text-decoration:underline}
.page-content-body ul{list-style:disc;padding-left:24px;margin-bottom:14px}
.page-content-body li{margin-bottom:6px}

/* ══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media(max-width:1199px){
  .hotels-grid{grid-template-columns:repeat(3,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .section-partner-logos{grid-template-columns:repeat(2,1fr)}
  .how-steps-slider{grid-template-columns:repeat(3,280px)}
}
@media(max-width:991px){
  .navbar-links{display:none}
  .navbar-end .navbar-divider,.navbar-end .nav-contact-icon{display:none}
  .mobile-toggle-wrap{display:flex}
  .hotels-grid{grid-template-columns:repeat(2,1fr)}
  /* Search form wraps on tablet */
  .search-form-row{flex-wrap:wrap}
  .sf-field{flex-basis:calc(50% - 4px);flex-grow:1}
  .sf-field.sf-dest{flex-basis:100%}
  .sf-btn{flex-basis:100%;min-height:48px}
  .how-steps-slider{grid-template-columns:repeat(3,240px)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .floating-side{display:none}
}
@media(max-width:767px){
  .hotels-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .hotel-card-img-wrap img{height:160px}
  .hotel-card-img-wrap{height:160px}
  .features-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .section-partner-logos{grid-template-columns:repeat(2,1fr);gap:16px}
  .results-fields{flex-direction:column}
  .rf-btn{width:100%}
  .how-steps-slider{grid-template-columns:repeat(3,200px)}
  .how-title{font-size:1.6rem}
  .reviews-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hotels-grid{grid-template-columns:1fr}
  .search-form-row{flex-direction:column}
  .sf-field,.sf-field.sf-dest,.sf-field.sf-nat{flex-basis:100%}
}

/* ══════════════════════════════════════════════════
   SEARCH RESULTS PAGE — exact match screenshot
══════════════════════════════════════════════════ */

/* Re-search bar */
.sr-search-bar {
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
  padding: 16px 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.sr-bar-fields {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.sr-field {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  flex: 1;
  border-right: 1px solid #e2e8f0;
  min-width: 0;
}
.sr-field:last-of-type { border-right: none; }
.sr-icon { flex-shrink: 0; color: #9ca3af; }
.sr-field-inner { flex: 1; min-width: 0; }
.sr-label { display: block; font-size: .68rem; font-weight: 600; color: #9ca3af; text-transform: uppercase; letter-spacing: .06em; }
.sr-val { display: block; font-size: .88rem; font-weight: 500; color: #1a1a2e; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sr-input { width: 100%; border: none; outline: none; font-size: .88rem; font-weight: 500; color: #1a1a2e; background: transparent; font-family: var(--font); cursor: pointer; }
.sr-search-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 28px;
  background: var(--secondary);
  color: #fff;
  border: none;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--font);
  transition: background .2s;
  flex-shrink: 0;
}
.sr-search-btn:hover { background: var(--secondary-dark); }

/* Layout */
.sr-layout {
  display: flex;
  gap: 24px;
  padding-top: 24px;
  padding-bottom: 60px;
  align-items: flex-start;
}

/* ── Sidebar ──────────────────────────────────── */
.sr-sidebar {
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: 88px;
}

.sr-map-wrap {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 0;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.sr-map-overlay {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
}
.sr-show-map-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--primary);
  color: #fff;
  border-radius: 6px;
  font-size: .82rem;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  border: none;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}

.sr-filters-box {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-top: none;
  border-radius: 0 0 8px 8px;
  padding: 16px;
}
.sr-filters-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #1a1a2e;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #e2e8f0;
}
.sr-filter-group {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f0f0f0;
}
.sr-filter-group:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.sr-filter-label {
  font-size: .85rem;
  font-weight: 700;
  color: #2d3748;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Price display */
.sr-price-display {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: .85rem;
  font-weight: 600;
  color: #2d3748;
  margin-bottom: 10px;
}
.sr-range-wrap { position: relative; height: 20px; margin-bottom: 4px; }
.sr-range {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(to right, #e2e8f0 0%, var(--primary) 30%, var(--primary) 70%, #e2e8f0 100%);
  outline: none;
  position: absolute;
  top: 8px;
  pointer-events: none;
}
.sr-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--primary);
  cursor: pointer;
  pointer-events: all;
}
.sr-range::-moz-range-thumb {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--primary);
  cursor: pointer;
  pointer-events: all;
}
.sr-price-limits {
  display: flex;
  justify-content: space-between;
  font-size: .75rem;
  color: #718096;
  margin-top: 8px;
}

/* Hotel name filter */
.sr-name-search {
  position: relative;
}
.sr-name-search svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: #9ca3af;
  font-size: .85rem;
}
.sr-name-search input {
  width: 100%;
  padding: 9px 10px 9px 32px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  font-size: .85rem;
  outline: none;
  font-family: var(--font);
  color: #1a1a2e;
}
.sr-name-search input:focus { border-color: var(--primary); }
.sr-name-search input::placeholder { color: #a0aec0; }

/* Checkboxes */
.sr-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .875rem;
  color: #4a5568;
  margin-bottom: 8px;
  cursor: pointer;
}
.sr-checkbox input[type="checkbox"] {
  width: 16px; height: 16px;
  accent-color: var(--primary);
  cursor: pointer;
}

/* ── Main Content ──────────────────────────────── */
.sr-main { flex: 1; min-width: 0; }

/* Sort Tabs */
.sr-sort-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
}
.sr-sort-tab {
  flex: 1;
  padding: 13px 8px;
  font-size: .82rem;
  font-weight: 600;
  color: #4a5568;
  background: #fff;
  border: none;
  border-right: 1px solid #e2e8f0;
  cursor: pointer;
  font-family: var(--font);
  transition: all .15s;
  text-align: center;
  white-space: nowrap;
}
.sr-sort-tab:last-child { border-right: none; }
.sr-sort-tab:hover { background: #f7fafc; color: var(--primary); }
.sr-sort-tab.active { background: var(--primary); color: #fff; }

.sr-count {
  font-size: .9rem;
  color: #718096;
  margin-bottom: 16px;
}
.sr-count strong { color: #1a1a2e; }

/* Hotel List — vertical cards like screenshot */
.sr-hotel-list { display: flex; flex-direction: column; gap: 16px; }

.sr-hotel-card {
  display: flex;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  transition: box-shadow .2s, transform .2s;
}
.sr-hotel-card:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,.1);
  transform: translateY(-2px);
}
.sr-hotel-card.hidden { display: none; }

/* Card image — left side */
.sr-card-img {
  width: 200px;
  flex-shrink: 0;
  overflow: hidden;
}
.sr-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  min-height: 160px;
  transition: transform .4s;
}
.sr-hotel-card:hover .sr-card-img img { transform: scale(1.04); }

/* Card body — middle */
.sr-card-body {
  flex: 1;
  padding: 16px 20px;
  min-width: 0;
}
.sr-card-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a1a2e;
  margin-bottom: 6px;
  line-height: 1.3;
}
.sr-card-location {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: .82rem;
  color: #718096;
  margin-bottom: 8px;
}
.sr-card-location svg { color: #718096; width: 12px; flex-shrink: 0; }
.sr-card-stars {
  display: flex;
  gap: 2px;
  color: var(--secondary);
  font-size: .9rem;
  margin-bottom: 10px;
}
.sr-card-stars svg { width: 14px; height: 14px; }
.sr-distance-badge {
  display: inline-block;
  background: var(--secondary);
  color: #fff;
  font-size: .75rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 4px;
  margin-bottom: 8px;
}
.sr-facilities-label {
  font-size: .8rem;
  color: #a0aec0;
}

/* Card right — price + button */
.sr-card-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 16px 20px;
  flex-shrink: 0;
  gap: 12px;
  min-width: 160px;
}
.sr-card-price {
  font-size: 1.3rem;
  font-weight: 800;
  color: #1a1a2e;
  white-space: nowrap;
}
.sr-availability-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 18px;
  background: var(--primary);
  color: #fff;
  border-radius: 8px;
  font-size: .85rem;
  font-weight: 700;
  font-family: var(--font);
  white-space: nowrap;
  transition: background .2s;
}
.sr-availability-btn:hover { background: var(--primary-dark); color: #fff; }
.sr-availability-btn svg { width: 10px; }

/* Responsive */
@media (max-width: 1100px) {
  .sr-sidebar { width: 230px; }
  .sr-sort-tab { font-size: .75rem; padding: 12px 6px; }
}
@media (max-width: 900px) {
  .sr-layout { flex-direction: column; }
  .sr-sidebar { width: 100%; position: static; }
  .sr-bar-fields { flex-wrap: wrap; }
  .sr-field { flex-basis: calc(50% - 1px); border-bottom: 1px solid #e2e8f0; }
  .sr-search-btn { width: 100%; justify-content: center; padding: 14px; }
  .sr-sort-tabs { flex-wrap: wrap; }
  .sr-sort-tab { flex-basis: calc(50% - 1px); border-bottom: 1px solid #e2e8f0; }
}
@media (max-width: 600px) {
  .sr-card-img { width: 120px; }
  .sr-card-right { min-width: 120px; padding: 12px; }
  .sr-card-price { font-size: 1.1rem; }
  .sr-availability-btn { font-size: .78rem; padding: 9px 12px; }
  .sr-field { flex-basis: 100%; }
}

/* ══════════════════════════════════════════════════
   CRITICAL DROPDOWN FIXES
══════════════════════════════════════════════════ */
/* Hero section must NOT clip dropdowns */
.hero-section,
.hero-body,
.hero-body > *,
.search-widget-wrap,
.search-form-card,
.search-form-row,
.sf-field {
  overflow: visible !important;
}

/* Destination dropdown — always on top */
.dest-dropdown {
  position: absolute !important;
  z-index: 99999 !important;
  top: calc(100% + 6px) !important;
  left: 0 !important;
  min-width: 280px !important;
  max-height: 300px;
  overflow-y: auto;
  display: none;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0,0,0,.18) !important;
}
.dest-dropdown.open { display: block !important; }

#destList { max-height: 240px; overflow-y: auto; }
#destList li {
  padding: 12px 16px;
  cursor: pointer;
  border-bottom: 1px solid #f0f4f8;
  font-size: .9rem;
  color: #2d3748;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#destList li:hover { background: #f0f9fa; color: var(--primary); }
#destList li.selected { background: var(--primary); color: #fff; }
#destList li h6 { font-weight: 500; margin: 0; }

/* Travelers dropdown — always on top */
.trav-dropdown {
  position: absolute !important;
  z-index: 99999 !important;
  top: calc(100% + 6px) !important;
  right: 0 !important;
  left: auto !important;
  width: 300px !important;
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.18) !important;
  padding: 16px !important;
  display: none;
}
.trav-dropdown.open { display: block !important; }

/* Make sure sf-field is positioned */
.sf-field { position: relative !important; }
#destContainer { position: relative !important; }
#travelerContainer { position: relative !important; }

/* Date input styling fix */
.sf-input[type="date"] {
  color: #1a1a2e;
  font-size: .88rem;
  font-weight: 500;
  min-width: 120px;
}

/* ── Hotel image fallback when CDN fails ──────────── */
.hotel-card-img-wrap.img-error {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 208px;
}
.hotel-card-img-wrap.img-error::after {
  content: attr(data-name);
  color: rgba(255,255,255,.7);
  font-size: .8rem;
  text-align: center;
  padding: 0 12px;
}

/* Results page image fallback */
.sr-card-img img[style*="display:none"] + .sr-card-img-placeholder,
.sr-card-img:has(img[style*="display:none"]) {
  background: linear-gradient(135deg, var(--primary), var(--primary-dark));
  min-height: 160px;
}

/* Make ALL images crossorigin safe */
.hotel-card-img-wrap img,
.sr-card-img img,
.result-card-img img,
.dest-card img {
  crossorigin: anonymous;
}

/* ══════════════════════════════════════════════════
   CUSTOM DATE RANGE CALENDAR
══════════════════════════════════════════════════ */
.cal-dropdown{
  display:none;position:absolute;top:calc(100% + 8px);left:0;z-index:9999;
  background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.16);
  border:1px solid #e2e8f0;padding:14px 16px;min-width:580px;
}
.cal-dropdown.open{display:block;}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-nav{background:none;border:none;font-size:1.6rem;line-height:1;color:var(--primary);cursor:pointer;padding:4px 10px;border-radius:6px;transition:background .15s;}
.cal-nav:hover{background:#f0f9fa;}
.cal-months-wrap{display:flex;gap:32px;flex:1;justify-content:center;}
.cal-month-label{font-size:.95rem;font-weight:600;color:var(--primary);text-align:center;}
.cal-body{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.cal-month{min-width:260px;}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px;}
.cal-weekdays span{text-align:center;font-size:.72rem;font-weight:600;color:#9ca3af;padding:4px 0;text-transform:uppercase;}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-day{text-align:center;padding:7px 4px;font-size:.85rem;border-radius:6px;cursor:pointer;transition:all .15s;color:#1a1a2e;user-select:none;}
.cal-day:hover:not(.cal-empty):not(.cal-disabled){background:#f0f9fa;color:var(--primary);}
.cal-day.cal-empty{pointer-events:none;}
.cal-day.cal-disabled{color:#d1d5db;pointer-events:none;}
.cal-day.cal-today{font-weight:700;color:var(--secondary);}
.cal-day.cal-selected-start,.cal-day.cal-selected-end{background:var(--primary)!important;color:#fff!important;border-radius:6px;}
.cal-day.cal-selected-start{border-radius:6px 0 0 6px;}
.cal-day.cal-selected-end{border-radius:0 6px 6px 0;}
.cal-day.cal-in-range{background:#e6f4f6;color:var(--primary);border-radius:0;}
.cal-day.cal-selected-start.cal-selected-end{border-radius:6px!important;}
.cal-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid #e2e8f0;}
#calNights{font-size:.85rem;color:#718096;font-weight:500;}

/* nationality select styling */
.sf-select optgroup{font-weight:700;font-size:.82rem;color:#9ca3af;}
.sf-select option{font-weight:400;font-size:.88rem;padding:4px;}

@media(max-width:768px){
  .cal-dropdown{min-width:320px;left:50%;transform:translateX(-50%);}
  .cal-body{grid-template-columns:1fr;}
}

/* ══════════════════════════════════════════════════
   HOTEL RESULTS — SIDEBAR LAYOUT (NEW)
══════════════════════════════════════════════════ */

/* Mobile filter toggle button */
.filter-mobile-toggle{
    display:none;
    align-items:center;
    gap:8px;
    margin:14px 0 0;
    padding:10px 18px;
    background:var(--primary);
    color:#fff;
    border:none;
    border-radius:8px;
    font-size:.9rem;
    font-weight:600;
    font-family:var(--font);
    cursor:pointer;
    position:relative;
}
.filter-active-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:var(--secondary);
    color:#fff;
    border-radius:9999px;
    width:20px;
    height:20px;
    font-size:.72rem;
    font-weight:700;
}

/* Two-column layout: sidebar + main */
.results-layout{
    display:grid;
    grid-template-columns:280px 1fr;
    gap:28px;
    padding:28px 0 60px;
    align-items:start;
}

/* ── SIDEBAR ─────────────────────────────────────── */
.results-sidebar{
    background:#fff;
    border-radius:14px;
    border:1px solid #e2e8f0;
    box-shadow:0 1px 4px rgba(0,0,0,.06);
    padding:0;
    position:sticky;
    top:80px;
    max-height:calc(100vh - 100px);
    overflow-y:auto;
}
.results-sidebar::-webkit-scrollbar{width:4px}
.results-sidebar::-webkit-scrollbar-track{background:transparent}
.results-sidebar::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:9999px}

.sidebar-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:18px 20px 14px;
    border-bottom:1px solid #f1f5f9;
    position:sticky;
    top:0;
    background:#fff;
    z-index:2;
}
.sidebar-header h3{
    font-size:1rem;
    font-weight:700;
    color:#1a1a2e;
    margin:0;
}
.sidebar-clear-btn{
    background:none;
    border:none;
    color:var(--primary);
    font-size:.8rem;
    font-weight:600;
    cursor:pointer;
    font-family:var(--font);
    padding:4px 0;
}
.sidebar-clear-btn:hover{text-decoration:underline}

/* Filter groups */
.filter-group{
    padding:16px 20px;
    border-bottom:1px solid #f1f5f9;
}
.filter-group:last-child{border-bottom:none}
.filter-group-title{
    display:block;
    font-size:.8rem;
    font-weight:700;
    color:#64748b;
    text-transform:uppercase;
    letter-spacing:.06em;
    margin-bottom:10px;
}

/* Name search input */
.filter-search-wrap{
    position:relative;
    display:flex;
    align-items:center;
}
.filter-search-wrap svg{
    position:absolute;
    left:10px;
    color:#94a3b8;
    pointer-events:none;
}
.filter-search-input{
    width:100%;
    padding:9px 12px 9px 32px;
    border:1px solid #e2e8f0;
    border-radius:8px;
    font-size:.875rem;
    font-family:var(--font);
    color:#1a1a2e;
    outline:none;
    transition:border-color .2s;
    background:#f8fafc;
}
.filter-search-input:focus{border-color:var(--primary);background:#fff}

/* Checkbox options */
.filter-options{
    display:flex;
    flex-direction:column;
    gap:8px;
}
.filter-check-label{
    display:flex;
    align-items:center;
    gap:9px;
    cursor:pointer;
    font-size:.875rem;
    color:#374151;
    line-height:1.4;
    user-select:none;
}
.filter-check-label input[type="checkbox"]{
    position:absolute;
    opacity:0;
    width:0;
    height:0;
}
.filter-check-box{
    width:17px;
    height:17px;
    border:2px solid #cbd5e0;
    border-radius:4px;
    background:#fff;
    flex-shrink:0;
    transition:background .15s,border-color .15s;
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
}
.filter-check-label input:checked + .filter-check-box{
    background:var(--primary);
    border-color:var(--primary);
}
.filter-check-label input:checked + .filter-check-box::after{
    content:'';
    display:block;
    width:5px;
    height:9px;
    border:2px solid #fff;
    border-top:none;
    border-left:none;
    transform:rotate(45deg) translateY(-1px);
}
.filter-check-label:hover .filter-check-box{border-color:var(--primary)}

/* Stars display in filter */
.filter-stars-display{
    display:flex;
    align-items:center;
    gap:2px;
}
.filter-stars-display svg{color:#e9a23b}
.star-label{color:#64748b;font-size:.8rem;margin-left:3px}

/* Facility icons */
.facility-icon{font-size:.95rem;line-height:1}

/* ── RESULTS MAIN ─────────────────────────────────── */
.results-main{min-width:0}

/* Count bar stays the same */
.results-count-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:8px}

/* Result card — property type badge */
.rc-prop-badge{
    position:absolute;
    top:12px;
    left:10px;
    background:rgba(0,0,0,.55);
    color:#fff;
    border-radius:6px;
    padding:3px 8px;
    font-size:.7rem;
    font-weight:600;
    text-transform:capitalize;
    backdrop-filter:blur(4px);
}

/* Facilities row on card */
.rc-facilities{
    display:flex;
    flex-wrap:wrap;
    gap:4px;
    margin:8px 0 12px;
}
.rc-fac-icon{
    font-size:1rem;
    line-height:1;
    cursor:default;
}

/* ── LAZY LOADING ─────────────────────────────────── */
.lazy-trigger{height:1px;margin-top:20px}
.lazy-loading{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:8px;
    padding:28px 0;
}
.lazy-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    background:var(--primary);
    opacity:.3;
    animation:lazyDotPulse 1.2s ease-in-out infinite;
}
.lazy-dot:nth-child(2){animation-delay:.2s}
.lazy-dot:nth-child(3){animation-delay:.4s}
@keyframes lazyDotPulse{
    0%,80%,100%{opacity:.3;transform:scale(.8)}
    40%{opacity:1;transform:scale(1)}
}

/* No filter results */
.no-filter-results{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:14px;
    padding:60px 20px;
    text-align:center;
    color:#64748b;
}
.no-filter-results p{font-size:.95rem}
.no-filter-results button{
    background:none;
    border:none;
    color:var(--primary);
    font-weight:600;
    cursor:pointer;
    font-family:var(--font);
    text-decoration:underline;
    font-size:inherit;
}

/* ══════════════════════════════════════════════════
   RESPONSIVE — SIDEBAR LAYOUT
══════════════════════════════════════════════════ */
@media(max-width:1024px){
    .results-layout{grid-template-columns:240px 1fr;gap:20px}
}
@media(max-width:767px){
    .filter-mobile-toggle{display:inline-flex}
    .results-layout{
        grid-template-columns:1fr;
        padding:16px 0 40px;
    }
    .results-sidebar{
        position:fixed;
        top:0;
        left:0;
        width:80vw;
        max-width:320px;
        height:100vh;
        max-height:100vh;
        border-radius:0;
        z-index:9999;
        transform:translateX(-110%);
        transition:transform .3s ease;
        box-shadow:4px 0 24px rgba(0,0,0,.18);
    }
    .results-sidebar.sidebar-open{
        transform:translateX(0);
    }
}

/* ══════════════════════════════════════════════════
   ADDITIONAL FIXES — match target website exactly
══════════════════════════════════════════════════ */

/* Search form card z-index & overflow override */
.hero-section,
.hero-section *:not(.hero-bg-img):not(.hero-gradient) {
  overflow: visible;
}
.hero-bg-img { clip-path: inset(0); }

/* All dropdowns on top */
.dest-dropdown,
.trav-dropdown,
.cal-dropdown { z-index: 99999 !important; }

/* Nav link hover teal */
.nav-btn:hover { color: #016575; }
.nav-link:hover { color: #016575; }

/* Search tab svg size */
.search-tab svg { width: 20px; height: 20px; flex-shrink: 0; }

/* sf-field hover */
.sf-field:hover { border-color: var(--primary); }

/* Nationality select */
.sf-select optgroup { font-weight: 700; font-size: .8rem; color: #9ca3af; }
.sf-select option   { font-weight: 400; font-size: .88rem; }

/* footer-nav wrapper */
.footer-partners { min-width: 200px; }
.footer-hotel-partners { min-width: 180px; }

/* footer-partner-logos images */
.footer-partner-logos img {
  width: 128px;
  height: 52px;
  object-fit: contain;
  padding: 6px;
  border-radius: 4px;
  background: #fff;
}
.hp-logo img {
  width: 100%;
  height: 48px;
  object-fit: contain;
}

/* Partner section images */
.partner-logo {
  display: block;
  width: 50%;
  height: auto;
  max-height: 80px;
  object-fit: contain;
  margin: 0 auto;
}
@media(min-width:1024px){
  .partner-logo { width: 75%; max-height: 100px; }
}

/* ══════════════════════════════════════════════════
   MATCH NEXT.JS SITE — EXACT OVERRIDE
══════════════════════════════════════════════════ */

/* Hero height exactly like Next.js min-h-[calc(100vh-76px)] */
.hero-section { min-height: calc(100vh - 76px) !important; }

/* Hero gradient — same as Next.js: from-primary via-primary/75 to-secondary/10, h-96 */
.hero-gradient {
  height: 384px !important;
  background: linear-gradient(to bottom, #016575 0%, rgba(1,101,117,0.75) 55%, rgba(233,162,59,0.10) 100%) !important;
}

/* Hero title — exact Next.js sizes: text-2xl sm:text-3xl md:text-4xl lg:text-5xl, font-extrabold */
.hero-text-wrap h1 {
  font-size: 1.5rem !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  letter-spacing: normal !important;
  margin-bottom: 0 !important;
}
@media(min-width:640px)  { .hero-text-wrap h1 { font-size: 1.875rem !important; } }
@media(min-width:768px)  { .hero-text-wrap h1 { font-size: 2.25rem !important; } }
@media(min-width:1024px) { .hero-text-wrap h1 { font-size: 3rem !important; } }

/* Hero padding — Next.js: pt-6 pb-2 lg:pt-14 lg:pb-14 */
.hero-body { padding: 24px 0 8px !important; }
@media(min-width:1024px) { .hero-body { padding: 56px 0 56px !important; } }

/* Search widget max-width matches Next.js container */
.search-widget-wrap { max-width: 1280px !important; }

/* Search form row — Next.js: grid lg:grid-flow-col one-way-round-trip */
/* Desktop: destination(2fr) | date(1.2fr) | travelers(1fr) | nationality(1.15fr) | button */
.search-form-row {
  display: grid !important;
  grid-template-columns: 2fr 1.2fr 1fr 1.15fr auto !important;
  gap: 8px !important;
  flex-wrap: unset !important;
  align-items: stretch !important;
}

/* Each sf-field — matches sb-input-container exactly */
.sf-field {
  flex: unset !important;
  background: #fff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 6px !important;
  padding: 10px 12px !important;
  min-height: 64px !important;
  gap: 8px !important;
  cursor: pointer !important;
}
.sf-field.sf-dest  { grid-column: span 1; }
.sf-field.sf-daterange { grid-column: span 1; }
.sf-field.sf-nat   { grid-column: span 1; }

/* Field label — matches sb-label */
.sf-label {
  font-size: 0.75rem !important;
  color: #6b7280 !important;
  font-weight: 400 !important;
  white-space: nowrap !important;
}

/* Field input — matches sb-input */
.sf-input {
  font-size: 0.875rem !important;
  color: #1a1a2e !important;
}
.sf-select {
  font-size: 0.875rem !important;
  color: #1a1a2e !important;
}

/* Icon — matches lucide h-7 w-7 */
.sf-field svg.sf-icon {
  width: 28px !important;
  height: 28px !important;
  color: #6b7280 !important;
}

/* Search button — matches btn-secondary, rounded (not pill), lg:max-w-[200px] */
.sf-btn {
  border-radius: 6px !important;
  padding: 0 20px !important;
  min-height: 64px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  background: var(--secondary) !important;
  min-width: 110px !important;
  max-width: 200px !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.sf-btn svg { font-size: 1.5rem; width: 24px; height: 24px; }
.sf-btn:hover { background: var(--secondary-dark) !important; }

/* Tablet responsive — matches Next.js grid wrapping */
@media(max-width:1023px) {
  .search-form-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .sf-field.sf-dest { grid-column: span 2; }
  .sf-btn { grid-column: span 2; max-width: 100% !important; min-height: 48px !important; }
}

@media(max-width:639px) {
  .search-form-row {
    grid-template-columns: 1fr !important;
  }
  .sf-field.sf-dest { grid-column: span 1; }
  .sf-btn { grid-column: span 1; }
}

/* ══════════════════════════════════════════════════
   FINAL HERO FIX — MATCH SCREENSHOT EXACTLY
══════════════════════════════════════════════════ */

/* Hero height — screenshot mein ~420px visible, NOT full viewport */
.hero-section {
  min-height: 620px !important;
  height: auto !important;
  align-items: center !important;
}

/* Gradient — full cover, teal dark overlay like screenshot */
.hero-gradient {
  height: 100% !important;
  background: rgba(1,101,117,0.82) !important;
  top: 0 !important;
}

/* Hero body padding — centered vertically */
.hero-body {
  padding: 60px 0 60px 0 !important;
}

/* Title — single line, very large, bold white, center */
.hero-text-wrap {
  padding-bottom: 32px !important;
  max-width: 100% !important;
}
.hero-text-wrap h1 {
  font-size: 2rem !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: #fff !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 0 !important;
}
@media(min-width:768px)  { .hero-text-wrap h1 { font-size: 2.5rem !important; } }
@media(min-width:1024px) { .hero-text-wrap h1 { font-size: 3rem !important; } }

/* Search widget — full width like screenshot */
.search-widget-wrap {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 16px !important;
}

/* Tab — Hotel tab pill style */
.search-tabs-bar { justify-content: center !important; margin-bottom: 0 !important; }
.search-tabs {
  border-radius: 8px 8px 0 0 !important;
  padding: 0 20px !important;
  background: #fff !important;
}
.search-tab {
  color: var(--secondary) !important;
  border-bottom: 2px solid var(--secondary) !important;
  font-size: 1rem !important;
  padding: 14px 16px !important;
}

/* Form card — white, no top border radius on left */
.search-form-card {
  border-radius: 0 8px 8px 8px !important;
  padding: 16px !important;
  margin-top: 0 !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.15) !important;
}

/* Form row — match screenshot: 4 fields + button */
.search-form-row {
  display: grid !important;
  grid-template-columns: 2fr 1.4fr 1.4fr 1.4fr auto !important;
  gap: 8px !important;
  align-items: center !important;
}

/* Each field — NO individual border, plain inside white card */
.sf-field {
  border: 1px solid #e5e7eb !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  min-height: 70px !important;
  background: #fff !important;
}

/* Search button — dark amber/brown like screenshot */
.sf-btn {
  background: #8B4513 !important;
  border-radius: 8px !important;
  min-height: 60px !important;
  padding: 0 28px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #fff !important;
  min-width: 120px !important;
  max-width: none !important;
  flex-direction: row !important;
  gap: 8px !important;
}
.sf-btn:hover { background: #7a3c10 !important; }

/* Responsive */
@media(max-width:1023px) {
  .search-form-row { grid-template-columns: 1fr 1fr !important; }
  .sf-field.sf-dest { grid-column: span 2; }
  .sf-btn { grid-column: span 2; max-width: 100% !important; }
  .hero-section { min-height: 580px !important; }
}
@media(max-width:639px) {
  .search-form-row { grid-template-columns: 1fr !important; }
  .sf-field.sf-dest { grid-column: span 1; }
  .sf-btn { grid-column: span 1; }
}

/* ── FareLord Logo Image ── */
.navbar-logo a { display:flex; align-items:center; }
.navbar-logo img,
.navbar-logo-img {
  height: auto !important;
  width: 220px !important;
  max-width: 220px !important;
  display: block !important;
  object-fit: contain !important;
}
@media(max-width: 768px) {
  .navbar-logo img,
  .navbar-logo-img {
    width: 160px !important;
    max-width: 160px !important;
  }
}

/* ════════════════════════════════════════════
   FINAL OVERRIDES — Logo + Form + Hero
════════════════════════════════════════════ */

/* LOGO — force big size, override everything */
.navbar-logo,
.navbar-logo a,
.navbar-logo img,
.navbar-logo-img {
  height: auto !important;
  width: 160px !important;
  max-width: 160px !important;
  min-width: 160px !important;
  display: block !important;
  object-fit: contain !important;
}
.navbar-logo a { display: flex !important; align-items: center !important; }
@media(max-width: 768px) {
  .navbar-logo img, .navbar-logo-img {
    width: 160px !important;
    max-width: 160px !important;
    min-width: 160px !important;
  }
}

/* HOME PAGE hero — form fields taller */
.hero-section .sf-field {
  min-height: 72px !important;
  padding: 12px 16px !important;
}
.hero-section .sf-btn {
  min-height: 72px !important;
}

/* MAKKAH / MADINAH pages — shorter hero, bigger form */
.page-template-hotel-mecca .hero-section,
.page-template-hotel-madinah .hero-section,
.page-template-template-hotel-mecca .hero-section,
.page-template-template-hotel-madinah .hero-section {
  min-height: 450px !important;
}
.page-template-hotel-mecca .hero-body,
.page-template-hotel-madinah .hero-body,
.page-template-template-hotel-mecca .hero-body,
.page-template-template-hotel-madinah .hero-body {
  padding: 32px 0 32px !important;
}
.page-template-hotel-mecca .sf-field,
.page-template-hotel-madinah .sf-field,
.page-template-template-hotel-mecca .sf-field,
.page-template-template-hotel-madinah .sf-field {
  min-height: 72px !important;
  padding: 12px 16px !important;
}
.page-template-hotel-mecca .sf-btn,
.page-template-hotel-madinah .sf-btn,
.page-template-template-hotel-mecca .sf-btn,
.page-template-template-hotel-madinah .sf-btn {
  min-height: 72px !important;
}
.page-template-hotel-mecca .search-form-card,
.page-template-hotel-madinah .search-form-card,
.page-template-template-hotel-mecca .search-form-card,
.page-template-template-hotel-madinah .search-form-card {
  padding: 20px !important;
}

/* Compact hero for Makkah/Madinah hotel pages */
.hero-section--compact {
  min-height: 450px !important;
  height: auto !important;
}
.hero-section--compact .hero-body {
  padding: 28px 0 28px !important;
}
.hero-section--compact .sf-field {
  min-height: 72px !important;
}
.hero-section--compact .sf-btn {
  min-height: 72px !important;
}
.hero-section--compact .search-form-card {
  padding: 20px !important;
}
