/* ============================================================
   Page-Specific Styles
   ============================================================ */

/* --- ABOUT PAGE --- */
.about-hero{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:clamp(8rem,15vw,12rem) 0 clamp(4rem,8vw,6rem);color:var(--white);text-align:center;position:relative;overflow:hidden}
.about-hero h1{color:var(--white);margin-bottom:var(--space-md)}
.about-hero p{color:rgba(255,255,255,.7);font-size:1.1rem;max-width:600px;margin:0 auto}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4xl);align-items:center}
.about-img{border-radius:var(--radius-xl);overflow:hidden;position:relative}
.about-img img{width:100%;height:400px;object-fit:cover}
.about-img::after{content:'';position:absolute;inset:0;border:3px solid var(--accent);border-radius:var(--radius-xl);transform:translate(12px,12px);z-index:-1}
.about-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-xl)}
.value-card{padding:var(--space-2xl);border-radius:var(--radius-lg);background:var(--off-white);text-align:center;transition:all var(--duration-normal) var(--ease-out)}
.value-card:hover{background:var(--white);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.value-icon{font-size:2.5rem;margin-bottom:var(--space-md);background:linear-gradient(135deg,var(--accent),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-xl)}
.team-card{text-align:center;padding:var(--space-xl);border-radius:var(--radius-lg);background:var(--white);border:1px solid var(--gray-50);transition:all var(--duration-normal)}
.team-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.team-avatar{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--gold));margin:0 auto var(--space-md);display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--white)}
.team-card h4{margin-bottom:.2rem}
.team-card p{font-size:.85rem;color:var(--gray-400)}

/* --- DESTINATIONS PAGE --- */
.dest-hero{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:clamp(8rem,15vw,12rem) 0 clamp(3rem,6vw,5rem);color:var(--white);text-align:center;overflow:hidden;position:relative}
.filter-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-3xl)}
.filter-tab{padding:.6rem 1.5rem;border-radius:var(--radius-full);font-family:var(--font-display);font-weight:500;font-size:.9rem;color:var(--gray-400);background:var(--off-white);border:1px solid var(--gray-100);cursor:pointer;transition:all var(--duration-fast)}
.filter-tab:hover,.filter-tab.active{background:var(--accent);color:var(--white);border-color:var(--accent)}

/* --- PACKAGES LIST --- */
.pkg-filters{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-bottom:var(--space-2xl)}
.pkg-filters select{padding:.6rem 2rem .6rem 1rem;border:2px solid var(--gray-100);border-radius:var(--radius-full);font-size:.9rem;color:var(--gray-500);cursor:pointer;appearance:none;background:var(--white) url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right .8rem center}
.pkg-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-xl)}

/* --- PACKAGE DETAIL PAGE --- */
.pkg-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;overflow:hidden}
.pkg-hero-bg{position:absolute;inset:0}
.pkg-hero-bg img{width:100%;height:100%;object-fit:cover}
.pkg-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,40,.9) 0%,rgba(10,22,40,.72) 24%,rgba(10,22,40,.38) 52%,rgba(10,22,40,.92) 100%)}
.pkg-hero-content{position:relative;z-index:2;color:var(--white);padding-bottom:var(--space-3xl);width:100%}
.pkg-hero-content h1{color:var(--white);margin-bottom:var(--space-md)}
.pkg-hero-badges{display:flex;flex-wrap:wrap;gap:var(--space-sm)}
.pkg-hero-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);padding:.45rem 1rem;border-radius:var(--radius-full);font-size:.85rem;color:rgba(255,255,255,.9)}
.pkg-hero-badge i{color:var(--gold)}
.pkg-hero .breadcrumb,
.pkg-hero .breadcrumb a,
.pkg-hero .breadcrumb .current,
.pkg-hero .breadcrumb span{color:rgba(255,255,255,.92)}
.pkg-hero .breadcrumb{margin-bottom:var(--space-md);text-shadow:0 2px 12px rgba(0,0,0,.45)}
.pkg-hero .breadcrumb a:hover{color:var(--gold)}
.has-sticky-bottom .header:not(.scrolled) .logo,
.has-sticky-bottom .header:not(.scrolled) .nav-link,
.has-sticky-bottom .header:not(.scrolled) .menu-toggle span{filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}

.pkg-detail-layout{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-3xl)}
.pkg-sidebar{position:sticky;top:calc(var(--header-height) + 2rem);height:fit-content}

/* Quick Info Bar */
.quick-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);padding:var(--space-xl);background:var(--off-white);border-radius:var(--radius-lg);margin-bottom:var(--space-2xl)}
.quick-info-item{display:flex;align-items:center;gap:var(--space-md)}
.qi-icon{width:44px;height:44px;background:linear-gradient(135deg,rgba(255,107,53,.1),rgba(255,107,53,.05));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.1rem;flex-shrink:0}
.qi-label{font-size:.75rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em}
.qi-value{font-family:var(--font-display);font-weight:600;color:var(--primary);font-size:.9rem}

/* Places Covered */
.places-covered{display:flex;align-items:center;flex-wrap:wrap;gap:.7rem}
.place-step{display:inline-flex;align-items:center;gap:.7rem;max-width:100%}
.place-chip{display:inline-flex;align-items:center;gap:.65rem;padding:.45rem .8rem .45rem .5rem;background:linear-gradient(180deg,#fafbfe 0%,#f3f5fa 100%);border:1px solid var(--gray-100);border-radius:var(--radius-full);min-height:48px;box-shadow:0 8px 18px rgba(17,24,39,.04)}
.place-index{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#ff8a5c);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:.72rem;font-family:var(--font-display);flex-shrink:0}
.place-name{font-weight:600;font-family:var(--font-display);color:var(--primary);line-height:1.2;font-size:.92rem;white-space:nowrap}
.place-connector{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--gray-300);font-size:.72rem;flex-shrink:0}

/* Day-wise Itinerary */
.itinerary-section{margin-bottom:var(--space-3xl)}
.day-item{border:1px solid var(--gray-100);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden;transition:all var(--duration-normal)}
.day-item.active{border-color:var(--accent);box-shadow:0 4px 20px var(--accent-glow)}
.day-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);cursor:pointer;transition:background var(--duration-fast)}
.day-header:hover{background:var(--off-white)}
.day-number{width:48px;height:48px;background:linear-gradient(135deg,var(--accent),#ff8a5c);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.day-number span{font-family:var(--font-display);font-weight:700;font-size:.65rem;color:var(--white);text-transform:uppercase;text-align:center;line-height:1.2}
.day-number span strong{display:block;font-size:1.1rem}
.day-title{flex:1}
.day-title h4{font-size:1rem;margin-bottom:.1rem}
.day-title p{font-size:.8rem;color:var(--gray-400);margin:0}
.day-toggle{width:32px;height:32px;border-radius:50%;background:var(--off-white);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--gray-400);transition:all var(--duration-fast);flex-shrink:0}
.day-item.active .day-toggle{background:var(--accent);color:var(--white);transform:rotate(180deg)}
.day-content{max-height:0;overflow:hidden;transition:max-height var(--duration-slow) var(--ease-out)}
.day-item.active .day-content{max-height:800px}
.day-content-inner{padding:0 var(--space-lg) var(--space-lg);padding-left:calc(48px + var(--space-lg) + var(--space-md))}
.day-content-inner p{font-size:.92rem;color:var(--gray-500);line-height:1.8}
.day-content-inner ul{margin:var(--space-md) 0}
.day-content-inner li{padding:.3rem 0;padding-left:1.5rem;position:relative;font-size:.9rem;color:var(--gray-500)}
.day-content-inner li::before{content:'✦';position:absolute;left:0;color:var(--accent);font-size:.7rem;top:.45rem}

/* Inclusions / Exclusions */
.inc-exc{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);margin-bottom:var(--space-3xl)}
.inc-box,.exc-box{padding:var(--space-xl);border-radius:var(--radius-lg)}
.inc-box{background:rgba(34,197,94,.04);border:1px solid rgba(34,197,94,.15)}
.exc-box{background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.15)}
.inc-box h3,.exc-box h3{display:flex;align-items:center;gap:.5rem;margin-bottom:var(--space-lg);font-size:1.1rem}
.inc-box h3 i{color:var(--success)}
.exc-box h3 i{color:var(--coral)}
.inc-list li,.exc-list li{padding:.5rem 0;padding-left:1.8rem;position:relative;font-size:.9rem;color:var(--gray-500);border-bottom:1px solid var(--gray-50)}
.inc-list li:last-child,.exc-list li:last-child{border:none}
.inc-list li::before{content:'✓';position:absolute;left:0;color:var(--success);font-weight:700}
.exc-list li::before{content:'✕';position:absolute;left:0;color:var(--coral);font-weight:700}

/* Sidebar Enquiry */
.sidebar-enquiry{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md)}
.sidebar-price{text-align:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--gray-100)}
.sidebar-price .price-from{font-size:.8rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em}
.sidebar-price .price-value{font-family:var(--font-display);font-size:2.2rem;font-weight:800;color:var(--accent);display:block;margin:.3rem 0}
.sidebar-price .price-note{font-size:.8rem;color:var(--gray-300)}

/* Sticky Bottom Bar (mobile) */
.sticky-bottom{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);padding:var(--space-md) var(--space-lg);box-shadow:0 -4px 20px rgba(0,0,0,.1);z-index:998;align-items:center;justify-content:space-between}
.sticky-bottom .price-value{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--accent)}
.sticky-bottom .price-label{font-size:.7rem;color:var(--gray-400)}

