/* ============================================================
   WINSOME CITIES — Power Design System v3.0
   Mobile-first · Glassmorphism · Cinematic · Spirited
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
  --blue:      #003580;
  --blue2:     #1a52a8;
  --blue3:     #3b82f6;
  --blue-gl:   rgba(0,53,128,.18);
  --blue-g:    rgba(0,53,128,.4);
  --gold:      #c9861a;
  --gold2:     #f0a500;
  --gold3:     #fbbf24;
  --gold-g:    rgba(201,134,26,.4);
  --navy:      #001240;
  --navy2:     #002060;
  --navy3:     #000d30;
  --sky:       #d6e4ff;
  --sky2:      #eaf0ff;
  --text:      #1a2634;
  --muted:     #5a7080;
  --light:     #f4f9f8;
  --border:    #e0eeec;
  --white:     #ffffff;
  --shadow:    0 4px 24px rgba(0,0,0,.08);
  --shadow-md: 0 8px 32px rgba(0,0,0,.13);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.2);
  --shadow-xl: 0 32px 80px rgba(0,0,0,.28);
  --glass:     rgba(255,255,255,.12);
  --glass2:    rgba(255,255,255,.06);
  --radius:    18px;
  --radius-sm: 12px;
  --tr:        .3s cubic-bezier(.4,0,.2,1);
  --spring:    .55s cubic-bezier(.34,1.56,.64,1);
  --bounce:    .6s cubic-bezier(.68,-.55,.265,1.55);
  --font-h:    'Playfair Display', Georgia, serif;
  --font-b:    'DM Sans', 'Segoe UI', system-ui, sans-serif;
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100%; overflow-x:hidden; }
body { font-family:var(--font-b); color:var(--text); overflow-x:hidden; background:#fff; line-height:1.6; }
img  { max-width:100%; height:auto; display:block; }
a    { text-decoration:none; color:inherit; }
ul,ol { list-style:none; }
button,input,textarea,select { font-family:inherit; border:none; outline:none; background:none; }
button { cursor:pointer; }
::selection { background:var(--blue); color:#fff; }

/* ── ANIMATIONS ── */
@keyframes fadeUp    { from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:none} }
@keyframes fadeLeft  { from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:none} }
@keyframes fadeRight { from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:none} }
@keyframes fadeIn    { from{opacity:0}to{opacity:1} }
@keyframes zoomIn    { from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)} }
@keyframes shimmer   { 0%{background-position:-200% 0}100%{background-position:200% 0} }
@keyframes float     { 0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)} }
@keyframes floatR    { 0%,100%{transform:translateY(0) rotate(3deg)}50%{transform:translateY(-10px) rotate(-3deg)} }
@keyframes gradShift { 0%,100%{background-position:0% 50%}50%{background-position:100% 50%} }
@keyframes ticker    { from{transform:translateX(0)}to{transform:translateX(-50%)} }
@keyframes pulse     { 0%,100%{transform:scale(1)}50%{transform:scale(1.08)} }
@keyframes spinSlow  { to{transform:rotate(360deg)} }
@keyframes ripple    { to{transform:scale(2.5);opacity:0} }
@keyframes barIn     { from{transform:translateX(-100%)}to{transform:translateX(200%)} }
@keyframes dotBlink  { 0%,100%{opacity:1}50%{opacity:.3} }
@keyframes slideUp   { from{transform:translateY(100%);opacity:0}to{transform:none;opacity:1} }
@keyframes heroKen   { 0%{transform:scale(1) translateX(0)}100%{transform:scale(1.08) translateX(-2%)} }
@keyframes navIn     { from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none} }
@keyframes counterUp { from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none} }

/* ── SCROLL REVEAL ── */
.reveal      { opacity:0;transform:translateY(36px);transition:opacity .75s ease,transform .75s ease; }
.reveal-l    { opacity:0;transform:translateX(-30px);transition:opacity .7s ease,transform .7s ease; }
.reveal-r    { opacity:0;transform:translateX(30px);transition:opacity .7s ease,transform .7s ease; }
.reveal-z    { opacity:0;transform:scale(.9);transition:opacity .7s ease,transform .7s ease; }
.reveal.on, .reveal-l.on, .reveal-r.on, .reveal-z.on { opacity:1;transform:none; }
.d1{transition-delay:.06s!important}.d2{transition-delay:.12s!important}
.d3{transition-delay:.18s!important}.d4{transition-delay:.24s!important}
.d5{transition-delay:.30s!important}.d6{transition-delay:.36s!important}

/* ── PRELOADER ── */
#ws-pl {
  position:fixed;inset:0;z-index:999999;
  background:var(--navy3);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
  transition:opacity .8s ease,visibility .8s ease;
}
#ws-pl.out { opacity:0;visibility:hidden;pointer-events:none; }
.pl-ring {
  width:90px;height:90px;border-radius:50%;
  border:3px solid rgba(255,255,255,.08);
  border-top-color:var(--blue3);
  animation:spinSlow .9s linear infinite;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
}
.pl-ring img { width:52px;height:52px;object-fit:contain;filter:brightness(10);animation:none; }
.pl-name { color:rgba(255,255,255,.7);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-bottom:18px; }
.pl-bar  { width:180px;height:2px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden; }
.pl-bar::after { content:'';display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--gold),var(--blue));background-size:300%;animation:gradShift 1.4s ease infinite; }

/* ── HEADER ── */
.ws-hdr {
  position:fixed;top:0;left:0;right:0;z-index:2000;
  padding:0 5%;
  height:88px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:transparent;
  transition:background .4s ease,box-shadow .4s ease,backdrop-filter .4s ease;
}
.ws-hdr.solid {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  box-shadow:0 2px 32px rgba(0,0,0,.1);
  border-bottom:1px solid rgba(0,53,128,.08);
}
.ws-hdr.solid .ws-logo-brand { color:var(--blue); }
.ws-hdr.solid .ws-logo-tag   { color:var(--muted); }
.ws-hdr.solid .ws-dnav>li>a  { color:var(--text); }
.ws-hdr.solid .ws-nav-book   { box-shadow:0 3px 14px var(--blue-g); }

