/*
Theme Name:        Spark Holidays
Theme URI:         https://sparkholidays.in
Author:            Spark Holidays Private Limited
Author URI:        https://sparkholidays.in
Description:       A premium, modern travel agency theme for Spark Holidays Private Limited. Built for lead generation, SEO, and conversion optimization. Compatible with Elementor, WooCommerce, Yoast SEO, Rank Math, WP Rocket, and more.
Version:           1.0.0
Requires at least: 6.0
Tested up to:      6.5
Requires PHP:      8.0
License:           GPL v2 or later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       spark-holidays
Tags:              travel, tour, agency, responsive, custom-post-types, custom-menu, featured-images, full-width-template, sticky-post, threaded-comments, rtl-language-support, translation-ready, wide-blocks, block-patterns, editor-style, wp-block-styles

Spark Holidays Theme - Copyright (C) 2024 Spark Holidays Private Limited
This theme is distributed under the terms of the GNU GPL v2.
*/

/* =====================================================
   BASE RESET & ROOT VARIABLES
   ===================================================== */
:root {
    --color-primary:       #0057B8;
    --color-primary-dark:  #003f8a;
    --color-primary-light: #3a80d2;
    --color-secondary:     #FF6B00;
    --color-secondary-dark:#cc5500;
    --color-accent:        #FFD700;
    --color-text:          #1a1a2e;
    --color-text-light:    #555570;
    --color-text-muted:    #888899;
    --color-bg:            #ffffff;
    --color-bg-alt:        #f5f7fb;
    --color-bg-dark:       #0a1628;
    --color-border:        #e0e4ef;
    --color-success:       #28a745;
    --color-error:         #dc3545;
    --color-warning:       #ffc107;

    --font-primary:        'Poppins', sans-serif;
    --font-size-base:      16px;
    --line-height-base:    1.7;

    --radius-sm:           4px;
    --radius-md:           8px;
    --radius-lg:           16px;
    --radius-xl:           24px;
    --radius-full:         9999px;

    --shadow-sm:           0 1px 3px rgba(0,0,0,.08);
    --shadow-md:           0 4px 16px rgba(0,0,0,.10);
    --shadow-lg:           0 8px 32px rgba(0,0,0,.14);
    --shadow-xl:           0 16px 64px rgba(0,0,0,.18);

    --transition-base:     all 0.3s ease;
    --transition-slow:     all 0.5s ease;
    --container-max:       1240px;
    --container-padding:   1.5rem;
    --header-height:       80px;
    --zindex-sticky:       900;
    --zindex-overlay:      1000;
    --zindex-modal:        1100;
    --zindex-toast:        1200;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html {
    scroll-behavior: smooth;
    font-size: var(--font-size-base);
}

body {
    font-family:    var(--font-primary);
    color:          var(--color-text);
    background:     var(--color-bg);
    line-height:    var(--line-height-base);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: var(--color-primary);
    text-decoration: none;
    transition: var(--transition-base);
}

a:hover { color: var(--color-primary-dark); }

ul, ol { list-style: none; }

button, input, select, textarea {
    font-family: inherit;
    font-size: inherit;
}

/* =====================================================
   CONTAINER & LAYOUT
   ===================================================== */
.container {
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.container-fluid {
    width: 100%;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin: -0.75rem;
}

[class*="col-"] {
    padding: 0.75rem;
}

.col-12 { width: 100%; }
.col-6  { width: 50%; }
.col-4  { width: 33.333%; }
.col-3  { width: 25%; }
.col-8  { width: 66.666%; }

@media (max-width: 768px) {
    .col-6, .col-4, .col-3, .col-8 { width: 100%; }
}

@media (min-width: 769px) and (max-width: 992px) {
    .col-4 { width: 50%; }
    .col-3 { width: 50%; }
}

.section {
    padding: 5rem 0;
}

.section-sm {
    padding: 3rem 0;
}

.section-lg {
    padding: 7rem 0;
}

.section-title {
    text-align: center;
    margin-bottom: 3rem;
}

.section-title .eyebrow {
    display: inline-block;
    color: var(--color-secondary);
    font-size: 0.875rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.section-title h2 {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.3;
    margin-bottom: 1rem;
}

.section-title p {
    font-size: 1.0625rem;
    color: var(--color-text-light);
    max-width: 600px;
    margin: 0 auto;
}

/* =====================================================
   TYPOGRAPHY
   ===================================================== */
h1,h2,h3,h4,h5,h6 {
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-text);
    margin-bottom: 0.75em;
}

h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

.lead {
    font-size: 1.125rem;
    font-weight: 400;
    color: var(--color-text-light);
}

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }
.text-white  { color: #fff !important; }
.text-primary{ color: var(--color-primary) !important; }
.text-secondary { color: var(--color-secondary) !important; }
.text-muted  { color: var(--color-text-muted) !important; }

/* =====================================================
   BUTTONS
   ===================================================== */
.btn {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             0.5rem;
    padding:         0.75rem 1.75rem;
    font-size:       0.9375rem;
    font-weight:     600;
    border-radius:   var(--radius-full);
    border:          2px solid transparent;
    cursor:          pointer;
    transition:      var(--transition-base);
    text-decoration: none;
    white-space:     nowrap;
    line-height:     1;
}

.btn-primary {
    background:  var(--color-primary);
    color:       #fff;
    border-color:var(--color-primary);
}

.btn-primary:hover {
    background:   var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color:        #fff;
    transform:    translateY(-2px);
    box-shadow:   0 8px 24px rgba(0,87,184,0.35);
}

.btn-secondary {
    background:   var(--color-secondary);
    color:        #fff;
    border-color: var(--color-secondary);
}

.btn-secondary:hover {
    background:   var(--color-secondary-dark);
    border-color: var(--color-secondary-dark);
    color:        #fff;
    transform:    translateY(-2px);
    box-shadow:   0 8px 24px rgba(255,107,0,0.35);
}

.btn-outline {
    background:   transparent;
    color:        var(--color-primary);
    border-color: var(--color-primary);
}

.btn-outline:hover {
    background:   var(--color-primary);
    color:        #fff;
    transform:    translateY(-2px);
}

.btn-outline-white {
    background:   transparent;
    color:        #fff;
    border-color: #fff;
}

.btn-outline-white:hover {
    background:   #fff;
    color:        var(--color-primary);
}

.btn-lg {
    padding:   1rem 2.25rem;
    font-size: 1.0625rem;
}

.btn-sm {
    padding:   0.5rem 1.25rem;
    font-size: 0.8125rem;
}

.btn-icon {
    width:         44px;
    height:        44px;
    padding:       0;
    border-radius: 50%;
}

/* =====================================================
   BADGES & LABELS
   ===================================================== */
.badge {
    display:      inline-block;
    padding:      0.2em 0.65em;
    font-size:    0.75rem;
    font-weight:  600;
    border-radius:var(--radius-full);
    line-height:  1;
}

.badge-primary   { background: var(--color-primary); color:#fff; }
.badge-secondary { background: var(--color-secondary); color:#fff; }
.badge-success   { background: var(--color-success); color:#fff; }
.badge-warning   { background: var(--color-warning); color:#fff; }

/* =====================================================
   CARDS
   ===================================================== */
.card {
    background:    var(--color-bg);
    border-radius: var(--radius-lg);
    box-shadow:    var(--shadow-md);
    overflow:      hidden;
    transition:    var(--transition-base);
}

.card:hover {
    transform:  translateY(-6px);
    box-shadow: var(--shadow-xl);
}

.card-img {
    position:   relative;
    overflow:   hidden;
}

.card-img img {
    width:      100%;
    height:     220px;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.card:hover .card-img img {
    transform: scale(1.06);
}

.card-body {
    padding: 1.5rem;
}

.card-title {
    font-size:   1.125rem;
    font-weight: 700;
    margin-bottom:0.5rem;
    color:       var(--color-text);
}

.card-meta {
    display:     flex;
    align-items: center;
    gap:         1rem;
    font-size:   0.8125rem;
    color:       var(--color-text-muted);
    margin-bottom:0.75rem;
}

.card-price {
    font-size:   1.25rem;
    font-weight: 700;
    color:       var(--color-primary);
}

.card-price .original {
    font-size:        0.875rem;
    font-weight:      400;
    color:            var(--color-text-muted);
    text-decoration:  line-through;
    margin-left:      0.5rem;
}

/* =====================================================
   FORMS
   ===================================================== */
.form-group {
    margin-bottom: 1.25rem;
}

.form-label {
    display:      block;
    font-size:    0.875rem;
    font-weight:  600;
    color:        var(--color-text);
    margin-bottom:0.4rem;
}

.form-control {
    width:        100%;
    padding:      0.75rem 1rem;
    font-size:    0.9375rem;
    color:        var(--color-text);
    background:   #fff;
    border:       1.5px solid var(--color-border);
    border-radius:var(--radius-md);
    transition:   var(--transition-base);
    outline:      none;
    appearance:   none;
}

.form-control:focus {
    border-color: var(--color-primary);
    box-shadow:   0 0 0 3px rgba(0,87,184,0.12);
}

.form-control::placeholder {
    color: var(--color-text-muted);
    font-size: 0.875rem;
}

textarea.form-control {
    resize:     vertical;
    min-height: 120px;
}

.form-row {
    display: flex;
    gap:     1rem;
    flex-wrap: wrap;
}

.form-row .form-group {
    flex: 1;
    min-width: 200px;
}

.form-error {
    font-size:   0.8125rem;
    color:       var(--color-error);
    margin-top:  0.35rem;
}

.form-success {
    background:   #d4edda;
    color:        #155724;
    border:       1px solid #c3e6cb;
    padding:      1rem 1.25rem;
    border-radius:var(--radius-md);
    margin-bottom:1.25rem;
}

.form-error-msg {
    background:   #f8d7da;
    color:        #721c24;
    border:       1px solid #f5c6cb;
    padding:      1rem 1.25rem;
    border-radius:var(--radius-md);
    margin-bottom:1.25rem;
}

/* =====================================================
   HEADER
   ===================================================== */
.site-header {
    position:   fixed;
    top:        0;
    left:       0;
    right:      0;
    z-index:    var(--zindex-sticky);
    height:     var(--header-height);
    background: transparent;
    transition: var(--transition-base);
}

.site-header.scrolled,
.site-header.header-solid {
    background:  #fff;
    box-shadow:  var(--shadow-md);
}

.header-inner {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    height:          var(--header-height);
}

.site-logo {
    display:     flex;
    align-items: center;
    gap:         0.6rem;
    text-decoration: none;
}

.site-logo .logo-icon {
    width:           42px;
    height:          42px;
    background:      linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    border-radius:   var(--radius-md);
    display:         flex;
    align-items:     center;
    justify-content: center;
    color:           #fff;
    font-size:       1.25rem;
    font-weight:     800;
    flex-shrink:     0;
}

.site-logo .logo-text {
    display:     flex;
    flex-direction: column;
    line-height: 1.2;
}

.site-logo .logo-name {
    font-size:   1.125rem;
    font-weight: 800;
    color:       var(--color-primary);
    letter-spacing:-0.5px;
}

.site-header.scrolled .logo-name,
.site-header.header-solid .logo-name { color: var(--color-primary); }

.site-logo:not(.site-header.scrolled *) .logo-name {
    color: #fff;
}

.site-header:not(.scrolled):not(.header-solid) .site-logo .logo-name { color:#fff; }
.site-header.scrolled .site-logo .logo-name,
.site-header.header-solid .site-logo .logo-name { color: var(--color-primary); }

.site-logo .logo-tagline {
    font-size:   0.6875rem;
    color:       var(--color-text-muted);
    font-weight: 500;
}

.site-header:not(.scrolled):not(.header-solid) .logo-tagline { color:rgba(255,255,255,0.7); }
.site-header.scrolled .logo-tagline { color: var(--color-text-muted); }

/* Primary Navigation */
.primary-navigation {
    display: flex;
    align-items: center;
}

.nav-menu {
    display:    flex;
    align-items:center;
    gap:        0.25rem;
    list-style: none;
    margin:     0;
    padding:    0;
}

.nav-menu > li { position: relative; }

.nav-menu > li > a {
    display:     block;
    padding:     0.5rem 0.875rem;
    font-size:   0.9rem;
    font-weight: 600;
    color:       #fff;
    border-radius: var(--radius-sm);
    transition:  var(--transition-base);
}

.site-header.scrolled .nav-menu > li > a,
.site-header.header-solid .nav-menu > li > a {
    color: var(--color-text);
}

.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a {
    color:      var(--color-secondary);
    background: rgba(255,107,0,0.08);
}

/* Dropdown */
.nav-menu .sub-menu {
    position:     absolute;
    top:          calc(100% + 0.5rem);
    left:         0;
    min-width:    220px;
    background:   #fff;
    border-radius:var(--radius-md);
    box-shadow:   var(--shadow-lg);
    padding:      0.5rem 0;
    opacity:      0;
    visibility:   hidden;
    transform:    translateY(10px);
    transition:   var(--transition-base);
    z-index:      10;
}

.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu {
    opacity:    1;
    visibility: visible;
    transform:  translateY(0);
}

.nav-menu .sub-menu li a {
    display:     block;
    padding:     0.625rem 1.25rem;
    font-size:   0.875rem;
    font-weight: 500;
    color:       var(--color-text);
    transition:  var(--transition-base);
}

.nav-menu .sub-menu li a:hover {
    color:      var(--color-primary);
    background: var(--color-bg-alt);
    padding-left:1.5rem;
}

.header-actions {
    display:    flex;
    align-items:center;
    gap:        1rem;
}

.header-phone {
    display:     flex;
    align-items: center;
    gap:         0.4rem;
    font-size:   0.875rem;
    font-weight: 600;
    color:       #fff;
}

.site-header.scrolled .header-phone,
.site-header.header-solid .header-phone { color: var(--color-text); }

.header-phone svg { flex-shrink:0; }

/* Hamburger */
.menu-toggle {
    display:        none;
    background:     none;
    border:         none;
    cursor:         pointer;
    padding:        0.5rem;
    flex-direction: column;
    gap:            5px;
    z-index:        10;
}

.menu-toggle span {
    display:     block;
    width:       26px;
    height:      2.5px;
    background:  #fff;
    border-radius:2px;
    transition:  var(--transition-base);
}

.site-header.scrolled .menu-toggle span,
.site-header.header-solid .menu-toggle span { background: var(--color-text); }

.menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5.5px, 5.5px); }
.menu-toggle.active span:nth-child(2) { opacity: 0; }
.menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(5.5px, -5.5px); }

/* Mobile menu overlay */
.mobile-menu-overlay {
    display:     none;
    position:    fixed;
    inset:       0;
    background:  rgba(0,0,0,0.5);
    z-index:     var(--zindex-overlay);
}

.mobile-menu-overlay.active { display:block; }

/* Mobile Nav Panel */
.mobile-nav-panel {
    position:   fixed;
    top:        0;
    right:      -320px;
    width:      320px;
    height:     100%;
    background: #fff;
    z-index:    calc(var(--zindex-overlay) + 1);
    overflow-y: auto;
    transition: right 0.35s ease;
    padding:    2rem 1.5rem;
}

.mobile-nav-panel.open { right:0; }

.mobile-nav-close {
    position:   absolute;
    top:        1rem;
    right:      1rem;
    background: none;
    border:     none;
    font-size:  1.5rem;
    cursor:     pointer;
    color:      var(--color-text);
    line-height:1;
    padding:    0.25rem;
}

.mobile-nav-panel .site-logo { margin-bottom:2rem; }
.mobile-nav-panel .site-logo .logo-name { color: var(--color-primary) !important; }
.mobile-nav-panel .site-logo .logo-tagline { color: var(--color-text-muted) !important; }

.mobile-nav-menu {
    list-style: none;
    padding:    0;
    margin:     0;
}

.mobile-nav-menu > li {
    border-bottom: 1px solid var(--color-border);
}

.mobile-nav-menu > li > a {
    display:     block;
    padding:     0.875rem 0;
    font-weight: 600;
    color:       var(--color-text);
    font-size:   0.9375rem;
}

.mobile-nav-menu > li > a:hover { color: var(--color-primary); }

.mobile-nav-menu .sub-menu {
    padding:    0 0 0.75rem 1rem;
    list-style: none;
}

.mobile-nav-menu .sub-menu li a {
    display:    block;
    padding:    0.4rem 0;
    font-size:  0.875rem;
    color:      var(--color-text-light);
}

.mobile-nav-footer {
    margin-top: 2rem;
    padding-top:2rem;
    border-top: 1px solid var(--color-border);
}

@media (max-width: 992px) {
    .primary-navigation { display: none; }
    .menu-toggle         { display: flex; }
    .header-phone        { display: none; }
}

/* =====================================================
   HERO SECTION
   ===================================================== */
.hero-section {
    position:       relative;
    min-height:     100vh;
    display:        flex;
    align-items:    center;
    background:     linear-gradient(135deg, #0a1628 0%, #0057B8 60%, #1a3a6b 100%);
    overflow:       hidden;
}

.hero-bg {
    position:   absolute;
    inset:      0;
    background: inherit;
}

.hero-bg img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.25;
}

.hero-particles {
    position:   absolute;
    inset:      0;
    overflow:   hidden;
    pointer-events: none;
}

.hero-particle {
    position:   absolute;
    width:      4px;
    height:     4px;
    background: rgba(255,255,255,0.4);
    border-radius:50%;
    animation:  particleFloat 8s infinite linear;
}

@keyframes particleFloat {
    0%   { transform: translateY(100vh) scale(0); opacity:0; }
    10%  { opacity:1; }
    90%  { opacity:1; }
    100% { transform: translateY(-100px) scale(1.5); opacity:0; }
}

.hero-content {
    position: relative;
    z-index:  2;
    padding:  120px 0 80px;
    max-width:800px;
}

.hero-badge {
    display:      inline-flex;
    align-items:  center;
    gap:          0.5rem;
    background:   rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
    border:       1px solid rgba(255,255,255,0.25);
    padding:      0.4rem 1rem;
    border-radius:var(--radius-full);
    font-size:    0.8125rem;
    font-weight:  600;
    color:        #fff;
    margin-bottom:1.5rem;
}

.hero-badge .dot {
    width:        8px;
    height:       8px;
    background:   var(--color-accent);
    border-radius:50%;
    animation:    pulse 2s infinite;
}

@keyframes pulse {
    0%,100% { transform:scale(1); opacity:1; }
    50%      { transform:scale(1.5); opacity:0.7; }
}

.hero-title {
    font-size:    clamp(2.25rem, 5.5vw, 4rem);
    font-weight:  800;
    color:        #fff;
    line-height:  1.15;
    margin-bottom:1.25rem;
    text-shadow:  0 2px 20px rgba(0,0,0,0.3);
}

.hero-title span {
    color: var(--color-accent);
    position: relative;
}

.hero-subtitle {
    font-size:    1.125rem;
    color:        rgba(255,255,255,0.85);
    margin-bottom:2.5rem;
    max-width:    600px;
    line-height:  1.75;
}

.hero-actions {
    display:   flex;
    flex-wrap: wrap;
    gap:       1rem;
    margin-bottom: 3rem;
}

.hero-stats {
    display:   flex;
    flex-wrap: wrap;
    gap:       2rem;
}

.hero-stat {
    text-align:center;
}

.hero-stat .number {
    font-size:   2rem;
    font-weight: 800;
    color:       #fff;
    line-height: 1;
}

.hero-stat .label {
    font-size:   0.8125rem;
    color:       rgba(255,255,255,0.7);
    font-weight: 500;
    margin-top:  0.25rem;
}

.hero-scroll-indicator {
    position:   absolute;
    bottom:     2rem;
    left:       50%;
    transform:  translateX(-50%);
    z-index:    2;
    display:    flex;
    flex-direction:column;
    align-items:center;
    gap:        0.5rem;
    color:      rgba(255,255,255,0.6);
    font-size:  0.75rem;
    animation:  bounce 2s infinite;
    cursor:     pointer;
}

@keyframes bounce {
    0%,100% { transform: translateX(-50%) translateY(0); }
    50%      { transform: translateX(-50%) translateY(8px); }
}

/* =====================================================
   LEAD / SEARCH FORM
   ===================================================== */
.search-form-section {
    position: relative;
    z-index:  3;
    margin-top: -50px;
}

.search-form-card {
    background:   #fff;
    border-radius:var(--radius-xl);
    box-shadow:   var(--shadow-xl);
    padding:      2.5rem;
}

.search-form-title {
    font-size:   1.25rem;
    font-weight: 700;
    color:       var(--color-text);
    margin-bottom:1.5rem;
    display:     flex;
    align-items: center;
    gap:         0.5rem;
}

.lead-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.25rem;
    align-items: end;
}

.lead-form-grid .btn {
    height: 52px;
    font-size: 1rem;
    letter-spacing: 0.5px;
}

.form-icon-group {
    position: relative;
}

.form-icon-group .form-control {
    padding-left: 2.75rem;
}

.form-icon-group .form-icon {
    position:  absolute;
    left:      0.9rem;
    top:       50%;
    transform: translateY(-50%);
    color:     var(--color-text-muted);
    pointer-events: none;
    width:     18px;
    height:    18px;
}

/* =====================================================
   DESTINATIONS
   ===================================================== */
.destination-card {
    position:      relative;
    border-radius: var(--radius-lg);
    overflow:      hidden;
    cursor:        pointer;
}

.destination-card img {
    width:      100%;
    height:     280px;
    object-fit: cover;
    transition: transform 0.5s ease;
}

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

.destination-overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.1) 60%, transparent 100%);
    transition: var(--transition-base);
}

.destination-card:hover .destination-overlay {
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 70%, rgba(0,0,0,0.05) 100%);
}