/* --- CONTACT PAGE --- */
.contact-hero{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:clamp(8rem,15vw,12rem) 0 clamp(3rem,6vw,5rem);color:var(--white);text-align:center}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-3xl)}
.contact-form-box{background:var(--white);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-lg)}
.contact-info-cards{display:flex;flex-direction:column;gap:var(--space-lg)}
.contact-card{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-xl);background:var(--off-white);border-radius:var(--radius-lg);transition:all var(--duration-normal)}
.contact-card:hover{background:var(--white);box-shadow:var(--shadow-md);transform:translateX(4px)}
.contact-card-icon{width:52px;height:52px;background:linear-gradient(135deg,var(--accent),#ff8a5c);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.2rem;flex-shrink:0}
.contact-card h4{margin-bottom:.3rem;font-size:1rem}
.contact-card p{font-size:.9rem;color:var(--gray-400);margin:0}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;margin-top:var(--space-xl);height:300px}
.contact-map iframe{width:100%;height:100%;border:0}

/* --- BLOG PAGE --- */
.blog-hero{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:clamp(8rem,15vw,12rem) 0 clamp(3rem,6vw,5rem);color:var(--white);text-align:center}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--space-xl)}
.blog-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--white);border:1px solid var(--gray-50);transition:all var(--duration-normal)}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.blog-card-img{height:220px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow)}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-body{padding:var(--space-lg)}
.blog-card-meta{display:flex;align-items:center;gap:var(--space-md);font-size:.8rem;color:var(--gray-400);margin-bottom:var(--space-md)}
.blog-card-meta i{color:var(--accent)}
.blog-card h3{font-size:1.1rem;margin-bottom:.5rem;line-height:1.4}
.blog-card h3 a:hover{color:var(--accent)}
.blog-card p{font-size:.9rem;color:var(--gray-400);margin-bottom:var(--space-md);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-read-more{font-weight:600;font-size:.9rem;color:var(--accent);display:inline-flex;align-items:center;gap:.3rem}
.blog-read-more:hover{gap:.6rem}

/* --- FAQ PAGE --- */
.faq-hero{background:linear-gradient(135deg,var(--primary),var(--primary-light));padding:clamp(8rem,15vw,12rem) 0 clamp(3rem,6vw,5rem);color:var(--white);text-align:center}
.faq-container{max-width:800px;margin:0 auto}
.faq-category{margin-bottom:var(--space-3xl)}
.faq-category h3{display:flex;align-items:center;gap:.5rem;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--gray-50)}
.faq-category h3 i{color:var(--accent)}
.faq-item{border:1px solid var(--gray-100);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden}
.faq-item.active{border-color:var(--accent)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);cursor:pointer;font-family:var(--font-display);font-weight:600;color:var(--primary);font-size:.95rem;transition:all var(--duration-fast)}
.faq-question:hover{background:var(--off-white)}
.faq-question .faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--off-white);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--gray-400);transition:all var(--duration-fast);flex-shrink:0}
.faq-item.active .faq-toggle{background:var(--accent);color:var(--white);transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height var(--duration-slow) var(--ease-out)}
.faq-item.active .faq-answer{max-height:500px}
.faq-answer-inner{padding:0 var(--space-lg) var(--space-lg);font-size:.92rem;color:var(--gray-500);line-height:1.8}

/* --- BREADCRUMB --- */
.breadcrumb{display:flex;align-items:center;gap:.5rem;padding:var(--space-md) 0;font-size:.85rem}
.breadcrumb a{color:var(--gray-400);transition:color var(--duration-fast)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{color:var(--gray-300)}
.breadcrumb .current{color:var(--primary);font-weight:500}

/* ============================================================
   PACKAGE DETAIL PAGE — Premium Redesign
   ============================================================ */

/* ── Body class ── */
.pkg-detail-page { background: #f7f9fc; }

/* ══════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════ */
.pd-hero {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.pd-hero-media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.pd-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  animation: pd-kenburns 18s ease-in-out infinite alternate;
}

@keyframes pd-kenburns {
  from { transform: scale(1.04) translate(0, 0); }
  to   { transform: scale(1.10) translate(-1%, 0.5%); }
}

.pd-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8,16,36,.55) 0%, rgba(8,16,36,.25) 35%, rgba(8,16,36,.75) 70%, rgba(8,16,36,.97) 100%),
    linear-gradient(90deg, rgba(8,16,36,.6) 0%, transparent 60%);
}

.pd-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-bottom: 4rem;
  padding-top: calc(var(--header-height) + 2rem);
  display: flex;
  flex-direction: column;
  min-height: 88vh;
  justify-content: flex-end;
}

/* Breadcrumb */
.pd-breadcrumb {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-size: .82rem;
  color: rgba(255,255,255,.6);
  margin-bottom: 2.5rem;
}
.pd-breadcrumb a {
  color: rgba(255,255,255,.7);
  transition: color .2s;
}
.pd-breadcrumb a:hover { color: var(--gold); }
.pd-bc-sep { font-size: .6rem; opacity: .5; }
.pd-breadcrumb span { color: rgba(255,255,255,.9); }

/* Hero body: left copy + right price card */
.pd-hero-body {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 3rem;
  align-items: flex-end;
}

.pd-hero-left { display: flex; flex-direction: column; }

.pd-hero-region {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .85rem;
  background: rgba(247,201,72,.15);
  border: 1px solid rgba(247,201,72,.3);
  border-radius: var(--radius-full);
  color: var(--gold);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 1rem;
  width: fit-content;
}

.pd-hero-inner h1 {
  font-size: clamp(2rem, 4.5vw, 3.6rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.08;
  margin-bottom: .85rem;
  max-width: 700px;
}

.pd-hero-tagline {
  font-size: 1.05rem;
  color: rgba(255,255,255,.62);
  line-height: 1.65;
  margin-bottom: 1.6rem;
  max-width: 540px;
  font-weight: 300;
}

/* Hero badges */
.pd-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.pd-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .42rem 1rem;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius-full);
  font-size: .82rem;
  color: rgba(255,255,255,.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.pd-badge i { color: var(--gold); font-size: .78rem; }

/* Hero Price Card */
.pd-hero-price-card {
  background: rgba(255,255,255,.97);
  border-radius: 20px;
  padding: 1.8rem 1.6rem;
  width: 280px;
  flex-shrink: 0;
  box-shadow: 0 24px 60px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.12);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  overflow: hidden;
}

.pd-hero-price-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--gold), var(--accent));
  background-size: 200%;
  animation: shimmer-bar 3s linear infinite;
}

.pd-price-tag { text-align: center; }

.pd-price-from {
  display: block;
  font-size: .72rem;
  font-weight: 700;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: .2rem;
}

.pd-price-value {
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  margin-bottom: .25rem;
}

.pd-price-note {
  font-size: .75rem;
  color: var(--gray-300);
}

.pd-hero-cta {
  width: 100%;
  justify-content: center;
  font-size: .95rem;
  padding: .95rem 1.5rem;
}

.pd-hero-trust {
  display: flex;
  justify-content: center;
  gap: 1.2rem;
  font-size: .72rem;
  color: var(--gray-400);
}

.pd-hero-trust i { color: var(--success); font-size: .65rem; margin-right: .2rem; }

/* Scroll hint */
.pd-scroll-hint {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.35);
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  animation: pd-scroll-fade 2.5s ease-in-out infinite;
}

.pd-scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,.5), transparent);
  animation: pd-scroll-pulse 2.5s ease-in-out infinite;
}

@keyframes pd-scroll-fade  { 0%,100%{opacity:.35} 50%{opacity:.7} }
@keyframes pd-scroll-pulse { 0%,100%{transform:scaleY(1)} 50%{transform:scaleY(.7)} }

/* ══════════════════════════════════════════════════════════
   STATS STRIP
══════════════════════════════════════════════════════════ */
.pd-stats-strip {
  background: var(--primary);
  border-bottom: 1px solid rgba(255,255,255,.06);
  position: relative;
  z-index: 10;
}

.pd-stats-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}

.pd-stat {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: 1.3rem 1.2rem;
  border-right: 1px solid rgba(255,255,255,.07);
  transition: background .2s;
  cursor: default;
}

.pd-stat:last-child { border-right: none; }
.pd-stat:hover { background: rgba(255,255,255,.04); }

.pd-stat-icon {
  width: 38px;
  height: 38px;
  background: linear-gradient(135deg, rgba(255,107,53,.2), rgba(255,107,53,.1));
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: .95rem;
  flex-shrink: 0;
}

.pd-stat-label {
  font-size: .67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.45);
  line-height: 1;
  margin-bottom: .22rem;
}

.pd-stat-value {
  font-family: var(--font-display);
  font-size: .9rem;
  font-weight: 700;
  color: rgba(255,255,255,.92);
  line-height: 1.2;
}

/* ══════════════════════════════════════════════════════════
   BODY LAYOUT
══════════════════════════════════════════════════════════ */
.pd-body {
  padding: clamp(2.5rem, 5vw, 4.5rem) 0 5rem;
}

.pd-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: start;
}

/* ══════════════════════════════════════════════════════════
   SECTIONS — shared
══════════════════════════════════════════════════════════ */
.pd-main { display: flex; flex-direction: column; gap: 0; min-width: 0; }

.pd-section {
  background: #fff;
  border-radius: 18px;
  padding: clamp(1.8rem, 3vw, 2.5rem);
  margin-bottom: 1.5rem;
  border: 1px solid rgba(14,28,53,.06);
  box-shadow: 0 2px 16px rgba(14,28,53,.05);
  transition: box-shadow .25s;
}

.pd-section:hover { box-shadow: 0 6px 32px rgba(14,28,53,.09); }

.pd-section-label {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--accent);
  margin-bottom: .6rem;
}
.pd-section-label i { font-size: .65rem; }

