/*
Theme Name: Ryf Travel
Theme URI: https://ryftravel.com
Author: Ryf Travel
Description: Premium travel agency theme
Version: 3.0.0
License: GNU General Public License v2 or later
Text Domain: ryftravel
*/

/* =============================================
   DESIGN TOKENS
============================================= */
:root {
  --primary:      #1a3d6e;
  --primary-dark: #102848;
  --primary-light:#2d5a9e;
  --accent:       #ff6b35;
  --accent-dark:  #e85520;
  --gold:         #f4c430;
  --light:        #f8f9fa;
  --light-2:      #eef2f7;
  --dark:         #0d1b2a;
  --text:         #2c3e50;
  --text-light:   #6b7280;
  --white:        #ffffff;
  --border:       #e2e8f0;
  --shadow-sm:    0 2px 8px rgba(26,61,110,.10);
  --shadow-md:    0 8px 32px rgba(26,61,110,.15);
  --radius-sm:    6px;
  --radius-md:    12px;
  --radius-lg:    20px;
  --font-head:    'Playfair Display', Georgia, serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition:   0.3s cubic-bezier(0.4,0,0.2,1);
  --max-width:    1280px;
}

/* =============================================
   RESET & BASE
============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
html, html.admin-bar { margin-top: 0 !important; padding-top: 0 !important; }
#wpadminbar { display: none !important; }
body { font-family: var(--font-body); color: var(--text); line-height: 1.6; background: var(--white); overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: var(--transition); }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* =============================================
   TYPOGRAPHY
============================================= */
h1,h2,h3,h4,h5,h6 { font-family: var(--font-head); line-height: 1.2; color: var(--dark); font-weight: 700; }
h1 { font-size: clamp(2rem,5vw,3.5rem); }
h2 { font-size: clamp(1.6rem,3.5vw,2.5rem); }
h3 { font-size: clamp(1.2rem,2.5vw,1.75rem); }
h4 { font-size: 1.25rem; }
p  { margin-bottom: 1rem; }
.section-label { display:inline-block; font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:.75rem; }
.section-title { font-family:var(--font-head); margin-bottom:1rem; color:var(--dark); font-size:clamp(1.5rem,3vw,2.2rem); }
.section-subtitle { font-size:1.05rem; color:var(--text-light); line-height:1.7; max-width:640px; margin:0 auto; }
.text-center { text-align:center; }
.container { max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; width:100%; }
.section { padding:5rem 0; }
.section--light { background:var(--light); }
.section--gray  { background:var(--light-2); }
.mt-3 { margin-top:2rem; }
.btn { display:inline-block; padding:.75rem 2rem; border-radius:8px; font-weight:700; font-size:.95rem; cursor:pointer; transition:all .2s; text-decoration:none; }
.btn-primary { background:var(--accent); color:white; }
.btn-primary:hover { background:var(--accent-dark); transform:translateY(-1px); }
.btn-secondary { background:transparent; border:2px solid var(--primary); color:var(--primary); }
.btn-secondary:hover { background:var(--primary); color:white; }
.btn-sm { padding:.5rem 1.25rem; font-size:.85rem; }
.btn-outline-primary { background:transparent; border:2px solid var(--primary); color:var(--primary); display:inline-block; padding:.75rem 2rem; border-radius:8px; font-weight:700; font-size:.95rem; transition:all .2s; text-decoration:none; }
.btn-outline-primary:hover { background:var(--primary); color:white; }
.btn-outline-white { background:transparent; border:2px solid rgba(255,255,255,.6); color:white; display:inline-block; padding:.75rem 2rem; border-radius:8px; font-weight:700; font-size:.95rem; transition:all .2s; text-decoration:none; }
.btn-outline-white:hover { background:rgba(255,255,255,.15); border-color:white; }

/* =============================================
   HEADER
============================================= */
.site-header { position:sticky; top:0; left:0; right:0; z-index:300; }

/* Top utility bar */
.hdr-topbar { background:var(--primary); height:36px; display:flex; align-items:center; border-bottom:none; }
.hdr-topbar__inner { max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; width:100%; display:flex; align-items:center; justify-content:space-between; font-size:.78rem; color:rgba(255,255,255,.85); }
.hdr-topbar__msg { font-weight:500; color:rgba(255,255,255,.85); }
.hdr-topbar__right { display:flex; align-items:center; gap:.75rem; color:rgba(255,255,255,.8); }
.hdr-topbar__right a { color:rgba(255,255,255,.85); text-decoration:none; transition:color .15s; }
.hdr-topbar__right a:hover { color:white; }
.hdr-sep { color:rgba(255,255,255,.3); }