.destination-info {
    position:   absolute;
    bottom:     0;
    left:       0;
    right:      0;
    padding:    1.5rem;
    color:      #fff;
}

.destination-info h3 {
    font-size:   1.25rem;
    font-weight: 700;
    color:       #fff;
    margin-bottom:0.25rem;
}

.destination-info .package-count {
    font-size:  0.8125rem;
    opacity:    0.85;
}

.destination-info .explore-link {
    display:    inline-flex;
    align-items:center;
    gap:        0.25rem;
    color:      var(--color-accent);
    font-size:  0.875rem;
    font-weight:600;
    margin-top: 0.75rem;
    opacity:    0;
    transform:  translateY(10px);
    transition: var(--transition-base);
}

.destination-card:hover .explore-link {
    opacity:   1;
    transform: translateY(0);
}

/* =====================================================
   PACKAGES
   ===================================================== */
.package-card {
    background:    #fff;
    border-radius: var(--radius-lg);
    overflow:      hidden;
    box-shadow:    var(--shadow-md);
    transition:    var(--transition-base);
}

.package-card:hover {
    transform:  translateY(-8px);
    box-shadow: var(--shadow-xl);
}

.package-img {
    position:   relative;
    overflow:   hidden;
    height:     220px;
}

.package-img img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.package-card:hover .package-img img {
    transform: scale(1.06);
}