.pd-section-title {
  font-size: clamp(1.25rem, 2.5vw, 1.6rem);
  font-weight: 800;
  color: var(--primary);
  margin-bottom: .5rem;
  line-height: 1.2;
}

.pd-section-sub {
  font-size: .88rem;
  color: var(--gray-400);
  margin-bottom: 1.5rem;
}

/* ── Overview ── */
.pd-overview-text {
  font-size: 1rem;
  color: var(--gray-500);
  line-height: 1.85;
  margin-top: .6rem;
  margin-bottom: 1.5rem;
}

.pd-highlights-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-top: 1rem;
}

.pd-highlight-tag {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .42rem .9rem;
  background: linear-gradient(135deg, rgba(255,107,53,.06), rgba(247,201,72,.06));
  border: 1px solid rgba(255,107,53,.14);
  border-radius: var(--radius-full);
  font-size: .8rem;
  font-weight: 600;
  color: var(--accent);
}

.pd-highlight-tag i { font-size: .68rem; color: var(--gold); }

/* ── Route / Places ── */
.pd-route-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  margin-top: 1rem;
}

.pd-route-step {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.pd-route-chip {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem 1rem .5rem .5rem;
  background: linear-gradient(180deg, #fafbfe 0%, #f3f5fa 100%);
  border: 1px solid rgba(14,28,53,.08);
  border-radius: var(--radius-full);
  box-shadow: 0 2px 10px rgba(14,28,53,.06);
  transition: all .2s;
}

.pd-route-chip:hover {
  background: linear-gradient(135deg, rgba(255,107,53,.06), rgba(247,201,72,.04));
  border-color: rgba(255,107,53,.2);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(255,107,53,.1);
}

.pd-route-num {
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, var(--accent), #ff8a5c);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: .72rem;
  flex-shrink: 0;
}

.pd-route-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .88rem;
  color: var(--primary);
  white-space: nowrap;
}

.pd-route-arrow {
  color: var(--gray-300);
  font-size: .85rem;
}

/* ── Itinerary ── */
.pd-itinerary { display: flex; flex-direction: column; gap: .65rem; }

.pd-day-item {
  border: 1.5px solid rgba(14,28,53,.08);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}

.pd-day-item:hover { border-color: rgba(255,107,53,.2); }
.pd-day-item.active { border-color: var(--accent); box-shadow: 0 4px 24px rgba(255,107,53,.12); }

.pd-day-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.2rem;
  cursor: pointer;
  background: #fff;
  transition: background .15s;
  user-select: none;
}

.pd-day-header:hover { background: #fafbfe; }

.pd-day-num {
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, var(--primary-light), var(--primary));
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .25s;
}

.pd-day-item.active .pd-day-num {
  background: linear-gradient(135deg, var(--accent), #ff8a5c);
}

.pd-day-word {
  font-size: .55rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.65);
  line-height: 1;
}

.pd-day-digit {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}

.pd-day-title { flex: 1; min-width: 0; }
.pd-day-title h4 { font-size: .97rem; font-weight: 700; color: var(--primary); margin-bottom: .12rem; line-height: 1.3; }
.pd-day-title p  { font-size: .78rem; color: var(--gray-400); margin: 0; }

.pd-day-toggle {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--off-white);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-400);
  font-size: .75rem;
  transition: all .25s;
  flex-shrink: 0;
}

.pd-day-item.active .pd-day-toggle {
  background: var(--accent);
  color: #fff;
  transform: rotate(180deg);
}

.pd-day-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s var(--ease-out);
}

.pd-day-item.active .pd-day-content { max-height: 1200px; }

.pd-day-inner {
  padding: 0 1.2rem 1.4rem;
  padding-left: calc(52px + 1rem + 1.2rem);
  border-top: 1px solid rgba(14,28,53,.05);
}

.pd-day-inner p {
  font-size: .92rem;
  color: var(--gray-500);
  line-height: 1.85;
  padding-top: 1rem;
}

/* ── Inclusions / Exclusions ── */
.pd-inc-exc {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-top: 1rem;
}

.pd-inc-card {
  border-radius: 14px;
  padding: 1.4rem 1.3rem;
  border: 1.5px solid;
}

.pd-inc-card:first-child {
  background: rgba(34,197,94,.03);
  border-color: rgba(34,197,94,.15);
}

.pd-inc-card:last-child {
  background: rgba(239,68,68,.03);
  border-color: rgba(239,68,68,.15);
}

.pd-inc-head {
  display: flex;
  align-items: center;
  gap: .7rem;
  margin-bottom: 1rem;
}

.pd-inc-head h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--primary);
  margin: 0;
}

.pd-inc-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  flex-shrink: 0;
}

.pd-inc-icon--yes { background: rgba(34,197,94,.12); color: var(--success); }
.pd-inc-icon--no  { background: rgba(239,68,68,.1);  color: var(--coral);   }

.pd-check-list { list-style: none; display: flex; flex-direction: column; gap: 0; }

.pd-check-list li {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  padding: .62rem 0;
  border-bottom: 1px solid rgba(14,28,53,.05);
  font-size: .88rem;
  line-height: 1.5;
}

.pd-check-list li:last-child { border: none; }

.pd-check-list--yes li i { color: var(--success); font-size: .78rem; margin-top: .22rem; flex-shrink: 0; }
.pd-check-list--no  li i { color: var(--coral);   font-size: .78rem; margin-top: .22rem; flex-shrink: 0; }
.pd-check-list li span { color: var(--gray-500); }

/* ── Important Info ── */
.pd-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1rem;
}

.pd-info-card {
  background: #fafbfe;
  border: 1px solid rgba(14,28,53,.07);
  border-radius: 14px;
  padding: 1.3rem;
  transition: box-shadow .2s, transform .2s;
}

.pd-info-card:hover {
  box-shadow: 0 4px 20px rgba(14,28,53,.08);
  transform: translateY(-2px);
}

.pd-info-card--warn {
  background: rgba(254,202,202,.06);
  border-color: rgba(239,68,68,.12);
}

.pd-info-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(255,107,53,.1), rgba(255,107,53,.05));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: .9rem;
  margin-bottom: .8rem;
}

.pd-info-card--warn .pd-info-icon {
  background: rgba(239,68,68,.08);
  color: var(--coral);
}

.pd-info-card h4 {
  font-size: .92rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .4rem;
}

.pd-info-card p {
  font-size: .83rem;
  color: var(--gray-500);
  line-height: 1.65;
  margin: 0;
}

/* ── Not found ── */
.pd-not-found {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--gray-400);
}
.pd-not-found i { font-size: 2.5rem; margin-bottom: 1rem; color: var(--accent); display: block; }
.pd-not-found h2 { margin-bottom: .5rem; }
.pd-not-found p { margin-bottom: 1.5rem; }

/* ══════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════ */
.pd-sidebar {
  position: sticky;
  top: calc(var(--header-height) + 1.5rem);
  height: fit-content;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

/* Enquiry Card */
.pd-enquiry-card {
  background: #fff;
  border-radius: 20px;
  padding: 1.8rem 1.6rem;
  box-shadow: 0 8px 40px rgba(14,28,53,.1), 0 0 0 1px rgba(14,28,53,.05);
  position: relative;
  overflow: hidden;
}

.pd-enquiry-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--gold), var(--accent));
  background-size: 200%;
  animation: shimmer-bar 3s linear infinite;
}

.pd-enquiry-price {
  text-align: center;
  padding-bottom: 1.3rem;
  margin-bottom: 1.3rem;
  border-bottom: 1px solid rgba(14,28,53,.07);
}

.pd-eq-from {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gray-400);
  margin-bottom: .2rem;
}

.pd-eq-amount {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--accent);
  display: block;
  line-height: 1;
  margin-bottom: .25rem;
}

.pd-eq-note { font-size: .75rem; color: var(--gray-300); }

/* Form fields */
.pd-enquiry-form { display: flex; flex-direction: column; gap: .85rem; margin-bottom: 1rem; }

.pd-field { display: flex; flex-direction: column; gap: .3rem; }

.pd-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--primary);
}

.pd-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.pd-input-icon {
  position: absolute;
  left: .9rem;
  color: var(--gray-300);
  font-size: .82rem;
  pointer-events: none;
  z-index: 1;
}

.pd-input {
  width: 100%;
  padding: .75rem 1rem .75rem 2.4rem;
  border: 1.5px solid rgba(14,28,53,.1);
  border-radius: 10px;
  font-size: .88rem;
  font-family: var(--font-body);
  background: #fafbfe;
  color: var(--primary);
  transition: border-color .2s, box-shadow .2s, background .2s;
  outline: none;
}

.pd-input:focus {
  border-color: var(--accent);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(255,107,53,.1);
}

.pd-textarea {
  padding-left: 1rem;
  resize: vertical;
  min-height: 80px;
  line-height: 1.55;
}

.pd-submit-btn {
  width: 100%;
  justify-content: center;
  font-size: .95rem;
  padding: 1rem;
  border-radius: 12px;
}

.pd-enquiry-or {
  text-align: center;
  position: relative;
  margin: 1rem 0 .8rem;
}

.pd-enquiry-or::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0; right: 0;
  height: 1px;
  background: rgba(14,28,53,.08);
}

.pd-enquiry-or span {
  position: relative;
  background: #fff;
  padding: 0 .8rem;
  font-size: .75rem;
  color: var(--gray-400);
}

.pd-call-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: 100%;
  padding: .75rem;
  border-radius: 10px;
  border: 1.5px solid rgba(14,28,53,.1);
  font-size: .9rem;
  font-weight: 700;
  color: var(--primary);
  transition: all .2s;
  background: #fafbfe;
}