/* Main nav bar */
.hdr-main { background:white; border-bottom:1px solid #e8edf2; box-shadow:0 2px 12px rgba(0,0,0,.07); }
.hdr-main__inner { max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; height:72px; display:flex; align-items:center; gap:2rem; }

/* Logo */
.hdr-logo { display:flex; align-items:center; flex-shrink:0; text-decoration:none; }
.hdr-logo__svg, .hdr-logo__img { display:block; }
.hdr-logo__img { height:46px; width:auto; object-fit:contain; }
.hdr-logo__color, .hdr-logo__white { height:44px; width:auto; display:block; object-fit:contain; }
.mn-head img { height:40px; width:auto; display:block; }
@media (max-width: 640px) {
  .hdr-logo__color, .hdr-logo__white { height:36px; }
}

/* Desktop nav */
.hdr-nav { flex:1; display:flex; justify-content:center; }
.hdr-nav__list { display:flex; align-items:center; gap:0; list-style:none; height:72px; }
.hdr-nav__item { position:relative; height:100%; display:flex; align-items:center; }
.hdr-nav__link { display:flex; align-items:center; gap:.35rem; padding:0 1rem; height:100%; font-size:.875rem; font-weight:600; color:#1a202c; text-decoration:none; white-space:nowrap; transition:color .15s; border-bottom:3px solid transparent; }
.hdr-nav__link:hover,.hdr-nav__item--open .hdr-nav__link { color:var(--primary); border-bottom-color:var(--accent); }
.hdr-nav__link--hot { color:var(--accent); font-weight:700; }
.hdr-caret { transition:transform .2s; }
.hdr-nav__item--open .hdr-caret { transform:rotate(180deg); }

/* Header actions */
.hdr-actions { display:flex; align-items:center; gap:.75rem; flex-shrink:0; }
.hdr-tel { display:flex; align-items:center; gap:.35rem; font-size:.8rem; font-weight:600; color:var(--primary); text-decoration:none; white-space:nowrap; }
.hdr-tel:hover { color:var(--accent); }
.hdr-cta { background:var(--accent); color:white; font-size:.85rem; font-weight:700; padding:.55rem 1.25rem; border-radius:6px; text-decoration:none; white-space:nowrap; transition:all .15s; }
.hdr-cta:hover { background:var(--accent-dark); transform:translateY(-1px); }
.hdr-burger { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; background:none; border:none; }
.hdr-burger span { display:block; width:22px; height:2px; background:var(--primary); border-radius:2px; transition:all .25s; }

/* ── Mega menu ────────────────────────────────────────────────────── */
.hdr-mega-container { position:fixed; top:108px; left:0; right:0; z-index:290; height:0; overflow:visible; transition:top .22s ease; }
.site-header.scrolled .hdr-mega-container { top:72px; }
.hdr-mega { display:none; background:#fff; border-top:3px solid var(--accent); box-shadow:0 8px 40px rgba(0,0,0,.12); animation:megaDown .18s ease forwards; }
.hdr-mega.is-open { display:block; }
@keyframes megaDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

/* Standard 3-col inner (types / flags / featured card) */
.hdr-mega__inner { max-width:var(--max-width); margin:0 auto; padding:2rem 2rem 1.75rem; display:grid; grid-template-columns:1fr 1fr 260px; gap:3rem; align-items:start; }

/* Column label */
.hm-label { font-size:.68rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:#9aa5b4; margin:0 0 .7rem; padding-bottom:.5rem; border-bottom:1px solid #edf2f7; }

/* List items — no emoji, plain clean links */
.hm-list { list-style:none; margin:0; padding:0; }
.hm-list a { display:flex; align-items:center; gap:.55rem; padding:.38rem .45rem; border-radius:5px; font-size:.875rem; color:#2d3748; text-decoration:none; transition:background .1s,color .1s; line-height:1.4; }
.hm-list a:hover { background:#f0f5ff; color:var(--primary); }
.hm-list--sm a { font-size:.82rem; padding:.3rem .4rem; }

/* Flag images */
.hm-flag { width:22px; height:16px; object-fit:cover; border-radius:2px; flex-shrink:0; box-shadow:0 0 0 1px rgba(0,0,0,.1); }

/* "See all" arrow link */
.hm-all { display:inline-flex; align-items:center; gap:.3rem; margin-top:.8rem; font-size:.8rem; font-weight:700; color:var(--accent); text-decoration:none; }
.hm-all:hover { text-decoration:underline; }

/* Featured card (right col) */
.hmf { display:block; border-radius:10px; overflow:hidden; position:relative; height:210px; text-decoration:none; transition:transform .2s; }
.hmf:hover { transform:translateY(-2px); }
.hmf__bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .35s ease; }
.hmf:hover .hmf__bg { transform:scale(1.05); }
.hmf::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.25) 55%,transparent 100%); }
.hmf__body { position:absolute; bottom:0; left:0; right:0; padding:1.1rem 1.2rem; z-index:1; display:flex; flex-direction:column; gap:.18rem; }
.hmf__badge { display:inline-block; background:var(--accent); color:#fff; font-size:.62rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; padding:.18rem .55rem; border-radius:3px; margin-bottom:.2rem; width:fit-content; }
.hmf__title { font-size:.95rem; font-weight:800; color:#fff; line-height:1.25; }
.hmf__sub,.hmf__price { font-size:.73rem; color:rgba(255,255,255,.8); }
.hmf__price b { color:#ffd166; font-size:1rem; }
.hmf__cta { display:inline-block; margin-top:.35rem; font-size:.75rem; font-weight:700; color:#fff; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.35); padding:.28rem .7rem; border-radius:4px; width:fit-content; }

/* ── Maroc mega — map + 4 text columns ───────────────────────────── */
.hdr-mega__inner--maroc { grid-template-columns:200px repeat(4,1fr); gap:2rem; padding:1.75rem 2rem; align-items:start; flex-wrap:wrap; }
.hdr-mega__inner--maroc .hm-dest-all { grid-column:1/-1; }

.hm-maroc-map { grid-row:1; }
.hm-map-link { display:block; border-radius:8px; overflow:hidden; text-decoration:none; position:relative; transition:box-shadow .15s; }
.hm-map-link:hover { box-shadow:0 4px 16px rgba(0,0,0,.18); }
.hm-map-bg { width:100%; height:155px; background-size:cover; background-position:center; }
.hm-map-caption { display:block; background:var(--primary); color:#fff; font-size:.72rem; font-weight:700; text-align:center; padding:.5rem .5rem; letter-spacing:.04em; }

/* ── Destinations mega — region thumbnail cards ───────────────────── */
.hdr-mega__inner--dest2 { grid-template-columns:repeat(4,1fr); gap:1.75rem; padding:1.75rem 2rem 1.25rem; align-items:start; }
.hdr-mega__inner--dest2 .hm-dest-all { grid-column:1/-1; }

.hm-region-card { display:block; border-radius:8px; overflow:hidden; height:90px; background-size:cover; background-position:center; position:relative; text-decoration:none; margin-bottom:.75rem; transition:transform .2s; }
.hm-region-card:hover { transform:translateY(-2px); }
.hm-region-card::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.15) 60%,transparent 100%); border-radius:8px; }
.hm-region-card__label { position:absolute; bottom:.55rem; left:.7rem; color:#fff; font-size:.78rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; z-index:1; line-height:1.2; }

/* Shared dest columns (used in Maroc wide) */
.hm-dest-col { }
.hm-dest-all { grid-column:1/-1; padding-top:.9rem; border-top:1px solid #edf2f7; text-align:center; }
.hm-dest-all a { font-size:.875rem; font-weight:700; color:var(--primary); text-decoration:none; }
.hm-dest-all a:hover { color:var(--accent); }

/* Overlay */
.hdr-mega-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.3); z-index:289; top:108px; transition:top .22s ease; }
.site-header.scrolled .hdr-mega-overlay { top:72px; }
.hdr-mega-overlay.is-active { display:block; }

/* Mobile nav */
.mn-backdrop { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:399; }
.mn-backdrop.is-open { display:block; }
.mn-panel { position:fixed; top:0; left:-340px; width:320px; max-width:90vw; height:100vh; background:white; z-index:400; overflow-y:auto; display:flex; flex-direction:column; transition:left .28s cubic-bezier(.4,0,.2,1); box-shadow:4px 0 24px rgba(0,0,0,.18); }
.mn-panel.is-open { left:0; }
.mn-head { display:flex; align-items:center; justify-content:space-between; padding:1.25rem; border-bottom:1px solid #e2e8f0; position:sticky; top:0; background:white; z-index:1; }
.mn-close { font-size:1.3rem; width:34px; height:34px; display:flex; align-items:center; justify-content:center; border-radius:50%; background:#f0f4f8; border:none; cursor:pointer; color:var(--text); }
.mn-section { border-bottom:1px solid #f0f4f8; }
.mn-group-toggle { width:100%; display:flex; align-items:center; justify-content:space-between; padding:.9rem 1.25rem; font-size:.9rem; font-weight:700; color:var(--dark); background:none; border:none; cursor:pointer; text-align:left; }
.mn-group { display:none; padding:0 1.25rem .75rem 1.5rem; }
.mn-group.is-open { display:block; }
.mn-group a { display:block; padding:.5rem; font-size:.875rem; color:#4a5568; text-decoration:none; border-radius:4px; transition:background .12s; }
.mn-group a:hover { background:#f0f4f8; color:var(--primary); }
.mn-flat { padding:.5rem 1.25rem; }
.mn-flat a { display:block; padding:.6rem .5rem; font-size:.875rem; font-weight:600; color:#2d3748; text-decoration:none; border-radius:4px; }
.mn-flat a:hover { color:var(--accent); }
.mn-footer { padding:1.25rem; margin-top:auto; border-top:1px solid #e2e8f0; display:flex; flex-direction:column; gap:.75rem; }
.mn-cta { display:block; text-align:center; padding:.75rem; background:var(--accent); color:white; font-weight:700; border-radius:8px; text-decoration:none; }
.mn-tel { display:block; text-align:center; font-size:.875rem; font-weight:600; color:var(--primary); text-decoration:none; }

/* =============================================
   TUI HERO CAROUSEL
============================================= */
.tui-hero { position:relative; width:100%; height:480px; overflow:hidden; }
.tui-hero__track { position:absolute; inset:0; overflow:hidden; }
.tui-hero__slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1s ease; will-change:opacity; }
.tui-hero__slide.active { opacity:1; z-index:1; }
.tui-hero__overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(10,20,50,.85) 0%,rgba(10,20,50,.55) 40%,rgba(10,20,50,.15) 70%,transparent 100%); }
.tui-hero__content { position:absolute; top:45%; left:5%; transform:translateY(-50%); color:white; max-width:500px; z-index:3; }
.tui-hero__tag { display:block; width:fit-content; background:rgba(255,107,53,.9); color:white; font-size:.75rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; padding:.3rem 1rem; border-radius:20px; margin-bottom:.875rem; }
.tui-hero__title { font-family:var(--font-head); font-size:clamp(2.2rem,4.5vw,3.2rem); font-weight:800; line-height:1.12; color:white; margin-bottom:.75rem; text-shadow:0 2px 20px rgba(0,0,0,.4); }
.tui-hero__sub { font-size:1rem; color:rgba(255,255,255,.85); line-height:1.6; margin-bottom:1.5rem; }
.tui-hero__btn { display:inline-block; background:var(--accent); color:white; padding:.8rem 2rem; border-radius:30px; font-weight:700; font-size:1rem; text-decoration:none; transition:all .2s; box-shadow:0 4px 16px rgba(255,107,53,.4); }
.tui-hero__btn:hover { background:var(--accent-dark); transform:translateY(-2px); box-shadow:0 6px 24px rgba(255,107,53,.5); }
.tui-hero__arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:42px; height:42px; background:rgba(255,255,255,.9); border:none; border-radius:50%; font-size:1.6rem; color:var(--primary); cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 12px rgba(0,0,0,.2); transition:background .15s; }
.tui-hero__arrow--prev { left:1.25rem; }
.tui-hero__arrow--next { right:1.25rem; }
.tui-hero__arrow:hover { background:white; }
.tui-hero__bottom { position:absolute; bottom:0; left:0; right:0; height:46px; background:white; z-index:10; display:flex; align-items:center; justify-content:space-between; padding:0 1.5rem; border-top:1px solid #e8edf2; }
.tui-hero__tabs { display:flex; gap:.25rem; }
.tui-hero__tab { padding:.4rem 1.1rem; font-size:.85rem; font-weight:700; border:none; background:none; cursor:pointer; color:#718096; border-bottom:3px solid transparent; transition:color .15s,border-color .15s; }
.tui-hero__tab.active { color:var(--primary); border-bottom-color:var(--accent); }
.tui-hero__dots { display:flex; gap:.4rem; align-items:center; }
.tui-hero__dots .hs-dot { width:8px; height:8px; border-radius:50%; background:rgba(0,0,0,.25); border:none; cursor:pointer; transition:all .25s; padding:0; }
.tui-hero__dots .hs-dot.active { background:var(--accent); width:20px; border-radius:4px; }

/* =============================================
   TUI SEARCH SECTION
============================================= */
.tui-search { background:white; border-bottom:3px solid var(--accent); box-shadow:0 4px 16px rgba(0,0,0,.08); padding:.875rem 0; }
.tui-search__panel { display:none; }
.tui-search__panel.active { display:block; }
.tui-search__row { display:flex; align-items:stretch; border:1.5px solid #e2e8f0; border-radius:8px; overflow:hidden; background:white; box-shadow:0 2px 12px rgba(26,61,110,.06); height:60px; }
.tui-search__field { flex:1; border-right:1.5px solid #e2e8f0; padding:.45rem 1.1rem; display:flex; flex-direction:column; justify-content:center; height:100%; }
.tui-search__field--sm { flex:.65; }
.tui-search__field label { font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:#9ca3af; margin-bottom:.15rem; white-space:nowrap; }
.tui-search__field select,.tui-search__field input { width:100%; border:none; outline:none; font-size:.9rem; color:#1a202c; background:transparent; padding:0; font-family:var(--font-body); }
.tui-search__counter { display:flex; align-items:center; gap:.5rem; }
.tui-ctr-dec,.tui-ctr-inc { width:22px; height:22px; border-radius:50%; background:#eef2f7; border:none; font-size:.9rem; cursor:pointer; display:flex; align-items:center; justify-content:center; font-weight:700; transition:background .15s; }
.tui-ctr-dec:hover,.tui-ctr-inc:hover { background:var(--primary); color:white; }
.tui-ctr-val { font-weight:700; min-width:20px; text-align:center; font-size:.95rem; }
.tui-search__btn { flex-shrink:0; height:100%; padding:0 2rem; background:var(--accent); color:white; border:none; font-size:.95rem; font-weight:700; cursor:pointer; display:flex; align-items:center; gap:.6rem; font-family:var(--font-body); transition:background .15s; white-space:nowrap; border-radius:0 6px 6px 0; }
.tui-search__btn:hover { background:var(--accent-dark); }

/* =============================================
   STATS BAR
============================================= */
.stats-bar { background:var(--primary); padding:1.75rem 0; position:relative; z-index:5; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; text-align:center; }
.stat-item { border-right:1px solid rgba(255,255,255,.15); }
.stat-item:last-child { border-right:none; }
.stat-number { font-family:var(--font-head); font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:800; color:white; line-height:1; margin-bottom:.35rem; }
.stat-number span { color:var(--accent); font-size:.7em; }
.stat-label { font-size:.8rem; color:rgba(255,255,255,.7); font-weight:600; letter-spacing:.05em; text-transform:uppercase; }

/* =============================================
   DEAL CARDS
============================================= */
.deals-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; margin-bottom:2rem; }
.deal-card { background:white; border-radius:14px; overflow:hidden; border:1px solid rgba(0,0,0,.06); box-shadow:0 4px 20px rgba(26,61,110,.08); transition:transform .3s,box-shadow .3s; }
.deal-card:hover { transform:translateY(-6px); box-shadow:0 16px 44px rgba(26,61,110,.17); }
.deal-image { position:relative; overflow:hidden; }
.deal-image img { display:block; width:100%; height:240px; object-fit:cover; transition:transform .4s; }
.deal-card:hover .deal-image img { transform:scale(1.04); }
.deal-badge-discount { position:absolute; top:.75rem; left:.75rem; background:var(--accent); color:white; font-size:.75rem; font-weight:800; padding:.25rem .65rem; border-radius:20px; }
.deal-badge-duration { position:absolute; top:.75rem; right:.75rem; background:rgba(0,0,0,.6); color:white; font-size:.75rem; padding:.25rem .65rem; border-radius:20px; }
.deal-body { padding:1.25rem; }
.deal-title { font-size:1.05rem; font-weight:700; color:var(--dark); margin-bottom:.3rem; }
.deal-dest { font-size:.85rem; color:var(--text-light); margin-bottom:.75rem; }
.deal-inc { display:flex; gap:.45rem; flex-wrap:wrap; margin-bottom:1rem; }
.deal-inc span { font-size:.72rem; font-weight:600; background:#eef2f7; color:var(--primary); padding:.2rem .55rem; border-radius:4px; }
.deal-footer { display:flex; align-items:center; justify-content:space-between; gap:.75rem; }
.deal-price { display:flex; align-items:baseline; gap:.3rem; flex-wrap:wrap; }
.deal-price-was { font-size:.8rem; color:#9ca3af; text-decoration:line-through; }
.deal-price-now { font-size:1.5rem; font-weight:800; color:var(--primary); }
.deal-price-pp { font-size:.75rem; color:#9ca3af; }

/* =============================================
   DESTINATION CARDS
============================================= */
.destinations-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; margin-bottom:2.5rem; }
.destination-card { position:relative; border-radius:14px; overflow:hidden; cursor:pointer; }
.destinations-grid .destination-card:first-child { grid-row:span 2; }
.dest-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s ease; }
.destination-card:hover .dest-bg { transform:scale(1.06); }
.dest-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.80) 0%,rgba(0,0,0,.1) 60%,transparent 100%); }
.dest-info { position:absolute; bottom:0; left:0; right:0; padding:1.25rem; color:white; }
.dest-flag { font-size:1.6rem; display:block; margin-bottom:.2rem; }
.dest-name { font-family:var(--font-head); font-size:1.15rem; font-weight:700; color:white; margin-bottom:.3rem; }
.dest-meta { display:flex; justify-content:space-between; font-size:.8rem; color:rgba(255,255,255,.8); margin-bottom:.5rem; }
.dest-price { color:var(--gold); font-weight:700; }
.dest-cta { display:inline-block; font-size:.78rem; font-weight:700; color:white; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.35); padding:.3rem .85rem; border-radius:4px; text-decoration:none; opacity:0; transform:translateY(6px); transition:opacity .25s,transform .25s; }
.destination-card:hover .dest-cta { opacity:1; transform:translateY(0); }

/* =============================================
   CIRCUIT CARDS
============================================= */
.circuits-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.circuit-card { background:white; border-radius:14px; overflow:hidden; border:1px solid rgba(0,0,0,.06); box-shadow:0 4px 20px rgba(26,61,110,.08); transition:transform .3s,box-shadow .3s; }
.circuit-card:hover { transform:translateY(-5px); box-shadow:0 14px 40px rgba(26,61,110,.16); }
.cc-image { position:relative; overflow:hidden; }
.cc-image img { display:block; width:100%; height:260px; object-fit:cover; transition:transform .4s; }
.circuit-card:hover .cc-image img { transform:scale(1.04); }
.cc-badge-days { position:absolute; top:.75rem; right:.75rem; background:var(--primary); color:white; font-size:.72rem; font-weight:700; padding:.25rem .7rem; border-radius:20px; }
.cc-badge-type { position:absolute; top:.75rem; left:.75rem; background:rgba(0,0,0,.55); color:white; font-size:.7rem; padding:.2rem .6rem; border-radius:4px; backdrop-filter:blur(4px); }
.cc-body { padding:1.1rem 1.25rem 1.25rem; }
.cc-title { font-size:1rem; font-weight:700; color:var(--dark); margin-bottom:.4rem; }
.cc-countries { font-size:.82rem; color:var(--text-light); margin-bottom:.75rem; }
.cc-footer { display:flex; align-items:center; justify-content:space-between; }
.cc-price { font-size:.9rem; color:var(--text-light); }
.cc-price strong { font-size:1.2rem; font-weight:800; color:var(--primary); }

/* =============================================
   THEME TILES
============================================= */
.themes-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:1rem; margin-bottom:2rem; }
.theme-tile { border-radius:12px; overflow:hidden; text-decoration:none; transition:transform .25s,box-shadow .25s; box-shadow:0 4px 16px rgba(0,0,0,.12); }
.theme-tile:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.2); }
.theme-tile__img { height:140px; background-size:cover; background-position:center; transition:transform .4s; }
.theme-tile:hover .theme-tile__img { transform:scale(1.06); }
.theme-tile__body { background:var(--primary); color:white; padding:.7rem .5rem; text-align:center; }
.theme-tile__body span { font-size:1.3rem; display:block; }
.theme-tile__body strong { font-size:.75rem; font-weight:700; letter-spacing:.03em; }

/* =============================================
   FEATURES (WHY US)
============================================= */
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.feature-card { background:white; border-radius:16px; padding:2rem 1.5rem; text-align:center; border:1px solid var(--border); transition:transform .3s,box-shadow .3s; box-shadow:0 2px 12px rgba(26,61,110,.06); }
.feature-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.feature-icon-wrap { width:64px; height:64px; background:linear-gradient(135deg,var(--primary),var(--primary-light)); border-radius:16px; display:flex; align-items:center; justify-content:center; margin:0 auto 1.25rem; box-shadow:0 8px 24px rgba(26,61,110,.25); }
.feature-icon { font-size:1.75rem; }
.feature-title { font-size:1.05rem; font-weight:700; color:var(--dark); margin-bottom:.6rem; }
.feature-text { font-size:.9rem; color:var(--text-light); line-height:1.6; }

/* =============================================
   EXPERIENCE BANNER
============================================= */
.experience-banner { padding:5rem 0; background-size:cover; background-position:center; }
.experience-inner { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.experience-text .section-title { color:white; }
.experience-list { display:flex; flex-direction:column; gap:1rem; margin-bottom:2rem; }
.exp-item { display:flex; align-items:flex-start; gap:1rem; }
.exp-check { width:28px; height:28px; border-radius:50%; background:var(--accent); color:white; display:flex; align-items:center; justify-content:center; font-weight:700; flex-shrink:0; font-size:.85rem; }
.exp-item-text strong { display:block; color:white; font-size:.95rem; margin-bottom:.2rem; }
.exp-item-text span { font-size:.85rem; color:rgba(255,255,255,.75); }
.experience-stats { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.exp-stat { background:rgba(255,255,255,.1); backdrop-filter:blur(8px); border-radius:12px; padding:1.5rem; text-align:center; border:1px solid rgba(255,255,255,.2); }
.exp-stat-number { font-family:var(--font-head); font-size:2.5rem; font-weight:800; color:white; }
.exp-stat-label { font-size:.85rem; color:rgba(255,255,255,.7); }

/* =============================================
   TESTIMONIALS
============================================= */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.testimonial-card { background:white; border-radius:16px; padding:1.75rem; border:1px solid var(--border); box-shadow:0 2px 16px rgba(26,61,110,.07); transition:transform .25s; }
.testimonial-card:hover { transform:translateY(-4px); }
.testimonial-stars { color:var(--gold); font-size:1.1rem; margin-bottom:.75rem; letter-spacing:.05em; }
.testimonial-text { font-size:.9rem; line-height:1.7; color:var(--text); font-style:italic; margin-bottom:1.25rem; }
.testimonial-author { display:flex; align-items:center; gap:.875rem; }
.author-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--primary-light)); color:white; font-weight:700; font-size:.85rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.author-name { font-weight:700; font-size:.9rem; color:var(--dark); }
.author-trip { font-size:.78rem; color:var(--text-light); }

/* =============================================
   NEWSLETTER
============================================= */
.newsletter { background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%); padding:4rem 0; }
.newsletter-inner { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.newsletter-title { font-family:var(--font-head); color:white; font-size:clamp(1.6rem,3vw,2.2rem); margin-bottom:.5rem; }
.newsletter-sub { color:rgba(255,255,255,.85); font-size:1rem; line-height:1.7; }
.newsletter-form { display:flex; flex-direction:column; gap:.75rem; }
.newsletter-form input[type="email"] { padding:.875rem 1.25rem; border:none; border-radius:10px; font-size:1rem; outline:none; }
.newsletter-form button { padding:.875rem 2rem; background:var(--primary); color:white; font-size:1rem; font-weight:700; border:none; border-radius:10px; cursor:pointer; transition:background .2s; }
.newsletter-form button:hover { background:var(--primary-dark); }
.nl-note,.newsletter-notice { font-size:.78rem; color:rgba(255,255,255,.7); text-align:center; }

/* =============================================
   FOOTER
============================================= */
.site-footer { background:#0d1b2a; color:rgba(255,255,255,.75); padding:4rem 0 2rem; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:3rem; margin-bottom:3rem; }
.footer-about p { font-size:.875rem; line-height:1.7; margin-bottom:1.5rem; color:rgba(255,255,255,.6); }
.footer-social { display:flex; gap:.75rem; }
.footer-social a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7); text-decoration:none; font-size:.9rem; transition:background .15s; }
.footer-social a:hover { background:var(--accent); color:white; }
.footer-col h4 { font-size:.78rem; font-weight:800; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.9); margin-bottom:1.25rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.footer-col ul a { font-size:.875rem; color:rgba(255,255,255,.6); text-decoration:none; transition:color .15s; }
.footer-col ul a:hover { color:white; }
.footer-contact { display:flex; flex-direction:column; gap:.75rem; margin-bottom:1.5rem; }
.footer-contact-item { display:flex; align-items:center; gap:.75rem; font-size:.875rem; color:rgba(255,255,255,.7); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:1.5rem; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-copyright { font-size:.8rem; color:rgba(255,255,255,.5); }
.footer-links { display:flex; gap:1.5rem; }
.footer-links a { font-size:.8rem; color:rgba(255,255,255,.5); text-decoration:none; transition:color .15s; }
.footer-links a:hover { color:rgba(255,255,255,.8); }
.footer-logo-text { font-family:var(--font-head); font-size:1.3rem; font-weight:700; color:white; display:flex; align-items:center; gap:.75rem; margin-bottom:1rem; }

/* =============================================
   SINGLE PAGE — SEJOUR/CIRCUIT
============================================= */
body:not(.home) { padding-top:0; }
.page-hero { min-height:45vh; display:flex; align-items:flex-end; padding:4rem 0 2.5rem; position:relative; background-size:cover; background-position:center; background-repeat:no-repeat; }
.page-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,rgba(0,0,0,.25) 0%,rgba(10,20,50,.82) 100%); }
.page-hero .container { position:relative; z-index:1; }
.page-hero__title { color:white; font-family:var(--font-head); font-size:clamp(2rem,5vw,3rem); margin-bottom:.5rem; }
.page-hero__sub { color:rgba(255,255,255,.8); font-size:1.1rem; }
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.85rem; color:rgba(255,255,255,.6); margin-bottom:1rem; }
.breadcrumb a { color:rgba(255,255,255,.6); }
.breadcrumb a:hover { color:var(--accent); }
.breadcrumb .sep { opacity:.4; }
.sj-detail-section { padding:3rem 0 5rem; background:var(--light); }
.sj-detail-layout { display:grid; grid-template-columns:1fr 360px; gap:2.5rem; align-items:start; }
.sj-detail-main { background:white; border-radius:14px; padding:2rem; box-shadow:0 2px 16px rgba(26,61,110,.07); }
.sj-section { margin-bottom:2rem; padding-bottom:2rem; border-bottom:1px solid var(--border); }
.sj-section:last-child { border-bottom:none; margin-bottom:0; }
.sj-section__title { font-size:1.15rem; font-weight:700; color:var(--dark); margin-bottom:1rem; }
.sj-gallery { margin-bottom:1.75rem; border-radius:12px; overflow:hidden; }
.sj-gallery__main { width:100%; height:380px; object-fit:cover; display:block; }
.sj-excerpt { font-size:1.05rem; color:var(--text-light); line-height:1.8; margin-bottom:1.75rem; font-style:italic; }
.sj-inclusions-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:.75rem; }
.sj-inc-item { display:flex; align-items:center; gap:.5rem; font-size:.875rem; padding:.5rem .75rem; background:var(--light); border-radius:8px; border:1px solid var(--border); }
.sj-inc-icon { font-size:1.1rem; }
.sj-details-table { width:100%; border-collapse:collapse; font-size:.9rem; }
.sj-details-table th,.sj-details-table td { padding:.75rem 1rem; border-bottom:1px solid var(--border); text-align:left; }
.sj-details-table th { color:var(--text-light); font-weight:600; width:40%; }
.sj-dates-row { display:flex; gap:.5rem; flex-wrap:wrap; }
.sj-date-pill { padding:.35rem .85rem; background:var(--light-2); border:1px solid var(--primary); color:var(--primary); border-radius:20px; font-size:.8rem; font-weight:600; }
.sj-type-pill { display:inline-block; padding:.2rem .75rem; background:var(--primary); color:white; border-radius:20px; font-size:.78rem; font-weight:600; }
.sj-related-section { background:var(--light-2); padding:3.5rem 0; }
.booking-card { position:sticky; top:120px; background:white; border-radius:16px; box-shadow:0 8px 40px rgba(26,61,110,.15); border-top:4px solid var(--accent); padding:1.75rem; }
.bc-stars { color:var(--gold); font-size:1.1rem; margin-bottom:.75rem; }
.bc-price-block { margin-bottom:1.25rem; }
.bc-price-original { font-size:.9rem; color:var(--text-light); text-decoration:line-through; margin-right:.5rem; }
.bc-discount-badge { background:var(--accent); color:white; font-size:.72rem; font-weight:800; padding:.15rem .5rem; border-radius:4px; }
.bc-price-main { margin-top:.25rem; }
.bc-price-amount { font-size:2rem; font-weight:800; color:var(--primary); }
.bc-price-label { font-size:.85rem; color:var(--text-light); }
.bc-price-note { font-size:.75rem; color:var(--text-light); margin-top:.25rem; }
.bc-meta-row { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.25rem; font-size:.875rem; color:var(--text); }
.bc-cta-group { display:flex; flex-direction:column; gap:.65rem; margin-bottom:1.25rem; }
.bc-btn { display:block; text-align:center; padding:.85rem 1.5rem; border-radius:10px; font-weight:700; font-size:.95rem; text-decoration:none; transition:all .2s; }
.bc-btn--primary { background:var(--accent); color:white; }
.bc-btn--primary:hover { background:var(--accent-dark); transform:translateY(-1px); }
.bc-btn--whatsapp { background:#25d366; color:white; }
.bc-btn--whatsapp:hover { background:#20bc5a; transform:translateY(-1px); }
.bc-trust { display:flex; flex-direction:column; gap:.4rem; }
.bc-trust-item { font-size:.8rem; color:var(--text-light); }
/* Booking form */
.booking-form-card { background:white; border-radius:16px; box-shadow:0 8px 40px rgba(26,61,110,.14); border-top:4px solid var(--accent); padding:1.5rem 1.75rem; margin-top:1rem; }
.bfc-title { font-size:1.1rem; font-weight:700; color:var(--dark); margin-bottom:.25rem; }
.bfc-subtitle { font-size:.82rem; color:var(--text-light); margin-bottom:1.25rem; }
.ryf-booking-form { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.bff-field { display:flex; flex-direction:column; gap:.35rem; }
.bff-field--full { grid-column:1/-1; }
.bff-label { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text-light); }
.bff-label .req { color:var(--accent); }
.bff-input,.bff-select,.bff-textarea { padding:.6rem .875rem; border:1.5px solid var(--border); border-radius:8px; font-size:.9rem; font-family:var(--font-body); outline:none; transition:border-color .18s; width:100%; box-sizing:border-box; background:white; }
.bff-input:focus,.bff-select:focus,.bff-textarea:focus { border-color:var(--primary); }
.bff-textarea { resize:vertical; min-height:80px; }
.bff-counter { display:flex; align-items:center; gap:.5rem; border:1.5px solid var(--border); border-radius:8px; padding:.4rem .75rem; width:fit-content; }
.bff-dec,.bff-inc { width:26px; height:26px; border-radius:50%; background:#f0f4f8; border:none; font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; font-weight:700; transition:background .15s; }
.bff-dec:hover,.bff-inc:hover { background:var(--primary); color:white; }
.bff-count { font-weight:700; min-width:24px; text-align:center; font-size:1rem; }
.bff-price-estimate { grid-column:1/-1; background:var(--light-2); border-radius:8px; padding:.6rem 1rem; font-size:.875rem; display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.bff-est-total { font-size:1.1rem; font-weight:800; color:var(--primary); }
.bff-est-note { font-size:.78rem; color:var(--text-light); }
.bff-submit { grid-column:1/-1; padding:.875rem; background:var(--accent); color:white; font-size:1rem; font-weight:700; border:none; border-radius:10px; cursor:pointer; transition:background .2s,transform .1s; font-family:var(--font-body); }
.bff-submit:hover { background:var(--accent-dark); transform:translateY(-1px); }
.bff-submit:disabled { opacity:.65; cursor:not-allowed; transform:none; }
.bff-message { grid-column:1/-1; padding:.875rem 1.1rem; border-radius:10px; font-size:.9rem; font-weight:600; line-height:1.5; }
.bff-success { background:#d1fae5; color:#065f46; border:1px solid #6ee7b7; }
.bff-error { background:#fee2e2; color:#7f1d1d; border:1px solid #fca5a5; }
.bfc-trust { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:1rem; font-size:.78rem; color:var(--text-light); }

/* =============================================
   ARCHIVE PAGES
============================================= */
.archive-hero { background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%); padding:5rem 0 3rem; text-align:center; }
.archive-hero h1 { color:white; font-family:var(--font-head); margin-bottom:.5rem; }
.archive-hero .archive-count { color:rgba(255,255,255,.75); }
.filter-tabs-bar { background:white; border-bottom:1px solid var(--border); position:sticky; top:108px; z-index:100; padding:.75rem 0; }
.filter-tabs-bar .container { display:flex; gap:.5rem; flex-wrap:wrap; align-items:center; }
.filter-tab { padding:.45rem 1.1rem; border-radius:20px; font-size:.825rem; font-weight:600; color:var(--text-light); border:1.5px solid var(--border); cursor:pointer; transition:all .18s; text-decoration:none; background:white; display:inline-block; }
.filter-tab.active,.filter-tab:hover { background:var(--primary); color:white; border-color:var(--primary); }
.archive-body { padding:2.5rem 0 4rem; }
.archive-2col { display:grid; grid-template-columns:280px 1fr; gap:2.5rem; align-items:start; }
.archive-sidebar { position:sticky; top:185px; }
.sidebar-card { background:white; border-radius:12px; border:1px solid var(--border); padding:1.25rem; margin-bottom:1rem; }
.sidebar-card h4 { font-size:.72rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--text-light); margin-bottom:.875rem; border-bottom:1px solid var(--border); padding-bottom:.5rem; }
.sidebar-option { display:flex; align-items:center; gap:.5rem; padding:.3rem 0; font-size:.875rem; color:var(--text); cursor:pointer; }
.sidebar-option input { accent-color:var(--primary); }
.sidebar-apply { width:100%; padding:.7rem; background:var(--accent); color:white; font-weight:700; border:none; border-radius:8px; cursor:pointer; font-size:.9rem; margin-top:.5rem; transition:background .2s; }
.archive-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.no-results { grid-column:1/-1; text-align:center; padding:4rem 2rem; color:var(--text-light); }
.pagination { display:flex; justify-content:center; gap:.5rem; margin-top:2.5rem; flex-wrap:wrap; }
.pagination a,.pagination span { padding:.5rem .9rem; border-radius:8px; border:1.5px solid var(--border); font-size:.875rem; font-weight:600; color:var(--text); text-decoration:none; transition:all .18s; }
.pagination a:hover,.pagination .current { background:var(--primary); color:white; border-color:var(--primary); }
/* Archive sejour card */
.sejour-card,.sc-image-wrap img { border-radius:14px; overflow:hidden; }
.sejour-card { background:white; border:1px solid rgba(0,0,0,.06); box-shadow:0 4px 20px rgba(26,61,110,.08); transition:transform .3s,box-shadow .3s; }
.sejour-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(26,61,110,.18); }
.sc-image-wrap { position:relative; overflow:hidden; }
.sc-image-wrap img,.sc-image { width:100%; height:240px; object-fit:cover; display:block; transition:transform .4s; }
.sejour-card:hover .sc-image { transform:scale(1.04); }
.sc-badge,.sc-badge--discount { position:absolute; top:.75rem; left:.75rem; background:var(--accent); color:white; font-size:.72rem; font-weight:800; padding:.2rem .6rem; border-radius:20px; }
.sc-body { padding:1.1rem 1.25rem 1.25rem; }
.sc-stars { color:var(--gold); font-size:.95rem; margin-bottom:.35rem; }
.sc-title { font-size:1rem; font-weight:700; color:var(--dark); margin-bottom:.4rem; }
.sc-title a { color:var(--dark); text-decoration:none; }
.sc-meta { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:.6rem; font-size:.8rem; color:var(--text-light); }
.sc-pills { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.75rem; }
.sc-pill { font-size:.7rem; font-weight:600; padding:.2rem .55rem; border-radius:4px; background:var(--light-2); color:var(--primary); }
.sc-services { display:flex; gap:.4rem; margin-bottom:.75rem; }
.sc-service { font-size:1rem; }
.sc-footer { display:flex; align-items:center; justify-content:space-between; }
.sc-price { display:flex; align-items:baseline; gap:.25rem; }
.sc-price-from { font-size:.75rem; color:var(--text-light); }
.sc-price-amount { font-size:1.3rem; font-weight:800; color:var(--primary); }
.sc-price-pp { font-size:.72rem; color:var(--text-light); }
.sc-cta { padding:.4rem 1rem; background:var(--accent); color:white; border-radius:6px; font-size:.82rem; font-weight:700; text-decoration:none; transition:background .15s; }
.sc-cta:hover { background:var(--accent-dark); }

/* =============================================
   DESTINATION SINGLE PAGE
============================================= */
.dest-info-bar { background:var(--primary); padding:1.5rem 0; }
.dib-item { display:flex; align-items:center; gap:.75rem; color:white; }
.dib-icon { font-size:1.4rem; }
.dib-label { font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:rgba(255,255,255,.65); }
.dib-val { font-weight:700; font-size:1rem; }

/* =============================================
   ANIMATIONS & UTILITIES
============================================= */
.fade-up { opacity:0; transform:translateY(30px); transition:opacity .6s ease,transform .6s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-up:nth-child(2) { transition-delay:.1s; }
.fade-up:nth-child(3) { transition-delay:.2s; }
.fade-up:nth-child(4) { transition-delay:.3s; }
.back-to-top { position:fixed; bottom:2rem; right:2rem; width:46px; height:46px; background:var(--accent); color:white; border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(255,107,53,.4); z-index:100; opacity:0; transform:translateY(16px); transition:var(--transition); border:none; cursor:pointer; font-size:1.1rem; }
.back-to-top.visible { opacity:1; transform:translateY(0); }
.back-to-top:hover { background:var(--accent-dark); }

/* =============================================
   RESPONSIVE
============================================= */
@media (max-width:1100px) {
  .themes-grid { grid-template-columns:repeat(3,1fr); }
  .hdr-nav__link { padding:0 .65rem; font-size:.825rem; }
}
@media (max-width:900px) {
  .hdr-nav,.hdr-tel { display:none; }
  .hdr-burger { display:flex; }
  .hdr-main__inner { justify-content:space-between; gap:1rem; }
  .deals-grid,.circuits-grid,.features-grid,.testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .destinations-grid { grid-template-columns:repeat(2,1fr); }
  .destinations-grid .destination-card:first-child { grid-row:span 1; }
  .newsletter-inner { grid-template-columns:1fr; gap:2rem; }
  .experience-inner { grid-template-columns:1fr; }
  .archive-2col { grid-template-columns:1fr; }
  .archive-sidebar { position:static; }
  .sj-detail-layout { grid-template-columns:1fr; }
  .booking-card { position:static; }
  .tui-hero { height:380px; }
  .tui-hero__title { font-size:2.2rem; }
  .tui-search__row { flex-direction:column; height:auto; border-radius:10px; }
  .tui-search__field { border-right:none; border-bottom:1.5px solid #e2e8f0; height:54px; }
  .tui-search__field--sm { flex:1; }
  .tui-search__btn { width:100%; justify-content:center; height:50px; border-radius:0 0 8px 8px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
}
@media (max-width:640px) {
  .tui-hero { height:300px; }
  .tui-hero__title { font-size:1.8rem; }
  .tui-hero__sub { display:none; }
  .deals-grid,.circuits-grid,.features-grid,.testimonials-grid,.themes-grid { grid-template-columns:1fr; }
  .destinations-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr; }
  .ryf-booking-form { grid-template-columns:1fr; }
  .hdr-topbar { display:none; }
}

/* ============================================================
   HERO FULL — Premium full-screen hero (v4.0.0)
   ============================================================ */

/* ---- Header: transparent on homepage, white on scroll ---- */
#site-header {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  z-index: 300;
  transition: background .3s, box-shadow .3s;
}
/* Transparent state */
#site-header:not(.scrolled) .hdr-topbar {
  background: rgba(0,0,0,.45) !important;
  border-bottom: 1px solid rgba(255,255,255,.1) !important;
}
#site-header:not(.scrolled) .hdr-main {
  background: rgba(0,0,0,.3) !important;
  backdrop-filter: blur(10px) !important;
  box-shadow: none !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
}
#site-header:not(.scrolled) .hdr-nav__link { color: rgba(255,255,255,.92) !important; }
#site-header:not(.scrolled) .hdr-nav__link--hot { color: #ff8c5a !important; }
#site-header:not(.scrolled) .hdr-tel { color: rgba(255,255,255,.85) !important; }
#site-header:not(.scrolled) .hdr-topbar__inner,
#site-header:not(.scrolled) .hdr-topbar__inner * { color: rgba(255,255,255,.85) !important; }
/* Scrolled = solid white */
#site-header.scrolled .hdr-topbar { background: #1a3d6e !important; }
#site-header.scrolled .hdr-main { background: white !important; backdrop-filter: none !important; box-shadow: 0 2px 12px rgba(0,0,0,.08) !important; }
#site-header.scrolled .hdr-nav__link { color: #1a202c !important; }
#site-header.scrolled .hdr-tel { color: #1a3d6e !important; }

/* Body: no padding — hero goes under fixed header */
body { padding-top: 0 !important; }

/* ---- Hero Full ---- */
.hero-full {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 650px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Slides */
.hf-slides { position: absolute; inset: 0; }
.hf-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.2s ease;
}
.hf-slide.active { opacity: 1; z-index: 1; }

/* Gradient overlay — dark bottom for search readability */
.hf-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom,
      rgba(10,20,50,.5) 0%,
      rgba(10,20,50,.4) 40%,
      rgba(10,20,50,.75) 75%,
      rgba(10,20,50,.95) 100%
    );
  z-index: 2;
}

/* Center text content */
.hf-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  text-align: center;
  color: white;
  z-index: 5;
  width: 90%;
  max-width: 720px;
  padding-top: 108px;
}
.hf-eyebrow {
  display: inline-block;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
  border: 1px solid rgba(255,255,255,.3);
  padding: .35rem 1.25rem;
  border-radius: 30px;
  margin-bottom: 1.25rem;
  backdrop-filter: blur(4px);
}
.hf-title {
  font-family: var(--font-head);
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 800;
  line-height: 1.05;
  color: white;
  margin-bottom: 1rem;
  text-shadow: 0 4px 24px rgba(0,0,0,.35);
}
.hf-title em { color: var(--accent); font-style: normal; }
.hf-sub {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: rgba(255,255,255,.82);
  margin-bottom: 1.5rem;
  line-height: 1.6;
}
.hf-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  font-size: .82rem;
  font-weight: 600;
  color: rgba(255,255,255,.85);
  flex-wrap: wrap;
}

/* ---- Search box ---- */
.hf-search-box {
  position: relative;
  z-index: 10;
  padding: 0 1.5rem 0;
  margin-bottom: 0;
}
.hf-search-inner {
  max-width: 1080px;
  margin: 0 auto;
  background: white;
  border-radius: 16px 16px 0 0;
  box-shadow: 0 -8px 40px rgba(0,0,0,.35);
  overflow: hidden;
}
/* Tabs */
.hf-tabs {
  display: flex;
  background: rgba(26,61,110,.06);
  border-bottom: 1px solid #e8edf2;
}
.hf-tab {
  flex: 1;
  padding: .75rem 1.5rem;
  font-size: .9rem;
  font-weight: 700;
  border: none;
  background: transparent;
  color: #6b7280;
  cursor: pointer;
  transition: all .2s;
  border-bottom: 3px solid transparent;
  font-family: var(--font-body);
}
.hf-tab.active { color: var(--primary); border-bottom-color: var(--accent); background: white; }
.hf-tab:hover { color: var(--primary); }
/* Panels */
.hf-panel { display: none; padding: 1rem 1.5rem 1.25rem; }
.hf-panel.active { display: block; }
/* Fields row */
.hf-fields {
  display: flex;
  align-items: center;
  gap: 0;
}
.hf-field {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .2rem;
  padding: .5rem 1rem;
}
.hf-field--sm { flex: .65; }
.hf-field--sep {
  flex: 0 0 1px;
  padding: 0;
  background: #e8edf2;
  height: 36px;
  align-self: center;
}
.hf-field label {
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #9ca3af;
  white-space: nowrap;
}
.hf-field select,
.hf-field input[type="month"] {
  width: 100%;
  border: none;
  outline: none;
  font-size: .95rem;
  color: #1a202c;
  background: transparent;
  font-family: var(--font-body);
  padding: 0;
  cursor: pointer;
}
.hf-counter { display: flex; align-items: center; gap: .5rem; }
.hf-dec, .hf-inc {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: #f0f4f8;
  border: none; cursor: pointer;
  font-size: 1rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.hf-dec:hover, .hf-inc:hover { background: var(--primary); color: white; }
.hf-cnt { font-weight: 700; min-width: 24px; text-align: center; font-size: 1rem; }
.hf-btn {
  flex-shrink: 0;
  margin-left: .5rem;
  padding: .75rem 2.25rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background .15s, transform .1s;
  white-space: nowrap;
}
.hf-btn:hover { background: var(--accent-dark); transform: translateY(-1px); }

/* Arrows */
.hf-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 50px; height: 50px;
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  border: 1.5px solid rgba(255,255,255,.3);
  color: white;
  border-radius: 50%;
  font-size: 1.8rem;
  cursor: pointer;
  transition: background .2s, transform .2s;
  display: flex; align-items: center; justify-content: center;
}
.hf-prev { left: 1.5rem; }
.hf-next { right: 1.5rem; }
.hf-arrow:hover { background: var(--accent); border-color: var(--accent); }

/* Dots */
.hf-dots {
  position: absolute;
  bottom: 1.25rem;
  right: 2rem;
  display: flex;
  gap: .4rem;
  z-index: 10;
}
.hf-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  border: none; cursor: pointer;
  transition: all .25s; padding: 0;
}
.hf-dot.active { background: var(--accent); width: 22px; border-radius: 4px; }

