/* ===========================================================
   Holiday Circle Travel & Tourism LLC — Brand Stylesheet
   Colors & fonts per official Brand Guidelines
   =========================================================== */

:root{
  /* Brand colors */
  --blue:#007FAC;
  --orange:#CA4A31;
  --navy:#0F3554;
  --sky:#39A9DB;
  --sand:#F5F2EE;
  --gray:#E9EEF2;
  --charcoal:#2D3748;
  --white:#FFFFFF;

  --blue-grad:linear-gradient(135deg,#007FAC 0%,#0F3554 100%);
  --orange-grad:linear-gradient(135deg,#CA4A31 0%,#e0613f 100%);

  --shadow-sm:0 4px 14px rgba(15,53,84,.08);
  --shadow:0 12px 40px rgba(15,53,84,.12);
  --shadow-lg:0 24px 60px rgba(15,53,84,.18);

  --radius:18px;
  --radius-lg:28px;

  --head:'Playfair Display',Georgia,serif;
  --body:'Montserrat',-apple-system,Segoe UI,Roboto,sans-serif;

  --maxw:1200px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--charcoal);
  background:var(--white);
  line-height:1.65;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:.25s}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--head);color:var(--navy);line-height:1.2;font-weight:700}
section{padding:84px 0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- Helpers ---------- */
.text-orange{color:var(--orange)}
.text-blue{color:var(--blue)}
.center{text-align:center}
.eyebrow{
  font-family:var(--body);font-weight:700;letter-spacing:3px;
  text-transform:uppercase;font-size:.74rem;color:var(--orange);
  display:inline-block;margin-bottom:12px;
}
.section-title{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-bottom:14px}
.section-sub{max-width:620px;margin:0 auto 50px;color:#5b6573;font-size:1.02rem}
.center .section-sub{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:600;font-size:.95rem;
  padding:14px 28px;border-radius:50px;cursor:pointer;border:none;
  transition:transform .25s,box-shadow .25s,background .25s;
}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--orange-grad);color:#fff;box-shadow:0 10px 24px rgba(202,74,49,.35)}
.btn-primary:hover{box-shadow:0 16px 34px rgba(202,74,49,.45)}
.btn-blue{background:var(--blue-grad);color:#fff;box-shadow:0 10px 24px rgba(0,127,172,.32)}
.btn-blue:hover{box-shadow:0 16px 34px rgba(0,127,172,.42)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-sm{padding:10px 20px;font-size:.85rem}

/* ===========================================================
   HEADER (glassy)
   =========================================================== */
.topbar{
  background:var(--navy);color:#dbe6ef;font-size:.82rem;
  padding:8px 0;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.topbar a{color:#dbe6ef}
.topbar a:hover{color:var(--sky)}
.topbar .socials{display:flex;gap:16px;align-items:center}
.topbar .socials a{font-size:.95rem}

.site-header{
  position:sticky;top:0;z-index:1000;
  background:linear-gradient(100deg,rgba(202,74,49,.92) 0%,rgba(176,52,33,.92) 45%,rgba(15,53,84,.93) 100%);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid rgba(255,255,255,.18);
  box-shadow:0 4px 22px rgba(176,52,33,.18);
  transition:.3s;
}
.site-header.scrolled{
  background:linear-gradient(100deg,rgba(202,74,49,.98) 0%,rgba(176,52,33,.98) 45%,rgba(15,53,84,.99) 100%);
  box-shadow:0 6px 26px rgba(176,52,33,.3);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:54px;width:auto;background:rgba(255,255,255,.92);border-radius:12px;padding:5px;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.brand .wordmark{font-family:var(--head);font-weight:800;font-size:1.25rem;line-height:1;letter-spacing:.5px;color:#fff}
.brand .wordmark b{color:#fff}
.brand .wordmark span{color:#ffd9cd}
.brand .wordmark small{display:block;font-family:var(--body);font-weight:600;font-size:.56rem;letter-spacing:3px;color:rgba(255,255,255,.72);margin-top:4px}

.menu{display:flex;align-items:center;gap:8px}
.menu a{
  display:flex;align-items:center;gap:8px;
  font-weight:600;font-size:.9rem;color:#fff;position:relative;
  padding:9px 15px;border-radius:40px;transition:.28s;
  border:1px solid transparent;
}
.menu a i{font-size:.92rem;opacity:.92}
.menu a:hover,.menu a.active{
  background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,.08));
  border-color:rgba(255,255,255,.35);
  color:#fff;backdrop-filter:blur(6px);
}
.menu a.active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}

.nav-actions{display:flex;align-items:center;gap:14px}
.cart-link{position:relative;font-size:1.2rem;color:#fff}
.cart-count{
  position:absolute;top:-9px;right:-11px;background:var(--orange);color:#fff;
  font-size:.66rem;font-weight:700;min-width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:var(--body);
}
.hamburger{display:none;font-size:1.6rem;color:#fff;background:none;border:none;cursor:pointer}

/* ===========================================================
   HERO + Booking widget
   =========================================================== */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-slides{position:absolute;inset:0;z-index:-2}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.4s ease,transform 7s ease;transform:scale(1.08);
}
.hero-slide.active{opacity:1;transform:scale(1)}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,rgba(15,53,84,.78) 0%,rgba(0,127,172,.45) 55%,rgba(15,53,84,.25) 100%)}
.hero-inner{max-width:680px;padding:60px 0}
.hero .eyebrow{color:#ffd9cd}
.hero h1{color:#fff;font-size:clamp(2.3rem,5vw,4rem);margin-bottom:20px}
.hero h1 span{color:#ffb59f}
.hero p{font-size:1.13rem;color:#eaf2f8;margin-bottom:30px;max-width:560px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;transition:.3s}
.hero-dots button.active{background:#fff;width:30px;border-radius:6px}

/* Booking widget (glass) */
.booking{
  position:relative;margin-top:-58px;z-index:30;
}
.booking-card{
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  border:1px solid rgba(255,255,255,.6);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:26px;display:grid;grid-template-columns:2fr 1.3fr 1.3fr auto;gap:18px;align-items:end;
}
.field label{display:block;font-size:.74rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin-bottom:7px}
.field select,.field input{
  width:100%;padding:13px 14px;border:1.5px solid var(--gray);border-radius:12px;
  font-family:var(--body);font-size:.92rem;color:var(--charcoal);background:#fff;
}
.field select:focus,.field input:focus{outline:none;border-color:var(--blue)}
.counter-trigger{cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.counter-pop{
  position:absolute;background:#fff;border-radius:14px;box-shadow:var(--shadow);
  padding:16px 18px;margin-top:8px;width:240px;z-index:40;display:none;
}
.counter-pop.open{display:block}
.counter-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}
.counter-row span{font-size:.9rem;font-weight:600}
.stepper{display:flex;align-items:center;gap:12px}
.stepper button{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--blue);background:#fff;color:var(--blue);font-size:1.1rem;cursor:pointer;line-height:1}
.stepper button:hover{background:var(--blue);color:#fff}
.stepper b{min-width:18px;text-align:center}

/* ===========================================================
   MULTI-SERVICE SEARCH WIDGET
   =========================================================== */
.search-widget{position:relative;margin-top:-70px;z-index:30}
.sw-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:-2px;position:relative;z-index:2}
.sw-tab{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border:none;cursor:pointer;padding:12px 22px;border-radius:14px 14px 0 0;
  font-family:var(--body);font-weight:600;font-size:.82rem;color:var(--navy);
  box-shadow:0 -4px 14px rgba(15,53,84,.08);transition:.25s;min-width:92px;
}
.sw-tab i{font-size:1.15rem;color:var(--blue)}
.sw-tab:hover{background:#fff;transform:translateY(-3px)}
.sw-tab.active{background:var(--blue-grad);color:#fff}
.sw-tab.active i{color:#fff}

.sw-body{
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border:1px solid rgba(255,255,255,.65);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:26px 28px;
}
.sw-panel{display:none;animation:swfade .35s ease}
.sw-panel.active{display:block}
@keyframes swfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.sw-trip{display:flex;gap:22px;margin-bottom:14px;flex-wrap:wrap}
.rad{display:flex;align-items:center;gap:7px;font-size:.88rem;font-weight:600;color:var(--navy);cursor:pointer}
.rad input{accent-color:var(--orange);width:16px;height:16px}
.sw-tag{font-weight:700;color:var(--navy);border-left:4px solid var(--orange);padding-left:12px;margin-bottom:18px;font-size:1rem}

.sw-fields{display:flex;gap:16px;align-items:end;flex-wrap:wrap}
.sw-f{flex:1;min-width:120px;display:flex;flex-direction:column}
.f-flight .sw-f{min-width:110px}
.sw-f label{font-size:.7rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.sw-f input,.sw-f select{
  width:100%;padding:12px 12px;border:1.5px solid var(--gray);border-radius:11px;
  font-family:var(--body);font-size:.9rem;color:var(--charcoal);background:#fff;
}
.sw-f input:focus,.sw-f select:focus{outline:none;border-color:var(--blue)}
.sw-search{height:46px;white-space:nowrap;align-self:flex-end}
.sw-fare{display:flex;gap:20px;align-items:center;margin-top:16px;flex-wrap:wrap}
.sw-fare b{color:var(--orange);font-size:.88rem}

/* ===========================================================
   CARDS GRID (packages / tours)
   =========================================================== */
.grid{display:grid;gap:26px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .35s,box-shadow .35s;
  display:flex;flex-direction:column;position:relative;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.card:hover .card-img img{transform:scale(1.08)}
.badge{
  position:absolute;top:14px;left:14px;background:var(--orange);color:#fff;
  font-size:.72rem;font-weight:700;padding:5px 12px;border-radius:30px;letter-spacing:.5px;
}
.badge-blue{background:var(--blue)}
.fav{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;color:var(--orange);backdrop-filter:blur(4px)}
.card-body{padding:20px;display:flex;flex-direction:column;flex:1}
.card-meta{display:flex;gap:14px;font-size:.8rem;color:#7c8794;margin-bottom:10px}
.card-meta span{display:flex;align-items:center;gap:5px}
.card h3{font-size:1.12rem;margin-bottom:12px;flex:1}
.card h3 a:hover{color:var(--orange)}
.price{display:flex;align-items:baseline;gap:8px;margin-bottom:16px}
.price .now{font-family:var(--head);font-size:1.45rem;font-weight:800;color:var(--navy)}
.price .was{font-size:.9rem;color:#9aa4b0;text-decoration:line-through}
.price .per{font-size:.78rem;color:#7c8794}
.card-actions{display:flex;gap:10px}
.card-actions .btn{flex:1;justify-content:center}

.rating{color:#f5a623;font-size:.85rem}

/* ---------- Categories strip ---------- */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cat{
  position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;
  display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-sm);
}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s;z-index:-1}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(15,53,84,.85),transparent 60%);z-index:-1}
.cat:hover img{transform:scale(1.1)}
.cat-info{padding:22px}
.cat-info h3{color:#fff;font-size:1.25rem}
.cat-info p{font-size:.82rem;opacity:.9}

/* ===========================================================
   ABOUT / STATS
   =========================================================== */
.about{background:var(--sand)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-img{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.about-img img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
.about-badge{
  position:absolute;bottom:22px;right:22px;background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);padding:18px 22px;border-radius:16px;box-shadow:var(--shadow)}
.about-badge b{font-family:var(--head);font-size:2rem;color:var(--orange);display:block;line-height:1}
.about-badge small{font-size:.78rem;color:var(--navy);font-weight:600}
.feature-list{margin-top:24px;display:grid;gap:16px}
.feature{display:flex;gap:14px}
.feature .ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.feature h4{font-size:1.02rem;margin-bottom:3px}
.feature p{font-size:.9rem;color:#5b6573;margin:0}

.stats{background:var(--blue-grad);color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{font-family:var(--head);font-size:clamp(2.2rem,4vw,3.2rem);display:block;line-height:1}
.stat span{font-size:.92rem;opacity:.9}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:14px}
.gallery-grid a{border-radius:14px;overflow:hidden;position:relative}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery-grid a:hover img{transform:scale(1.1)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* ---------- Testimonials ---------- */
.testi{background:var(--sand)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);position:relative}
.testi-card .quote{font-family:var(--head);font-size:3rem;color:var(--gray);position:absolute;top:12px;right:20px;line-height:1}
.testi-card p{font-size:.94rem;color:#5b6573;margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-author .av{width:46px;height:46px;border-radius:50%;background:var(--blue-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--head)}
.testi-author b{display:block;font-size:.95rem;color:var(--navy)}
.testi-author small{color:#7c8794}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--gray);border-radius:14px;margin-bottom:14px;overflow:hidden}
.faq-q{padding:18px 22px;font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--navy)}
.faq-q .pm{color:var(--orange);font-size:1.4rem;transition:.3s}
.faq-item.open .faq-q .pm{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 22px}
.faq-item.open .faq-a{max-height:300px;padding:0 22px 20px}
.faq-a p{font-size:.92rem;color:#5b6573}

/* ---------- CTA band ---------- */
.cta-band{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1512453979798-5ea266f8880c?auto=format&fit=crop&w=1600&q=70') center/cover;z-index:-2}
.cta-band::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(202,74,49,.9),rgba(15,53,84,.9));z-index:-1}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,3.5vw,2.8rem);margin-bottom:14px}
.cta-band p{max-width:600px;margin:0 auto 26px;opacity:.95}

/* ---------- Blog ---------- */
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.35s}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.blog-card .card-img{aspect-ratio:16/10}
.blog-card .card-body{padding:22px}
.blog-date{font-size:.78rem;color:var(--orange);font-weight:700;letter-spacing:.5px;margin-bottom:8px}
.blog-card h3{font-size:1.08rem;margin-bottom:10px}
.blog-card p{font-size:.9rem;color:#5b6573;margin-bottom:14px}
.readmore{color:var(--blue);font-weight:600;font-size:.88rem}
.readmore:hover{color:var(--orange)}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{background:var(--navy);color:#bcccdb;padding-top:70px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.3fr;gap:36px;padding-bottom:46px}
.footer img.flogo{height:70px;margin-bottom:18px;filter:brightness(0) invert(1);opacity:.95}
.footer p{font-size:.9rem;line-height:1.8}
.footer h4{color:#fff;font-family:var(--body);font-weight:700;font-size:1.02rem;margin-bottom:18px}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:.9rem}
.footer ul a:hover{color:var(--sky);padding-left:5px}
.footer .contact-li{display:flex;gap:10px;margin-bottom:14px;font-size:.9rem;align-items:flex-start}
.footer .contact-li i{color:var(--orange);margin-top:3px}
.fsocials{display:flex;gap:12px;margin-top:18px}
.fsocials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff}
.fsocials a:hover{background:var(--orange)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;text-align:center;font-size:.84rem}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:900;width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.7rem;
  box-shadow:0 8px 24px rgba(37,211,102,.5);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;color:#fff;text-align:center;padding:120px 0 90px;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1518684079-3c830dcef090?auto=format&fit=crop&w=1600&q=70') center/cover;z-index:-2}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(15,53,84,.85),rgba(0,127,172,.6));z-index:-1}
.page-hero h1{color:#fff;font-size:clamp(2.2rem,4.5vw,3.4rem)}
.breadcrumb{margin-top:12px;font-size:.9rem;color:#dce8f2}
.breadcrumb a:hover{color:#fff}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:46px;align-items:start}
.info-card{display:flex;gap:16px;background:#fff;border:1px solid var(--gray);border-radius:16px;padding:22px;margin-bottom:18px;transition:.3s}
.info-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.info-card .ic{flex:none;width:52px;height:52px;border-radius:14px;background:var(--blue-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.info-card h4{font-size:1rem;margin-bottom:4px}
.info-card p{font-size:.9rem;color:#5b6573;margin:0}
.form-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:34px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--gray);border-radius:12px;font-family:var(--body);font-size:.92rem}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue)}
.map-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-top:40px;height:400px}
.map-wrap iframe{width:100%;height:100%;border:0}

/* ---------- Cart ---------- */
.cart-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:34px;align-items:start}
.cart-item{display:grid;grid-template-columns:90px 1fr auto;gap:18px;background:#fff;border:1px solid var(--gray);border-radius:16px;padding:16px;margin-bottom:16px;align-items:center}
.cart-item img{width:90px;height:75px;object-fit:cover;border-radius:10px}
.cart-item h4{font-size:1rem;margin-bottom:4px}
.cart-item .meta{font-size:.82rem;color:#7c8794}
.cart-item .ci-price{font-family:var(--head);font-weight:800;color:var(--navy);font-size:1.15rem}
.ci-remove{background:none;border:none;color:var(--orange);cursor:pointer;font-size:.82rem;margin-top:6px}
.summary{background:#fff;border:1px solid var(--gray);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:26px;position:sticky;top:100px}
.summary h3{font-size:1.3rem;margin-bottom:18px}
.sum-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.94rem;color:#5b6573}
.sum-row.total{border-top:1px solid var(--gray);margin-top:8px;padding-top:16px;font-size:1.15rem;font-weight:700;color:var(--navy)}
.empty-cart{text-align:center;padding:70px 20px;color:#7c8794}
.empty-cart i{font-size:3.4rem;color:var(--gray);margin-bottom:16px}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:.7s ease}
.reveal.in{opacity:1;transform:none}

@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .cats{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .search-widget{margin-top:-40px}
  .sw-fields{gap:12px}
  .sw-f{min-width:140px}
  .sw-search{width:100%;margin-top:6px}
  .f-flight .sw-f,.f-hotel .sw-f,.f-visa .sw-f{flex:1 1 30%}
}
@media(max-width:860px){
  .menu{position:fixed;top:0;right:-100%;height:100vh;width:78%;max-width:330px;background:#fff;flex-direction:column;align-items:flex-start;gap:4px;padding:90px 26px;box-shadow:var(--shadow-lg);transition:right .35s;z-index:1001}
  .menu.open{right:0}
  .menu a{padding:14px 14px;width:100%;border-radius:12px;color:var(--navy);border:none}
  .menu a i{color:var(--orange);width:22px;text-align:center}
  .menu a:hover,.menu a.active{background:var(--sand);color:var(--orange);border:none}
  .hamburger{display:block;z-index:1002}
  .about-grid,.contact-grid,.cart-layout{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  section{padding:58px 0}
  .grid-4,.grid-3,.grid-2,.cats,.testi-grid,.gallery-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .gallery-grid{grid-auto-rows:200px}
  .g-wide{grid-column:span 1}
  .topbar .container{justify-content:center}
  .topbar .tb-left{display:none}

  .search-widget{margin-top:18px}
  .sw-tabs{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;gap:6px;padding-bottom:2px;-webkit-overflow-scrolling:touch}
  .sw-tab{min-width:78px;padding:10px 14px;flex:none}
  .sw-body{padding:20px 16px}
  .sw-fields{flex-direction:column;gap:14px}
  .sw-f{width:100%;min-width:0}
  .sw-trip,.sw-fare{justify-content:center}
  .sw-tag{text-align:left}

  .hero-inner{text-align:center}
  .hero-cta{justify-content:center}
  .about-grid>div,.reveal{text-align:center}
  .feature{flex-direction:column;align-items:center;text-align:center}
  .info-card{flex-direction:column;align-items:center;text-align:center}
  .section-title,.eyebrow,h1,h2,h3{text-align:center}
  .hero p,.about p,.testi-card p,.feature p,.info-card p,.card h3,.section-sub,p{text-align:justify;text-justify:inter-word}
  .hero p,.section-sub,.cta-band p,.stat span,.blog-date{text-align:center}
  .card-actions{justify-content:center}
  .footer p,.footer .contact-li{text-align:left}
  .footer-grid{text-align:center}
  .footer .contact-li{justify-content:center}
  .fsocials,.about-img,.feature .ic,.info-card .ic{margin-left:auto;margin-right:auto}
}