.pd-call-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(255,107,53,.04);
}

/* Why Book Card */
.pd-why-card {
  background: var(--primary);
  border-radius: 18px;
  padding: 1.6rem 1.5rem;
  position: relative;
  overflow: hidden;
}

.pd-why-card::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -20%;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(255,107,53,.18), transparent);
  border-radius: 50%;
  pointer-events: none;
}

.pd-why-title {
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1.1rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.pd-why-title i { color: var(--gold); }

.pd-why-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .7rem;
  margin-bottom: 1.3rem;
}

.pd-why-list li {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-size: .88rem;
  color: rgba(255,255,255,.78);
}

.pd-why-list li i { color: var(--success); font-size: .82rem; flex-shrink: 0; }

.pd-why-rating {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,.08);
}

.pd-why-stars {
  font-size: 1.1rem;
  color: var(--gold);
  letter-spacing: .05em;
  line-height: 1;
}

.pd-why-rating strong {
  display: block;
  font-size: .95rem;
  color: #fff;
  font-weight: 700;
}

.pd-why-rating span {
  font-size: .72rem;
  color: rgba(255,255,255,.45);
}

/* ══════════════════════════════════════════════════════════
   STICKY BOTTOM BAR
══════════════════════════════════════════════════════════ */
.pd-sticky-bar {
  background: #fff;
  border-top: 1px solid rgba(14,28,53,.08);
  box-shadow: 0 -6px 30px rgba(14,28,53,.1);
  transition: transform 0.4s var(--ease-out), opacity 0.4s;
}

.pd-sticky-hidden {
  transform: translateY(120%);
  opacity: 0;
  pointer-events: none;
}

.pd-sticky-price { display: flex; flex-direction: column; }
.pd-sticky-from  { font-size: .68rem; color: var(--gray-400); letter-spacing: .04em; }
.pd-sticky-value {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.35rem;
  color: var(--accent);
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .pd-stats-grid { grid-template-columns: repeat(3, 1fr); }
  .pd-stat { border-right: 1px solid rgba(255,255,255,.07); }
  .pd-stat:nth-child(3) { border-right: none; }
  .pd-layout { grid-template-columns: 1fr 320px; gap: 2rem; }
}

@media (max-width: 900px) {
  .pd-hero { min-height: 70vh; }
  .pd-hero-inner { min-height: 70vh; }
  .pd-hero-body { grid-template-columns: 1fr; }
  .pd-hero-price-card { display: none; }
  .pd-hero-inner h1 { font-size: clamp(1.8rem, 6vw, 2.8rem); }
  .pd-layout { grid-template-columns: 1fr; }
  .pd-sidebar { position: static; }
  .pd-inc-exc { grid-template-columns: 1fr; }
  .pd-info-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .pd-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .pd-stat:nth-child(3) { border-right: 1px solid rgba(255,255,255,.07); }
  .pd-stat:nth-child(2n) { border-right: none; }
  .pd-day-inner { padding-left: 1.2rem; }
  .pd-section { padding: 1.4rem 1.2rem; }
}

@media (max-width: 420px) {
  .pd-stats-grid { grid-template-columns: 1fr 1fr; }
  .pd-hero-badges { gap: .4rem; }
  .pd-badge { font-size: .75rem; padding: .35rem .75rem; }
}

/* ============================================================
   DESTINATIONS PAGE — Premium Redesign
   ============================================================ */

/* ══════════════════════════════════════════════
   HERO
══════════════════════════════════════════════ */
.dh-hero {
  position: relative;
  min-height: 82vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

/* Slideshow bg */
.dh-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.dh-hero-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.4s ease;
  transform: scale(1.04);
  animation: dh-slow-zoom 14s ease-in-out infinite alternate;
}

.dh-hero-slide.active { opacity: 1; }

@keyframes dh-slow-zoom {
  from { transform: scale(1.04); }
  to   { transform: scale(1.10); }
}

.dh-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(8,16,36,.85) 0%, rgba(8,16,36,.4) 55%, rgba(8,16,36,.2) 100%),
    linear-gradient(to top, rgba(8,16,36,.98) 0%, rgba(8,16,36,.5) 40%, transparent 70%);
}

.dh-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: calc(var(--header-height) + 3rem);
  padding-bottom: 3.5rem;
  display: flex;
  flex-direction: column;
  min-height: 82vh;
  justify-content: flex-end;
  gap: 2.5rem;
}

/* Hero copy */
.dh-hero-content { max-width: 680px; }

.dh-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .32rem .9rem;
  background: rgba(247,201,72,.15);
  border: 1px solid rgba(247,201,72,.28);
  border-radius: 999px;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.1rem;
}

.dh-eyebrow i { font-size: .65rem; }

.dh-hero h1 {
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.05;
  margin-bottom: 1rem;
}

.dh-heading-accent {
  background: linear-gradient(135deg, var(--accent), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.dh-hero p {
  font-size: 1.05rem;
  color: rgba(255,255,255,.62);
  line-height: 1.75;
  max-width: 520px;
  margin-bottom: 2rem;
  font-weight: 300;
}

.dh-hero-stats {
  display: flex;
  align-items: center;
  gap: 1.4rem;
}

.dh-hstat strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
}

.dh-hstat span {
  font-size: .72rem;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .07em;
  font-weight: 600;
}

.dh-hstat-div {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,.14);
}

/* Region pills in hero */
.dh-region-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.dh-rpill {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .55rem 1.1rem;
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: rgba(255,255,255,.75);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .22s;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.dh-rpill:hover {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.28);
  color: #fff;
  transform: translateY(-1px);
}

.dh-rpill.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  box-shadow: 0 4px 20px rgba(255,107,53,.4);
}

.dh-rpill-icon { font-size: 1rem; line-height: 1; }

/* ══════════════════════════════════════════════
   FILTER BAR
══════════════════════════════════════════════ */
.dh-filter-bar {
  background: #fff;
  border-bottom: 1px solid rgba(14,28,53,.07);
  position: sticky;
  top: var(--header-height);
  z-index: 50;
  transition: box-shadow .25s;
}

.dh-filter-bar.dh-filter-stuck {
  box-shadow: 0 4px 24px rgba(14,28,53,.1);
}

.dh-filter-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: .85rem 0;
  flex-wrap: wrap;
}

.dh-tabs {
  margin-bottom: 0 !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.dh-tabs::-webkit-scrollbar { display: none; }

.dh-tabs .filter-tab {
  white-space: nowrap;
  font-size: .82rem;
  padding: .48rem 1.1rem;
}

.dh-filter-right {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}

.dh-results-count {
  font-size: .82rem;
  color: var(--gray-400);
  white-space: nowrap;
}

.dh-results-count span {
  font-weight: 700;
  color: var(--primary);
}

.dh-sort-wrap {
  position: relative;
}

.dh-sort-select {
  appearance: none;
  padding: .45rem 2.2rem .45rem .9rem;
  border: 1.5px solid rgba(14,28,53,.1);
  border-radius: 999px;
  font-size: .8rem;
  font-family: var(--font-body);
  color: var(--primary);
  background: #fafbfe;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='7' viewBox='0 0 10 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L5 5.5L9 1.5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .7rem center;
  transition: border-color .2s;
  outline: none;
}

.dh-sort-select:focus { border-color: var(--accent); }

/* ══════════════════════════════════════════════
   GRID SECTION
══════════════════════════════════════════════ */
.dh-grid-section {
  padding: 2.5rem 0 5rem;
  background: #f4f6fb;
}

.dh-active-filter {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.6rem;
  font-size: .82rem;
}

.dh-af-label { color: var(--gray-400); }

.dh-af-value {
  font-weight: 700;
  color: var(--primary);
  background: rgba(255,107,53,.07);
  border: 1px solid rgba(255,107,53,.14);
  padding: .18rem .65rem;
  border-radius: 999px;
  font-size: .78rem;
  color: var(--accent);
}

/* Grid layout */
.dh-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.6rem;
}

/* ── Card ── */
.dh-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(14,28,53,.06);
  box-shadow: 0 2px 16px rgba(14,28,53,.06);
  display: flex;
  flex-direction: column;
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out), border-color .28s;
  animation: dh-card-in .45s ease both;
  text-decoration: none;
  color: inherit;
}

.dh-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(14,28,53,.14);
  border-color: rgba(255,107,53,.15);
}

@keyframes dh-card-in {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Card image */
.dh-card-img-wrap {
  position: relative;
  height: 220px;
  overflow: hidden;
  flex-shrink: 0;
}

.dh-card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s var(--ease-out);
  display: block;
}

.dh-card:hover .dh-card-img-wrap img { transform: scale(1.07); }

.dh-card-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,16,36,.55) 0%, rgba(8,16,36,.05) 50%, transparent 100%);
}