/* Logo */
.ws-logo { display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none; }
.ws-logo img { height:80px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(0,53,128,.4)); }
.ws-logo-text { display:block; }
.ws-logo-brand { font-family:var(--font-h);font-size:1.1rem;font-weight:900;color:#fff;line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.3); }
.ws-logo-tag   { font-size:10px;color:#7eb8ff;letter-spacing:.5px;font-weight:700; }

/* Desktop Nav */
.ws-dnav { display:none;list-style:none;gap:0; }
@media(min-width:960px){ .ws-dnav { display:flex;align-items:center; } }
.ws-dnav>li { position:relative; }
.ws-dnav>li>a {
  display:flex;align-items:center;gap:4px;
  font-size:13px;font-weight:600;color:#fff;
  padding:8px 13px;border-radius:30px;
  transition:all .2s;white-space:nowrap;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.ws-dnav>li>a:hover, .ws-dnav>li.active>a {
  background:rgba(255,255,255,.15);color:#fff;
}
.ws-hdr.solid .ws-dnav>li>a:hover,
.ws-hdr.solid .ws-dnav>li.active>a { background:#dce8ff;color:#002060; }
.ws-dnav .caret { font-size:9px;opacity:.5;transition:transform .2s; }
.ws-dnav>li:hover .caret { transform:rotate(180deg); }

/* Dropdown */
.ws-dd {
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:#fff;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-lg);padding:8px;min-width:210px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:all .25s;
  border:1px solid var(--border);
}
.ws-dnav>li:hover .ws-dd {
  opacity:1;visibility:visible;pointer-events:auto;
  animation:navIn .2s ease both;
}
.ws-dd a { display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:8px;font-size:13px;color:var(--text);transition:all .2s; }
.ws-dd a:hover { background:#dce8ff;color:#002060; }

/* Nav CTA */
.ws-hdr-right { display:flex;align-items:center;gap:8px; }

/* Header icon buttons (search, WhatsApp) */
.ws-hdr-icon-btn {
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:15px;
  transition:all .2s;flex-shrink:0;
  text-decoration:none;
}
.ws-hdr-icon-btn:hover { background:rgba(255,255,255,.25);transform:scale(1.05); }
.ws-hdr.solid .ws-hdr-icon-btn { background:var(--sky);border-color:var(--border);color:var(--blue); }
.ws-hdr-wa-btn { color:#25d366 !important; }
.ws-hdr.solid .ws-hdr-wa-btn { color:#25d366 !important; }

/* hide search+wa on desktop where there's less need */
@media(min-width:960px) { .ws-hdr-icon-btn { display:none; } }
.ws-nav-book {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;padding:9px 20px;border-radius:50px;font-size:13px;font-weight:700;
  transition:all .3s;display:none;align-items:center;gap:6px;
  box-shadow:0 3px 14px rgba(0,0,0,.25);
  white-space:nowrap;
}
@media(min-width:960px){ .ws-nav-book { display:flex; } }
.ws-nav-book:hover { transform:translateY(-2px);box-shadow:0 7px 22px var(--blue-g); }
#wsUserBtn .ws-user-name { display:none; }
@media(min-width:480px){ #wsUserBtn .ws-user-name { display:inline; } }

/* Hamburger */
.ws-ham {
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(10px);
  display:flex;flex-direction:column;gap:5px;align-items:center;justify-content:center;
  transition:all .2s;
}
.ws-hdr.solid .ws-ham { background:var(--sky);border-color:var(--border); }
.ws-ham span { width:20px;height:2px;background:#fff;border-radius:2px;transition:all .35s; }
.ws-hdr.solid .ws-ham span { background:var(--blue); }
.ws-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.ws-ham.open span:nth-child(2){opacity:0;width:0;}
.ws-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(min-width:960px){ .ws-ham { display:none; } }

/* ── MOBILE NAV (slide-in panel) ── */
.ws-mob { position:fixed;inset:0;z-index:9998;pointer-events:none; }
.ws-mob-bg { position:absolute;inset:0;background:rgba(5,18,28,.82);backdrop-filter:blur(10px);opacity:0;transition:opacity .35s; }
.ws-mob-panel {
  position:absolute;top:0;right:0;bottom:0;
  width:min(320px,88vw);
  background:linear-gradient(160deg,#001240 0%,#002060 50%,#000d30 100%);
  transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;overflow-y:auto;
  box-shadow:-10px 0 60px rgba(0,0,0,.5);
}
.ws-mob.open { pointer-events:auto; }
.ws-mob.open .ws-mob-bg { opacity:1; }
.ws-mob.open .ws-mob-panel { transform:none; }

.ws-mob-head {
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.07);
  flex-shrink:0;
}
.ws-mob-brand { display:flex;align-items:center;gap:10px; }
.ws-mob-brand img { width:38px;height:38px;object-fit:contain;filter:brightness(10);border-radius:8px;background:rgba(255,255,255,.06);padding:4px; }
.ws-mob-brand-txt .name { font-family:var(--font-h);color:#fff;font-size:1rem;line-height:1; }
.ws-mob-brand-txt .tag  { font-size:10px;color:rgba(255,255,255,.4);margin-top:2px; }
.ws-mob-close {
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.ws-mob-close:hover { background:rgba(255,255,255,.18);transform:rotate(90deg); }

/* Maze-style nav tiles */
.ws-mob-nav { padding:14px 16px;flex:1; }
.ws-mob-nav-grid { display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px; }
.ws-mob-tile {
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  padding:16px 10px;border-radius:14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);
  color:rgba(255,255,255,.85);font-size:12px;font-weight:700;
  transition:all .25s;text-align:center;
}
.ws-mob-tile:hover,
.ws-mob-tile.active { background:rgba(0,53,128,.55);border-color:rgba(0,53,128,.8);color:#fff; }
.ws-mob-tile .tile-icon { font-size:1.5rem; }
.ws-mob-list { display:flex;flex-direction:column;gap:2px; }
.ws-mob-list li a {
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-radius:10px;
  color:rgba(255,255,255,.75);font-size:14px;font-weight:600;
  transition:all .2s;
}
.ws-mob-list li a:hover { background:rgba(255,255,255,.07);color:#fff; }
.ws-mob-list li a .mi { font-size:10px;opacity:.3; }

.ws-mob-cta {
  padding:16px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;
  display:flex;flex-direction:column;gap:8px;
}
.ws-mob-book {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:50px;padding:13px;text-align:center;
  font-weight:800;font-size:14px;transition:all .3s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.ws-mob-book:hover { transform:scale(1.02);box-shadow:0 6px 20px var(--blue-g); }
.ws-mob-socials { display:flex;gap:8px;justify-content:center; }
.ws-mob-soc {
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:all .2s;
}
.ws-mob-soc:hover { background:var(--blue);color:#fff;transform:scale(1.1); }

/* ── TICKER ── */
.ws-ticker {
  background:linear-gradient(90deg,var(--blue) 0%,#002878 40%,var(--gold) 100%);
  color:#fff;padding:8px 0;overflow:hidden;position:relative;
  margin-top:119px; /* account for topbar (31px) + fixed header (88px) */
}
.ws-ticker-lbl {
  position:absolute;left:0;top:0;bottom:0;
  background:rgba(0,0,0,.35);
  padding:0 14px;display:flex;align-items:center;
  font-weight:800;font-size:11px;letter-spacing:.5px;white-space:nowrap;z-index:2;
}
.ws-ticker-wrap { overflow:hidden;padding-left:110px; }
.ws-ticker-track {
  display:flex;white-space:nowrap;
  animation:ticker 32s linear infinite;
}
.ws-ticker-track:hover { animation-play-state:paused; }
.ws-ticker-item { padding:0 24px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:5px; }
.ws-ticker-item a { color:#fff;transition:opacity .2s; }
.ws-ticker-item a:hover { opacity:.8; }
.ws-ticker-sep { opacity:.3; }

/* ── HERO ── */
.ws-hero {
  position:relative;width:100%;min-height:100svh;
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--navy3);
}
.ws-hero-slides { position:absolute;inset:0;z-index:0; }
.ws-hero-slide {
  position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;
  background-size:cover;background-position:center;
}
.ws-hero-slide.active { opacity:1; }
.ws-hero-slide::after {
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom, rgba(0,18,64,.65) 0%, rgba(0,18,64,.1) 45%, rgba(0,18,64,.9) 100%);
}
/* Ken Burns on active slide */
.ws-hero-slide.active .ws-hero-slide-img {
  animation:heroKen 12s ease forwards;
}

.ws-hero-body {
  position:relative;z-index:2;flex:1;
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  padding:151px 5% 80px;max-width:700px; /* 120px + 31px topbar */
}
.ws-hero-badge {
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,53,128,.3);border:1px solid rgba(0,53,128,.55);
  backdrop-filter:blur(12px);color:#fff;
  padding:7px 18px;border-radius:50px;
  font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  margin-bottom:22px;animation:fadeUp .6s ease both;
}
.ws-hero-dot { width:7px;height:7px;border-radius:50%;background:var(--gold2);animation:pulse 1.5s ease infinite; }
.ws-hero-h1 {
  font-family:var(--font-h);
  font-size:clamp(2.4rem,8vw,5rem);
  font-weight:900;color:#fff;line-height:1.05;
  margin-bottom:20px;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
  animation:fadeUp .7s ease .1s both;
}
.ws-hero-h1 em { color:var(--gold2);font-style:normal; }
.ws-hero-sub {
  color:rgba(255,255,255,.82);font-size:clamp(.95rem,2.2vw,1.1rem);
  line-height:1.8;margin-bottom:36px;max-width:520px;
  animation:fadeUp .7s ease .2s both;
}
.ws-hero-cta { display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .7s ease .3s both; }
.ws-btn-hero-p {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;padding:15px 32px;border-radius:50px;
  font-weight:800;font-size:15px;display:flex;align-items:center;gap:9px;
  box-shadow:0 6px 28px var(--blue-g),0 0 0 0 var(--blue-g);
  transition:all .35s var(--spring);
  animation:pulse 3s ease 2s infinite;
  white-space:nowrap;
}
.ws-btn-hero-p:hover { transform:translateY(-4px) scale(1.03);box-shadow:0 14px 40px var(--blue-g);color:#fff; }
.ws-btn-hero-o {
  border:2px solid rgba(255,255,255,.55);color:#fff;
  padding:13px 28px;border-radius:50px;font-weight:700;font-size:15px;
  backdrop-filter:blur(8px);background:rgba(255,255,255,.08);
  display:flex;align-items:center;gap:8px;transition:all .3s;
}
.ws-btn-hero-o:hover { background:rgba(255,255,255,.2);transform:translateY(-3px);color:#fff;border-color:rgba(255,255,255,.85); }
@media(max-width:480px){
  .ws-btn-hero-p { font-size:13px;padding:12px 22px;gap:7px; }
  .ws-btn-hero-o { font-size:13px;padding:11px 18px;gap:7px; }
  .ws-hero-cta { gap:10px; }
}

/* Hero slide indicators */
.ws-hero-dots {
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;gap:8px;align-items:center;
}
.ws-hero-dot-btn {
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);
  transition:all .3s;
}
.ws-hero-dot-btn.active { background:#fff;width:24px;border-radius:4px; }

/* Hero scroll hint */
.ws-scroll-hint {
  position:absolute;bottom:36px;right:5%;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:rgba(255,255,255,.5);font-size:11px;letter-spacing:1px;text-transform:uppercase;
}
.ws-scroll-mouse { width:22px;height:34px;border:2px solid rgba(255,255,255,.35);border-radius:11px;display:flex;align-items:flex-start;justify-content:center;padding-top:4px; }
.ws-scroll-wheel { width:3px;height:6px;background:rgba(255,255,255,.6);border-radius:2px;animation:float 1.8s ease infinite; }

/* ── SEARCH BAR ── */
.ws-search-outer { padding:0 5%;transform:translateY(-32px);position:relative;z-index:10; }
.ws-search-box {
  background:rgba(255,255,255,.98);backdrop-filter:blur(24px);
  border-radius:var(--radius);box-shadow:var(--shadow-xl);
  display:grid;grid-template-columns:1fr 1fr 1fr 1fr minmax(130px,auto);
  border:1px solid rgba(0,53,128,.1);
  overflow:hidden;
  animation:fadeUp .7s ease .4s both;
}
@media(max-width:900px){ .ws-search-box { grid-template-columns:1fr 1fr; } .ws-si-wrap:last-child { grid-column:span 2; } }
@media(max-width:520px){ .ws-search-box { grid-template-columns:1fr; } .ws-si-wrap:last-child { grid-column:span 1; } }
.ws-si-wrap { padding:14px 20px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:4px;min-width:0;position:relative; }
.ws-si-wrap:last-child { border-right:none;padding:10px 14px;justify-content:center; }
.ws-si-lbl { font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.8px;text-transform:uppercase; }
.ws-si-inp { border:none;outline:none;font-size:14px;font-weight:600;color:var(--text);background:transparent;width:100%; }
.ws-si-inp::placeholder { color:#b0c4cc;font-weight:400; }
.ws-search-go {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:12px;padding:12px 22px;
  font-weight:800;font-size:14px;display:flex;align-items:center;gap:8px;
  transition:all .3s;white-space:nowrap;width:100%;
  box-shadow:0 4px 16px var(--blue-g);
}
.ws-search-go:hover { transform:scale(1.04);box-shadow:0 8px 24px var(--blue-g); }

/* ── STATS ── */
.ws-stats-bar {
  background:linear-gradient(135deg,var(--blue) 0%,#002060 50%,var(--navy2) 100%);
  background-size:200%;animation:gradShift 8s ease infinite;
  padding:30px 5%;display:grid;grid-template-columns:repeat(4,1fr);
  color:#fff;position:relative;overflow:hidden;
}
.ws-stats-bar::before { content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:barIn 3s ease infinite;background-size:200%;pointer-events:none; }
@media(max-width:600px){ .ws-stats-bar { grid-template-columns:repeat(2,1fr); } }
.ws-stat { text-align:center;padding:12px 8px;position:relative;z-index:1;transition:transform .3s; }
.ws-stat:hover { transform:translateY(-5px); }
.ws-stat+.ws-stat::before { content:'';position:absolute;left:0;top:15%;bottom:15%;width:1px;background:rgba(255,255,255,.15); }
.ws-stat-num { font-size:2.2rem;font-weight:900;line-height:1;font-feature-settings:"tnum"; }
.ws-stat-lbl { font-size:12px;opacity:.7;margin-top:5px; }

/* ── CATEGORY PILLS ── */
.ws-cats { padding:44px 5% 16px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap; }
.ws-cat {
  display:flex;align-items:center;gap:8px;padding:10px 20px;
  border-radius:50px;font-weight:700;font-size:13.5px;
  border:2px solid var(--border);background:#fff;color:var(--text);
  transition:all .3s var(--spring);position:relative;overflow:hidden;
}
.ws-cat::after { content:'';position:absolute;inset:0;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s;z-index:0;border-radius:50px; }
.ws-cat span, .ws-cat i { position:relative;z-index:1; }
.ws-cat:hover, .ws-cat.on { color:#fff;border-color:var(--blue);box-shadow:0 8px 24px var(--blue-g); }
.ws-cat:hover::after, .ws-cat.on::after { transform:scaleX(1); }
.ws-cat:hover { transform:translateY(-3px);background:var(--blue); }
.ws-cat:hover::after { display:none; }
/* Fix: direct text node inside button hidden behind ::after — use solid background instead of pseudo */
.ws-cat.on { background:var(--blue);color:#fff; }
.ws-cat.on::after { display:none; }

/* ── SECTION ── */
.ws-sec { padding:72px 5%; }
.ws-sec.alt { background:var(--light); }
.ws-sec.dark { background:var(--navy);color:#fff; }
.ws-sec.gradient { background:linear-gradient(135deg,#001240 0%,#002060 50%,var(--navy) 100%);color:#fff; }
.ws-sh { text-align:center;margin-bottom:50px; }
.ws-sh h2 { font-family:var(--font-h);font-size:clamp(1.7rem,4.5vw,2.6rem);font-weight:900;color:var(--blue);margin-bottom:10px; }
.ws-sh p  { color:var(--muted);font-size:15px;max-width:560px;margin:0 auto;line-height:1.7; }
.ws-sh::after { content:'';display:block;width:54px;height:3px;background:linear-gradient(90deg,var(--blue),var(--gold));margin:14px auto 0;border-radius:2px; }
.ws-sh.lt h2 { color:var(--gold2); }
.ws-sh.lt p  { color:rgba(255,255,255,.6); }
.ws-sh.lt::after { background:linear-gradient(90deg,var(--gold),var(--blue3)); }
.ws-more { text-align:center;margin-top:40px; }
.ws-btn-ghost { display:inline-flex;align-items:center;gap:8px;border:2px solid var(--blue);color:var(--blue);padding:12px 28px;border-radius:50px;font-weight:700;font-size:14px;transition:all .3s; }
.ws-btn-ghost:hover { background:var(--blue);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px var(--blue-g); }

/* ── HOTEL CARDS ── */
.ws-hotel-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:24px; }
.ws-hc {
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:all .4s var(--spring);position:relative;
}
.ws-hc:hover { transform:translateY(-12px);box-shadow:var(--shadow-xl); }
.ws-hc-img { height:190px;overflow:hidden;position:relative; }
.ws-hc-img img { width:100%;height:100%;object-fit:cover;transition:transform .6s ease; }
.ws-hc:hover .ws-hc-img img { transform:scale(1.1); }
.ws-hc-badge { position:absolute;top:12px;left:12px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;font-size:10px;font-weight:800;padding:4px 11px;border-radius:20px;backdrop-filter:blur(6px); }
.ws-hc-fav  { position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;font-size:14px;transition:transform .2s;box-shadow:0 2px 8px rgba(0,0,0,.15); }
.ws-hc-fav:hover { transform:scale(1.2); }
.ws-hc-body { padding:16px 18px 18px; }
.ws-hc-stars { display:flex;gap:2px;margin-bottom:6px; }
.ws-hc-stars i { color:var(--gold2);font-size:11px; }
.ws-hc-body h3 { font-size:1rem;font-weight:700;margin-bottom:4px; }
.ws-hc-loc { display:flex;align-items:center;gap:5px;color:var(--muted);font-size:12px;margin-bottom:12px; }
.ws-hc-bottom { display:flex;align-items:center;justify-content:space-between; }
.ws-hc-price { font-size:1.15rem;font-weight:900;color:var(--blue); }
.ws-hc-price small { font-size:11px;font-weight:400;color:var(--muted); }
.ws-hc-btn { background:linear-gradient(135deg,var(--sky),#d4f1ec);color:var(--blue);border-radius:20px;padding:7px 15px;font-size:12px;font-weight:800;transition:all .2s; }
.ws-hc-btn:hover { background:var(--blue);color:#fff;box-shadow:0 4px 14px var(--blue-g); }

/* Horizontal hotel slider */
.ws-hscroll { display:flex;gap:22px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch; }
.ws-hscroll::-webkit-scrollbar { height:4px; }
.ws-hscroll::-webkit-scrollbar-track { background:var(--border);border-radius:2px; }
.ws-hscroll::-webkit-scrollbar-thumb { background:var(--blue3);border-radius:2px; }
.ws-hscroll .ws-hc { min-width:260px;scroll-snap-align:start;flex-shrink:0; }

/* ── WHY BAR ── */
.ws-why {
  background:linear-gradient(135deg,var(--navy3),var(--navy2));
  padding:40px 5%;display:flex;flex-wrap:wrap;justify-content:center;
}
.ws-why-item { flex:1;min-width:160px;text-align:center;padding:20px 16px;position:relative;color:#fff;transition:transform .3s; }
.ws-why-item:hover { transform:translateY(-6px); }
.ws-why-item+.ws-why-item::before { content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:rgba(255,255,255,.1); }
.ws-why-ico { width:60px;height:60px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--blue-gl);border:2px solid rgba(0,53,128,.35);transition:all .3s; }
.ws-why-item:hover .ws-why-ico { background:rgba(0,53,128,.35);transform:scale(1.1); }
.ws-why-item h4 { font-size:.9rem;font-weight:800;margin-bottom:5px;color:var(--gold2); }
.ws-why-item p  { font-size:12px;color:rgba(255,255,255,.5);line-height:1.6; }

/* ── FEATURE CARDS ── */
.ws-feat-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px; }
.ws-feat-card {
  border-radius:var(--radius);overflow:hidden;height:220px;
  position:relative;cursor:pointer;box-shadow:var(--shadow);
  transition:all .4s var(--spring);
}
.ws-feat-card:hover { transform:translateY(-10px) scale(1.02);box-shadow:var(--shadow-xl); }
.ws-feat-card img { width:100%;height:100%;object-fit:cover;transition:transform .7s ease;filter:brightness(.7);display:block; }
.ws-feat-card:hover img { transform:scale(1.12);filter:brightness(.55); }
.ws-feat-over { position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:22px;background:linear-gradient(to top,rgba(0,18,64,.9) 0%,transparent 55%); }
.ws-feat-over h3 { font-family:var(--font-h);font-size:1.3rem;font-weight:900;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5); }
.ws-feat-over p  { font-size:12px;color:rgba(255,255,255,.7);margin-top:4px;max-height:0;overflow:hidden;transition:max-height .4s ease; }
.ws-feat-card:hover .ws-feat-over p { max-height:60px; }
.ws-feat-tag { position:absolute;top:14px;right:14px;background:var(--gold);color:#fff;font-size:10px;font-weight:800;padding:4px 12px;border-radius:20px;opacity:0;transform:translateY(-8px);transition:all .3s; }
.ws-feat-card:hover .ws-feat-tag { opacity:1;transform:none; }

/* ── SERVICE LAUNCH CARDS ── */
.ws-launch-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px; }
.ws-launch-card {
  background:#fff;border-radius:var(--radius);padding:26px 20px;
  box-shadow:var(--shadow);transition:all .35s var(--spring);
  text-align:center;position:relative;overflow:hidden;
  border-bottom:3px solid transparent;cursor:pointer;
}
.ws-launch-card::before { content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-gl),transparent);opacity:0;transition:opacity .3s; }
.ws-launch-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-lg);border-bottom-color:var(--blue); }
.ws-launch-card:hover::before { opacity:1; }
.ws-launch-coming { position:absolute;top:12px;right:12px;background:var(--gold);color:#fff;font-size:9px;font-weight:800;padding:2px 8px;border-radius:20px;letter-spacing:.5px; }
.ws-launch-icon { font-size:2.6rem;margin-bottom:12px;display:block;animation:float 3s ease infinite; }
.ws-launch-card h3 { font-size:.95rem;font-weight:800;margin-bottom:5px;position:relative; }
.ws-launch-card p  { font-size:12.5px;color:var(--muted);line-height:1.6;position:relative; }
.ws-launch-btn { margin-top:14px;background:#dce8ff;color:#002060;padding:7px 16px;border-radius:20px;font-size:12px;font-weight:700;transition:all .2s;display:inline-flex;align-items:center;gap:5px;position:relative; }
.ws-launch-card:hover .ws-launch-btn { background:var(--blue);color:#fff; }

/* ── COMMUNITY ── */
.ws-community {
  background:linear-gradient(135deg,var(--blue) 0%,#002878 55%,var(--navy) 100%);
  padding:64px 5%;display:flex;align-items:center;gap:48px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.ws-community::before { content:'';position:absolute;top:-40%;right:-8%;width:440px;height:440px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none; }
.ws-community::after  { content:'';position:absolute;bottom:-30%;left:-5%;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.03);pointer-events:none; }
.ws-comm-left { flex:1;min-width:240px;color:#fff; }
.ws-comm-left h2 { font-family:var(--font-h);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;margin-bottom:14px; }
.ws-comm-left p { font-size:15px;opacity:.82;line-height:1.8;max-width:460px;margin-bottom:24px; }
.ws-comm-right { flex-shrink:0; }
.ws-comm-card {
  background:#fff;border-radius:var(--radius);padding:22px 24px;
  box-shadow:0 24px 70px rgba(0,0,0,.35);min-width:260px;max-width:100%;
  animation:float 5s ease infinite;
}
.ws-comm-card h4 { font-size:14px;font-weight:800;color:var(--blue);margin-bottom:12px; }
.ws-comm-avs { display:flex;gap:3px;margin-bottom:12px; }
.ws-comm-av { width:34px;height:34px;border-radius:50%;background:#003580;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 2px 6px rgba(0,0,0,.1); }
.ws-comm-tags { display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px; }
.ws-comm-tag { background:#dce8ff;color:#002060;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px; }
.ws-comm-meta { display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-bottom:14px; }
.ws-comm-join { width:100%;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;border-radius:50px;padding:11px;font-weight:800;font-size:13px;transition:all .3s; }
.ws-comm-join:hover { transform:translateY(-2px);box-shadow:0 6px 20px var(--blue-g); }

/* ── DESTINATION CARDS ── */
.ws-dest-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px; }
.ws-dest-card {
  border-radius:var(--radius);overflow:hidden;height:220px;
  position:relative;cursor:pointer;box-shadow:var(--shadow);
  transition:all .4s var(--spring);
}
.ws-dest-card:hover { transform:translateY(-10px);box-shadow:var(--shadow-xl); }
.ws-dest-card img { width:100%;height:100%;object-fit:cover;transition:transform .6s;filter:brightness(.75); }
.ws-dest-card:hover img { transform:scale(1.12);filter:brightness(.6); }
.ws-dest-info { position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px;background:linear-gradient(to top,rgba(0,18,64,.9) 0%,transparent 50%); }
.ws-dest-name  { font-family:var(--font-h);font-size:1rem;font-weight:700;color:#fff;margin-bottom:3px; }
.ws-dest-price { font-size:11.5px;color:var(--gold2);font-weight:700; }
.ws-dest-fav { position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;font-size:13px;transition:transform .2s;box-shadow:0 2px 8px rgba(0,0,0,.15); }
.ws-dest-fav:hover { transform:scale(1.2); }

/* ── TOUR CARDS ── */
.ws-tour-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px; }
.ws-tc {
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:all .4s var(--spring);display:flex;flex-direction:column;
}
.ws-tc:hover { transform:translateY(-10px);box-shadow:var(--shadow-xl); }
.ws-tc-img { height:200px;overflow:hidden;position:relative; }
.ws-tc-img img { width:100%;height:100%;object-fit:cover;transition:transform .6s; }
.ws-tc:hover .ws-tc-img img { transform:scale(1.08); }
.ws-tc-cat    { position:absolute;top:12px;left:12px;background:rgba(0,53,128,.9);backdrop-filter:blur(6px);color:#fff;font-size:10px;font-weight:800;padding:4px 11px;border-radius:20px; }
.ws-tc-rating { position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);color:var(--gold2);font-size:11px;font-weight:800;padding:4px 9px;border-radius:20px;display:flex;align-items:center;gap:4px; }
.ws-tc-body { padding:18px;flex:1;display:flex;flex-direction:column; }
.ws-tc-body h3 { font-size:1rem;font-weight:800;margin-bottom:8px; }
.ws-tc-meta { display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px; }
.ws-tc-meta span { font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px; }
.ws-tc-incs { display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px; }
.ws-tc-inc { background:#dce8ff;color:#002060;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:12px; }
.ws-tc-foot { display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;border-top:1px solid var(--border); }
.ws-tc-price { font-size:1.25rem;font-weight:900;color:var(--blue); }
.ws-tc-price small { font-size:10.5px;color:var(--muted);font-weight:400; }
.ws-tc-book { background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;padding:9px 18px;border-radius:22px;font-size:12.5px;font-weight:800;transition:all .2s; }
.ws-tc-book:hover { transform:scale(1.06);box-shadow:0 4px 16px var(--blue-g); }

/* ── ACTIVITIES GRID ── */
.ws-act-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px; }
.ws-act-card {
  background:#fff;border-radius:var(--radius);padding:24px 18px;
  box-shadow:var(--shadow);transition:all .35s var(--spring);
  text-align:center;border-bottom:3px solid transparent;
}
.ws-act-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-lg);border-bottom-color:var(--blue); }
.ws-act-card .a-icon { font-size:2.4rem;margin-bottom:10px;animation:float 3.5s ease infinite; }
.ws-act-card h3 { font-size:.9rem;font-weight:800;margin-bottom:4px; }
.ws-act-card .a-place { font-size:11.5px;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:6px; }
.ws-act-card .a-price { font-size:1rem;font-weight:900;color:var(--blue);margin-bottom:8px; }
.ws-act-card .a-desc { font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:12px; }
.ws-act-card .a-btn { background:#dce8ff;color:#002060;padding:7px 16px;border-radius:20px;font-size:12px;font-weight:700;transition:all .2s;display:inline-flex;align-items:center;gap:5px; }
.ws-act-card:hover .a-btn { background:var(--blue);color:#fff; }

/* ── TESTIMONIALS ── */
.ws-testi-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px; }
.ws-testi-card {
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius);padding:26px;transition:all .3s;
  position:relative;overflow:hidden;
}
.ws-testi-card::before { content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--gold));opacity:0;transition:opacity .3s; }
.ws-testi-card:hover { background:rgba(255,255,255,.1);transform:translateY(-5px); }
.ws-testi-card:hover::before { opacity:1; }
.ws-testi-q { font-size:2.8rem;color:var(--blue);opacity:.35;line-height:1;margin-bottom:10px;font-family:Georgia; }
.ws-testi-txt { color:rgba(255,255,255,.76);font-size:14px;line-height:1.85;margin-bottom:18px; }
.ws-testi-auth { display:flex;align-items:center;gap:12px; }
.ws-testi-av { width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue2));display:flex;align-items:center;justify-content:center;font-size:1.2rem;border:2px solid rgba(255,255,255,.15);flex-shrink:0; }
.ws-testi-name { font-weight:700;color:#fff;font-size:14px; }
.ws-testi-role { font-size:11px;color:rgba(255,255,255,.4);margin-top:2px; }
.ws-testi-stars { display:flex;gap:2px;margin-top:4px; }
.ws-testi-stars i { color:var(--gold2);font-size:11px; }

/* ── BLOG ── */
.ws-blog-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px; }
.ws-bc {
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:all .4s var(--spring);
}
.ws-bc:hover { transform:translateY(-9px);box-shadow:var(--shadow-xl); }
.ws-bc-img { height:195px;overflow:hidden;position:relative; }
.ws-bc-img img { width:100%;height:100%;object-fit:cover;transition:transform .6s; }
.ws-bc:hover .ws-bc-img img { transform:scale(1.08); }
.ws-bc-cat { position:absolute;top:12px;left:12px;background:var(--blue);color:#fff;font-size:10px;font-weight:800;padding:4px 11px;border-radius:20px; }
.ws-bc-body { padding:18px; }
.ws-bc-date { font-size:11.5px;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:5px; }
.ws-bc-body h3 { font-size:.95rem;font-weight:800;margin-bottom:7px;line-height:1.45; }
.ws-bc-body p  { font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:12px; }
.ws-bc-read { display:flex;align-items:center;gap:5px;color:var(--blue);font-size:13px;font-weight:700;transition:gap .2s; }
.ws-bc:hover .ws-bc-read { gap:9px; }

/* ── APP SECTION ── */
.ws-app {
  background:linear-gradient(135deg,#001240 0%,#003580 50%,var(--navy) 100%);
  padding:72px 5%;display:flex;align-items:center;gap:56px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.ws-app::before { content:'';position:absolute;top:-30%;right:-10%;width:500px;height:500px;border-radius:50%;background:rgba(0,53,128,.08);pointer-events:none; }
.ws-app-text { flex:1;min-width:240px;color:#fff; }
.ws-app-text h2 { font-family:var(--font-h);font-size:clamp(1.7rem,4vw,2.6rem);font-weight:900;margin-bottom:14px; }
.ws-app-text p { opacity:.8;font-size:15px;line-height:1.85;max-width:460px;margin-bottom:28px; }
.ws-app-btns { display:flex;gap:12px;flex-wrap:wrap; }
.ws-app-btn {
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(10px);color:#fff;padding:12px 20px;border-radius:16px;
  transition:all .3s;
}
.ws-app-btn:hover { background:rgba(255,255,255,.22);transform:translateY(-3px);color:#fff;box-shadow:0 8px 28px rgba(0,0,0,.3); }
.ws-app-btn i { font-size:1.8rem; }
.ws-app-btn .sl { font-size:9.5px;opacity:.65; }
.ws-app-btn .sn { font-weight:800;font-size:14px; }
.ws-app-visual { flex-shrink:0;text-align:center;position:relative; }
.ws-phone {
  width:200px;background:rgba(255,255,255,.07);border:2px solid rgba(255,255,255,.12);
  border-radius:32px;padding:12px;margin:0 auto;
  box-shadow:0 36px 80px rgba(0,0,0,.4);
  animation:float 5s ease infinite;
}
.ws-phone img { border-radius:22px;width:100%; }
.ws-phone-glow { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(0,53,128,.25),transparent 70%);pointer-events:none; }

/* ── FOOTER ── */
.ws-footer { background:var(--navy3);color:rgba(255,255,255,.6);padding:56px 5% 22px; }
.ws-footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px; }
@media(max-width:900px){ .ws-footer-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .ws-footer-grid { grid-template-columns:1fr; } }
.ws-fb-name { font-family:var(--font-h);font-size:1.5rem;color:#fff;font-weight:900;margin-bottom:10px; }
.ws-fb p { font-size:13.5px;line-height:1.8;max-width:280px;margin-bottom:18px; }
.ws-fb-socs { display:flex;gap:8px; }
.ws-fsoc { width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s; }
.ws-fsoc:hover { background:var(--blue);color:#fff;transform:scale(1.1);border-color:var(--blue); }
.ws-fc h4 { color:#fff;font-weight:800;font-size:12px;letter-spacing:.6px;text-transform:uppercase;margin-bottom:16px; }
.ws-fc ul { display:flex;flex-direction:column;gap:9px; }
.ws-fc ul li a { color:rgba(255,255,255,.52);font-size:13.5px;transition:color .2s;display:flex;align-items:center;gap:6px; }
.ws-fc ul li a:hover { color:var(--gold2); }
.ws-f-btm { border-top:1px solid rgba(255,255,255,.07);padding-top:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px; }
.ws-f-btm p { font-size:12px; }
.ws-f-links { display:flex;gap:16px; }
.ws-f-links a { font-size:12px;color:rgba(255,255,255,.38);transition:color .2s; }
.ws-f-links a:hover { color:var(--gold2); }

/* ── PAGE HERO ── */
.ws-page-hero {
  background:linear-gradient(135deg,var(--navy3) 0%,#002060 100%);
  padding:110px 5% 60px;color:#fff;text-align:center;position:relative;overflow:hidden;
}
.ws-page-hero::before { content:'';position:absolute;inset:0;opacity:.15;background:url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e?w=1400&q=80') center/cover no-repeat; }
.ws-page-hero .inner { position:relative;z-index:1;animation:fadeUp .7s ease both; }
.ws-page-hero h1 { font-family:var(--font-h);font-size:clamp(2rem,5vw,3.4rem);font-weight:900;margin-bottom:12px; }
.ws-page-hero p  { color:rgba(255,255,255,.75);font-size:15px;max-width:520px;margin:0 auto 20px; }
.ws-breadcrumb { display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:rgba(255,255,255,.5); }
.ws-breadcrumb a { color:var(--blue3);font-weight:600;transition:color .2s; }
.ws-breadcrumb a:hover { color:#fff; }

/* ── FORMS ── */
.ws-input {
  width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:12px 15px;font-size:14px;background:#fff;color:var(--text);
  transition:border .2s,box-shadow .2s;
}
.ws-input:focus { border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,53,128,.1); }
.ws-input::placeholder { color:#b0c4cc; }
.ws-form-btn {
  background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;
  border-radius:50px;padding:14px;font-weight:800;font-size:14px;
  transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;
}
.ws-form-btn:hover { transform:translateY(-2px);box-shadow:0 8px 28px var(--blue-g); }

/* ── PWA BANNER ── */
.ws-pwa {
  position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
  background:#fff;border-radius:16px;
  box-shadow:0 12px 48px rgba(0,0,0,.2),0 0 0 1px rgba(0,53,128,.12);
  padding:15px 22px;display:none;align-items:center;gap:14px;
  z-index:9100;max-width:380px;width:92%;
  animation:slideUp .4s ease both;
}
.ws-pwa.show { display:flex; }
.ws-pwa-ico { font-size:2rem;flex-shrink:0; }
.ws-pwa h4 { font-size:13.5px;font-weight:800;color:var(--text); }
.ws-pwa p  { font-size:12px;color:var(--muted);margin-top:2px; }
.ws-pwa-btns { display:flex;gap:7px;flex-shrink:0; }
.ws-pwa-install { background:var(--blue);color:#fff;border-radius:20px;padding:8px 16px;font-size:12px;font-weight:800;transition:background .2s; }
.ws-pwa-install:hover { background:var(--blue2); }
.ws-pwa-dismiss { background:#dce8ff;color:#002060;border-radius:20px;padding:8px 12px;font-size:12px;font-weight:700; }

/* ── BACK TO TOP ── */
.ws-top {
  position:fixed;bottom:24px;right:24px;width:46px;height:46px;
  border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;font-size:18px;display:none;align-items:center;justify-content:center;
  box-shadow:0 4px 20px var(--blue-g);transition:all .3s;z-index:9000;
}
.ws-top.show { display:flex; }
.ws-top:hover { transform:translateY(-4px);box-shadow:0 10px 30px var(--blue-g); }

/* ── BOOKING MODAL ── */
.ws-modal-wrap {
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(5,18,28,.85);backdrop-filter:blur(12px);
  align-items:center;justify-content:center;padding:20px;
}
.ws-modal-wrap.open { display:flex; }
.ws-modal {
  background:#fff;border-radius:var(--radius);
  max-width:500px;width:100%;position:relative;
  max-height:92vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  animation:zoomIn .3s ease both;
}
.ws-modal-hdr {
  background:linear-gradient(135deg,var(--navy3),#002060);
  padding:22px 24px;color:#fff;border-radius:var(--radius) var(--radius) 0 0;
  position:relative;
}
.ws-modal-hdr h3 { font-family:var(--font-h);font-size:1.3rem;margin-bottom:3px; }
.ws-modal-hdr p  { font-size:13px;opacity:.7; }
.ws-modal-close {
  position:absolute;top:14px;right:14px;width:34px;height:34px;
  border-radius:50%;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);color:#fff;font-size:16px;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.ws-modal-close:hover { background:rgba(255,255,255,.2);transform:rotate(90deg); }
.ws-modal-body { padding:24px;display:flex;flex-direction:column;gap:12px; }

/* ── CONTACT ── */
.ws-contact-grid { display:grid;grid-template-columns:1fr 1.5fr;gap:40px;max-width:920px;margin:0 auto; }
@media(max-width:767px){ .ws-contact-grid { grid-template-columns:1fr; } }
.ws-ci { display:flex;flex-direction:column;gap:14px; }
.ws-ci-item { display:flex;align-items:center;gap:14px;background:#fff;border-radius:14px;padding:18px;box-shadow:var(--shadow); }
.ws-ci-ico { width:46px;height:46px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0; }
.ws-ci-item h4 { font-weight:800;font-size:13px;color:var(--blue); }
.ws-ci-item p  { font-size:13.5px;color:var(--muted);margin-top:2px; }

/* ── UTILITY ── */
.tag-t { background:var(--sky);color:var(--blue);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px; }
.tag-g { background:rgba(240,165,0,.12);color:var(--gold);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px; }
.tag-n { background:rgba(13,27,42,.1);color:var(--navy);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px; }
.flex-center { display:flex;align-items:center;justify-content:center; }
.gap-2 { gap:8px; } .gap-3 { gap:12px; }

/* ── FIX 1: Responsive 2-column grid — replaces JS fixLayouts() hacks ── */
.ws-2col {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:38px;
  align-items:center;
}
.ws-2col-inner {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
@media(max-width:767px){
  .ws-2col        { grid-template-columns:1fr !important; gap:24px; }
  .ws-2col-inner  { grid-template-columns:1fr 1fr; }
}
/* Fix 6: 2col-inner also collapses on very small phones */
@media(max-width:480px){
  .ws-2col-inner  { grid-template-columns:1fr; }
}

/* ── FIX 2: Minimum 44×44px touch targets ── */
.ws-pay-method {
  min-height:44px;
  padding:10px 14px;
}
.ws-cat {
  min-height:44px;
  padding:10px 20px;
}
.ws-weather-month {
  min-height:64px;
  padding:10px 6px;
}
.ws-faq-q {
  min-height:52px;
}
.ws-mob-tile {
  min-height:72px;
}

/* ── FIX 3: Search button overflow on 360px phones ── */
@media(max-width:400px){
  .ws-search-go {
    font-size:13px;
    padding:11px 14px;
    gap:6px;
  }
  .ws-si-wrap { padding:12px 14px; }
}

/* ── FIX 6: Date inputs — prevent iOS auto-zoom + style consistency ── */
.ws-si-inp[type="date"],
.ws-input[type="date"] {
  font-size:16px !important;
  color:var(--text);
  min-height:44px;
  -webkit-appearance:none;
  appearance:none;
}
@media(max-width:767px){
  .ws-si-inp[type="date"],
  .ws-input[type="date"] {
    padding:10px 4px;
  }
}
/* Prevent iOS zoom on ALL inputs — must be 16px minimum */
@media(max-width:767px){
  .ws-si-inp,
  .ws-input,
  .ws-filter-select,
  .ws-nl-input,
  select {
    font-size:16px !important;
  }
}



/* ── RESPONSIVE ── */
@media(max-width:767px){
  .ws-sec { padding:52px 4%; }
  .ws-hero-body { padding:131px 4% 60px; } /* 100px + 31px topbar */
  .ws-search-outer { padding:0 4%; }
  .ws-cats { padding:38px 4% 10px; }
  .ws-community { padding:48px 4%; }
  .ws-app { padding:52px 4%; }
  .ws-footer { padding:44px 4% 18px; }
  /* Fix 5: hide phone mockup on mobile — saves space, prevents overlap */
  .ws-app-visual { display:none; }
  /* Fix 4: comm-card full width on small screens */
  .ws-comm-card { min-width:unset;width:100%; }
  .ws-comm-right { width:100%; }
}

/* ══════════════════════════════════════════════════
   WINSOME v4 — NEW FEATURES STYLES
   WhatsApp · Weather · Filters · Guides · FAQ · Safety
   Payment · Trust · Live Chat · Sticky CTA · Dark Mode
══════════════════════════════════════════════════ */

/* ── WHATSAPP FLOAT BUTTON — always visible on all screens (Fix 7) ── */
.ws-wa-float {
  position:fixed;bottom:90px;right:24px;z-index:8999;
  width:54px;height:54px;border-radius:50%;
  background:#25d366;color:#fff;font-size:26px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  transition:all .3s;text-decoration:none;
  animation:pulse 2.5s ease infinite;
}
.ws-wa-float:hover { transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.6); color:#fff; }
.ws-wa-tooltip {
  position:absolute;right:64px;top:50%;transform:translateY(-50%);
  background:var(--navy);color:#fff;font-size:12px;font-weight:700;
  padding:6px 12px;border-radius:20px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.ws-wa-float:hover .ws-wa-tooltip { opacity:1; }
/* On desktop: reposition WA float — no sticky bar to avoid */
@media(min-width:768px){
  .ws-wa-float { bottom:28px; right:28px; width:60px; height:60px; font-size:30px; }
}

/* ── STICKY MOBILE CTA ── */
.ws-sticky-cta {
  position:fixed;bottom:0;left:0;right:0;z-index:8998;
  background:#fff;border-top:1px solid var(--border);
  padding:10px 16px;
  display:none;align-items:center;gap:10px;
  box-shadow:0 -4px 20px rgba(0,0,0,.1);
}
.ws-sticky-cta.show { display:flex; }
/* FIX 7: Sticky bar stays mobile-only. WA float button covers desktop. */
@media(min-width:768px){ .ws-sticky-cta { display:none!important; } }

/* ── STICKY MOBILE CTA ── */
.ws-sticky-cta {
  position:fixed;bottom:0;left:0;right:0;z-index:8998;
  background:#fff;border-top:1px solid var(--border);
  padding:10px 16px;
  display:none;align-items:center;gap:10px;
  box-shadow:0 -4px 20px rgba(0,0,0,.1);
}
.ws-sticky-cta.show { display:flex; }
@media(min-width:768px){ .ws-sticky-cta { display:none!important; } }
.ws-sticky-price { flex:1; }
.ws-sticky-price .from { font-size:11px;color:var(--muted); }
.ws-sticky-price .amt  { font-size:1.1rem;font-weight:900;color:var(--blue); }
.ws-sticky-book {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:50px;padding:12px 24px;
  font-weight:800;font-size:14px;white-space:nowrap;
  flex-shrink:0;transition:all .2s;
}
.ws-sticky-book:hover { transform:scale(1.04); }
.ws-sticky-wa {
  background:#25d366;color:#fff;border-radius:50px;
  padding:12px 18px;font-size:18px;flex-shrink:0;
  transition:all .2s;
}

/* ── WEATHER CALENDAR ── */
.ws-weather-grid {
  display:grid;grid-template-columns:repeat(6,1fr);gap:8px;
}
@media(max-width:600px){ .ws-weather-grid { grid-template-columns:repeat(4,1fr); } }
@media(max-width:400px){ .ws-weather-grid { grid-template-columns:repeat(2,1fr); } } /* Fix 7: very small phones */
.ws-weather-month {
  border-radius:var(--radius-sm);padding:10px 6px;text-align:center;
  border:1.5px solid var(--border);transition:all .2s;cursor:pointer;
}
.ws-weather-month.perfect { background:rgba(0,53,128,.08);border-color:var(--blue); }
.ws-weather-month.good    { background:rgba(240,165,0,.08);border-color:var(--gold2); }
.ws-weather-month.avoid   { background:rgba(220,53,69,.06);border-color:rgba(220,53,69,.3); }
.ws-weather-month:hover   { transform:translateY(-3px);box-shadow:var(--shadow); }
.ws-wm-ico  { font-size:1.3rem;margin-bottom:4px; }
.ws-wm-name { font-size:11px;font-weight:700;color:var(--text); }
.ws-wm-temp { font-size:10px;color:var(--muted);margin-top:2px; }
.ws-wm-badge{font-size:9px;font-weight:800;padding:1px 6px;border-radius:10px;margin-top:3px;display:inline-block;}
.ws-wm-badge.perfect { background:var(--blue);color:#fff; }
.ws-wm-badge.good    { background:var(--gold2);color:#fff; }
.ws-wm-badge.avoid   { background:rgba(220,53,69,.15);color:#dc3545; }
.weather-legend { display:flex;gap:14px;flex-wrap:wrap;margin-bottom:16px;font-size:12px; }
.weather-legend span { display:flex;align-items:center;gap:5px; }
.wl-dot { width:10px;height:10px;border-radius:50%; }

/* ── PRICE FILTER & SEARCH FILTERS ── */
.ws-filter-bar {
  background:#fff;border-bottom:1px solid var(--border);
  padding:14px 5%;display:flex;gap:10px;flex-wrap:wrap;align-items:center;
  position:sticky;top:95px;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.ws-filter-group { display:flex;align-items:center;gap:8px; }
.ws-filter-group label { font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap; }
.ws-filter-select {
  border:1.5px solid var(--border);border-radius:20px;
  padding:7px 14px;font-size:13px;font-weight:600;
  color:var(--text);background:#fff;cursor:pointer;
  transition:border .2s;
}
.ws-filter-select:focus { border-color:var(--blue);outline:none; }
.ws-price-range { display:flex;align-items:center;gap:8px; }
.ws-price-range input[type=range] { width:120px;accent-color:var(--blue); }
.ws-price-val { font-size:12px;font-weight:700;color:var(--blue);white-space:nowrap; }
.ws-filter-clear { font-size:12px;font-weight:700;color:var(--muted);cursor:pointer;transition:color .2s; }
.ws-filter-clear:hover { color:var(--blue); }
.ws-results-count { font-size:13px;color:var(--muted);font-weight:600;margin-bottom:16px; }

/* ── GUIDE CARDS ── */
.ws-guide-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px; }
.ws-guide-card {
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);transition:all .4s var(--spring);text-align:center;
}
.ws-guide-card:hover { transform:translateY(-8px);box-shadow:var(--shadow-lg); }
.ws-guide-img-wrap { position:relative;height:180px;overflow:hidden; }
.ws-guide-img-wrap img { width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s; }
.ws-guide-card:hover .ws-guide-img-wrap img { transform:scale(1.06); }
.ws-guide-cert {
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  background:rgba(0,53,128,.9);backdrop-filter:blur(6px);
  color:#fff;font-size:9px;font-weight:800;padding:3px 10px;border-radius:20px;
  white-space:nowrap;
}
.ws-guide-body { padding:14px 16px 16px; }
.ws-guide-body h3 { font-size:.95rem;font-weight:800;margin-bottom:2px; }
.ws-guide-spec { font-size:12px;color:var(--blue);font-weight:700;margin-bottom:6px; }
.ws-guide-langs { display:flex;gap:4px;justify-content:center;flex-wrap:wrap;margin-bottom:8px; }
.ws-guide-lang { background:var(--sky);color:var(--blue);font-size:10px;font-weight:700;padding:2px 8px;border-radius:12px; }
.ws-guide-meta { display:flex;justify-content:center;gap:14px;font-size:11.5px;color:var(--muted);margin-bottom:10px; }
.ws-guide-meta strong { color:var(--text); }
.ws-guide-stars { display:flex;justify-content:center;gap:2px;margin-bottom:10px; }
.ws-guide-stars i { color:var(--gold2);font-size:11px; }
.ws-guide-book {
  width:100%;background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:50px;padding:9px;font-weight:700;font-size:12.5px;
  transition:all .2s;
}
.ws-guide-book:hover { transform:scale(1.04); }

/* ── TRUST BADGES ── */
.ws-trust-bar {
  background:var(--sky2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:18px 5%;display:flex;align-items:center;justify-content:center;
  gap:32px;flex-wrap:wrap;
}
.ws-trust-item { display:flex;align-items:center;gap:8px;font-size:13px; }
.ws-trust-item .t-ico { font-size:1.3rem; }
.ws-trust-item .t-label { font-weight:800;color:var(--text);font-size:13px; }
.ws-trust-item .t-sub { font-size:11px;color:var(--muted);margin-top:1px; }

/* ── PAYMENT SECTION ── */
.ws-payment-methods {
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;
  padding:18px 22px;background:var(--sky2);border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
}
.ws-pay-method {
  display:flex;align-items:center;gap:6px;background:#fff;
  border:1.5px solid var(--border);border-radius:10px;padding:7px 14px;
  font-size:13px;font-weight:700;color:var(--text);transition:all .2s;cursor:pointer;
}
.ws-pay-method:hover { border-color:var(--blue);box-shadow:0 2px 10px var(--blue-gl); }
.ws-pay-method .pm-ico { font-size:1.2rem; }
.ws-pay-bkash  { border-color:rgba(220,0,115,.3); }
.ws-pay-nagad  { border-color:rgba(255,100,0,.3); }
.ws-pay-card   { border-color:rgba(0,53,128,.3); }

/* ── FAQ ACCORDION ── */
.ws-faq-list { display:flex;flex-direction:column;gap:8px; }
.ws-faq-item {
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  overflow:hidden;transition:border-color .2s;
}
.ws-faq-item.open { border-color:var(--blue); }
.ws-faq-q {
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;cursor:pointer;font-size:14.5px;font-weight:700;
  color:var(--text);background:#fff;transition:background .2s;user-select:none;
  gap:12px;
}
.ws-faq-q:hover { background:var(--sky2); }
.ws-faq-item.open .ws-faq-q { background:var(--sky);color:var(--blue); }
.ws-faq-caret { font-size:12px;opacity:.5;transition:transform .3s;flex-shrink:0; }
.ws-faq-item.open .ws-faq-caret { transform:rotate(180deg);opacity:1; }
.ws-faq-a {
  max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;
  padding:0 20px;font-size:14px;color:var(--muted);line-height:1.75;background:#fff;
}
.ws-faq-item.open .ws-faq-a { max-height:200px;padding:12px 20px 18px; }

/* ── SAFETY PAGE ── */
.ws-safety-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px; }
.ws-safety-card {
  background:#fff;border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);border-top:3px solid var(--blue);
}
.ws-safety-card.red  { border-top-color:#dc3545; }
.ws-safety-card.gold { border-top-color:var(--gold2); }
.ws-safety-card h3 { font-size:1rem;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:8px; }
.ws-safety-card ul { list-style:none;display:flex;flex-direction:column;gap:7px; }
.ws-safety-card ul li { font-size:13.5px;color:var(--muted);display:flex;align-items:flex-start;gap:8px; }
.ws-safety-card ul li::before { content:"•";color:var(--blue);font-weight:900;flex-shrink:0; }
.ws-emergency-num { font-size:1.1rem;font-weight:900;color:var(--blue); }

/* ── VISA INFO ── */
.ws-visa-countries { display:flex;flex-wrap:wrap;gap:7px; }
.ws-visa-country {
  background:rgba(0,53,128,.1);color:var(--blue);
  font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px;
}
.ws-visa-steps { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:20px; }
.ws-visa-step {
  background:#fff;border-radius:var(--radius-sm);padding:18px;
  box-shadow:var(--shadow);text-align:center;
  border-top:3px solid var(--blue);
}
.ws-visa-step .step-num { width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;font-weight:900;font-size:15px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px; }
.ws-visa-step h4 { font-size:.9rem;font-weight:800;margin-bottom:5px; }
.ws-visa-step p { font-size:12px;color:var(--muted);line-height:1.6; }

/* ── ITINERARY TIMELINE ── */
.ws-itinerary { display:flex;flex-direction:column;gap:0; }
.ws-itin-day {
  display:flex;gap:16px;position:relative;padding-bottom:20px;
}
.ws-itin-day:last-child { padding-bottom:0; }
.ws-itin-left { display:flex;flex-direction:column;align-items:center;flex-shrink:0; }
.ws-itin-circle { width:36px;height:36px;border-radius:50%;background:var(--blue);color:#fff;font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.ws-itin-line { width:2px;background:var(--border);flex:1;margin-top:4px; }
.ws-itin-day:last-child .ws-itin-line { display:none; }
.ws-itin-content { background:var(--sky2);border-radius:var(--radius-sm);padding:12px 16px;flex:1; }
.ws-itin-content h4 { font-size:.9rem;font-weight:800;color:var(--blue);margin-bottom:4px; }
.ws-itin-content p  { font-size:13px;color:var(--muted);line-height:1.65; }

/* ── SCARCITY/SOCIAL PROOF BADGES ── */
.ws-spots-badge {
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(220,53,69,.1);color:#dc3545;
  font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;
  animation:pulse 2s ease infinite;
}
.ws-viewed-badge {
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(240,165,0,.12);color:var(--gold);
  font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;
}
.ws-sale-badge {
  position:absolute;top:12px;right:48px;
  background:#dc3545;color:#fff;font-size:10px;font-weight:800;
  padding:3px 9px;border-radius:20px;
}

/* ── PROGRESS STEPS ── */
.ws-progress-steps {
  display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px;
}
.ws-ps { display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;max-width:120px; }
.ws-ps-circle {
  width:32px;height:32px;border-radius:50%;border:2px solid var(--border);
  background:#fff;display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:var(--muted);transition:all .3s;
}
.ws-ps.active .ws-ps-circle { background:var(--blue);border-color:var(--blue);color:#fff; }
.ws-ps.done   .ws-ps-circle { background:var(--blue);border-color:var(--blue);color:#fff; }
.ws-ps-label { font-size:10px;color:var(--muted);font-weight:600;text-align:center; }
.ws-ps.active .ws-ps-label { color:var(--blue);font-weight:800; }
.ws-ps-line { flex:1;height:2px;background:var(--border);margin-bottom:16px; }
.ws-ps-line.done { background:var(--blue); }

/* ── LIVE CHAT WIDGET ── */
.ws-chat-widget {
  position:fixed;bottom:24px;left:24px;z-index:8997;
  display:flex;flex-direction:column;gap:0;
}
.ws-chat-bubble {
  background:var(--navy);color:#fff;border-radius:16px 16px 16px 4px;
  padding:12px 16px;max-width:240px;font-size:13px;line-height:1.5;
  box-shadow:var(--shadow-md);animation:fadeUp .5s ease both;
  margin-bottom:8px;display:none;position:relative;
}
.ws-chat-bubble.show { display:block; }
.ws-chat-bubble::after { content:'';position:absolute;bottom:-8px;left:12px;border:8px solid transparent;border-top-color:var(--navy);border-bottom:0; }
.ws-chat-open {
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);transition:all .3s;cursor:pointer;
  border:none;
}
.ws-chat-open:hover { transform:scale(1.1); }

/* ── NEWSLETTER BAR ── */
.ws-newsletter {
  background:linear-gradient(135deg,var(--navy3) 0%,#002060 100%);
  padding:48px 5%;text-align:center;color:#fff;
}
.ws-newsletter h2 { font-family:var(--font-h);font-size:clamp(1.4rem,3.5vw,2rem);font-weight:900;margin-bottom:8px; }
.ws-newsletter p  { color:rgba(255,255,255,.65);font-size:14.5px;margin-bottom:24px; }
.ws-nl-form { display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap; }
.ws-nl-input {
  flex:1;min-width:200px;border:1.5px solid rgba(255,255,255,.2);
  border-radius:50px;padding:12px 20px;font-size:14px;
  background:rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(10px);
  font-family:var(--font-b);transition:border .2s;
}
.ws-nl-input::placeholder { color:rgba(255,255,255,.45); }
.ws-nl-input:focus { border-color:var(--blue3);outline:none; }
.ws-nl-btn {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:50px;padding:12px 28px;font-weight:800;font-size:14px;
  transition:all .3s;border:none;cursor:pointer;white-space:nowrap;
}
.ws-nl-btn:hover { transform:translateY(-2px);box-shadow:0 6px 20px var(--blue-g); }
.ws-nl-privacy { font-size:11px;color:rgba(255,255,255,.35);margin-top:10px; }

/* ── COMPARISON BAR ── */
.ws-compare-bar {
  position:fixed;bottom:0;left:0;right:0;z-index:8996;
  background:var(--navy);color:#fff;padding:12px 5%;
  display:none;align-items:center;gap:12px;flex-wrap:wrap;
  box-shadow:0 -4px 24px rgba(0,0,0,.3);
  transform:translateY(100%);transition:transform .35s ease;
}
.ws-compare-bar.show { display:flex;transform:none; }
.ws-compare-items { display:flex;gap:8px;flex:1;flex-wrap:wrap; }
.ws-compare-item {
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:10px;padding:6px 12px;font-size:12px;font-weight:600;
  display:flex;align-items:center;gap:6px;
}
.ws-compare-item .rm { cursor:pointer;opacity:.6;font-size:14px; }
.ws-compare-btn { background:var(--blue);color:#fff;border-radius:20px;padding:8px 18px;font-size:13px;font-weight:800;border:none;cursor:pointer;white-space:nowrap; }
.ws-compare-clear { color:rgba(255,255,255,.5);font-size:12px;cursor:pointer; }

/* ── RECENTLY VIEWED ── */
.ws-recent-bar { padding:0 5% 40px; }
.ws-recent-label { font-size:13px;font-weight:800;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:14px; }
.ws-recent-scroll { display:flex;gap:14px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x mandatory; }
.ws-recent-scroll::-webkit-scrollbar { height:3px; }
.ws-recent-scroll::-webkit-scrollbar-thumb { background:var(--blue3);border-radius:2px; }
.ws-recent-card {
  flex-shrink:0;width:150px;scroll-snap-align:start;
  border-radius:var(--radius-sm);overflow:hidden;
  box-shadow:var(--shadow);cursor:pointer;transition:transform .2s;
}
.ws-recent-card:hover { transform:translateY(-4px); }
.ws-recent-card img { width:100%;height:90px;object-fit:cover; }
.ws-recent-card-body { padding:8px 10px;background:#fff; }
.ws-recent-card-body .name  { font-size:12px;font-weight:700;color:var(--text); }
.ws-recent-card-body .price { font-size:11px;color:var(--blue);font-weight:700; }

/* ── DARK MODE ── */
@media(prefers-color-scheme:dark){
  :root {
    --text:#e8eef8; --muted:#8fa8c8; --light:#0a1428;
    --sky:#0d1a30; --sky2:#0a1224; --border:#1a2d50;
    --white:#001240; --navy:#060d20; --navy2:#001240;
  }
  body,.ws-sec,.ws-hc,.ws-tc,.ws-bc,.ws-act-card,.ws-launch-card,.ws-guide-card,.ws-faq-q,.ws-faq-a,.ws-safety-card,.ws-visa-step,.ws-comm-card,.ws-ci-item,.ws-contact-form,.ws-itin-content,.ws-recent-card,.ws-recent-card-body,.ws-payment-methods,.ws-pay-method,.ws-trust-bar {
    background:var(--navy)!important;
    color:var(--text)!important;
  }
  .ws-hdr.solid { background:rgba(0,10,40,.97)!important; }
  .ws-sec.alt,.ws-trust-bar,.ws-nl-form .ws-nl-input { background:var(--light)!important; }
  .ws-sec-head h2,.ws-sh h2 { color:var(--blue3)!important; }
  .ws-input { background:var(--navy2)!important;border-color:var(--border)!important;color:var(--text)!important; }
  .ws-filter-select,.ws-filter-bar { background:var(--navy)!important;color:var(--text)!important; }
  .ws-weather-month.perfect { background:rgba(0,53,128,.2)!important; }
  .ws-weather-month.good    { background:rgba(240,165,0,.15)!important; }
  .ws-weather-month.avoid   { background:rgba(220,53,69,.12)!important; }
}

/* ══════════════════════════════════════════════════
   WINSOME v5 — GROUP TRIP BOARD (Join With Others)
══════════════════════════════════════════════════ */

/* ── SECTION WRAPPER ── */
.ws-group-section {
  background:linear-gradient(160deg,#000d30 0%,#001240 40%,#002060 100%);
  padding:72px 5%;position:relative;overflow:hidden;
}
.ws-group-section::before {
  content:'';position:absolute;top:-80px;right:-80px;
  width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,53,128,.12),transparent 70%);
  pointer-events:none;
}
.ws-group-section::after {
  content:'';position:absolute;bottom:-60px;left:-40px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,134,26,.08),transparent 70%);
  pointer-events:none;
}

/* ── SECTION HEADER ── */
.ws-grp-head {
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:20px;flex-wrap:wrap;margin-bottom:36px;position:relative;z-index:1;
}
.ws-grp-head-left h2 {
  font-family:var(--font-h);
  font-size:clamp(1.7rem,4vw,2.6rem);
  font-weight:900;color:#fff;margin-bottom:8px;
}
.ws-grp-head-left p {
  color:rgba(255,255,255,.55);font-size:15px;line-height:1.7;max-width:480px;
}
.ws-grp-live-badge {
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.3);
  color:#25d366;font-size:12px;font-weight:800;
  padding:7px 16px;border-radius:50px;letter-spacing:.3px;
  flex-shrink:0;
}
.ws-grp-live-dot {
  width:7px;height:7px;border-radius:50%;background:#25d366;
  animation:pulse 1.4s ease infinite;
}

/* ── FILTER PILLS ── */
.ws-grp-filters {
  display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;
  position:relative;z-index:1;
}
.ws-grp-filter {
  padding:8px 18px;border-radius:50px;font-size:12.5px;font-weight:700;
  border:1.5px solid rgba(255,255,255,.15);color:rgba(255,255,255,.6);
  background:rgba(255,255,255,.05);cursor:pointer;
  transition:all .25s;min-height:44px;display:flex;align-items:center;
}
.ws-grp-filter:hover { border-color:rgba(255,255,255,.5);color:#fff;background:rgba(255,255,255,.12); }
.ws-grp-filter.on  { background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 4px 16px rgba(0,53,128,.4); }

/* ── TRIP CARDS GRID ── */
.ws-grp-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:20px;
  position:relative;z-index:1;
}
@media(max-width:640px){ .ws-grp-grid { grid-template-columns:1fr; } }

/* ── TRIP CARD ── */
.ws-grp-card {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;overflow:hidden;
  transition:all .35s;position:relative;
  display:flex;flex-direction:column;
}
.ws-grp-card:hover {
  background:rgba(255,255,255,.1);
  border-color:rgba(0,53,128,.5);
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.4);
}
.ws-grp-card.urgent { border-color:rgba(220,53,69,.4); }
.ws-grp-card.full   { opacity:.55;pointer-events:none; }

/* Card image strip */
.ws-grp-img {
  height:148px;overflow:hidden;position:relative;
}
.ws-grp-img img {
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;filter:brightness(.75);
}
.ws-grp-card:hover .ws-grp-img img { transform:scale(1.06); }

/* Badges on image */
.ws-grp-cat-badge {
  position:absolute;top:12px;left:12px;
  background:rgba(0,53,128,.9);backdrop-filter:blur(8px);
  color:#fff;font-size:10px;font-weight:800;
  padding:4px 11px;border-radius:20px;
}
.ws-grp-urgency {
  position:absolute;top:12px;right:12px;
  background:rgba(220,53,69,.9);backdrop-filter:blur(8px);
  color:#fff;font-size:10px;font-weight:800;
  padding:4px 10px;border-radius:20px;
  display:flex;align-items:center;gap:4px;
  animation:pulse 2s ease infinite;
}
.ws-grp-discount {
  position:absolute;bottom:12px;left:12px;
  background:var(--gold);color:#fff;
  font-size:11px;font-weight:900;
  padding:4px 12px;border-radius:20px;
}

/* Card body */
.ws-grp-body { padding:16px 18px 20px;flex:1;display:flex;flex-direction:column;gap:10px; }

.ws-grp-title {
  font-size:15px;font-weight:800;color:#fff;line-height:1.35;
}
.ws-grp-dest {
  font-size:12px;color:rgba(255,255,255,.45);
  display:flex;align-items:center;gap:5px;margin-top:-4px;
}

/* Seat progress bar */
.ws-grp-seats-wrap { display:flex;flex-direction:column;gap:5px; }
.ws-grp-seats-top {
  display:flex;align-items:center;justify-content:space-between;
  font-size:11.5px;
}
.ws-grp-seats-label { color:rgba(255,255,255,.5); }
.ws-grp-seats-count { font-weight:800;color:#fff; }
.ws-grp-seats-count.few { color:#f87171; }
.ws-grp-bar-bg {
  height:5px;background:rgba(255,255,255,.1);
  border-radius:3px;overflow:hidden;
}
.ws-grp-bar-fill {
  height:100%;border-radius:3px;
  background:linear-gradient(90deg,var(--blue),var(--blue3));
  transition:width .8s ease;
}
.ws-grp-bar-fill.urgent-fill {
  background:linear-gradient(90deg,#f87171,#ef4444);
}

/* Meta row */
.ws-grp-meta {
  display:flex;gap:14px;flex-wrap:wrap;
}
.ws-grp-meta-item {
  display:flex;align-items:center;gap:5px;
  font-size:12px;color:rgba(255,255,255,.5);
}
.ws-grp-meta-item i { color:var(--blue3);font-size:11px; }

/* Avatars row */
.ws-grp-avs {
  display:flex;align-items:center;gap:0;
}
.ws-grp-av {
  width:28px;height:28px;border-radius:50%;
  border:2px solid rgba(20,50,40,.9);
  background:var(--blue);display:flex;align-items:center;justify-content:center;
  font-size:12px;margin-left:-6px;color:#fff;font-weight:700;
  overflow:hidden;
}
.ws-grp-av:first-child { margin-left:0; }
.ws-grp-av img { width:100%;height:100%;object-fit:cover; }
.ws-grp-av-more {
  width:28px;height:28px;border-radius:50%;margin-left:-6px;
  background:rgba(255,255,255,.12);border:2px solid rgba(20,50,40,.9);
  font-size:9px;font-weight:800;color:rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
}
.ws-grp-avs-label {
  font-size:11.5px;color:rgba(255,255,255,.45);margin-left:9px;
}

/* Price + CTA */
.ws-grp-foot {
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;margin-top:auto;padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
}
.ws-grp-price-block {}
.ws-grp-orig { font-size:11px;color:rgba(255,255,255,.3);text-decoration:line-through;margin-bottom:1px; }
.ws-grp-price { font-size:1.2rem;font-weight:900;color:var(--gold2); }
.ws-grp-price small { font-size:11px;color:rgba(255,255,255,.4);font-weight:400; }

.ws-grp-join-btn {
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;border-radius:50px;
  padding:10px 20px;font-size:13px;font-weight:800;
  border:none;cursor:pointer;transition:all .25s;
  display:flex;align-items:center;gap:7px;white-space:nowrap;
  flex-shrink:0;min-height:44px;
}
.ws-grp-join-btn:hover { transform:scale(1.05);box-shadow:0 6px 20px rgba(0,53,128,.5); }
.ws-grp-join-btn.wa-btn {
  background:linear-gradient(135deg,#25d366,#128c4a);
}
.ws-grp-join-btn.wa-btn:hover { box-shadow:0 6px 20px rgba(37,211,102,.4); }
.ws-grp-join-btn.full-btn {
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.4);
  pointer-events:none;
}

/* ── BOTTOM CTA BAR ── */
.ws-grp-cta-bar {
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  margin-top:36px;padding:24px 28px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;position:relative;z-index:1;
}
.ws-grp-cta-bar-left h3 {
  color:#fff;font-size:1rem;font-weight:800;margin-bottom:4px;
}
.ws-grp-cta-bar-left p {
  color:rgba(255,255,255,.5);font-size:13px;
}
.ws-grp-cta-btns { display:flex;gap:10px;flex-wrap:wrap; }
.ws-grp-cta-primary {
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;padding:12px 24px;border-radius:50px;
  font-weight:800;font-size:14px;border:none;cursor:pointer;
  transition:all .3s;min-height:44px;
}
.ws-grp-cta-primary:hover { transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,53,128,.5); }
.ws-grp-cta-wa {
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(37,211,102,.15);border:1.5px solid rgba(37,211,102,.35);
  color:#25d366;padding:11px 22px;border-radius:50px;
  font-weight:800;font-size:14px;cursor:pointer;
  transition:all .3s;min-height:44px;text-decoration:none;
}
.ws-grp-cta-wa:hover { background:rgba(37,211,102,.25);color:#25d366; }

/* ── COUNTDOWN TIMER ── */
.ws-grp-countdown {
  display:flex;gap:6px;align-items:center;margin-top:6px;
}
.ws-grp-cd-unit {
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.08);border-radius:8px;
  padding:4px 8px;min-width:34px;
}
.ws-grp-cd-num { font-size:14px;font-weight:900;color:#fff;line-height:1; }
.ws-grp-cd-label { font-size:8px;color:rgba(255,255,255,.4);margin-top:2px; }
.ws-grp-cd-sep { color:rgba(255,255,255,.3);font-size:14px;font-weight:800;margin-bottom:8px; }

/* ── MOBILE RESPONSIVE ── */
@media(max-width:767px){
  .ws-group-section { padding:52px 4%; }
  .ws-grp-head { flex-direction:column;align-items:flex-start;margin-bottom:24px; }
  .ws-grp-cta-bar { flex-direction:column;align-items:flex-start; }
  .ws-grp-cta-btns { width:100%; }
  .ws-grp-cta-primary,.ws-grp-cta-wa { flex:1;justify-content:center; }
  .ws-grp-card { border-radius:16px; }
}

/* ══════════════════════════════════════════════
   BOTTOM MAZE NAV — mobile tab bar
   ══════════════════════════════════════════════ */
.ws-maze-nav {
  display: none; /* hidden on desktop */
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 9100;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(0,53,128,0.12);
  box-shadow: 0 -4px 24px rgba(0,0,0,0.10);
  padding: 6px 0 max(6px, env(safe-area-inset-bottom));
  align-items: stretch;
  justify-content: space-around;
}
@media(max-width:959px){
  .ws-maze-nav { display: flex; }
}

.ws-maze-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: 6px 4px;
  text-decoration: none;
  color: #8ca8a4;
  border: none;
  background: none;
  cursor: pointer;
  transition: color .2s, transform .15s;
  -webkit-tap-highlight-color: transparent;
  font-family: inherit;
  min-width: 0;
  position: relative;
}
.ws-maze-item::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 28px; height: 3px;
  background: var(--blue3, #003580);
  border-radius: 0 0 4px 4px;
  transition: transform .2s;
}
.ws-maze-item.active::before { transform: translateX(-50%) scaleX(1); }
.ws-maze-item.active {
  color: var(--blue3, #003580);
}
.ws-maze-item:active { transform: scale(0.9); }

.ws-maze-icon {
  font-size: 22px;
  line-height: 1;
  transition: transform .2s;
}
.ws-maze-item.active .ws-maze-icon { transform: scale(1.15); }

.ws-maze-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2px;
  white-space: nowrap;
}

/* push page content up so maze nav doesn't overlap footer */
@media(max-width:959px){
  body { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
  /* keep WA float above maze nav */
  .ws-wa-float { bottom: 80px !important; }
  /* live chat above maze nav */
  .ws-chat-widget { bottom: 80px !important; }
  /* PWA banner above maze nav */
  .ws-pwa { bottom: 80px !important; }
  /* back-to-top above maze nav */
  .ws-top { bottom: 80px !important; }
  /* sticky CTA bar sits above maze nav */
  .ws-sticky-cta { bottom: 64px !important; }
  /* hide WhatsApp + Book Tour nav buttons on mobile — already in maze */
  .ws-nav-book { display: none !important; }
}

/* ── HAMBURGER — shown on mobile, hidden on desktop ── */
@media(max-width:959px){
  /* hamburger is shown via the mobile header layout rule above */
}

/* ── DARK MODE maze nav ── */
.dark .ws-maze-nav {
  background: rgba(10, 20, 30, 0.97);
  border-top-color: rgba(0,53,128,0.2);
}
.dark .ws-maze-item { color: rgba(255,255,255,0.4); }
.dark .ws-maze-item.active { color: var(--blue3, #003580); }

/* ── TOP BAR (location · date · time) ── */
.ws-topbar {
  background: linear-gradient(135deg,#003580,#002060);
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding: 5px 0;
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 2001;
}
.ws-topbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
}
.ws-topbar-inner span {
  color: rgba(255,255,255,.85);
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.ws-topbar-inner span i { color: #7eb8ff; font-size: 11px; }
@media(max-width:959px) {
  .ws-topbar-inner { gap: 10px; }
  .ws-topbar-inner span { font-size: 10px; }
}

/* push header below topbar (topbar ~31px tall) */
.ws-hdr { top: 31px !important; }
@media(max-width:959px) {
  .ws-hdr { top: 27px !important; height: 60px !important; }
  .ws-logo img { height: 44px; }
  .ws-ticker { margin-top: 87px; /* topbar 27px + header 60px */ }
}

/* FAB hamburger removed — maze nav মেনু button handles this */

/* ── Mobile header layout ── */
@media(max-width:959px) {
  .ws-hdr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    gap: 12px;
  }
  .ws-dnav { display: none !important; }
  /* restore hamburger on mobile */
  .ws-ham { display: flex !important; }
  /* hide Book Tour CTA on mobile — maze nav handles it */
  .ws-nav-book { display: none !important; }
}

/* ══════════════════════════════════════════════════════════════
   WINSOME CITIES — Extended Styles v5.0
   Property Owner · Mobile Fixes · Header Improvements
   ══════════════════════════════════════════════════════════════ */

/* ── HEADER ICON BUTTONS (already in file but ensure override) ── */
.ws-hdr-icon-btn {
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:15px;transition:all .25s;flex-shrink:0;
  text-decoration:none;cursor:pointer;
}
.ws-hdr-icon-btn:hover { background:rgba(255,255,255,.28);transform:scale(1.08); }
.ws-hdr.solid .ws-hdr-icon-btn { background:var(--sky);border-color:var(--border);color:var(--blue); }
.ws-hdr-wa-btn { border-color:rgba(37,211,102,.3) !important; }
.ws-hdr-wa-btn i { color:#25d366; }
.ws-hdr.solid .ws-hdr-wa-btn i { color:#25d366; }
@media(min-width:960px) { .ws-hdr-icon-btn { display:none; } }

/* ── CATEGORY PILLS — horizontal scroll on mobile ── */
.ws-cats {
  display:flex;gap:8px;
  padding:16px 5%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.ws-cats::-webkit-scrollbar { display:none; }
.ws-cat {
  scroll-snap-align:start;
  flex-shrink:0;
  background:#fff;border:1.5px solid var(--border);
  border-radius:50px;padding:9px 18px;
  font-size:13px;font-weight:600;color:var(--muted);
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.ws-cat:hover { border-color:var(--blue);color:var(--blue); }
.ws-cat.on { background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 4px 14px var(--blue-g); }

/* ── STATS BAR — better mobile grid ── */
.ws-stats-bar {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);
  padding:28px 5%;
  gap:0;
}
@media(max-width:600px) {
  .ws-stats-bar { grid-template-columns:repeat(2,1fr); gap:0; }
  .ws-stat { border-right:none !important; }
  .ws-stat:nth-child(odd) { border-right:1px solid rgba(255,255,255,.1) !important; }
}
.ws-stat {
  text-align:center;padding:16px 8px;
  border-right:1px solid rgba(255,255,255,.1);
}
.ws-stat:last-child { border-right:none; }
.ws-stat-num { font-family:var(--font-h);font-size:clamp(1.5rem,4vw,2.2rem);font-weight:900;color:#fff;line-height:1; }
.ws-stat-lbl { font-size:11px;color:rgba(255,255,255,.6);margin-top:4px;font-weight:600;letter-spacing:.3px; }

/* ── PAYMENT METHODS — proper CSS ── */
.ws-payment-methods {
  display:flex;flex-wrap:wrap;gap:8px;
}
.ws-pay-method {
  display:flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:50px;
  font-size:12.5px;font-weight:700;
  background:#fff;border:1.5px solid var(--border);
  color:var(--text);transition:all .2s;
}
.ws-pay-method:hover { border-color:var(--blue);transform:translateY(-1px); }
.ws-pay-bkash { border-color:rgba(220,0,115,.3);color:#dc0073;background:rgba(220,0,115,.06); }
.ws-pay-nagad  { border-color:rgba(255,100,0,.3);color:#e05c00;background:rgba(255,100,0,.06); }
.ws-pay-card   { border-color:rgba(0,53,128,.2);color:var(--blue);background:var(--sky2); }
.pm-ico { font-size:16px;line-height:1; }

/* ══════════════════════════════════════════════
   PROPERTY OWNER / LIST YOUR PROPERTY SECTION
   ══════════════════════════════════════════════ */

.ws-partner-section {
  background:linear-gradient(135deg, #000d30 0%, #001f6e 50%, #003580 100%);
  padding:72px 5%;
  position:relative;
  overflow:hidden;
}
.ws-partner-section::before {
  content:'';
  position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h60v60H0z' fill='none'/%3E%3Ccircle cx='30' cy='30' r='1' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E") repeat;
  pointer-events:none;
}
.ws-partner-section::after {
  content:'';position:absolute;
  top:-120px;right:-120px;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(59,130,246,.18) 0%, transparent 70%);
  pointer-events:none;
}

.ws-partner-header {
  text-align:center;margin-bottom:48px;
}
.ws-partner-eyebrow {
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(59,130,246,.2);border:1px solid rgba(59,130,246,.35);
  color:#93c5fd;font-size:11px;font-weight:800;
  letter-spacing:.8px;text-transform:uppercase;
  padding:6px 16px;border-radius:50px;margin-bottom:16px;
}
.ws-partner-header h2 {
  font-family:var(--font-h);
  font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:900;color:#fff;
  margin-bottom:12px;line-height:1.2;
}
.ws-partner-header h2 em { color:#fbbf24;font-style:normal; }
.ws-partner-header p {
  color:rgba(255,255,255,.6);
  font-size:15px;max-width:540px;margin:0 auto;line-height:1.8;
}

/* Partner type cards */
.ws-partner-types {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-bottom:40px;
}
@media(max-width:768px) { .ws-partner-types { grid-template-columns:1fr; } }
@media(min-width:480px) and (max-width:768px) { .ws-partner-types { grid-template-columns:repeat(2,1fr); } }

.ws-partner-card {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  padding:28px 24px;
  transition:all .3s;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.ws-partner-card:hover {
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.25);
  transform:translateY(-4px);
  box-shadow:0 20px 40px rgba(0,0,0,.3);
}
.ws-partner-card.featured {
  border-color:rgba(251,191,36,.4);
  background:rgba(251,191,36,.08);
}
.ws-partner-card.featured::before {
  content:'🔥 Most Popular';
  position:absolute;top:14px;right:14px;
  background:var(--gold2);color:#000;
  font-size:9px;font-weight:900;
  padding:3px 10px;border-radius:50px;
  letter-spacing:.3px;
}
.ws-pc-icon {
  font-size:2.4rem;margin-bottom:14px;
  display:block;
}
.ws-pc-title {
  font-size:1.05rem;font-weight:800;color:#fff;
  margin-bottom:8px;
}
.ws-pc-desc {
  font-size:13px;color:rgba(255,255,255,.55);
  line-height:1.7;margin-bottom:16px;
}
.ws-pc-perks {
  list-style:none;display:flex;flex-direction:column;gap:6px;
  margin-bottom:20px;
}
.ws-pc-perks li {
  font-size:12.5px;color:rgba(255,255,255,.7);
  display:flex;align-items:flex-start;gap:7px;
}
.ws-pc-perks li::before {
  content:'✓';color:#4ade80;font-weight:900;flex-shrink:0;margin-top:1px;
}
.ws-pc-cta {
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;padding:10px 18px;border-radius:50px;
  font-size:12.5px;font-weight:700;
  transition:all .2s;text-decoration:none;width:100%;justify-content:center;
}
.ws-partner-card.featured .ws-pc-cta {
  background:var(--gold2);border-color:var(--gold2);color:#000;
}
.ws-pc-cta:hover { transform:scale(1.02);box-shadow:0 6px 20px rgba(0,0,0,.2); }

/* Partner stats strip */
.ws-partner-stats {
  display:flex;justify-content:center;
  gap:0;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:20px;
  flex-wrap:wrap;
  margin-bottom:36px;
}
.ws-pstat {
  flex:1;min-width:120px;text-align:center;
  padding:12px 16px;
  border-right:1px solid rgba(255,255,255,.08);
}
.ws-pstat:last-child { border-right:none; }
@media(max-width:480px) {
  .ws-pstat { min-width:100px;border-right:none;border-bottom:1px solid rgba(255,255,255,.08); }
  .ws-pstat:last-child { border-bottom:none; }
}
.ws-pstat-num { font-family:var(--font-h);font-size:1.6rem;font-weight:900;color:#fff; }
.ws-pstat-lbl { font-size:11px;color:rgba(255,255,255,.5);margin-top:4px;font-weight:600; }

/* Partner bottom CTA */
.ws-partner-cta-row {
  display:flex;align-items:center;justify-content:center;
  gap:12px;flex-wrap:wrap;
}
.ws-partner-btn-primary {
  display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  color:#000;padding:14px 32px;border-radius:50px;
  font-weight:900;font-size:14px;
  transition:all .3s;border:none;cursor:pointer;
  box-shadow:0 4px 20px rgba(251,191,36,.4);
}
.ws-partner-btn-primary:hover { transform:translateY(-2px);box-shadow:0 8px 28px rgba(251,191,36,.5); }
.ws-partner-btn-secondary {
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;padding:14px 28px;border-radius:50px;
  font-weight:700;font-size:14px;transition:all .2s;text-decoration:none;
}
.ws-partner-btn-secondary:hover { background:rgba(255,255,255,.18); }

/* ══════════════════════════════════════════════
   DEMAND INSIGHTS SECTION (What Travelers Want)
   ══════════════════════════════════════════════ */
.ws-demand-section {
  padding:64px 5%;
  background:var(--light);
}
.ws-demand-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:36px;
}
@media(max-width:900px) { .ws-demand-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .ws-demand-grid { grid-template-columns:1fr 1fr; gap:10px; } }

.ws-demand-card {
  background:#fff;border-radius:18px;padding:20px 16px;
  border:1.5px solid var(--border);
  text-align:center;transition:all .25s;cursor:pointer;
  position:relative;overflow:hidden;
}
.ws-demand-card:hover { border-color:var(--blue);transform:translateY(-3px);box-shadow:var(--shadow-md); }
.ws-demand-card.hot::after {
  content:'🔥 Hot';position:absolute;top:10px;right:10px;
  background:#fee2e2;color:#dc2626;font-size:9px;font-weight:900;
  padding:2px 8px;border-radius:50px;
}
.ws-dc-icon { font-size:2rem;margin-bottom:10px; }
.ws-dc-name { font-size:13px;font-weight:800;color:var(--text);margin-bottom:4px; }
.ws-dc-demand {
  font-size:10px;font-weight:700;
  padding:2px 10px;border-radius:50px;display:inline-block;margin-bottom:8px;
}
.ws-dc-demand.high { background:#dcfce7;color:#16a34a; }
.ws-dc-demand.medium { background:#fef9c3;color:#ca8a04; }
.ws-dc-demand.rising { background:#dbeafe;color:#2563eb; }
.ws-dc-count { font-size:11px;color:var(--muted); }

/* ══════════════════════════════════════════════
   MOBILE QUICK ACCESS BAR (below hero)
   ══════════════════════════════════════════════ */
.ws-quick-bar {
  display:none;
  padding:12px 16px;
  gap:8px;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  background:#fff;
  border-bottom:1px solid var(--border);
}
.ws-quick-bar::-webkit-scrollbar { display:none; }
@media(max-width:768px) { .ws-quick-bar { display:flex; } }
.ws-quick-chip {
  display:flex;align-items:center;gap:6px;
  background:var(--sky2);border:1.5px solid var(--border);
  border-radius:50px;padding:8px 14px;
  font-size:12px;font-weight:700;color:var(--blue);
  white-space:nowrap;flex-shrink:0;
  text-decoration:none;transition:all .2s;
  -webkit-tap-highlight-color:transparent;
}
.ws-quick-chip:hover { background:var(--blue);color:#fff;border-color:var(--blue); }
.ws-quick-chip.wa { background:rgba(37,211,102,.1);border-color:rgba(37,211,102,.3);color:#16a34a; }

/* ══════════════════════════════════════════════
   TRENDING DESTINATIONS HORIZONTAL SCROLL
   ══════════════════════════════════════════════ */
.ws-trending-strip {
  padding:0 5% 40px;
}
.ws-trending-scroll {
  display:flex;gap:12px;
  overflow-x:auto;
  scrollbar-width:none;
  padding-bottom:4px;
  width:100%;
  flex-wrap:nowrap;
  scroll-behavior:auto;
  -webkit-overflow-scrolling:auto;
}
.ws-trending-scroll::-webkit-scrollbar { display:none; }
.ws-trend-chip {
  scroll-snap-align:start;flex-shrink:0;
  display:flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid var(--border);
  border-radius:50px;padding:10px 16px;
  font-size:13px;font-weight:600;cursor:pointer;
  transition:all .2s;text-decoration:none;color:var(--text);
}
.ws-trend-chip img {
  width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;
}
.ws-trend-chip:hover { border-color:var(--blue);color:var(--blue);transform:translateY(-2px); }
.ws-trend-chip .price { font-size:11px;color:var(--blue);font-weight:800; }

/* ══════════════════════════════════════════════
   FOOTER IMPROVEMENTS
   ══════════════════════════════════════════════ */
.ws-f-links { display:flex;gap:16px;flex-wrap:wrap; }
.ws-f-links a { font-size:12px;color:rgba(255,255,255,.35);transition:color .2s; }
.ws-f-links a:hover { color:#fff; }
@media(max-width:480px) {
  .ws-f-btm { flex-direction:column;text-align:center; }
  .ws-f-links { justify-content:center; }
  .ws-newsletter { padding:36px 5%; }
  .ws-nl-form { flex-direction:column; }
  .ws-nl-btn { width:100%; }
}

/* ── Payment badges in footer — proper CSS ── */
.ws-footer-pay {
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  margin-bottom:20px;padding-top:20px;
  border-top:1px solid rgba(255,255,255,.07);
}
.ws-footer-pay-label { font-size:12px;color:rgba(255,255,255,.4); }
.ws-fpay-badge {
  padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;
}
.ws-fpay-bkash { background:rgba(220,0,115,.15);color:#ff69b4;border:1px solid rgba(220,0,115,.3); }
.ws-fpay-nagad  { background:rgba(255,100,0,.15);color:#ff8c00;border:1px solid rgba(255,100,0,.3); }
.ws-fpay-card   { background:rgba(10,124,110,.2);color:#2dd4bf;border:1px solid rgba(10,124,110,.3); }
.ws-fpay-bank   { background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.12); }

/* ── MOBILE SEARCH BAR improvements ── */
@media(max-width:768px) {
  .ws-search-box {
    flex-direction:column;
    gap:8px;
    padding:16px;
    border-radius:20px;
  }
  .ws-si-wrap { width:100%; }
  .ws-si-wrap.btn-wrap { margin-top:4px; }
  .ws-search-go { width:100%;justify-content:center;padding:14px; }
}

/* ── TRUST BAR mobile ── */
@media(max-width:600px) {
  .ws-trust-bar {
    grid-template-columns:repeat(2,1fr) !important;
    gap:10px !important;
  }
}


/* ══════════════════════════════════════════════════
   OVERLAP FIX v5.2 + MOBILE HEADER FIX
   ══════════════════════════════════════════════════ */

/* Mobile header: solid white at top and when scrolled */
@media (max-width:959px) {
  .ws-hdr {
    background: rgba(255,255,255,0.97) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 2px 16px rgba(0,0,0,.1);
    border-bottom: 1px solid rgba(0,53,128,.08);
  }
  /* Logo text colors flip to dark on solid white header */
  .ws-logo-brand { color: var(--blue) !important; text-shadow: none !important; }
  .ws-logo-tag   { color: var(--muted) !important; }
  /* Icon buttons dark on white */
  .ws-hdr-icon-btn {
    background: var(--sky) !important;
    border-color: var(--border) !important;
    color: var(--blue) !important;
  }
  .ws-hdr-wa-btn i { color: #25d366 !important; }
}

/* Maze nav ≈ 62px. All fixed floats clear it. */
@media (max-width:959px) {
  .ws-pwa         { bottom: 78px !important; }
  .ws-top         { bottom: 78px !important; right: 16px !important; }
  .ws-wa-float    { bottom: 132px !important; right: 16px !important; width: 50px !important; height: 50px !important; font-size: 24px !important; }
  .ws-chat-widget { bottom: 78px !important; left: 12px !important; }
  .ws-sticky-cta  { display: none !important; }
  .ws-compare-bar { bottom: 62px !important; }
  .ws-compare-bar.show { transform: none !important; }
}

/* Desktop: natural positions */
@media (min-width:960px) {
  .ws-pwa         { bottom: 24px; }
  .ws-top         { bottom: 24px; right: 24px; }
  .ws-wa-float    { bottom: 28px; right: 28px; }
  .ws-chat-widget { bottom: 24px; left: 24px; }
}

/* ══════════════════════════════════════════════════
   LOGIN BUTTON + CTA GROUP — v5.3
   ══════════════════════════════════════════════════ */

/* CTA group: Login stacked above Book Tour */
.ws-hdr-cta-group {
  display: none;
  flex-direction: column;
  align-items: stretch;
  gap: 5px;
}
@media(min-width:960px) {
  .ws-hdr-cta-group { display: flex; }
}

/* Login button — same width as Book Tour, outline style */
.ws-nav-login {
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.45);
  color: #fff;
  padding: 7px 20px;
  border-radius: 50px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  transition: all .25s;
  font-family: inherit;
  text-align: center;
}
.ws-nav-login:hover {
  background: rgba(255,255,255,.28);
}
/* Book Tour — same width */
.ws-hdr-cta-group .ws-nav-book {
  justify-content: center;
  padding: 7px 20px;
  font-size: 12px;
}
/* On solid white header */
.ws-hdr.solid .ws-nav-login {
  background: var(--sky, #f0f9f7);
  border-color: var(--teal3, #0a7c6e);
  color: var(--teal3, #0a7c6e);
  backdrop-filter: none;
}
.ws-hdr.solid .ws-nav-login:hover {
  background: rgba(10,124,110,.12);
}

/* Mobile: show only Login (no Book Tour — maze nav has it) */
@media(max-width:959px) {
  .ws-hdr-cta-group {
    display: flex !important;
    flex-direction: row;
  }
  .ws-nav-login {
    background: var(--sky, #f0f9f7) !important;
    border-color: var(--teal3, #0a7c6e) !important;
    color: var(--teal3, #0a7c6e) !important;
    backdrop-filter: none !important;
    padding: 7px 14px;
    font-size: 12px;
  }
  .ws-hdr-cta-group .ws-nav-book {
    display: none !important;
  }
}