/* Stats bar flush after hero */
.stats-bar { position: relative; z-index: 5; margin-top: 0 !important; }

/* Mega container: offset for fixed header */
.hdr-mega-container { position: fixed !important; top: 108px !important; }

/* Disable old hero */
.tui-hero { display: none !important; }
.tui-search { display: none !important; }
.home-search-bridge { display: none !important; }

/* Responsive */
@media (max-width: 1024px) {
  .hf-fields { flex-wrap: wrap; }
  .hf-field--sep { display: none; }
  .hf-field { flex: 1 1 40%; border-bottom: 1px solid #f0f4f8; }
  .hf-btn { width: 100%; margin: .5rem 0 0; border-radius: 8px; padding: .875rem; }
}
@media (max-width: 768px) {
  .hero-full { height: 100svh; }
  .hf-center { top: 48%; }
  .hf-title { font-size: 2.4rem; }
  .hf-trust { gap: 1rem; font-size: .75rem; }
  .hf-field { flex: 1 1 100%; }
  .hf-search-inner { border-radius: 12px 12px 0 0; }
  .hf-arrow { width: 40px; height: 40px; font-size: 1.4rem; }
  .hf-prev { left: .75rem; }
  .hf-next { right: .75rem; }
}

/* ============================================================
   HERO — full viewport, header overlays (sticky transparent)
   ============================================================ */
.hero-full {
  height: 100vh !important;
  min-height: 600px !important;
}
/* Search box at bottom — always fully visible */
.hf-search-box {
  position: relative;
  z-index: 10;
  padding: 0 1.5rem 0;
  flex-shrink: 0;
}
/* Stats bar: comes right after hero+search */
.stats-bar { margin-top: 0 !important; }

/* Center content: adjusted for shorter hero */
.hf-center {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  padding-top: 80px !important;
}

/* ============================================================
   VISUAL IMPROVEMENTS — polish pass v4
   ============================================================ */

/* Hero: richer gradient */
.hf-overlay {
  background: linear-gradient(
    to bottom,
    rgba(10,20,50,.4) 0%,
    rgba(10,20,50,.35) 35%,
    rgba(10,20,50,.65) 65%,
    rgba(10,20,50,.92) 100%
  ) !important;
}

/* Eyebrow: premium pill */
.hf-eyebrow {
  background: rgba(255,255,255,.12) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255,255,255,.25) !important;
  font-size: .7rem !important;
  letter-spacing: .22em !important;
  padding: .4rem 1.5rem !important;
}