/* Badge */
.dh-card-badge {
  position: absolute;
  top: .85rem;
  left: .85rem;
  padding: .28rem .72rem;
  border-radius: 999px;
  font-size: .7rem;
  font-weight: 700;
  z-index: 2;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.dh-badge-hot     { background: rgba(239,68,68,.85);   color: #fff; }
.dh-badge-new     { background: rgba(34,197,94,.85);   color: #fff; }
.dh-badge-ltd     { background: rgba(245,158,11,.85);  color: #fff; }
.dh-badge-special { background: rgba(124,58,237,.85);  color: #fff; }

/* Region tag on image bottom-right */
.dh-card-region-tag {
  position: absolute;
  bottom: .75rem;
  right: .75rem;
  font-size: .68rem;
  font-weight: 700;
  color: rgba(255,255,255,.85);
  background: rgba(8,16,36,.55);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: .22rem .65rem;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  letter-spacing: .05em;
  text-transform: uppercase;
  z-index: 2;
}

/* Card body */
.dh-card-body {
  padding: 1.25rem 1.3rem 1.3rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: .4rem;
}

.dh-card-meta-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .25rem;
}

.dh-card-tag {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--accent);
  background: rgba(255,107,53,.08);
  border: 1px solid rgba(255,107,53,.14);
  border-radius: 999px;
  padding: .2rem .6rem;
}

.dh-card-dur {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .76rem;
  color: var(--gray-400);
  font-weight: 500;
}

.dh-card-dur i { color: var(--accent); font-size: .68rem; }

.dh-card-title {
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1.25;
  margin: 0;
  transition: color .2s;
}

.dh-card:hover .dh-card-title { color: var(--accent); }

.dh-card-tagline {
  font-size: .82rem;
  color: var(--gray-400);
  line-height: 1.55;
  margin: .1rem 0 auto;
}

/* Card footer */
.dh-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: .9rem;
  margin-top: .6rem;
  border-top: 1px solid rgba(14,28,53,.06);
}

.dh-card-price {
  display: flex;
  align-items: baseline;
  gap: .25rem;
}

.dh-price-from {
  font-size: .7rem;
  color: var(--gray-400);
  font-weight: 500;
}

.dh-price-val {
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}

.dh-price-pp {
  font-size: .68rem;
  color: var(--gray-300);
}

.dh-card-cta {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .78rem;
  font-weight: 700;
  color: var(--primary);
  background: var(--off-white);
  border: 1px solid rgba(14,28,53,.08);
  border-radius: 999px;
  padding: .38rem .85rem;
  transition: all .2s;
}

.dh-card:hover .dh-card-cta {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.dh-card-cta i { font-size: .7rem; transition: transform .2s; }
.dh-card:hover .dh-card-cta i { transform: translateX(3px); }

/* ── Empty state ── */
.dh-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 5rem 2rem;
  text-align: center;
  color: var(--gray-400);
}

.dh-empty i {
  font-size: 2.5rem;
  color: var(--accent);
  opacity: .4;
}

.dh-empty h3 { color: var(--primary); font-size: 1.3rem; margin: 0; }
.dh-empty p  { font-size: .9rem; margin: 0; }
.dh-empty a  { color: var(--accent); font-weight: 600; }

/* ══════════════════════════════════════════════
   BOTTOM CTA BAND
══════════════════════════════════════════════ */
.dh-cta-band {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
  padding: clamp(3rem, 6vw, 5rem) 0;
  position: relative;
  overflow: hidden;
}

.dh-cta-band::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(255,107,53,.15), transparent);
  border-radius: 50%;
  pointer-events: none;
}

.dh-cta-band::after {
  content: '';
  position: absolute;
  bottom: -40%;
  left: -10%;
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, rgba(46,196,182,.12), transparent);
  border-radius: 50%;
  pointer-events: none;
}

.dh-cta-inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
  flex-wrap: wrap;
}

.dh-cta-text h2 {
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  color: #fff;
  margin-bottom: .5rem;
  font-weight: 800;
}

.dh-cta-text p {
  color: rgba(255,255,255,.6);
  font-size: .98rem;
  margin: 0;
  max-width: 440px;
}

.dh-cta-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .dh-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .dh-hero { min-height: 70vh; }
  .dh-hero-inner { min-height: 70vh; }
  .dh-hero h1 { font-size: clamp(2rem, 7vw, 3rem); }
  .dh-filter-inner { gap: .7rem; }
  .dh-filter-right { width: 100%; justify-content: space-between; }
}

@media (max-width: 640px) {
  .dh-grid { grid-template-columns: 1fr; gap: 1.2rem; }
  .dh-cta-inner { flex-direction: column; text-align: center; }
  .dh-cta-actions { justify-content: center; width: 100%; }
  .dh-hero-stats { gap: .9rem; }
  .dh-hstat strong { font-size: 1.2rem; }
}

@media (max-width: 480px) {
  .dh-card-img-wrap { height: 190px; }
  .dh-region-pills { gap: .4rem; }
  .dh-rpill { padding: .45rem .85rem; font-size: .78rem; }
}

/* ============================================================
   PACKAGES PAGE — Premium Redesign
   ============================================================ */

/* ══════════════════════════════════════════════
   HERO
══════════════════════════════════════════════ */
.pk-hero {
  position: relative;
  background: linear-gradient(145deg, var(--primary) 0%, #0d1f3c 50%, var(--primary-light) 100%);
  padding: clamp(8rem,14vw,11rem) 0 clamp(3.5rem,6vw,5rem);
  overflow: hidden;
}

/* Animated background blobs */
.pk-hero::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -12%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(255,107,53,.14) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}

.pk-hero::after {
  content: '';
  position: absolute;
  bottom: -20%;
  left: -8%;
  width: 450px;
  height: 450px;
  background: radial-gradient(circle, rgba(46,196,182,.1) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}

/* Floating particles */
.pk-hero-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.pk-hero-particle {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--s);
  height: var(--s);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.04) 0%, transparent 70%);
  animation: pk-float var(--d) ease-in-out infinite alternate var(--dl);
}

@keyframes pk-float {
  from { transform: translateY(0) scale(1); opacity: .6; }
  to   { transform: translateY(-28px) scale(1.06); opacity: 1; }
}

.pk-hero-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 2.2rem;
}

.pk-hero-content { max-width: 620px; }

.pk-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .32rem .9rem;
  background: rgba(247,201,72,.12);
  border: 1px solid rgba(247,201,72,.25);
  border-radius: 999px;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1rem;
}

.pk-eyebrow i { font-size: .65rem; }

.pk-hero h1 {
  font-size: clamp(2.4rem,5.2vw,4rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.06;
  margin-bottom: .9rem;
}

.pk-heading-accent {
  background: linear-gradient(135deg, var(--accent), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.pk-hero p {
  font-size: 1rem;
  color: rgba(255,255,255,.58);
  line-height: 1.72;
  max-width: 500px;
  font-weight: 300;
}

/* Hero summary chips */
.pk-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.pk-hchip {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem 1rem;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 999px;
  font-size: .83rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  backdrop-filter: blur(8px);
}

.pk-hchip i { color: var(--gold); font-size: .75rem; }

.pk-hchip--accent {
  background: linear-gradient(135deg, rgba(255,107,53,.2), rgba(247,201,72,.12));
  border-color: rgba(255,107,53,.25);
  color: var(--gold);
}

/* ══════════════════════════════════════════════
   CONTROL BAR
══════════════════════════════════════════════ */
.pk-control-bar {
  background: #fff;
  border-bottom: 1px solid rgba(14,28,53,.07);
  position: sticky;
  top: var(--header-height);
  z-index: 50;
  transition: box-shadow .25s;
}

.pk-control-bar.pk-bar-stuck {
  box-shadow: 0 4px 28px rgba(14,28,53,.1);
}

.pk-control-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .8rem 0;
  flex-wrap: wrap;
}

/* Tabs inside control bar */
.pk-tabs {
  margin-bottom: 0 !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  flex: 1;
  min-width: 0;
}

.pk-tabs::-webkit-scrollbar { display: none; }

.pk-tabs .filter-tab {
  white-space: nowrap;
  font-size: .8rem;
  padding: .42rem .95rem;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}

.pk-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 .35rem;
  background: rgba(255,107,53,.12);
  border-radius: 999px;
  font-size: .66rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}

.filter-tab.active .pk-tab-count {
  background: rgba(255,255,255,.25);
  color: #fff;
}

/* Right controls */
.pk-ctrl-right {
  display: flex;
  align-items: center;
  gap: .7rem;
  flex-shrink: 0;
}

/* Search */
.pk-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.pk-search-icon {
  position: absolute;
  left: .75rem;
  color: var(--gray-300);
  font-size: .78rem;
  pointer-events: none;
}

.pk-search {
  width: 190px;
  padding: .46rem 2.2rem .46rem 2.1rem;
  border: 1.5px solid rgba(14,28,53,.1);
  border-radius: 999px;
  font-size: .82rem;
  font-family: var(--font-body);
  color: var(--primary);
  background: #fafbfe;
  outline: none;
  transition: border-color .2s, box-shadow .2s, width .3s;
}

.pk-search:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(255,107,53,.1);
  width: 240px;
}

.pk-search::placeholder { color: var(--gray-300); }

.pk-search-clear {
  position: absolute;
  right: .6rem;
  background: none;
  border: none;
  color: var(--gray-300);
  cursor: pointer;
  padding: .2rem;
  font-size: .75rem;
  line-height: 1;
  transition: color .15s;
}

.pk-search-clear:hover { color: var(--accent); }

/* Sort */
.pk-sort-select {
  appearance: none;
  padding: .46rem 2rem .46rem .85rem;
  border: 1.5px solid rgba(14,28,53,.1);
  border-radius: 999px;
  font-size: .8rem;
  font-family: var(--font-body);
  color: var(--primary);
  background: #fafbfe;
  cursor: pointer;
  outline: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='7' viewBox='0 0 10 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L5 5.5L9 1.5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .65rem center;
  transition: border-color .2s;
}

.pk-sort-select:focus { border-color: var(--accent); }

/* Count */
.pk-result-count {
  font-size: .78rem;
  color: var(--gray-400);
  white-space: nowrap;
}

.pk-result-count span {
  font-weight: 700;
  color: var(--primary);
}

/* ══════════════════════════════════════════════
   GRID SECTION
══════════════════════════════════════════════ */
.pk-grid-section {
  padding: 2rem 0 5rem;
  background: #f4f6fb;
}

/* Breadline */
.pk-breadline {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 1.5rem;
  font-size: .82rem;
  flex-wrap: wrap;
}