.package-badges {
    position: absolute;
    top:      1rem;
    left:     1rem;
    display:  flex;
    gap:      0.4rem;
    flex-wrap:wrap;
}

.package-wishlist {
    position:   absolute;
    top:        1rem;
    right:      1rem;
    width:      36px;
    height:     36px;
    background: rgba(255,255,255,0.9);
    border:     none;
    border-radius:50%;
    display:    flex;
    align-items:center;
    justify-content:center;
    cursor:     pointer;
    color:      var(--color-text-muted);
    transition: var(--transition-base);
    font-size:  1rem;
}

.package-wishlist:hover,
.package-wishlist.active { color:var(--color-error); background:#fff; }

.package-body {
    padding: 1.5rem;
}

.package-location {
    display:     flex;
    align-items: center;
    gap:         0.3rem;
    font-size:   0.8125rem;
    color:       var(--color-text-muted);
    margin-bottom:0.5rem;
}

.package-title {
    font-size:   1.0625rem;
    font-weight: 700;
    color:       var(--color-text);
    margin-bottom:0.75rem;
    line-height: 1.4;
    display:     -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow:    hidden;
}

.package-highlights {
    display:     flex;
    flex-wrap:   wrap;
    gap:         0.5rem;
    margin-bottom:1rem;
}

.package-highlights span {
    display:      flex;
    align-items:  center;
    gap:          0.25rem;
    font-size:    0.75rem;
    color:        var(--color-text-light);
    background:   var(--color-bg-alt);
    padding:      0.25rem 0.625rem;
    border-radius:var(--radius-full);
}

.package-footer {
    display:      flex;
    align-items:  center;
    justify-content:space-between;
    padding-top:  1rem;
    border-top:   1px solid var(--color-border);
    margin-top:   1rem;
}

.package-price-block .label {
    font-size:  0.75rem;
    color:      var(--color-text-muted);
}

.package-price-block .price {
    font-size:   1.25rem;
    font-weight: 800;
    color:       var(--color-primary);
}

.package-price-block .per-person {
    font-size: 0.75rem;
    color:     var(--color-text-muted);
}

/* =====================================================
   WHY CHOOSE US
   ===================================================== */
.why-us-section {
    background: linear-gradient(135deg, var(--color-bg-dark) 0%, #112244 100%);
}

.why-card {
    background:    rgba(255,255,255,0.05);
    border:        1px solid rgba(255,255,255,0.1);
    border-radius: var(--radius-lg);
    padding:       2rem 1.5rem;
    text-align:    center;
    transition:    var(--transition-base);
}

.why-card:hover {
    background: rgba(255,255,255,0.1);
    border-color:rgba(255,255,255,0.2);
    transform:  translateY(-4px);
}

.why-icon {
    width:         64px;
    height:        64px;
    background:    linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    border-radius: var(--radius-lg);
    display:       flex;
    align-items:   center;
    justify-content:center;
    margin:        0 auto 1.25rem;
    font-size:     1.75rem;
    transition:    var(--transition-base);
}

.why-card:hover .why-icon {
    transform: scale(1.1) rotate(5deg);
    background: linear-gradient(135deg, var(--color-secondary), var(--color-secondary-dark));
}

.why-card h3 {
    font-size:   1.0625rem;
    font-weight: 700;
    color:       #fff;
    margin-bottom:0.5rem;
}

.why-card p {
    font-size: 0.875rem;
    color:     rgba(255,255,255,0.65);
    line-height:1.7;
    margin:    0;
}

/* =====================================================
   TESTIMONIALS
   ===================================================== */
.testimonials-section {
    background: var(--color-bg-alt);
}

.testimonial-card {
    background:    #fff;
    border-radius: var(--radius-lg);
    padding:       2rem;
    box-shadow:    var(--shadow-sm);
    position:      relative;
    transition:    var(--transition-base);
}

.testimonial-card::before {
    content:     '"';
    position:    absolute;
    top:         1rem;
    left:        1.5rem;
    font-size:   5rem;
    font-family: Georgia, serif;
    color:       var(--color-primary);
    opacity:     0.15;
    line-height: 1;
    font-weight: 700;
}

.testimonial-rating {
    display:       flex;
    gap:           0.2rem;
    margin-bottom: 1rem;
    color:         var(--color-accent);
    font-size:     1rem;
}

.testimonial-text {
    font-size:   0.9375rem;
    color:       var(--color-text-light);
    font-style:  italic;
    line-height: 1.8;
    margin-bottom:1.5rem;
}

.testimonial-author {
    display:    flex;
    align-items:center;
    gap:        0.75rem;
}

.testimonial-avatar {
    width:        48px;
    height:       48px;
    border-radius:50%;
    object-fit:   cover;
    background:   var(--color-bg-alt);
}

.testimonial-author-info .name {
    font-size:   0.9375rem;
    font-weight: 700;
    color:       var(--color-text);
    margin:      0;
}

.testimonial-author-info .location {
    font-size: 0.8125rem;
    color:     var(--color-text-muted);
}

/* Testimonials Slider */
.testimonials-slider {
    overflow:   hidden;
    position:   relative;
}

.testimonials-track {
    display:    flex;
    transition: transform 0.5s ease;
}

.testimonials-track .testimonial-card {
    min-width:  calc(33.333% - 1rem);
    margin:     0 0.5rem;
    flex-shrink:0;
}

.slider-controls {
    display:         flex;
    justify-content: center;
    align-items:     center;
    gap:             1rem;
    margin-top:      2rem;
}

.slider-btn {
    width:         40px;
    height:        40px;
    border-radius: 50%;
    background:    #fff;
    border:        2px solid var(--color-border);
    display:       flex;
    align-items:   center;
    justify-content:center;
    cursor:        pointer;
    transition:    var(--transition-base);
    color:         var(--color-text);
}

.slider-btn:hover {
    background:  var(--color-primary);
    border-color:var(--color-primary);
    color:       #fff;
}

.slider-dots {
    display:   flex;
    gap:       0.5rem;
}

.slider-dot {
    width:        10px;
    height:       10px;
    border-radius:50%;
    background:   var(--color-border);
    cursor:       pointer;
    transition:   var(--transition-base);
    border:       none;
}

.slider-dot.active {
    background: var(--color-primary);
    width:      28px;
    border-radius:var(--radius-full);
}

@media (max-width: 992px) {
    .testimonials-track .testimonial-card { min-width: calc(50% - 1rem); }
}

@media (max-width: 576px) {
    .testimonials-track .testimonial-card { min-width: calc(100% - 1rem); }
}

/* =====================================================
   BLOG SECTION
   ===================================================== */
.blog-card {
    background:    #fff;
    border-radius: var(--radius-lg);
    overflow:      hidden;
    box-shadow:    var(--shadow-sm);
    transition:    var(--transition-base);
}

.blog-card:hover {
    transform:  translateY(-4px);
    box-shadow: var(--shadow-md);
}

.blog-card-img {
    overflow: hidden;
    height:   200px;
}

.blog-card-img img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.blog-card:hover .blog-card-img img {
    transform: scale(1.05);
}

.blog-card-body {
    padding: 1.5rem;
}

.blog-meta {
    display:     flex;
    align-items: center;
    gap:         1rem;
    font-size:   0.8125rem;
    color:       var(--color-text-muted);
    margin-bottom:0.75rem;
}

.blog-category {
    color:      var(--color-primary);
    font-weight:600;
}

.blog-card-title {
    font-size:   1rem;
    font-weight: 700;
    color:       var(--color-text);
    margin-bottom:0.75rem;
    line-height: 1.5;
    display:     -webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:    hidden;
}

.blog-card-title a { color:inherit; }
.blog-card-title a:hover { color: var(--color-primary); }

.blog-excerpt {
    font-size:   0.875rem;
    color:       var(--color-text-light);
    margin-bottom:1rem;
    display:     -webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:    hidden;
}

.read-more {
    font-size:   0.875rem;
    font-weight: 600;
    color:       var(--color-primary);
    display:     inline-flex;
    align-items: center;
    gap:         0.25rem;
}

.read-more:hover { gap:0.5rem; color:var(--color-primary-dark); }

/* =====================================================
   CTA BANNER
   ===================================================== */
.cta-section {
    background:   linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    position:     relative;
    overflow:     hidden;
}

.cta-section::before {
    content:   '';
    position:  absolute;
    top:       -50%;
    right:     -10%;
    width:     600px;
    height:    600px;
    background:rgba(255,255,255,0.05);
    border-radius:50%;
}

.cta-section::after {
    content:      '';
    position:     absolute;
    bottom:       -50%;
    left:         -5%;
    width:        400px;
    height:       400px;
    background:   rgba(255,255,255,0.04);
    border-radius:50%;
}

.cta-content {
    position:    relative;
    z-index:     1;
    text-align:  center;
}

.cta-content h2 {
    color:       #fff;
    font-size:   clamp(1.5rem, 3vw, 2.5rem);
    margin-bottom:1rem;
}

.cta-content p {
    color:        rgba(255,255,255,0.85);
    font-size:    1.0625rem;
    margin-bottom:2rem;
    max-width:    600px;
    margin-left:  auto;
    margin-right: auto;
}

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

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer {
    background: var(--color-bg-dark);
    color:      rgba(255,255,255,0.75);
}

.footer-top {
    padding:       4rem 0 3rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.footer-brand p {
    font-size:   0.875rem;
    line-height: 1.8;
    margin:      1rem 0 1.5rem;
    color:       rgba(255,255,255,0.6);
}

.footer-social {
    display: flex;
    gap:     0.75rem;
}

.footer-social a {
    width:         38px;
    height:        38px;
    background:    rgba(255,255,255,0.08);
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    color:         rgba(255,255,255,0.7);
    font-size:     0.875rem;
    transition:    var(--transition-base);
}

.footer-social a:hover {
    background: var(--color-primary);
    color:      #fff;
    transform:  translateY(-2px);
}

.footer-heading {
    font-size:   0.9375rem;
    font-weight: 700;
    color:       #fff;
    margin-bottom:1.25rem;
    position:    relative;
    padding-bottom:0.75rem;
}

.footer-heading::after {
    content:     '';
    position:    absolute;
    bottom:      0;
    left:        0;
    width:       32px;
    height:      2px;
    background:  var(--color-secondary);
    border-radius:1px;
}

.footer-links {
    list-style: none;
    padding:    0;
    margin:     0;
}

.footer-links li { margin-bottom:0.625rem; }

.footer-links a {
    font-size:  0.875rem;
    color:      rgba(255,255,255,0.6);
    display:    flex;
    align-items:center;
    gap:        0.375rem;
    transition: var(--transition-base);
}

.footer-links a:hover {
    color:        #fff;
    padding-left: 0.25rem;
}

.footer-contact-item {
    display:     flex;
    gap:         0.75rem;
    font-size:   0.875rem;
    color:       rgba(255,255,255,0.65);
    margin-bottom:0.875rem;
    line-height: 1.6;
}

.footer-contact-item .icon {
    flex-shrink:  0;
    color:        var(--color-secondary);
    margin-top:   2px;
}

.footer-bottom {
    padding:     1.5rem 0;
    display:     flex;
    align-items: center;
    justify-content:space-between;
    flex-wrap:   wrap;
    gap:         1rem;
    font-size:   0.8125rem;
    color:       rgba(255,255,255,0.5);
}

.footer-bottom a {
    color:   rgba(255,255,255,0.6);
    font-size:0.8125rem;
}

.footer-bottom a:hover { color:#fff; }

.footer-bottom-links {
    display:     flex;
    flex-wrap:   wrap;
    gap:         1.25rem;
    list-style:  none;
    padding:     0;
    margin:      0;
}

/* =====================================================
   FLOATING ELEMENTS
   ===================================================== */
/* WhatsApp */
.whatsapp-float {
    position:  fixed;
    bottom:    2rem;
    right:     2rem;
    z-index:   var(--zindex-sticky);
    display:   flex;
    flex-direction:column;
    align-items:center;
    gap:       0.5rem;
}

.whatsapp-float a {
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           56px;
    height:          56px;
    background:      #25D366;
    border-radius:   50%;
    color:           #fff;
    font-size:       1.625rem;
    box-shadow:      0 4px 16px rgba(37,211,102,0.45);
    transition:      var(--transition-base);
    text-decoration: none;
}

.whatsapp-float a:hover {
    transform:  scale(1.1);
    box-shadow: 0 6px 24px rgba(37,211,102,0.6);
}

.whatsapp-float a::before {
    content:     '';
    position:    absolute;
    width:       56px;
    height:      56px;
    border-radius:50%;
    background:  #25D366;
    opacity:     0.4;
    animation:   waRipple 2s infinite;
}

@keyframes waRipple {
    0%  { transform:scale(1); opacity:0.5; }
    100%{ transform:scale(2); opacity:0; }
}

/* Scroll to Top */
.scroll-to-top {
    position:  fixed;
    bottom:    5.5rem;
    right:     2rem;
    z-index:   var(--zindex-sticky);
    width:     44px;
    height:    44px;
    background:var(--color-primary);
    color:     #fff;
    border:    none;
    border-radius:50%;
    display:   flex;
    align-items:center;
    justify-content:center;
    cursor:    pointer;
    box-shadow:var(--shadow-md);
    transition:var(--transition-base);
    opacity:   0;
    visibility:hidden;
    transform: translateY(20px);
}

.scroll-to-top.visible {
    opacity:   1;
    visibility:visible;
    transform: translateY(0);
}

.scroll-to-top:hover {
    background: var(--color-primary-dark);
    transform:  translateY(-2px);
}

/* Sticky CTA */
.sticky-cta {
    position:  fixed;
    bottom:    0;
    left:      0;
    right:     0;
    z-index:   calc(var(--zindex-sticky) - 1);
    background:#fff;
    box-shadow:0 -4px 20px rgba(0,0,0,0.1);
    padding:   0.75rem 1.5rem;
    display:   none;
    align-items:center;
    justify-content:space-between;
    gap:       1rem;
}

@media (max-width: 768px) {
    .sticky-cta { display:flex; }
}

.sticky-cta p {
    font-size:  0.875rem;
    font-weight:600;
    color:      var(--color-text);
    margin:     0;
}

/* =====================================================
   PAGE HERO (inner pages)
   ===================================================== */
.page-hero {
    background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-primary) 100%);
    padding:    8rem 0 4rem;
    position:   relative;
    overflow:   hidden;
}

.page-hero::before {
    content:     '';
    position:    absolute;
    inset:       0;
    background:  url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.page-hero-content { position:relative; z-index:1; }

.page-hero h1 {
    font-size:   clamp(1.75rem, 4vw, 3rem);
    font-weight: 800;
    color:       #fff;
    margin-bottom:0.75rem;
}

.page-hero p {
    font-size: 1.0625rem;
    color:     rgba(255,255,255,0.8);
    margin:    0;
}

/* =====================================================
   BREADCRUMBS
   ===================================================== */
.breadcrumb-nav {
    padding:    0.75rem 0;
    background: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
}

.breadcrumb-list {
    display:   flex;
    flex-wrap: wrap;
    gap:       0.25rem;
    list-style:none;
    padding:   0;
    margin:    0;
    font-size: 0.8125rem;
}

.breadcrumb-list li {
    display:    flex;
    align-items:center;
    gap:        0.25rem;
    color:      var(--color-text-muted);
}

.breadcrumb-list li::after {
    content: '/';
    color:   var(--color-border);
    margin-left: 0.25rem;
}

.breadcrumb-list li:last-child::after { display:none; }

.breadcrumb-list a { color:var(--color-primary); font-weight:500; }
.breadcrumb-list a:hover { color: var(--color-primary-dark); }
.breadcrumb-list .current { font-weight:600; color:var(--color-text); }

/* =====================================================
   SIDEBAR
   ===================================================== */
.sidebar-widget {
    background:    #fff;
    border-radius: var(--radius-lg);
    padding:       1.5rem;
    margin-bottom: 1.5rem;
    box-shadow:    var(--shadow-sm);
}

.sidebar-widget-title {
    font-size:    1rem;
    font-weight:  700;
    color:        var(--color-text);
    margin-bottom:1.25rem;
    padding-bottom:0.75rem;
    border-bottom:2px solid var(--color-primary);
}

.recent-post-item {
    display:      flex;
    gap:          0.875rem;
    margin-bottom:1rem;
    padding-bottom:1rem;
    border-bottom:1px solid var(--color-border);
}

.recent-post-item:last-child {
    margin-bottom:0;
    padding-bottom:0;
    border-bottom:none;
}

.recent-post-img {
    width:         70px;
    height:        70px;
    flex-shrink:   0;
    border-radius: var(--radius-md);
    overflow:      hidden;
}

.recent-post-img img {
    width:      100%;
    height:     100%;
    object-fit: cover;
}

.recent-post-info .title {
    font-size:   0.875rem;
    font-weight: 600;
    color:       var(--color-text);
    line-height: 1.45;
    margin-bottom:0.3rem;
}

.recent-post-info .title a { color:inherit; }
.recent-post-info .title a:hover { color:var(--color-primary); }

.recent-post-info .date {
    font-size: 0.75rem;
    color:     var(--color-text-muted);
}

.category-list { list-style:none; padding:0; margin:0; }

.category-list li {
    display:      flex;
    justify-content:space-between;
    align-items:  center;
    padding:      0.625rem 0;
    border-bottom:1px solid var(--color-border);
    font-size:    0.875rem;
}

.category-list li:last-child { border-bottom:none; }

.category-list a { color:var(--color-text); }
.category-list a:hover { color:var(--color-primary); }

.category-list .count {
    background:    var(--color-bg-alt);
    color:         var(--color-text-muted);
    padding:       0.1em 0.5em;
    border-radius: var(--radius-full);
    font-size:     0.75rem;
}

.tag-cloud { display:flex; flex-wrap:wrap; gap:0.5rem; }

.tag-cloud a {
    display:      inline-block;
    padding:      0.3rem 0.75rem;
    background:   var(--color-bg-alt);
    color:        var(--color-text-light);
    border-radius:var(--radius-full);
    font-size:    0.8125rem;
    transition:   var(--transition-base);
    border:       1px solid var(--color-border);
}

.tag-cloud a:hover {
    background:  var(--color-primary);
    color:       #fff;
    border-color:var(--color-primary);
}

/* =====================================================
   BLOG SINGLE
   ===================================================== */
.post-content {
    font-size:   1rem;
    line-height: 1.9;
    color:       var(--color-text-light);
}

.post-content h2 {
    font-size:   1.5rem;
    margin-top:  2.5rem;
    color:       var(--color-text);
}

.post-content h3 {
    font-size:   1.25rem;
    margin-top:  2rem;
    color:       var(--color-text);
}

.post-content img {
    border-radius:var(--radius-lg);
    margin:      1.5rem 0;
}

.post-content blockquote {
    border-left:  4px solid var(--color-primary);
    padding:      1.25rem 1.5rem;
    background:   var(--color-bg-alt);
    border-radius:0 var(--radius-md) var(--radius-md) 0;
    margin:       1.5rem 0;
    font-size:    1.0625rem;
    font-style:   italic;
    color:        var(--color-text);
}

.post-content ul, .post-content ol {
    padding-left: 1.5rem;
    margin-bottom:1rem;
}

.post-content ul { list-style:disc; }
.post-content ol { list-style:decimal; }

.post-content li { margin-bottom:0.5rem; }

.post-tags {
    display:    flex;
    flex-wrap:  wrap;
    gap:        0.5rem;
    margin-top: 2rem;
}

.post-share {
    display:     flex;
    align-items: center;
    gap:         0.75rem;
    flex-wrap:   wrap;
    margin-top:  2rem;
    padding-top: 2rem;
    border-top:  1px solid var(--color-border);
}

.post-share-label {
    font-weight: 600;
    font-size:   0.875rem;
    color:       var(--color-text);
}

.post-share a {
    width:         36px;
    height:        36px;
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    font-size:     0.875rem;
    color:         #fff;
    transition:    var(--transition-base);
}

.post-share a:hover { transform:translateY(-2px); }
.share-fb  { background:#1877F2; }
.share-tw  { background:#1DA1F2; }
.share-wa  { background:#25D366; }
.share-li  { background:#0077B5; }

/* =====================================================
   FAQ ACCORDION
   ===================================================== */
.faq-item {
    border:        1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: 0.75rem;
    overflow:      hidden;
    transition:    var(--transition-base);
}

.faq-item.open { border-color: var(--color-primary); }

.faq-question {
    width:       100%;
    background:  none;
    border:      none;
    padding:     1.125rem 1.5rem;
    display:     flex;
    align-items: center;
    justify-content:space-between;
    gap:         1rem;
    cursor:      pointer;
    font-size:   0.9375rem;
    font-weight: 600;
    color:       var(--color-text);
    text-align:  left;
    transition:  var(--transition-base);
}

.faq-question:hover { color: var(--color-primary); }

.faq-item.open .faq-question {
    color:      var(--color-primary);
    background: rgba(0,87,184,0.04);
}

.faq-icon {
    width:         24px;
    height:        24px;
    background:    var(--color-bg-alt);
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    flex-shrink:   0;
    transition:    var(--transition-base);
    color:         var(--color-text-muted);
    font-size:     1rem;
    font-weight:   700;
}

.faq-item.open .faq-icon {
    background: var(--color-primary);
    color:      #fff;
    transform:  rotate(45deg);
}

.faq-answer {
    max-height: 0;
    overflow:   hidden;
    transition: max-height 0.4s ease;
}

.faq-item.open .faq-answer {
    max-height: 500px;
}

.faq-answer-inner {
    padding:    0 1.5rem 1.25rem;
    font-size:  0.9375rem;
    color:      var(--color-text-light);
    line-height:1.8;
}

/* =====================================================
   PAGINATION
   ===================================================== */
.pagination {
    display:         flex;
    justify-content: center;
    flex-wrap:       wrap;
    gap:             0.4rem;
    margin:          3rem 0;
}

.pagination .page-numbers {
    display:      flex;
    align-items:  center;
    justify-content:center;
    min-width:    40px;
    height:       40px;
    padding:      0 0.75rem;
    border-radius:var(--radius-md);
    background:   #fff;
    border:       1.5px solid var(--color-border);
    color:        var(--color-text);
    font-size:    0.875rem;
    font-weight:  600;
    transition:   var(--transition-base);
}

.pagination .page-numbers:hover,
.pagination .page-numbers.current {
    background:   var(--color-primary);
    border-color: var(--color-primary);
    color:        #fff;
}

.pagination .prev, .pagination .next {
    background: var(--color-primary);
    border-color:var(--color-primary);
    color:      #fff;
}

/* =====================================================
   ABOUT PAGE
   ===================================================== */
.about-vision-card {
    background:    var(--color-bg-alt);
    border-radius: var(--radius-lg);
    padding:       2rem;
    text-align:    center;
    transition:    var(--transition-base);
    border:        2px solid transparent;
}

.about-vision-card:hover {
    border-color: var(--color-primary);
    background:   #fff;
    box-shadow:   var(--shadow-md);
}

.about-icon {
    width:         60px;
    height:        60px;
    background:    linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    border-radius: var(--radius-lg);
    display:       flex;
    align-items:   center;
    justify-content:center;
    margin:        0 auto 1rem;
    font-size:     1.5rem;
    color:         #fff;
}

.team-card {
    text-align:   center;
    background:   #fff;
    border-radius:var(--radius-lg);
    padding:      2rem 1.5rem;
    box-shadow:   var(--shadow-sm);
    transition:   var(--transition-base);
}

.team-card:hover {
    transform:  translateY(-4px);
    box-shadow: var(--shadow-md);
}

.team-avatar {
    width:         100px;
    height:        100px;
    border-radius: 50%;
    object-fit:    cover;
    margin:        0 auto 1rem;
    border:        3px solid var(--color-primary);
}

.team-name {
    font-size:   1.0625rem;
    font-weight: 700;
    color:       var(--color-text);
    margin-bottom:0.25rem;
}

.team-role {
    font-size: 0.875rem;
    color:     var(--color-text-muted);
}

/* =====================================================
   CONTACT PAGE
   ===================================================== */
.contact-info-card {
    background:    #fff;
    border-radius: var(--radius-lg);
    padding:       2rem;
    box-shadow:    var(--shadow-sm);
    margin-bottom: 1.5rem;
}

.contact-info-item {
    display:     flex;
    gap:         1rem;
    margin-bottom:1.5rem;
}

.contact-info-item:last-child { margin-bottom:0; }

.contact-icon {
    width:         46px;
    height:        46px;
    background:    rgba(0,87,184,0.1);
    border-radius: var(--radius-md);
    display:       flex;
    align-items:   center;
    justify-content:center;
    color:         var(--color-primary);
    flex-shrink:   0;
    font-size:     1.125rem;
}

.contact-details .label {
    font-size:   0.75rem;
    font-weight: 600;
    color:       var(--color-text-muted);
    text-transform:uppercase;
    letter-spacing:0.5px;
    margin-bottom:0.2rem;
}

.contact-details .value {
    font-size:   0.9375rem;
    font-weight: 600;
    color:       var(--color-text);
}

.map-container {
    border-radius: var(--radius-lg);
    overflow:      hidden;
    box-shadow:    var(--shadow-sm);
}

.map-container iframe {
    display: block;
    width:   100%;
    height:  400px;
    border:  none;
}

/* =====================================================
   PACKAGE SINGLE PAGE
   ===================================================== */
.package-detail-hero {
    position:    relative;
    height:      500px;
    overflow:    hidden;
}

.package-detail-hero img {
    width:      100%;
    height:     100%;
    object-fit: cover;
}

.package-detail-overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
}

.package-detail-title {
    position:    absolute;
    bottom:      2rem;
    left:        0;
    right:       0;
}

.package-detail-title h1 {
    color:   #fff;
    font-size:clamp(1.5rem, 3vw, 2.25rem);
    margin-bottom:0.5rem;
}

.package-highlights-bar {
    display:     flex;
    flex-wrap:   wrap;
    gap:         1.5rem;
    background:  #fff;
    padding:     1.25rem 2rem;
    border-radius:0 0 var(--radius-lg) var(--radius-lg);
    box-shadow:  var(--shadow-md);
    margin-bottom:2rem;
}

.highlight-item {
    display:     flex;
    align-items: center;
    gap:         0.5rem;
    font-size:   0.875rem;
    color:       var(--color-text);
}

.highlight-item .hi-icon {
    color:     var(--color-primary);
    font-size: 1rem;
}

.package-booking-card {
    background:    #fff;
    border-radius: var(--radius-lg);
    padding:       2rem;
    box-shadow:    var(--shadow-lg);
    position:      sticky;
    top:           calc(var(--header-height) + 1rem);
}

.package-booking-card .price-block {
    text-align:  center;
    padding:     1.5rem;
    background:  var(--color-bg-alt);
    border-radius:var(--radius-md);
    margin-bottom:1.5rem;
}

.package-booking-card .from-label {
    font-size:  0.8125rem;
    color:      var(--color-text-muted);
    margin-bottom:0.25rem;
}

.package-booking-card .big-price {
    font-size:   2rem;
    font-weight: 800;
    color:       var(--color-primary);
}

.package-booking-card .per-person {
    font-size: 0.8125rem;
    color:     var(--color-text-muted);
}

.package-itinerary .day-item {
    display:      flex;
    gap:          1.25rem;
    margin-bottom:1.5rem;
    padding-bottom:1.5rem;
    border-bottom:1px solid var(--color-border);
}

.package-itinerary .day-item:last-child {
    border-bottom:none;
    margin-bottom:0;
    padding-bottom:0;
}

.day-number {
    width:         40px;
    height:        40px;
    background:    var(--color-primary);
    color:         #fff;
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    font-size:     0.75rem;
    font-weight:   700;
    flex-shrink:   0;
}

.day-content .day-title {
    font-size:   0.9375rem;
    font-weight: 700;
    color:       var(--color-text);
    margin-bottom:0.375rem;
}

.day-content p {
    font-size: 0.875rem;
    color:     var(--color-text-light);
    margin:    0;
}

/* =====================================================
   SEARCH PAGE
   ===================================================== */
.search-header-bar {
    background:   var(--color-bg-alt);
    padding:      2rem 0;
    border-bottom:1px solid var(--color-border);
    margin-bottom:3rem;
}

.search-bar-form {
    display:   flex;
    gap:       0.75rem;
    max-width: 600px;
}

.search-bar-form .form-control {
    flex: 1;
    border-radius:var(--radius-full);
    padding-left: 1.25rem;
}

.search-bar-form .btn {
    border-radius:var(--radius-full);
}

/* =====================================================
   404 PAGE
   ===================================================== */
.error-404-section {
    min-height: calc(100vh - var(--header-height));
    display:    flex;
    align-items:center;
    text-align: center;
}

.error-404-code {
    font-size:   clamp(6rem, 20vw, 12rem);
    font-weight: 800;
    line-height: 1;
    background:  linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:0;
}

.error-404-section h2 {
    font-size:   1.75rem;
    margin-bottom:1rem;
}

.error-404-section p {
    font-size:   1.0625rem;
    color:       var(--color-text-muted);
    max-width:   500px;
    margin:      0 auto 2rem;
}

/* =====================================================
   NOTIFICATIONS & ALERTS
   ===================================================== */
.alert {
    padding:      1rem 1.25rem;
    border-radius:var(--radius-md);
    margin-bottom:1rem;
    font-size:    0.9375rem;
    border:       1.5px solid transparent;
    display:      flex;
    align-items:  flex-start;
    gap:          0.75rem;
}

.alert-success { background:#d4edda; color:#155724; border-color:#c3e6cb; }
.alert-error   { background:#f8d7da; color:#721c24; border-color:#f5c6cb; }
.alert-info    { background:#d1ecf1; color:#0c5460; border-color:#bee5eb; }
.alert-warning { background:#fff3cd; color:#856404; border-color:#ffeeba; }

/* =====================================================
   STATS COUNTER
   ===================================================== */
.stats-section {
    background: var(--color-primary);
    padding:    3rem 0;
}

.stats-grid {
    display:             grid;
    grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
    gap:                 2rem;
    text-align:          center;
}

.stat-item .number {
    font-size:   2.5rem;
    font-weight: 800;
    color:       #fff;
    line-height: 1;
    margin-bottom:0.25rem;
}

.stat-item .label {
    font-size:   0.875rem;
    color:       rgba(255,255,255,0.75);
}

/* =====================================================
   GALLERY
   ===================================================== */
.gallery-grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   0.75rem;
}

@media (max-width: 576px) {
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

.gallery-item {
    border-radius:var(--radius-md);
    overflow:     hidden;
    aspect-ratio: 1;
    cursor:       pointer;
}

.gallery-item img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.gallery-item:hover img { transform:scale(1.08); }

/* =====================================================
   UTILITIES
   ===================================================== */
.d-none     { display:none !important; }
.d-flex     { display:flex !important; }
.d-block    { display:block !important; }
.d-grid     { display:grid !important; }
.align-center{ align-items:center !important; }
.justify-center{ justify-content:center !important; }
.justify-between{ justify-content:space-between !important; }
.flex-wrap  { flex-wrap:wrap !important; }
.gap-1      { gap:0.5rem !important; }
.gap-2      { gap:1rem !important; }
.gap-3      { gap:1.5rem !important; }
.gap-4      { gap:2rem !important; }
.mt-1       { margin-top:0.5rem !important; }
.mt-2       { margin-top:1rem !important; }
.mt-3       { margin-top:1.5rem !important; }
.mt-4       { margin-top:2rem !important; }
.mt-5       { margin-top:3rem !important; }
.mb-1       { margin-bottom:0.5rem !important; }
.mb-2       { margin-bottom:1rem !important; }
.mb-3       { margin-bottom:1.5rem !important; }
.mb-4       { margin-bottom:2rem !important; }
.mb-5       { margin-bottom:3rem !important; }
.p-1        { padding:0.5rem !important; }
.p-2        { padding:1rem !important; }
.p-3        { padding:1.5rem !important; }
.p-4        { padding:2rem !important; }
.w-100      { width:100% !important; }
.rounded    { border-radius:var(--radius-md) !important; }
.rounded-lg { border-radius:var(--radius-lg) !important; }
.shadow     { box-shadow:var(--shadow-md) !important; }
.bg-primary { background:var(--color-primary) !important; }
.bg-alt     { background:var(--color-bg-alt) !important; }
.bg-dark    { background:var(--color-bg-dark) !important; }

/* =====================================================
   ANIMATIONS (AOS-like)
   ===================================================== */
[data-aos] {
    opacity:   0;
    transform: translateY(30px);
    transition:opacity 0.7s ease, transform 0.7s ease;
}

[data-aos].aos-animated {
    opacity:   1;
    transform: translateY(0);
}

[data-aos="fade-left"]  { transform:translateX(-30px); }
[data-aos="fade-right"] { transform:translateX(30px); }
[data-aos="zoom-in"]    { transform:scale(0.9); }
[data-aos="fade-left"].aos-animated,
[data-aos="fade-right"].aos-animated,
[data-aos="zoom-in"].aos-animated { transform:none; opacity:1; }

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 768px) {
    :root { --header-height:64px; }

    .hero-content { padding:100px 0 60px; }

    .search-form-card { padding:1.5rem; border-radius:var(--radius-lg); }
    .lead-form-grid   { grid-template-columns:1fr; }

    .destination-card img { height:220px; }
    .package-img          { height:180px; }

    .section  { padding:3.5rem 0; }
    .section-lg { padding:5rem 0; }

    .why-card { padding:1.5rem 1rem; }

    .footer-top { padding:3rem 0 2rem; }

    .testimonials-slider { overflow:visible; }

    .package-detail-hero { height:300px; }

    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .hero-title    { font-size:1.875rem; }
    .hero-subtitle { font-size:0.9375rem; }
    .btn-lg        { padding:0.875rem 1.5rem; font-size:0.9375rem; }
}

/* =====================================================
   PRINT
   ===================================================== */
@media print {
    .site-header,.site-footer,.whatsapp-float,.scroll-to-top,.sticky-cta,
    .menu-toggle, .mobile-nav-panel { display:none !important; }
    body { font-size:12pt; color:#000; }
}

/* =====================================================
   WP BLOCK EDITOR COMPATIBILITY
   ===================================================== */
.wp-block-image img { border-radius:var(--radius-md); }
.wp-block-quote     { border-left:4px solid var(--color-primary); padding:1rem 1.5rem; }
.wp-block-separator { border-color: var(--color-border); }

/* =====================================================
   ELEMENTOR COMPATIBILITY
   ===================================================== */
.elementor-section .elementor-container { max-width:var(--container-max); }