/* Title: larger, bolder */
.hf-title {
  font-size: clamp(3rem, 8vw, 5.5rem) !important;
  line-height: 1.0 !important;
  margin-bottom: 1.25rem !important;
}
.hf-title em { 
  display: block; 
  font-style: normal;
  color: #ff6b35 !important;
}

/* Sub: readable */
.hf-sub {
  font-size: clamp(1rem, 2vw, 1.25rem) !important;
  color: rgba(255,255,255,.88) !important;
  line-height: 1.65 !important;
  margin-bottom: 1.75rem !important;
}

/* Trust: more spacious */
.hf-trust {
  background: rgba(255,255,255,.08) !important;
  backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 30px !important;
  padding: .6rem 2rem !important;
  gap: 2.5rem !important;
  display: inline-flex !important;
  font-size: .85rem !important;
}

/* Search inner: premium look */
.hf-search-inner {
  border-radius: 16px 16px 0 0 !important;
  box-shadow: 0 -12px 50px rgba(0,0,0,.45) !important;
}

/* Search tabs: cleaner */
.hf-tabs {
  background: #f8f9fa !important;
  border-bottom: 2px solid #e8edf2 !important;
}
.hf-tab {
  padding: .85rem 1.5rem !important;
  font-size: .875rem !important;
  font-weight: 700 !important;
}
.hf-tab.active {
  background: white !important;
  color: #1a3d6e !important;
  border-bottom-color: #ff6b35 !important;
}