.pk-bl-label { color: var(--gray-400); }

.pk-bl-value {
  font-weight: 700;
  color: var(--accent);
  background: rgba(255,107,53,.07);
  border: 1px solid rgba(255,107,53,.14);
  padding: .18rem .65rem;
  border-radius: 999px;
  font-size: .78rem;
}

.pk-bl-clear {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  background: none;
  border: none;
  font-size: .75rem;
  color: var(--gray-400);
  cursor: pointer;
  padding: .2rem .4rem;
  border-radius: 6px;
  transition: color .15s, background .15s;
}

.pk-bl-clear:hover { color: var(--accent); background: rgba(255,107,53,.06); }

/* ── Grid ── */
.pk-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* ── Card ── */
.pk-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(14,28,53,.06);
  box-shadow: 0 2px 14px rgba(14,28,53,.05);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out), border-color .28s;
  animation: pk-card-in .4s ease both;
}

.pk-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 20px 52px rgba(14,28,53,.14);
  border-color: rgba(255,107,53,.18);
}

@keyframes pk-card-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Card image */
.pk-card-img-wrap {
  position: relative;
  height: 230px;
  overflow: hidden;
  flex-shrink: 0;
}

.pk-card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s var(--ease-out);
}

.pk-card:hover .pk-card-img-wrap img { transform: scale(1.08); }

.pk-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
    rgba(8,16,36,.7)  0%,
    rgba(8,16,36,.15) 45%,
    transparent       70%);
}

/* Badge top-left */
.pk-card-badge {
  position: absolute;
  top: .85rem;
  left: .85rem;
  padding: .3rem .72rem;
  border-radius: 999px;
  font-size: .69rem;
  font-weight: 700;
  z-index: 2;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  letter-spacing: .03em;
}

.pk-badge-hot     { background: rgba(220,38,38,.88);   color: #fff; }
.pk-badge-new     { background: rgba(22,163,74,.88);   color: #fff; }
.pk-badge-ltd     { background: rgba(217,119,6,.88);   color: #fff; }
.pk-badge-special { background: rgba(109,40,217,.88);  color: #fff; }

/* Image bottom meta strip */
.pk-card-img-meta {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding: .7rem .9rem;
  z-index: 2;
}

.pk-card-region {
  font-size: .68rem;
  font-weight: 700;
  color: rgba(255,255,255,.8);
  text-transform: uppercase;
  letter-spacing: .08em;
  background: rgba(8,16,36,.45);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: .2rem .6rem;
  backdrop-filter: blur(6px);
}

.pk-card-price-over {
  font-family: var(--font-display);
  font-size: .88rem;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
}

/* Card body */
.pk-card-body {
  padding: 1.2rem 1.25rem 1.3rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: .55rem;
}

.pk-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pk-card-cat {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: .22rem .65rem;
  border-radius: 999px;
  border: 1px solid;
}

.pk-cat-pack { background: rgba(255,107,53,.08); border-color: rgba(255,107,53,.18); color: var(--accent); }
.pk-cat-adv  { background: rgba(46,196,182,.08); border-color: rgba(46,196,182,.2);  color: var(--teal-dark); }
.pk-cat-cult { background: rgba(124,58,237,.07); border-color: rgba(124,58,237,.18); color: #7c3aed; }

.pk-card-dur {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .76rem;
  color: var(--gray-400);
  font-weight: 500;
}

.pk-card-dur i { color: var(--accent); font-size: .66rem; }

/* Title & tagline */
.pk-card-title {
  font-family: var(--font-display);
  font-size: 1.07rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1.25;
  margin: 0;
  transition: color .2s;
}

.pk-card:hover .pk-card-title { color: var(--accent); }

.pk-card-tagline {
  font-size: .82rem;
  color: var(--gray-400);
  line-height: 1.55;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Highlights mini-list */
.pk-card-hl {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .3rem;
  margin: .1rem 0 0;
}

.pk-card-hl li {
  display: flex;
  align-items: center;
  gap: .42rem;
  font-size: .77rem;
  color: var(--gray-500);
  line-height: 1.35;
}

.pk-card-hl li i {
  color: var(--success);
  font-size: .65rem;
  flex-shrink: 0;
}

/* Chips row */
.pk-card-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  margin-top: auto;
  padding-top: .2rem;
}

.pk-card-chip {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .7rem;
  color: var(--gray-400);
  background: #f4f6fb;
  border: 1px solid rgba(14,28,53,.07);
  border-radius: 999px;
  padding: .22rem .62rem;
  font-weight: 500;
}

.pk-card-chip i { color: var(--accent); font-size: .6rem; }

.pk-chip-visa {
  background: rgba(22,163,74,.07);
  border-color: rgba(22,163,74,.18);
  color: #15803d;
}

.pk-chip-visa i { color: #15803d; }

/* Footer */
.pk-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: .9rem;
  margin-top: .3rem;
  border-top: 1px solid rgba(14,28,53,.06);
}

.pk-card-price-block {
  display: flex;
  align-items: baseline;
  gap: .22rem;
}

.pk-card-from {
  font-size: .68rem;
  color: var(--gray-400);
}

.pk-card-amount {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}

.pk-card-pp {
  font-size: .65rem;
  color: var(--gray-300);
}

.pk-card-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .77rem;
  font-weight: 700;
  color: var(--primary);
  background: #f4f6fb;
  border: 1px solid rgba(14,28,53,.09);
  border-radius: 999px;
  padding: .38rem .85rem;
  transition: all .2s;
  white-space: nowrap;
}

.pk-card:hover .pk-card-cta-btn {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.pk-card-cta-btn i { font-size: .68rem; transition: transform .2s; }
.pk-card:hover .pk-card-cta-btn i { transform: translateX(3px); }

/* ── Empty state ── */
.pk-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 5rem 2rem;
  gap: .9rem;
}

.pk-empty-icon {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(255,107,53,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  color: var(--accent);
  margin-bottom: .4rem;
}

.pk-empty h3 { font-size: 1.3rem; color: var(--primary); margin: 0; }
.pk-empty p  { font-size: .9rem; color: var(--gray-400); margin: 0; }

/* ══════════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════════ */
.pk-cta-section {
  position: relative;
  background: linear-gradient(145deg, var(--primary) 0%, #0d1f3c 60%, var(--primary-light) 100%);
  padding: clamp(4rem, 8vw, 7rem) 0;
  overflow: hidden;
}

.pk-cta-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.pk-cta-glow--1 {
  width: 560px;
  height: 560px;
  top: -40%;
  right: -8%;
  background: radial-gradient(circle, rgba(255,107,53,.14) 0%, transparent 65%);
}

.pk-cta-glow--2 {
  width: 400px;
  height: 400px;
  bottom: -30%;
  left: -6%;
  background: radial-gradient(circle, rgba(46,196,182,.1) 0%, transparent 65%);
}

.pk-cta-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: clamp(2.5rem, 5vw, 6rem);
  align-items: center;
}

.pk-cta-tag {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .85rem;
  background: rgba(247,201,72,.12);
  border: 1px solid rgba(247,201,72,.25);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1rem;
}

.pk-cta-left h2 {
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 1rem;
}

.pk-cta-left p {
  font-size: .97rem;
  color: rgba(255,255,255,.58);
  line-height: 1.75;
  max-width: 420px;
}

/* CTA card (right column) */
.pk-cta-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 22px;
  padding: 2rem 1.8rem;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: .85rem;
}

.pk-cta-card-row {
  display: flex;
  align-items: center;
  gap: .7rem;
  font-size: .9rem;
  color: rgba(255,255,255,.78);
}

.pk-cta-card-row i {
  color: var(--success);
  font-size: .85rem;
  flex-shrink: 0;
}

.pk-cta-btn {
  width: 100%;
  justify-content: center;
  margin-top: .4rem;
  font-size: .97rem;
  padding: 1rem;
  border-radius: 12px;
}

.pk-cta-call {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  font-size: .82rem;
  color: rgba(255,255,255,.45);
  transition: color .2s;
  text-align: center;
}

.pk-cta-call:hover { color: var(--gold); }
.pk-cta-call i     { font-size: .78rem; }

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .pk-grid { grid-template-columns: repeat(2, 1fr); }
  .pk-cta-inner { grid-template-columns: 1fr; }
  .pk-cta-card { max-width: 440px; }
}

@media (max-width: 900px) {
  .pk-control-inner { gap: .6rem; }
  .pk-ctrl-right { width: 100%; justify-content: space-between; }
  .pk-search { width: 160px; }
  .pk-search:focus { width: 200px; }
}

@media (max-width: 640px) {
  .pk-grid { grid-template-columns: 1fr; gap: 1.2rem; }
  .pk-hero-chips { gap: .4rem; }
  .pk-hchip { font-size: .76rem; padding: .4rem .8rem; }
  .pk-cta-inner { text-align: center; }
  .pk-cta-left p { margin: 0 auto; }
  .pk-cta-card { align-items: flex-start; text-align: left; }
}

@media (max-width: 480px) {
  .pk-card-img-wrap { height: 200px; }
  .pk-card-body { padding: 1rem 1.1rem 1.15rem; }
}

/* ============================================================
   ABOUT PAGE — Premium Redesign
   ============================================================ */

/* ══════════════════════════════════════════════
   SHARED SECTION TOKENS
══════════════════════════════════════════════ */
.ab-section { padding: clamp(4rem,8vw,7rem) 0; }

.ab-section-tag {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .32rem .9rem;
  background: linear-gradient(135deg, rgba(255,107,53,.1), rgba(247,201,72,.06));
  border: 1px solid rgba(255,107,53,.18);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: .9rem;
}

.ab-section-head {
  text-align: center;
  max-width: 620px;
  margin: 0 auto clamp(2.5rem,5vw,4rem);
}

.ab-section-head h2 {
  font-size: clamp(1.7rem, 3.5vw, 2.5rem);
  font-weight: 800;
  color: var(--primary);
  margin-bottom: .7rem;
  line-height: 1.18;
}

.ab-section-head p {
  font-size: .98rem;
  color: var(--gray-400);
  line-height: 1.72;
  margin: 0;
}

/* ══════════════════════════════════════════════
   HERO — Split layout
══════════════════════════════════════════════ */
.ab-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
}

/* Image side */
.ab-hero-img-side {
  position: relative;
  overflow: hidden;
}

.ab-hero-img-side img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  animation: ab-kenburns 18s ease-in-out infinite alternate;
}

@keyframes ab-kenburns {
  from { transform: scale(1.04) translate(0,0); }
  to   { transform: scale(1.10) translate(-1.5%,.5%); }
}

.ab-hero-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, transparent 50%, rgba(8,16,36,.15) 100%),
              linear-gradient(to top, rgba(8,16,36,.5) 0%, transparent 40%);
}

