/* styles.css — Travel Planner Global Stylesheet */
:root {
  --red: #E31E24;
  --red-dark: #B81519;
  --red-light: #FF3A3F;
  --navy: #1A2B4A;
  --navy-mid: #243352;
  --sky: #E8F4FF;
  --sky-mid: #D0E8FF;
  --text: #1A2B4A;
  --text-muted: #6B7A99;
  --border: #E5E9F2;
  --white: #ffffff;
  --offwhite: #F7F9FC;
  --gold: #F5A623;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Nunito',sans-serif; background:var(--white); color:var(--text); overflow-x:hidden; }
h1,h2,h3,h4,h5 { font-family:'Libre Baskerville',serif; }

/* TOPBAR */
.topbar { background:var(--navy); padding:7px 0; font-size:12.5px; color:rgba(255,255,255,0.7); }
.topbar a { color:rgba(255,255,255,0.8); text-decoration:none; transition:color .2s; }
.topbar a:hover { color:#fff; }
.topbar-sep { color:rgba(255,255,255,0.25); margin:0 10px; }

/* NAVBAR */
.navbar-custom { background:#fff !important; height:100px; padding:0; border-bottom:2px solid var(--border); position:sticky; top:0; z-index:1000; box-shadow:0 2px 20px rgba(26,43,74,0.07); }
.brand-name { font-family:'Libre Baskerville',serif; font-size:1.35rem; font-weight:700; color:var(--navy); line-height:1; }
.brand-name span { color:var(--red); }
.brand-tag { font-size:10px; color:var(--text-muted); letter-spacing:1px; text-transform:uppercase; }
.nav-pill { display:flex; align-items:center; gap:6px; padding:8px 16px; border:1.5px solid var(--border); border-radius:50px; font-size:15px; font-weight:700; color:var(--text); text-decoration:none; transition:all .2s; cursor:pointer; white-space:nowrap; background:#fff; }
.nav-pill:hover { border-color:var(--red); color:var(--red); }
.btn-plantour { background:var(--red); color:#fff; padding:10px 22px; border-radius:8px; font-weight:800; font-size:13.5px; text-decoration:none; display:flex; align-items:center; gap:7px; transition:background .2s,transform .2s; white-space:nowrap; }
.btn-plantour:hover { background:var(--red-dark); color:#fff; transform:translateY(-1px); }

/* TICKER */
.ticker-bar { background:var(--navy); padding:10px 0; overflow:hidden; }
.ticker-track { display:flex; gap:60px; width:max-content; animation:ticker 30s linear infinite; }
.ticker-track:hover { animation-play-state:paused; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,0.85); font-size:13px; font-weight:700; white-space:nowrap; }
.ticker-dot { width:7px; height:7px; border-radius:50%; background:var(--red); flex-shrink:0; }

/* SECTION COMMON */
section { padding:80px 0; }
.section-tag { display:inline-flex; align-items:center; gap:8px; color:var(--red); font-size:12px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:10px; }
.section-tag::before { content:''; width:24px; height:2.5px; background:var(--red); border-radius:2px; }
.section-title { font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:700; color:var(--navy); line-height:1.15; }
.section-title span { color:var(--red); }
.section-sub { font-size:15px; color:var(--text-muted); margin-top:12px; line-height:1.65; }
.bg-offwhite { background:var(--offwhite); }

/* PACKAGE CARDS */
.pkg-card { background:#fff; border-radius:22px; overflow:hidden; box-shadow:0 14px 35px rgba(10,18,40,0.08); transition:transform .3s,box-shadow .3s; height:100%; }
.pkg-card:hover { transform:translateY(-6px); box-shadow:0 18px 42px rgba(10,18,40,0.14); }
.pkg-img { position:relative; height:240px; background-size:cover; background-position:center; border-radius:16px 16px 0 0; overflow:hidden; }
.pkg-img::before { content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.48),rgba(0,0,0,0.12)); z-index:1; pointer-events:none; }
.pkg-type-badge { position:absolute; top:16px; left:16px; background:var(--red); color:#fff; padding:8px 14px; border-radius:999px; font-size:12px; font-weight:800; z-index:2; }
.pkg-days-badge { position:absolute; top:16px; right:16px; background:rgba(255,255,255,0.95); color:var(--navy); padding:8px 14px; border-radius:999px; font-size:12px; font-weight:800; z-index:2; }
.pkg-rating { position:absolute; left:16px; bottom:16px; background:rgba(255,255,255,0.95); color:#1b2d4a; padding:8px 12px; border-radius:999px; font-size:13px; font-weight:800; z-index:2; display:flex; align-items:center; gap:6px; }
.pkg-rating i { color:var(--gold); }
.pkg-body { padding:20px 20px 0; }
.pkg-body h5 { font-family:'Nunito',sans-serif; font-weight:900; color:var(--navy); margin-bottom:14px; }
.pkg-hl { padding-left:18px; margin:0; color:#45556f; }
.pkg-hl li { margin-bottom:8px; font-size:13.5px; }
.pkg-footer { padding:18px 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; border-top:1.5px solid var(--border); }
.pkg-price { font-family:'Libre Baskerville',serif; font-size:1.5rem; color:var(--red); font-weight:700; }
.pkg-price span { font-family:'Nunito',sans-serif; font-size:11px; color:var(--text-muted); font-weight:400; }
.btn-pkg { background:var(--red); color:#fff; border:none; padding:10px 16px; border-radius:12px; font-weight:800; font-size:13px; cursor:pointer; transition:.25s ease; font-family:'Nunito',sans-serif; display:flex; align-items:center; gap:6px; }
.btn-pkg:hover { background:var(--red-dark); transform:translateY(-2px); }
.btn-pkg-outline { background:#eef2f8; color:var(--navy); border:none; padding:10px 16px; border-radius:12px; font-size:13px; font-weight:700; cursor:pointer; transition:.25s ease; font-family:'Nunito',sans-serif; }
.btn-pkg-outline:hover { background:var(--border); }
.filter-pill { padding:8px 20px; border-radius:50px; border:1.5px solid var(--border); background:#fff; font-size:13px; font-weight:700; color:var(--text-muted); cursor:pointer; transition:all .2s; font-family:'Nunito',sans-serif; }
.filter-pill:hover,.filter-pill.active { background:var(--red); color:#fff; border-color:var(--red); }

/* HERO BUTTONS */
.btn-hero-primary { background:var(--red); color:#fff; padding:13px 30px; border-radius:8px; font-weight:800; font-size:15px; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; box-shadow:0 6px 20px rgba(227,30,36,0.3); }
.btn-hero-primary:hover { background:var(--red-dark); color:#fff; transform:translateY(-2px); }
.btn-hero-outline { background:#fff; color:var(--navy); border:2px solid var(--border); padding:13px 28px; border-radius:8px; font-weight:700; font-size:15px; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; }
.btn-hero-outline:hover { border-color:var(--red); color:var(--red); }

/* STATS BAR */
.stats-bar { background:var(--red); padding:36px 0; }
.stat-item { text-align:center; }
.stat-num { font-family:'Libre Baskerville',serif; font-size:2.4rem; font-weight:700; color:#fff; }
.stat-label { font-size:13px; color:rgba(255,255,255,0.75); margin-top:4px; font-weight:600; }

/* WHY CARDS */
.why-card { background:#fff; border-radius:16px; padding:28px 24px; border:1.5px solid var(--border); box-shadow:0 2px 12px rgba(26,43,74,0.05); transition:transform .3s,box-shadow .3s,border-color .3s; text-align:center; }
.why-card:hover { transform:translateY(-5px); box-shadow:0 14px 40px rgba(26,43,74,0.12); border-color:rgba(227,30,36,0.2); }
.why-icon { width:64px; height:64px; border-radius:16px; background:rgba(227,30,36,0.08); display:flex; align-items:center; justify-content:center; font-size:26px; color:var(--red); margin:0 auto 18px; transition:background .2s; }
.why-card:hover .why-icon { background:var(--red); color:#fff; }
.why-card h5 { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; }
.why-card p { font-size:13.5px; color:var(--text-muted); line-height:1.65; }

/* TESTIMONIALS */
.testi-card { background:#fff; border:1.5px solid var(--border); border-radius:16px; padding:28px; box-shadow:0 2px 12px rgba(26,43,74,0.05); transition:transform .3s,box-shadow .3s; }
.testi-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(26,43,74,0.12); }
.testi-stars { color:var(--gold); font-size:14px; margin-bottom:14px; }
.testi-text { font-size:14px; color:var(--text-muted); line-height:1.7; margin-bottom:20px; font-style:italic; }
.testi-avatar { width:44px; height:44px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:16px; color:#fff; }
.testi-name { font-weight:800; font-size:14px; color:var(--navy); }
.testi-loc { font-size:12px; color:var(--text-muted); }

/* PROMO */
.promo-strip { background:var(--navy); border-radius:20px; padding:50px 48px; position:relative; overflow:hidden; }
.promo-strip::before { content:''; position:absolute; top:-80px; right:-80px; width:320px; height:320px; border-radius:50%; background:rgba(227,30,36,0.12); }
.promo-strip h2 { font-size:clamp(1.8rem,3.5vw,2.8rem); color:#fff; font-weight:700; }
.promo-strip p { color:rgba(255,255,255,0.7); font-size:15px; }
.btn-promo { background:var(--red); color:#fff; padding:13px 30px; border-radius:8px; font-weight:800; font-size:15px; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; }
.btn-promo:hover { background:var(--red-dark); color:#fff; transform:translateY(-2px); }
.btn-promo-white { background:#fff; color:var(--navy); padding:13px 28px; border-radius:8px; font-weight:800; font-size:15px; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; }
.btn-promo-white:hover { background:#f0f4f8; }

/* DEST TILES */
.dest-tile { border-radius:16px; overflow:hidden; position:relative; cursor:pointer; box-shadow:0 4px 16px rgba(26,43,74,0.1); transition:transform .3s; }
.dest-tile:hover { transform:scale(1.02); }
.dest-tile-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(26,43,74,0.82) 0%,transparent 55%); }
.dest-tile-info { position:absolute; bottom:18px; left:18px; }
.dest-tile-info .sub { font-size:10px; font-weight:800; color:rgba(255,255,255,0.65); text-transform:uppercase; letter-spacing:1px; }
.dest-tile-info h4 { font-size:1.3rem; font-weight:700; color:#fff; margin:2px 0 4px; }
.dest-tile-info span { font-size:12px; color:rgba(255,255,255,0.6); }
.dest-tile-tag { position:absolute; top:14px; right:14px; background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.3); color:#fff; padding:5px 12px; border-radius:50px; font-size:11px; font-weight:700; backdrop-filter:blur(6px); }
.tile-tall { height:380px; }
.tile-short { height:180px; }

/* FOOTER */
.footer { background:var(--navy); padding:60px 0 28px; }
.footer-brand { font-family:'Libre Baskerville',serif; font-size:1.5rem; font-weight:700; color:#fff; }
.footer-brand span { color:#FFD700; }
.footer-tagline { font-size:12px; color:rgba(255,255,255,0.4); letter-spacing:1px; text-transform:uppercase; margin-top:3px; }
.footer p { font-size:14px; color:rgba(255,255,255,0.5); line-height:1.7; margin-top:14px; }
.footer-social a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.6); display:inline-flex; align-items:center; justify-content:center; font-size:14px; text-decoration:none; transition:background .2s,color .2s; }
.footer-social a:hover { background:var(--red); color:#fff; }
.footer-heading { font-family:'Nunito',sans-serif; font-size:12px; text-transform:uppercase; letter-spacing:1.5px; color:rgba(255,255,255,0.35); margin-bottom:18px; font-weight:800; }
.footer ul { list-style:none; padding:0; }
.footer ul li { margin-bottom:10px; }
.footer ul li a { color:rgba(255,255,255,0.6); text-decoration:none; font-size:14px; font-weight:600; transition:color .2s; }
.footer ul li a:hover { color:var(--red); }
.footer-divider { border-color:rgba(255,255,255,0.08); margin:30px 0 20px; }
.footer-bottom { font-size:13px; color:rgba(255,255,255,0.3); font-weight:600; }

/* FLOAT BTNS */
.float-wa,.float-call { position:fixed; left:16px; width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:24px; z-index:999; box-shadow:0 6px 20px rgba(0,0,0,0.25); text-decoration:none; transition:transform .2s; }
.float-wa { bottom:20px; background:#25D366; color:#fff; }
.float-call { bottom:84px; background:var(--red); color:#fff; }
.float-wa:hover,.float-call:hover { transform:scale(1.12); color:#fff; }

/* SEARCH BOX */
.search-box { background:#fff; border-radius:16px; padding:28px 32px; box-shadow:0 8px 40px rgba(26,43,74,0.12); border:1px solid var(--border); }
.search-label { font-size:11px; font-weight:800; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:7px; }
.search-input { border:1.5px solid var(--border); border-radius:10px; padding:11px 14px; font-size:14px; font-weight:600; color:var(--text); width:100%; background:#fff; outline:none; font-family:'Nunito',sans-serif; transition:border-color .2s,box-shadow .2s; }
.search-input:focus { border-color:var(--red); box-shadow:0 0 0 3px rgba(227,30,36,0.1); }
.btn-search { background:var(--red); color:#fff; border:none; padding:12px 28px; border-radius:10px; font-weight:800; font-size:15px; width:100%; transition:background .2s,transform .2s; font-family:'Nunito',sans-serif; display:flex; align-items:center; justify-content:center; gap:8px; cursor:pointer; }
.btn-search:hover { background:var(--red-dark); transform:translateY(-1px); }

/* ENQUIRY FORM */
.enquiry-section { background:var(--offwhite); }
.enquiry-form-card { background:#fff; border-radius:20px; padding:36px; box-shadow:0 8px 40px rgba(26,43,74,0.1); border:1.5px solid var(--border); }
.form-label-custom { font-size:12.5px; font-weight:700; color:var(--text-muted); margin-bottom:6px; text-transform:uppercase; letter-spacing:.5px; }
.form-ctrl { border:1.5px solid var(--border); border-radius:10px; padding:11px 14px; font-size:14px; font-weight:600; color:var(--text); width:100%; outline:none; font-family:'Nunito',sans-serif; transition:border-color .2s,box-shadow .2s; background:#fff; }
.form-ctrl:focus { border-color:var(--red); box-shadow:0 0 0 3px rgba(227,30,36,0.1); }
.form-ctrl::placeholder { color:#B0BAD0; font-weight:500; }
.btn-submit { background:var(--red); color:#fff; border:none; padding:14px; border-radius:10px; font-weight:800; font-size:15px; width:100%; cursor:pointer; font-family:'Nunito',sans-serif; transition:background .2s,transform .2s; display:flex; align-items:center; justify-content:center; gap:8px; }
.btn-submit:hover { background:var(--red-dark); transform:translateY(-1px); }

/* TOUR PILL CARDS */
.tour-pill-card { border-radius:14px; overflow:hidden; position:relative; cursor:pointer; box-shadow:0 2px 12px rgba(26,43,74,0.08); transition:transform .3s,box-shadow .3s; }
.tour-pill-card:hover { transform:scale(1.03); box-shadow:0 10px 30px rgba(26,43,74,0.15); }
.tour-pill-card .tc-img { height:170px; display:flex; align-items:center; justify-content:center; }
.tc-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(26,43,74,0.8) 0%,rgba(26,43,74,0.1) 55%); }
.tc-label { position:absolute; bottom:14px; left:14px; right:14px; }
.tc-label h6 { font-size:14px; font-weight:700; color:#fff; margin:0; }
.tc-label span { font-size:11px; color:rgba(255,255,255,0.7); }

/* PAGE HERO */
.page-hero { background:linear-gradient(120deg,var(--sky),#C8E0FF); padding:80px 0 60px; position:relative; overflow:hidden; }
.page-hero h1 { font-size:clamp(2rem,5vw,3.5rem); color:var(--navy); font-weight:700; }
.page-hero p { color:var(--text-muted); font-size:16px; }
.breadcrumb-custom a { color:var(--red); text-decoration:none; font-weight:700; }
.breadcrumb-custom span { color:var(--text-muted); font-size:14px; }

/* CONTACT CARDS */
.cinfo-card { background:#fff; border:1.5px solid var(--border); border-radius:14px; padding:22px 20px; display:flex; align-items:center; gap:16px; box-shadow:0 2px 8px rgba(26,43,74,0.05); transition:border-color .2s; }
.cinfo-card:hover { border-color:rgba(227,30,36,0.2); }
.cinfo-icon { width:48px; height:48px; border-radius:12px; background:rgba(227,30,36,0.08); display:flex; align-items:center; justify-content:center; font-size:20px; color:var(--red); flex-shrink:0; }

/* BLOG CARDS */
.blog-card { background:#fff; border-radius:16px; overflow:hidden; border:1.5px solid var(--border); box-shadow:0 2px 12px rgba(26,43,74,0.05); transition:transform .3s,box-shadow .3s; height:100%; }
.blog-card:hover { transform:translateY(-5px); box-shadow:0 14px 40px rgba(26,43,74,0.12); }
.blog-img { height:200px; background-size:cover; background-position:center; }
.blog-body { padding:20px; }
.blog-cat { font-size:11px; font-weight:800; color:var(--red); text-transform:uppercase; letter-spacing:1px; }
.blog-body h5 { font-size:1.05rem; color:var(--navy); margin:8px 0 10px; }
.blog-body p { font-size:13.5px; color:var(--text-muted); line-height:1.65; }
.blog-meta { font-size:12px; color:var(--text-muted); display:flex; gap:12px; margin-top:12px; }

/* GALLERY */
.gallery-item { border-radius:12px; overflow:hidden; position:relative; cursor:pointer; }
.gallery-item img { width:100%; height:220px; object-fit:cover; transition:transform .4s; }
.gallery-item:hover img { transform:scale(1.06); }
.gallery-item-overlay { position:absolute; inset:0; background:rgba(26,43,74,0.5); opacity:0; display:flex; align-items:center; justify-content:center; transition:opacity .3s; font-size:28px; color:#fff; }
.gallery-item:hover .gallery-item-overlay { opacity:1; }

/* ACTIVITY CARDS */
.activity-card { background:#fff; border-radius:16px; overflow:hidden; border:1.5px solid var(--border); box-shadow:0 2px 12px rgba(26,43,74,0.05); transition:transform .3s; height:100%; }
.activity-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(26,43,74,0.12); }
.activity-img { height:180px; background-size:cover; background-position:center; }
.activity-body { padding:18px; }
.activity-body h5 { font-size:1rem; color:var(--navy); margin-bottom:6px; }
.activity-badge { font-size:11px; font-weight:800; background:rgba(227,30,36,0.1); color:var(--red); padding:4px 10px; border-radius:50px; display:inline-block; }

/* REVEAL */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .55s ease,transform .55s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* SCROLLBAR */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:#f0f4f8; }
::-webkit-scrollbar-thumb { background:var(--red); border-radius:3px; }

/* RESPONSIVE */
@media (max-width:991px) {
  .navbar-custom { height:auto; padding:12px 0; }
}
@media (max-width:768px) {
  section { padding:50px 0; }
  .promo-strip { padding:36px 24px; }
}