/* Search fields: bigger, cleaner */
.hf-panel { padding: 1.1rem 1.5rem 1.25rem !important; }
.hf-field label {
  font-size: .66rem !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  color: #9ca3af !important;
}
.hf-field select,
.hf-field input[type="month"] {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #1a202c !important;
  padding: .15rem 0 !important;
}
.hf-btn {
  padding: .8rem 2.5rem !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 16px rgba(255,107,53,.4) !important;
  letter-spacing: .02em !important;
}
.hf-btn:hover {
  box-shadow: 0 6px 24px rgba(255,107,53,.55) !important;
  transform: translateY(-1px) !important;
}

/* Arrows: glassmorphism */
.hf-arrow {
  width: 48px !important;
  height: 48px !important;
  font-size: 1.8rem !important;
  background: rgba(255,255,255,.18) !important;
  backdrop-filter: blur(10px) !important;
  border: 1.5px solid rgba(255,255,255,.35) !important;
}

/* Dots: accent colored */
.hf-dot.active { background: #ff6b35 !important; width: 24px !important; }

/* Stats: more visual impact */
.stats-bar {
  padding: 2rem 0 !important;
}
.stat-number { 
  font-size: clamp(2rem,4vw,3rem) !important;
  letter-spacing: -.02em !important;
}
.stat-label {
  font-size: .75rem !important;
  letter-spacing: .12em !important;
}

/* Deal cards: hover more pronounced */
.deal-card:hover { transform: translateY(-8px) !important; }
.deal-price-now { color: #1a3d6e !important; font-size: 1.6rem !important; }
.deal-badge-discount { 
  font-size: .8rem !important; 
  padding: .3rem .75rem !important;
}

/* Section labels: bolder */
.section-label {
  font-size: .7rem !important;
  letter-spacing: .2em !important;
  font-weight: 800 !important;
}

/* Destination cards: taller on desktop */
@media (min-width: 1024px) {
  .destination-card { height: 300px !important; }
  .destinations-grid .destination-card:first-child { min-height: 620px !important; }
}

/* Circuit cards: better image height */
.cc-image img { height: 280px !important; }

/* Feature cards: premium icon boxes */
.feature-icon-wrap { 
  box-shadow: 0 10px 30px rgba(26,61,110,.3) !important;
}

/* Testimonial: subtle left border accent */
.testimonial-card {
  border-left: 3px solid #ff6b35 !important;
}

/* Responsive: search on mobile */
@media (max-width: 900px) {
  .hero-full { height: 100svh !important; min-height: 560px !important; }
  .hf-fields { flex-direction: column; }
  .hf-field--sep { display: none; }
  .hf-field { width: 100%; padding: .4rem .75rem; border-bottom: 1px solid #f0f4f8; }
  .hf-btn { width: 100%; margin-top: .5rem; }
}

/* =============================================
   SEARCH RESULTS PAGE — Professional UI
============================================= */

/* ---- Search Tabs ---- */
.search-tabs {
  display: flex;
  gap: .5rem;
  margin-bottom: 1.75rem;
  border-bottom: 2px solid #e5eaf0;
  padding-bottom: 0;
}
.search-tab {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .7rem 1.5rem;
  font-size: .9rem;
  font-weight: 700;
  color: #64748b;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color .18s, border-color .18s;
  font-family: var(--font-body);
  white-space: nowrap;
}
.search-tab:hover { color: var(--primary); }
.search-tab.active {
  color: var(--primary);
  border-bottom-color: var(--accent);
}
.search-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  background: #f1f5f9;
  color: #475569;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 700;
  transition: background .18s, color .18s;
}
.search-tab.active .search-tab-count {
  background: var(--accent);
  color: white;
}

/* ---- Search Panels ---- */
.search-panel { display: none; }
.search-panel.active { display: block; }

/* ---- Active Filters Bar ---- */
.active-filters-bar {
  background: #f8fafc;
  border-top: 1px solid #e5eaf0;
  border-bottom: 1px solid #e5eaf0;
  padding: .75rem 0;
  margin-bottom: 0;
}
.active-filters-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
}
.af-label {
  font-size: .8rem;
  font-weight: 700;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-right: .25rem;
  white-space: nowrap;
}
.af-pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .75rem .3rem .85rem;
  background: white;
  border: 1.5px solid #cbd5e1;
  border-radius: 20px;
  font-size: .82rem;
  font-weight: 600;
  color: #334155;
  white-space: nowrap;
  transition: border-color .15s;
}
.af-pill:hover { border-color: #94a3b8; }
.af-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  background: #e2e8f0;
  border-radius: 50%;
  font-size: .65rem;
  color: #475569;
  text-decoration: none;
  flex-shrink: 0;
  transition: background .15s, color .15s;
  line-height: 1;
}
.af-remove:hover { background: #ef4444; color: white; }
.af-clear-all {
  margin-left: auto;
  font-size: .8rem;
  font-weight: 700;
  color: #ef4444;
  text-decoration: none;
  padding: .3rem .75rem;
  border: 1.5px solid #fecaca;
  border-radius: 20px;
  transition: all .15s;
  white-space: nowrap;
}
.af-clear-all:hover { background: #ef4444; color: white; border-color: #ef4444; }

/* ---- Results Grid ---- */
.results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 1.5rem;
  margin-top: 1.5rem;
}

/* ---- Search Result Cards ---- */
.results-grid .sejour-card,
.results-grid .circuit-card {
  background: white;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.07);
  transition: transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
}
.results-grid .sejour-card:hover,
.results-grid .circuit-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 28px rgba(0,0,0,.13);
}
.sc-image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, #1a3d6e, #2d5a9e);
}
.sc-image-wrap a { display: block; height: 100%; }
.sc-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s;
}
.results-grid .sejour-card:hover .sc-image,
.results-grid .circuit-card:hover .sc-image { transform: scale(1.04); }
.sc-image--placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #1a3d6e 0%, #2d5a9e 100%);
}
.sc-badge {
  position: absolute;
  top: .75rem;
  left: .75rem;
  padding: .25rem .6rem;
  border-radius: 6px;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1.3;
}
.sc-badge--discount { background: #ef4444; color: white; }
.sc-badge--duration { background: rgba(0,0,0,.55); color: white; backdrop-filter: blur(4px); }
.sc-body {
  padding: 1rem 1.1rem 1.1rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.sc-stars { display: flex; gap: 2px; margin-bottom: .4rem; }
.sc-stars .star { font-size: .9rem; color: #d1d5db; }
.sc-stars .star.filled { color: #f59e0b; }
.sc-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 .5rem;
  line-height: 1.35;
  color: var(--text);
}
.sc-title a { color: inherit; text-decoration: none; }
.sc-title a:hover { color: var(--primary); }
.sc-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .75rem;
  margin-bottom: .6rem;
}
.sc-meta-item { font-size: .8rem; color: #64748b; }
.sc-pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-bottom: .6rem;
}
.sc-pill {
  padding: .2rem .6rem;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 600;
}
.sc-pill--country { background: #eff6ff; color: #1d4ed8; }
.sc-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid #f1f5f9;
}
.sc-price { display: flex; align-items: baseline; gap: .25rem; }
.sc-price-from { font-size: .75rem; color: #94a3b8; }
.sc-price-amount { font-size: 1.15rem; font-weight: 800; color: var(--primary); }
.sc-cta {
  padding: .45rem 1.1rem;
  background: var(--accent);
  color: white;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
  white-space: nowrap;
}
.sc-cta:hover { background: var(--accent-dark); transform: translateY(-1px); }

/* ---- Destination cards in search ---- */
.destination-grid--search {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1.25rem;
  margin-top: 1.5rem;
}
.destination-card { border-radius: 14px; overflow: hidden; }
.dest-card-link {
  display: block;
  position: relative;
  aspect-ratio: 4/3;
  text-decoration: none;
}
.dest-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s;
}
.destination-card:hover .dest-card-img { transform: scale(1.05); }
.dest-card-img--placeholder { background: linear-gradient(135deg, #1a3d6e, #2d5a9e); }
.dest-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.75) 0%, transparent 55%);
}
.dest-card-content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: .85rem;
}
.dest-card-top { display: flex; justify-content: flex-end; }
.dest-flag { font-size: 1.6rem; filter: drop-shadow(0 2px 4px rgba(0,0,0,.3)); }
.dest-card-bottom { }
.dest-card-title { color: white; font-weight: 800; font-size: 1.05rem; margin: 0 0 .2rem; }
.dest-card-count { color: rgba(255,255,255,.8); font-size: .78rem; margin: 0 0 .15rem; }
.dest-card-price { color: rgba(255,255,255,.9); font-size: .82rem; margin: 0; }
.dest-card-hover {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26,61,110,.72);
  opacity: 0;
  transition: opacity .2s;
}
.destination-card:hover .dest-card-hover { opacity: 1; }
.dest-card-cta {
  background: var(--accent);
  color: white;
  padding: .55rem 1.25rem;
  border-radius: 8px;
  font-weight: 700;
  font-size: .9rem;
}