/* Floating review badge */
.ab-hero-img-badge {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  display: flex;
  align-items: center;
  gap: .75rem;
  background: rgba(255,255,255,.95);
  border-radius: 14px;
  padding: .9rem 1.2rem;
  box-shadow: 0 12px 40px rgba(0,0,0,.18);
  backdrop-filter: blur(12px);
}

.ab-hero-img-badge i {
  color: var(--gold);
  font-size: 1.3rem;
}

.ab-hero-img-badge strong {
  display: block;
  font-size: .95rem;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
}

.ab-hero-img-badge span {
  font-size: .72rem;
  color: var(--gray-400);
}

/* Content side */
.ab-hero-content-side {
  background: var(--primary);
  display: flex;
  align-items: center;
  padding: clamp(5rem,8vw,8rem) clamp(2rem,5vw,5rem);
  position: relative;
  overflow: hidden;
}

.ab-hero-content-side::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -20%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(255,107,53,.14) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}

.ab-hero-content-side::after {
  content: '';
  position: absolute;
  bottom: -25%;
  left: -15%;
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, rgba(46,196,182,.1) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}

.ab-hero-content { position: relative; z-index: 2; max-width: 520px; }

.ab-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .32rem .9rem;
  background: rgba(247,201,72,.12);
  border: 1px solid rgba(247,201,72,.25);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.2rem;
}

.ab-eyebrow i { font-size: .65rem; }

.ab-hero h1 {
  font-size: clamp(2rem,4vw,3.2rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 1.1rem;
}

.ab-heading-accent {
  background: linear-gradient(135deg, var(--accent), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.ab-hero p {
  font-size: .98rem;
  color: rgba(255,255,255,.6);
  line-height: 1.78;
  margin-bottom: 1.8rem;
  font-weight: 300;
}

.ab-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin-bottom: 2rem;
}

.ab-pill {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  padding: .42rem .9rem;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
}

.ab-pill i { color: var(--gold); font-size: .72rem; }

.ab-hero-actions {
  display: flex;
  gap: .85rem;
  flex-wrap: wrap;
}

/* ══════════════════════════════════════════════
   STATS STRIP
══════════════════════════════════════════════ */
.ab-stats-strip {
  background: #fff;
  border-top: 1px solid rgba(14,28,53,.06);
  border-bottom: 1px solid rgba(14,28,53,.06);
  padding: 2rem 0;
}

.ab-stats-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}

.ab-stat {
  text-align: center;
  padding: .8rem 2.5rem;
}

.ab-stat-num {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--accent), var(--gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: .3rem;
}

.ab-stat-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gray-400);
}

.ab-stat-div {
  width: 1px;
  height: 36px;
  background: rgba(14,28,53,.1);
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════
   STORY SECTION
══════════════════════════════════════════════ */
.ab-story-section { background: #fff; }

.ab-story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem,6vw,7rem);
  align-items: center;
}

/* Visual side */
.ab-story-visual { position: relative; }

.ab-story-img-wrap {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.ab-story-img-wrap img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  display: block;
  transition: transform .6s var(--ease-out);
}

.ab-story-img-wrap:hover img { transform: scale(1.04); }

.ab-story-img-accent {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-xl);
  border: 3px solid var(--accent);
  transform: translate(14px, 14px);
  z-index: -1;
  opacity: .4;
}

/* Floating card */
.ab-story-float-card {
  position: absolute;
  bottom: -1.5rem;
  right: -1.5rem;
  background: #fff;
  border-radius: 16px;
  padding: 1rem 1.25rem;
  box-shadow: 0 16px 48px rgba(14,28,53,.14);
  border: 1px solid rgba(14,28,53,.06);
  display: flex;
  align-items: center;
  gap: .8rem;
  max-width: 240px;
}

.ab-sfc-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--accent), #ff8a5c);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .9rem;
  flex-shrink: 0;
}

.ab-story-float-card strong {
  display: block;
  font-size: .85rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1.2;
}

.ab-story-float-card span {
  font-size: .72rem;
  color: var(--gray-400);
}

/* Copy side */
.ab-story-copy { }

.ab-story-copy h2 {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  color: var(--primary);
  line-height: 1.18;
  margin-bottom: 1.2rem;
}

.ab-story-copy p {
  font-size: .97rem;
  color: var(--gray-500);
  line-height: 1.85;
  margin-bottom: 1rem;
}

.ab-story-checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
  margin-top: 1.6rem;
}

.ab-story-check {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-size: .87rem;
  color: var(--gray-600);
  font-weight: 500;
}

.ab-story-check i {
  color: var(--success);
  font-size: .82rem;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════
   MISSION BANNER
══════════════════════════════════════════════ */
.ab-mission-banner {
  background: linear-gradient(145deg, var(--primary) 0%, #0d1f3c 55%, var(--primary-light) 100%);
  padding: clamp(4rem,7vw,6rem) 0;
  position: relative;
  overflow: hidden;
}

.ab-mission-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.ab-mission-glow--l {
  width: 400px; height: 400px;
  top: -50%; left: -10%;
  background: radial-gradient(circle, rgba(255,107,53,.12), transparent);
}

.ab-mission-glow--r {
  width: 350px; height: 350px;
  bottom: -40%; right: -8%;
  background: radial-gradient(circle, rgba(46,196,182,.1), transparent);
}

.ab-mission-inner {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}

.ab-mission-quote-mark {
  font-family: var(--font-display);
  font-size: 6rem;
  line-height: .6;
  color: var(--accent);
  opacity: .25;
  margin-bottom: 1rem;
  display: block;
}

.ab-mission-quote {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.5vw, 1.75rem);
  font-weight: 600;
  color: rgba(255,255,255,.92);
  line-height: 1.5;
  font-style: italic;
  margin-bottom: 2rem;
}

.ab-mission-attr {
  display: inline-flex;
  align-items: center;
  gap: .9rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: .55rem 1.2rem .55rem .55rem;
}

.ab-mission-av {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--gold));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: .78rem;
  color: #fff;
  flex-shrink: 0;
}

.ab-mission-attr strong {
  display: block;
  font-size: .85rem;
  color: #fff;
  font-weight: 700;
  line-height: 1.2;
}

.ab-mission-attr span {
  font-size: .72rem;
  color: rgba(255,255,255,.45);
}

/* ══════════════════════════════════════════════
   VALUES
══════════════════════════════════════════════ */
.ab-values-section { background: #f4f6fb; }

.ab-values-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1.4rem;
}

.ab-value-card {
  background: #fff;
  border-radius: 20px;
  padding: 2rem 1.6rem;
  border: 1px solid rgba(14,28,53,.06);
  box-shadow: 0 2px 16px rgba(14,28,53,.05);
  position: relative;
  overflow: hidden;
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out);
}

.ab-value-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(14,28,53,.12);
}

.ab-value-icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
}

.ab-vi-orange { background: linear-gradient(135deg, rgba(255,107,53,.12), rgba(255,107,53,.05)); }
.ab-vi-teal   { background: linear-gradient(135deg, rgba(46,196,182,.12), rgba(46,196,182,.05)); }
.ab-vi-gold   { background: linear-gradient(135deg, rgba(247,201,72,.15), rgba(247,201,72,.06)); }
.ab-vi-green  { background: linear-gradient(135deg, rgba(34,197,94,.1),  rgba(34,197,94,.04)); }

.ab-value-emoji { font-size: 1.6rem; line-height: 1; }

.ab-value-num {
  position: absolute;
  top: 1.2rem;
  right: 1.4rem;
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 900;
  color: rgba(14,28,53,.04);
  line-height: 1;
  user-select: none;
}

.ab-value-card h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .55rem;
  line-height: 1.3;
}

.ab-value-card p {
  font-size: .85rem;
  color: var(--gray-400);
  line-height: 1.68;
  margin: 0 0 1.2rem;
}

.ab-value-line {
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--gold));
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: opacity .3s, transform .3s var(--ease-out);
}

.ab-value-card:hover .ab-value-line {
  opacity: 1;
  transform: scaleX(1);
}

/* ══════════════════════════════════════════════
   WHY US
══════════════════════════════════════════════ */
.ab-why-section { background: #fff; }

.ab-why-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1.4rem;
}

.ab-why-card {
  background: #fafbfe;
  border: 1px solid rgba(14,28,53,.07);
  border-radius: 16px;
  padding: 1.8rem 1.5rem;
  transition: box-shadow .25s, transform .25s, border-color .25s;
}

.ab-why-card:hover {
  box-shadow: 0 10px 36px rgba(14,28,53,.1);
  transform: translateY(-4px);
  border-color: rgba(255,107,53,.15);
  background: #fff;
}

.ab-why-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(255,107,53,.1), rgba(255,107,53,.04));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 1.1rem;
  margin-bottom: 1rem;
  transition: background .25s, transform .25s;
}

.ab-why-card:hover .ab-why-icon {
  background: linear-gradient(135deg, var(--accent), #ff8a5c);
  color: #fff;
  transform: scale(1.08) rotate(4deg);
}

.ab-why-card h4 {
  font-size: .97rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .5rem;
}

.ab-why-card p {
  font-size: .84rem;
  color: var(--gray-400);
  line-height: 1.68;
  margin: 0;
}

/* ══════════════════════════════════════════════
   TIMELINE
══════════════════════════════════════════════ */
.ab-timeline-section { background: #f4f6fb; }

.ab-timeline {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  padding: 1rem 0;
}

/* Centre line */
.ab-timeline::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: linear-gradient(to bottom,
    transparent 0%,
    rgba(255,107,53,.3) 10%,
    rgba(255,107,53,.3) 90%,
    transparent 100%);
  transform: translateX(-50%);
}

.ab-timeline-item {
  display: grid;
  grid-template-columns: 1fr 32px 1fr;
  gap: 0 1.5rem;
  align-items: start;
  margin-bottom: 2.5rem;
  position: relative;
}

/* Year — left side by default */
.ab-tl-year {
  text-align: right;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 800;
  color: var(--accent);
  padding-top: .3rem;
  padding-right: .5rem;
}

/* Dot — centre column */
.ab-tl-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid rgba(255,107,53,.4);
  margin: .35rem auto 0;
  position: relative;
  z-index: 2;
  transition: border-color .3s, transform .3s;
  flex-shrink: 0;
}

.ab-timeline-item:hover .ab-tl-dot {
  border-color: var(--accent);
  transform: scale(1.25);
}

.ab-tl-dot--active {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(255,107,53,.2);
}

/* Content — right side by default */
.ab-tl-content {
  background: #fff;
  border-radius: 14px;
  padding: 1.1rem 1.3rem;
  border: 1px solid rgba(14,28,53,.07);
  box-shadow: 0 2px 12px rgba(14,28,53,.05);
  transition: box-shadow .25s, transform .25s;
}

.ab-timeline-item:hover .ab-tl-content {
  box-shadow: 0 8px 32px rgba(14,28,53,.1);
  transform: translateX(4px);
}

.ab-tl-content h4 {
  font-size: .95rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .35rem;
}

.ab-tl-content p {
  font-size: .83rem;
  color: var(--gray-400);
  line-height: 1.65;
  margin: 0;
}

.ab-tl-content--active {
  border-color: rgba(255,107,53,.2);
  background: linear-gradient(135deg, rgba(255,107,53,.03), rgba(247,201,72,.02));
}

/* Right-side items — swap year and content */
.ab-tl-right .ab-tl-year    { order: 3; text-align: left; padding-right: 0; padding-left: .5rem; }
.ab-tl-right .ab-tl-dot     { order: 2; }
.ab-tl-right .ab-tl-content { order: 1; }

.ab-tl-right:hover .ab-tl-content { transform: translateX(-4px); }

/* ══════════════════════════════════════════════
   TEAM
══════════════════════════════════════════════ */
.ab-team-section { background: #fff; }

.ab-team-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1.4rem;
}

.ab-team-card {
  background: #fff;
  border: 1px solid rgba(14,28,53,.07);
  border-radius: 20px;
  padding: 1.8rem 1.4rem 1.4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: transform .28s var(--ease-out), box-shadow .28s var(--ease-out), border-color .28s;
}

.ab-team-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 18px 50px rgba(14,28,53,.12);
  border-color: rgba(255,107,53,.15);
}

.ab-team-avatar {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.2rem;
  margin-bottom: 1.1rem;
  flex-shrink: 0;
  transition: transform .3s var(--ease-out);
}

.ab-team-card:hover .ab-team-avatar { transform: scale(1.08); }

.ab-av-gradient-1 { background: linear-gradient(135deg, var(--accent), #ff8a5c); }
.ab-av-gradient-2 { background: linear-gradient(135deg, var(--teal), var(--teal-dark)); }
.ab-av-gradient-3 { background: linear-gradient(135deg, var(--gold), #e5b340); }
.ab-av-gradient-4 { background: linear-gradient(135deg, #7c3aed, #5b21b6); }

.ab-team-body { flex: 1; }

.ab-team-body h4 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: .25rem;
}

.ab-team-role {
  display: block;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--accent);
  margin-bottom: .7rem;
}

.ab-team-body p {
  font-size: .82rem;
  color: var(--gray-400);
  line-height: 1.6;
  margin: 0;
}

.ab-team-footer {
  margin-top: 1.1rem;
  padding-top: .9rem;
  border-top: 1px solid rgba(14,28,53,.06);
  width: 100%;
}

.ab-team-trips {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .75rem;
  font-weight: 600;
  color: var(--gray-400);
}

.ab-team-trips i { color: var(--accent); font-size: .68rem; }

/* ══════════════════════════════════════════════
   SOCIAL PROOF STRIP
══════════════════════════════════════════════ */
.ab-proof-strip {
  background: linear-gradient(135deg, rgba(255,107,53,.05), rgba(247,201,72,.04));
  border-top: 1px solid rgba(255,107,53,.1);
  border-bottom: 1px solid rgba(255,107,53,.1);
  padding: 2rem 0;
}

.ab-proof-inner {
  display: flex;
  align-items: center;
  gap: 2.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.ab-proof-rating {
  display: flex;
  align-items: center;
  gap: .8rem;
  flex-shrink: 0;
}

.ab-proof-stars {
  font-size: 1.4rem;
  color: var(--gold);
  letter-spacing: .05em;
  line-height: 1;
}

.ab-proof-rating strong {
  display: block;
  font-size: .95rem;
  font-weight: 800;
  color: var(--primary);
  line-height: 1.2;
}

.ab-proof-rating span {
  font-size: .72rem;
  color: var(--gray-400);
}

.ab-proof-div {
  width: 1px;
  height: 36px;
  background: rgba(14,28,53,.1);
  flex-shrink: 0;
}

.ab-proof-quotes { flex: 1; min-width: 220px; }

.ab-proof-quote {
  font-style: italic;
  font-size: .92rem;
  color: var(--primary);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: .2rem;
}

.ab-proof-author {
  font-size: .75rem;
  color: var(--gray-400);
}

/* ══════════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════════ */
.ab-cta-section {
  position: relative;
  padding: clamp(5rem,10vw,8rem) 0;
  overflow: hidden;
}

.ab-cta-bg-img {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.ab-cta-bg-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ab-cta-bg-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(8,16,36,.92) 0%, rgba(8,16,36,.7) 60%, rgba(8,16,36,.5) 100%);
}

.ab-cta-inner {
  position: relative;
  z-index: 2;
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.ab-cta-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .85rem;
  background: rgba(247,201,72,.12);
  border: 1px solid rgba(247,201,72,.25);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.2rem;
}

.ab-cta-inner h2 {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 900;
  color: #fff;
  margin-bottom: 1rem;
  line-height: 1.12;
}

.ab-cta-inner p {
  font-size: 1rem;
  color: rgba(255,255,255,.62);
  line-height: 1.75;
  margin-bottom: 2rem;
  font-weight: 300;
}

.ab-cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 1.8rem;
}

.ab-cta-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  font-size: .78rem;
  color: rgba(255,255,255,.45);
  font-weight: 500;
}

.ab-cta-trust i {
  color: var(--gold);
  font-size: .72rem;
  margin-right: .22rem;
}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .ab-values-grid { grid-template-columns: repeat(2,1fr); }
  .ab-team-grid   { grid-template-columns: repeat(2,1fr); }
  .ab-why-grid    { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  .ab-hero               { grid-template-columns: 1fr; min-height: auto; }
  .ab-hero-img-side      { height: 55vw; min-height: 300px; max-height: 420px; }
  .ab-hero-content-side  { padding: 3rem 1.5rem 3.5rem; }
  .ab-hero h1            { font-size: clamp(1.8rem,6vw,2.6rem); }
  .ab-story-grid         { grid-template-columns: 1fr; }
  .ab-story-visual       { order: -1; }
  .ab-story-img-wrap img { height: 320px; }
  .ab-story-float-card   { right: 1rem; bottom: -1rem; }
  .ab-timeline::before   { left: 16px; transform: none; }
  .ab-timeline-item      { grid-template-columns: 32px 1fr; }
  .ab-tl-year            { display: none; }
  .ab-tl-right .ab-tl-year    { display: none; }
  .ab-tl-right .ab-tl-dot     { order: 1; }
  .ab-tl-right .ab-tl-content { order: 2; }
  .ab-tl-right:hover .ab-tl-content { transform: translateX(4px); }
  .ab-proof-div          { display: none; }
  .ab-proof-inner        { gap: 1.2rem; flex-direction: column; text-align: center; }
}

@media (max-width: 640px) {
  .ab-values-grid { grid-template-columns: 1fr; }
  .ab-team-grid   { grid-template-columns: 1fr 1fr; }
  .ab-why-grid    { grid-template-columns: 1fr; }
  .ab-stats-grid  { justify-content: space-around; gap: .5rem; }
  .ab-stat        { padding: .6rem 1rem; }
  .ab-stat-div    { display: none; }
  .ab-mission-quote { font-size: 1.1rem; }
  .ab-story-checks { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .ab-team-grid { grid-template-columns: 1fr; }
  .ab-hero-img-side { height: 70vw; }
}