/* ---- No results ---- */
.no-results-inline {
  padding: 3rem 2rem;
  text-align: center;
  color: #64748b;
  background: #f8fafc;
  border-radius: 12px;
  margin-top: 1.5rem;
}
.no-results-inline p { font-size: 1rem; margin-bottom: .75rem; }
.no-results-inline a { color: var(--primary); font-weight: 600; text-decoration: underline; }
.no-results-block {
  text-align: center;
  padding: 4rem 2rem;
  background: #f8fafc;
  border-radius: 16px;
  border: 1.5px dashed #cbd5e1;
}
.no-results-icon { font-size: 3rem; display: block; margin-bottom: 1rem; }
.no-results-block h2 { font-size: 1.4rem; color: var(--text); margin-bottom: .5rem; }
.no-results-block p { color: #64748b; margin-bottom: 1.5rem; }
.bc-btn {
  display: inline-flex;
  align-items: center;
  padding: .6rem 1.4rem;
  border-radius: 8px;
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: all .18s;
}
.bc-btn--primary { background: var(--primary); color: white; }
.bc-btn--primary:hover { background: #2d5a9e; transform: translateY(-1px); }
.bc-btn--outline { border: 2px solid var(--primary); color: var(--primary); }
.bc-btn--outline:hover { background: var(--primary); color: white; }

/* ---- Homepage search form improvements ---- */
.hf-tabs {
  display: flex;
  background: rgba(255,255,255,.12);
  border-bottom: 1px solid rgba(255,255,255,.15);
}
.hf-tab {
  flex: 1;
  padding: .85rem 1.5rem;
  font-size: .88rem;
  font-weight: 700;
  border: none;
  background: transparent;
  color: rgba(255,255,255,.65);
  cursor: pointer;
  transition: all .2s;
  border-bottom: 3px solid transparent;
  font-family: var(--font-body);
  letter-spacing: .01em;
}
.hf-tab.active {
  color: white;
  background: rgba(255,255,255,.08);
  border-bottom-color: var(--accent);
}
.hf-tab:hover:not(.active) { color: white; background: rgba(255,255,255,.05); }

/* ---- Search responsive ---- */
@media (max-width: 640px) {
  .search-tabs { gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .search-tab { padding: .6rem 1rem; font-size: .82rem; }
  .results-grid { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .af-clear-all { margin-left: 0; width: 100%; text-align: center; }
}
@media (max-width: 480px) {
  .results-grid { grid-template-columns: 1fr; }
  .destination-grid--search { grid-template-columns: 1fr 1fr; }
}

/* =============================================
   PROFESSIONAL FILTER SYSTEM — flt-* / ftb-*
   Used on archive-sejour.php + archive-circuit.php
============================================= */

/* ── Filter Tabs Bar — top = header height (36px topbar + 72px nav = 108px) ── */
.ftb {
  background: white;
  border-bottom: 1px solid #e5eaf0;
  position: sticky;
  top: 108px;
  z-index: 200;
  padding: .6rem 0;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
}
/* When scrolled, topbar collapses so ftb sticks just below the 72px nav */
.site-header.scrolled ~ * .ftb,
body.scrolled .ftb { top: 72px; }
.ftb-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.ftb-tabs {
  display: flex;
  gap: .4rem;
  overflow-x: auto;
  scrollbar-width: none;
  flex: 1;
  padding: .15rem 0;
}
.ftb-tabs::-webkit-scrollbar { display: none; }
.ftb-tab {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .5rem 1.1rem;
  border-radius: 20px;
  font-size: .84rem;
  font-weight: 600;
  color: #475569;
  border: 1.5px solid #e2e8f0;
  background: white;
  text-decoration: none;
  white-space: nowrap;
  transition: all .18s;
  cursor: pointer;
  flex-shrink: 0;
}
.ftb-tab:hover { border-color: var(--primary); color: var(--primary); background: #f0f5ff; }
.ftb-tab.active { background: var(--primary); color: white; border-color: var(--primary); }

/* Mobile filter button */
.flt-mobile-btn {
  display: none;
  align-items: center;
  gap: .45rem;
  padding: .55rem 1.1rem;
  background: white;
  border: 1.5px solid #e2e8f0;
  border-radius: 20px;
  font-size: .84rem;
  font-weight: 700;
  color: var(--text);
  cursor: pointer;
  white-space: nowrap;
  transition: all .18s;
  flex-shrink: 0;
}
.flt-mobile-btn:hover { border-color: var(--primary); color: var(--primary); }
.flt-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  background: var(--accent);
  color: white;
  border-radius: 20px;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
}

/* ── Layout ── */
.flt-layout {
  display: grid;
  grid-template-columns: 270px 1fr;
  gap: 2rem;
  align-items: start;
  padding: 2rem 0 4rem;
}

/* ── Sidebar card — top = filter tabs bar height (~60px) below header ── */
.flt-sidebar {
  position: sticky;
  top: 174px;
  background: white;
  border-radius: 16px;
  border: 1px solid #e5eaf0;
  box-shadow: 0 4px 20px rgba(0,0,0,.07);
  overflow: hidden;
  transition: left .3s ease;
}
.flt-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem .875rem;
  border-bottom: 1px solid #f1f5f9;
}
.flt-sidebar-header h3 {
  font-size: .92rem;
  font-weight: 800;
  color: var(--text);
  margin: 0;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.flt-close {
  display: none;
  background: none;
  border: none;
  font-size: 1.3rem;
  color: #94a3b8;
  cursor: pointer;
  line-height: 1;
  padding: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, color .15s;
}
.flt-close:hover { background: #fee2e2; color: #ef4444; }

/* ── Filter Groups ── */
.flt-group { border-bottom: 1px solid #f1f5f9; }
.flt-group:last-of-type { border-bottom: none; }

.flt-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .875rem 1.25rem .75rem;
  font-size: .78rem;
  font-weight: 800;
  color: #374151;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
  user-select: none;
  transition: background .15s;
}
.flt-group-head:hover { background: #f8fafc; }

.flt-toggle-icon {
  font-size: 1.1rem;
  color: #94a3b8;
  transition: transform .22s;
  font-weight: 300;
  display: inline-block;
}
.flt-group.open .flt-toggle-icon { transform: rotate(90deg); }

.flt-group-body {
  display: none;
  padding: 0 1.25rem 1rem;
  flex-direction: column;
  gap: .3rem;
}
.flt-group.open .flt-group-body { display: flex; }

/* ── Custom Checkbox ── */
.flt-check {
  display: flex;
  align-items: center;
  gap: .65rem;
  cursor: pointer;
  padding: .35rem 0;
  user-select: none;
  border-radius: 6px;
  margin: 0 -.25rem;
  padding-left: .25rem;
  transition: background .12s;
}
.flt-check:hover { background: #f8fafc; }
.flt-check input[type="checkbox"],
.flt-check input[type="radio"] { display: none; }
.flt-check-box {
  width: 18px;
  height: 18px;
  border: 2px solid #cbd5e1;
  border-radius: 5px;
  background: white;
  flex-shrink: 0;
  transition: all .15s;
  position: relative;
}
.flt-check input:checked + .flt-check-box {
  background: var(--primary);
  border-color: var(--primary);
}
.flt-check input:checked + .flt-check-box::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 6px;
  height: 10px;
  border: 2px solid white;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}
.flt-check-label {
  font-size: .875rem;
  color: #374151;
  font-weight: 500;
  line-height: 1.3;
}
.flt-check:hover .flt-check-box { border-color: var(--primary); }

/* ── Stars Radio ── */
.flt-star-radio {
  display: flex;
  align-items: center;
  gap: .65rem;
  cursor: pointer;
  padding: .35rem .25rem;
  user-select: none;
  border-radius: 6px;
  transition: background .12s;
}
.flt-star-radio:hover { background: #f8fafc; }
.flt-star-radio input { display: none; }
.flt-radio-dot {
  width: 18px;
  height: 18px;
  border: 2px solid #cbd5e1;
  border-radius: 50%;
  background: white;
  flex-shrink: 0;
  transition: all .15s;
  position: relative;
}
.flt-star-radio input:checked + .flt-radio-dot { border-color: var(--primary); }
.flt-star-radio input:checked + .flt-radio-dot::after {
  content: '';
  position: absolute;
  inset: 3px;
  background: var(--primary);
  border-radius: 50%;
}
.flt-stars-display { font-size: .9rem; color: #f59e0b; letter-spacing: .05em; }
.flt-star-empty { color: #d1d5db; }

/* ── Budget Range Slider ── */
.flt-range-wrap { padding: .25rem 0 .5rem; }
.flt-range-value {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--primary);
  text-align: center;
  display: block;
  margin-bottom: .65rem;
}
.flt-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 5px;
  border-radius: 5px;
  background: linear-gradient(to right, var(--primary) 0%, var(--primary) var(--pct, 100%), #e2e8f0 var(--pct, 100%), #e2e8f0 100%);
  outline: none;
  cursor: pointer;
  margin-bottom: .6rem;
}
.flt-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: white;
  border: 3px solid var(--primary);
  box-shadow: 0 2px 10px rgba(26,61,110,.2);
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
.flt-range::-webkit-slider-thumb:hover {
  transform: scale(1.15);
  box-shadow: 0 4px 16px rgba(26,61,110,.3);
}
.flt-range::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: white;
  border: 3px solid var(--primary);
  box-shadow: 0 2px 10px rgba(26,61,110,.2);
  cursor: pointer;
}
.flt-range-numbers {
  display: flex;
  justify-content: space-between;
  font-size: .75rem;
  color: #94a3b8;
  font-weight: 500;
}

/* ── Actions ── */
.flt-actions {
  padding: 1rem 1.25rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .65rem;
  background: white;
}
.flt-apply {
  width: 100%;
  padding: .875rem;
  background: var(--accent);
  color: white;
  font-weight: 800;
  font-size: .95rem;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: background .18s, transform .15s, box-shadow .15s;
  letter-spacing: .02em;
  font-family: var(--font-body);
}
.flt-apply:hover {
  background: var(--accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(255,107,53,.35);
}
.flt-reset {
  display: block;
  text-align: center;
  font-size: .82rem;
  color: #94a3b8;
  font-weight: 600;
  text-decoration: none;
  transition: color .15s;
  padding: .2rem 0;
}
.flt-reset:hover { color: #ef4444; }

/* ── Results area ── */
.flt-results {}
.flt-results-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1.5px solid #f1f5f9;
}
.flt-results-count {
  font-size: .9rem;
  color: #475569;
  font-weight: 500;
}
.flt-results-count strong { color: var(--text); font-weight: 800; }
.flt-active-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-left: auto;
}
.flt-active-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .3rem .75rem .3rem .9rem;
  background: #eff6ff;
  border: 1.5px solid #bfdbfe;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 600;
  color: #1d4ed8;
}
.flt-active-pill a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 15px;
  height: 15px;
  background: #1d4ed8;
  color: white;
  border-radius: 50%;
  font-size: .6rem;
  text-decoration: none;
  font-weight: 800;
  flex-shrink: 0;
  transition: background .15s;
}
.flt-active-pill a:hover { background: #ef4444; }

/* ── Included icons on card ── */
.sc-inc-icons {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  margin-bottom: .6rem;
}
.sc-icon-tag {
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  font-size: .72rem;
  padding: .2rem .55rem;
  background: #f8fafc;
  border: 1px solid #e5eaf0;
  border-radius: 4px;
  color: #475569;
  font-weight: 500;
}
.sc-highlight-preview {
  font-size: .8rem;
  color: #6b7280;
  line-height: 1.4;
  margin: 0 0 .6rem;
  font-style: italic;
}
.sc-badge--type {
  position: absolute;
  bottom: .75rem;
  left: .75rem;
  top: auto !important;
  right: auto !important;
  background: rgba(0,0,0,.6);
  color: white;
  backdrop-filter: blur(4px);
  font-size: .72rem;
  font-weight: 700;
  padding: .2rem .6rem;
  border-radius: 6px;
}

/* ── Overlay (mobile) ── */
.flt-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 998;
  backdrop-filter: blur(2px);
  display: none;
  opacity: 0;
  transition: opacity .3s;
}
.flt-overlay.is-open { display: block; opacity: 1; }

/* ── Pagination ── */
.archive-pagination {
  display: flex;
  justify-content: center;
  gap: .4rem;
  margin-top: 2.5rem;
  flex-wrap: wrap;
}
.archive-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 .75rem;
  border-radius: 8px;
  font-size: .875rem;
  font-weight: 600;
  color: #475569;
  border: 1.5px solid #e2e8f0;
  text-decoration: none;
  transition: all .18s;
}
.archive-pagination .page-numbers.current {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}
.archive-pagination .page-numbers:hover:not(.current) {
  border-color: var(--primary);
  color: var(--primary);
}
.archive-pagination .dots { border: none; background: none; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .flt-layout { grid-template-columns: 240px 1fr; gap: 1.5rem; }
}
@media (max-width: 768px) {
  .flt-mobile-btn { display: flex; }
  .flt-layout { grid-template-columns: 1fr; }

  .flt-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(320px, 90vw);
    border-radius: 0;
    z-index: 999;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform .3s ease;
    box-shadow: none;
  }
  .flt-sidebar.is-open {
    transform: translateX(0);
    box-shadow: 6px 0 40px rgba(0,0,0,.18);
  }
  .flt-close { display: flex !important; }
  .flt-actions { position: sticky; bottom: 0; border-top: 1px solid #f1f5f9; }
  .flt-results-bar { flex-direction: column; align-items: flex-start; }
  .flt-active-pills { margin-left: 0; }
}
@media (max-width: 480px) {
  .ftb-tab { font-size: .78rem; padding: .45rem .85rem; }
}

/* =============================================
   COMPREHENSIVE VISUAL POLISH — Final Sweep
============================================= */

/* ── Top Utility Bar — keep at original 36px, collapse on scroll ── */
.hdr-topbar {
  background: linear-gradient(90deg, #0d2347 0%, #1a3d6e 50%, #0d2347 100%) !important;
  height: 36px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  overflow: hidden;
  transition: height .22s ease, opacity .22s ease !important;
}
/* Collapse on scroll — nav becomes sole sticky element */
.site-header.scrolled .hdr-topbar {
  height: 0 !important;
  opacity: 0 !important;
}
.hdr-topbar__inner { font-size: .79rem !important; }
.hdr-topbar__msg { font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hdr-topbar__right { gap: 1rem !important; flex-shrink: 0; }
.hdr-topbar__right a {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-weight: 600;
  color: rgba(255,255,255,.9) !important;
  padding: .18rem .6rem;
  border-radius: 20px;
  transition: background .15s, color .15s !important;
  white-space: nowrap;
}
.hdr-topbar__right a:hover { background: rgba(255,255,255,.12); color: white !important; }

/* ── Logo: color vs white switching ── */
.hdr-logo__color { display: block; }
.hdr-logo__white { display: none; }
.site-header.transparent .hdr-logo__color { display: none; }
.site-header.transparent .hdr-logo__white { display: block; }
.site-header.scrolled .hdr-logo__color { display: block !important; }
.site-header.scrolled .hdr-logo__white { display: none !important; }

/* ── Transparent header (homepage hero, before scroll) ── */
.site-header.transparent .hdr-main {
  background: transparent !important;
  border-bottom-color: rgba(255,255,255,.12) !important;
  box-shadow: none !important;
}
.site-header.transparent .hdr-nav__link { color: rgba(255,255,255,.9) !important; }
.site-header.transparent .hdr-nav__link:hover { color: white !important; }
.site-header.transparent .hdr-tel { color: rgba(255,255,255,.85) !important; }
.site-header.transparent .hdr-tel svg { color: rgba(255,255,255,.85); }
.site-header.transparent .hdr-cta {
  background: rgba(255,255,255,.15) !important;
  border: 1.5px solid rgba(255,255,255,.55) !important;
  color: white !important;
  box-shadow: none !important;
}
.site-header.transparent .hdr-cta:hover { background: rgba(255,255,255,.28) !important; }
.site-header.transparent .hdr-burger span { background: white !important; }

/* ── Back to Top — circle ── */
.back-to-top {
  border-radius: 50% !important;
  width: 48px !important;
  height: 48px !important;
  font-size: 1.2rem !important;
  box-shadow: 0 6px 20px rgba(255,107,53,.45) !important;
}

/* ── Social Links (SVG) ── */
.social-links { display: flex; align-items: center; flex-wrap: wrap; gap: .5rem; margin-top: 1.25rem; }
.social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.7);
  transition: background .18s, color .18s, transform .15s;
  text-decoration: none;
}
.social-link:hover { background: rgba(255,255,255,.18); color: white; transform: translateY(-2px); }
.social-link--fb:hover { background: #1877f2; color: white; }
.social-link--ig:hover { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color: white; }
.social-link--wa:hover { background: #25d366; color: white; }

/* WhatsApp CTA in footer */
.footer-whatsapp-cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  margin-top: .5rem;
  padding: .55rem 1.1rem;
  background: #25d366;
  color: white !important;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, transform .15s;
}
.footer-whatsapp-cta:hover { background: #128c7e; transform: translateY(-1px); }

/* ── Improved stat bar ── */
.stats-bar {
  background: linear-gradient(135deg, #0d2347 0%, #1a3d6e 60%, #1d4e9a 100%) !important;
  padding: 2rem 0 !important;
  border-bottom: 3px solid var(--accent) !important;
}
.stat-item { position: relative; }
.stat-item + .stat-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10%;
  height: 80%;
  width: 1px;
  background: rgba(255,255,255,.15);
}
.stat-number {
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 900 !important;
  color: white !important;
  font-family: var(--font-head);
  line-height: 1.1;
}
.stat-number span { color: var(--accent); font-size: .7em; }
.stat-label {
  font-size: .8rem !important;
  color: rgba(255,255,255,.65) !important;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
  margin-top: .35rem;
}

/* ── Deal cards polish ── */
.deal-card { border-radius: 16px !important; }
.deal-body { padding: 1.25rem; }
.deal-title { font-size: 1.05rem; font-weight: 700; margin-bottom: .4rem; color: var(--text); }
.deal-dest { font-size: .82rem; color: #64748b; margin-bottom: .6rem; }
.deal-inc {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  margin-bottom: .875rem;
}
.deal-inc span {
  font-size: .72rem;
  padding: .2rem .55rem;
  background: #f0f9ff;
  border: 1px solid #bae6fd;
  border-radius: 4px;
  color: #0369a1;
  font-weight: 500;
}
.deal-footer { display: flex; align-items: center; justify-content: space-between; }
.deal-price { display: flex; align-items: baseline; gap: .35rem; }
.deal-price-was { font-size: .82rem; color: #94a3b8; text-decoration: line-through; }
.deal-price-now { font-size: 1.35rem; font-weight: 900; color: var(--primary); }
.deal-price-pp { font-size: .75rem; color: #64748b; }
.deal-badge-discount {
  background: #ef4444 !important;
  font-weight: 800 !important;
  letter-spacing: .02em;
  border-radius: 6px !important;
}
.deal-badge-duration {
  position: absolute;
  bottom: .75rem;
  right: .75rem;
  background: rgba(0,0,0,.6);
  color: white;
  font-size: .75rem;
  font-weight: 700;
  padding: .25rem .65rem;
  border-radius: 6px;
  backdrop-filter: blur(4px);
}

/* ── Feature cards improved ── */
.feature-card { border-radius: 20px !important; }
.feature-icon-wrap {
  border-radius: 14px !important;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%) !important;
}
.feature-icon { font-size: 1.8rem !important; }
.feature-title { font-size: 1.05rem; font-weight: 800; margin-bottom: .5rem; }
.feature-text { font-size: .875rem; color: #64748b; line-height: 1.7; }

/* ── Testimonials polish ── */
.testimonial-card {
  border-radius: 20px !important;
  border-left: 4px solid var(--accent) !important;
  padding: 1.5rem 1.5rem 1.5rem 1.25rem !important;
}
.testimonial-stars { color: #f59e0b !important; font-size: 1rem !important; }
.testimonial-text { font-size: .88rem !important; color: #374151 !important; }
.author-avatar {
  width: 46px !important;
  height: 46px !important;
  border-radius: 12px !important;
  font-size: .88rem !important;
  box-shadow: 0 4px 12px rgba(26,61,110,.25);
}
.author-name { font-weight: 800; font-size: .9rem; color: var(--text); }
.author-trip { font-size: .75rem; color: #94a3b8; }

/* ── Theme tiles improved ── */
.theme-tile__img { height: 150px !important; }
.theme-tile__body {
  background: linear-gradient(135deg, #0d2347 0%, #1a3d6e 100%) !important;
  padding: .8rem .6rem !important;
}
.theme-tile__body span { font-size: 1.5rem !important; }
.theme-tile__body strong { font-size: .78rem !important; letter-spacing: .05em; }

/* ── Newsletter section improved ── */
.newsletter {
  background: linear-gradient(135deg, #ff6b35 0%, #e85520 50%, #c94020 100%) !important;
  position: relative;
  overflow: hidden;
}
.newsletter::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}
.newsletter-form input[type="email"] {
  border-radius: 10px !important;
  font-size: .95rem !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.1) !important;
  border: 2px solid transparent;
}
.newsletter-form input[type="email"]:focus { border-color: var(--accent); outline: none; }
.newsletter-form button {
  background: var(--primary) !important;
  border-radius: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .02em;
  box-shadow: 0 4px 16px rgba(26,61,110,.3);
  transition: all .2s !important;
}
.newsletter-form button:hover {
  background: var(--primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(26,61,110,.4);
}

/* ── Footer brand column ── */
.footer-brand .site-logo {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: 1.3rem;
  font-weight: 800;
  color: white;
  text-decoration: none;
  margin-bottom: 1rem;
}
.footer-brand .site-logo .logo-icon {
  width: 38px;
  height: 38px;
  background: var(--accent);
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
}
.footer-brand > p {
  font-size: .875rem;
  line-height: 1.7;
  color: rgba(255,255,255,.6);
}

/* ── Page hero improvements ── */
.page-hero {
  min-height: 38vh !important;
  padding: 3.5rem 0 2.5rem !important;
}
.page-hero__title { font-size: clamp(1.8rem, 4vw, 2.8rem) !important; font-weight: 800 !important; }
.page-hero__sub { font-size: 1rem !important; margin-top: .4rem; }

/* ── Header CTA button ── */
.hdr-cta {
  background: var(--accent) !important;
  padding: .55rem 1.2rem !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  font-size: .85rem !important;
  letter-spacing: .02em;
  box-shadow: 0 3px 12px rgba(255,107,53,.35);
  transition: background .18s, transform .15s, box-shadow .15s !important;
}
.hdr-cta:hover {
  background: var(--accent-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 5px 18px rgba(255,107,53,.45);
}

/* ── Destination cards on homepage ── */
.destination-card {
  border-radius: 16px !important;
  overflow: hidden;
  box-shadow: 0 6px 24px rgba(0,0,0,.15) !important;
  transition: transform .3s, box-shadow .3s !important;
}
.destination-card:hover { transform: translateY(-6px) !important; box-shadow: 0 16px 40px rgba(0,0,0,.22) !important; }
.dest-flag { font-size: 2rem !important; filter: drop-shadow(0 2px 4px rgba(0,0,0,.3)); }
.dest-name { font-size: 1.15rem !important; font-weight: 800 !important; }
.dest-meta { font-size: .8rem !important; margin-top: .3rem !important; }
.dest-price { font-weight: 700 !important; color: var(--accent) !important; }
.dest-cta {
  display: inline-block;
  margin-top: .75rem;
  padding: .45rem 1.1rem;
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.5);
  border-radius: 20px;
  color: white;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  backdrop-filter: blur(4px);
  transition: background .18s, border-color .18s;
}
.dest-cta:hover { background: rgba(255,255,255,.25); border-color: white; }

/* ── Experience banner stats ── */
.exp-stat-number {
  font-size: 2.2rem;
  font-weight: 900;
  color: white;
  font-family: var(--font-head);
  line-height: 1;
}
.exp-stat-label {
  font-size: .78rem;
  color: rgba(255,255,255,.6);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: .35rem;
  font-weight: 600;
}
.exp-check {
  width: 24px;
  height: 24px;
  background: var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 900;
  font-size: .85rem;
  flex-shrink: 0;
}

/* ── Booking card on single pages ── */
.booking-card, .booking-form-card {
  border-radius: 20px !important;
  box-shadow: 0 8px 32px rgba(26,61,110,.12) !important;
  border: 1px solid #e5eaf0 !important;
}

/* ── sc-price-pp ── */
.sc-price-pp { font-size: .75rem; color: #94a3b8; margin-left: .1rem; }

/* ── Mobile: hide topbar msg on small screens ── */
@media (max-width: 768px) {
  .hdr-topbar__msg { display: none; }
  .hdr-topbar { height: 36px !important; }
  .themes-grid { grid-template-columns: repeat(3,1fr) !important; }
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; }
  .stat-item + .stat-item::before { display: none; }
  .footer-whatsapp-cta { font-size: .78rem; }
}
@media (max-width: 480px) {
  .themes-grid { grid-template-columns: repeat(2,1fr) !important; }
  .features-grid { grid-template-columns: 1fr 1fr !important; }
}