/* ============================================
   THE LOST ROUTE — Global Stylesheet
   ============================================ */

:root {
  --primary:        #1a5c3a;
  --primary-light:  #2d8a5e;
  --primary-dark:   #0e3d25;
  --secondary:      #c8a45e;
  --secondary-light:#dfc07a;
  --accent:         #e8b931;
  --dark:           #0a0a0a;
  --dark-2:         #1a1a2e;
  --dark-3:         #16213e;
  --light:          #f8f9fa;
  --light-2:        #e9ecef;
  --gray:           #6c757d;
  --gray-light:     #adb5bd;
  --white:          #ffffff;
  --glass-bg:       rgba(255,255,255,0.06);
  --glass-border:   rgba(255,255,255,0.12);
  --shadow:         0 4px 24px rgba(0,0,0,0.08);
  --shadow-md:      0 8px 32px rgba(0,0,0,0.12);
  --shadow-lg:      0 20px 60px rgba(0,0,0,0.15);
  --radius:         16px;
  --radius-sm:      8px;
  --radius-lg:      24px;
  --transition:     all 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
  --font-primary:   'Playfair Display', serif;
  --font-secondary: 'Inter', sans-serif;
  --font-accent:    'Cormorant Garamond', serif;
}

/* ---- Reset ---- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; font-size:16px; overflow-x:hidden }
body { font-family:var(--font-secondary); color:var(--dark); background:var(--white); line-height:1.7; overflow-x:hidden; -webkit-font-smoothing:antialiased }
a { text-decoration:none; color:inherit; transition:var(--transition) }
ul,ol { list-style:none }
img { max-width:100%; height:auto; display:block }
button,input,textarea,select { font-family:inherit; font-size:inherit; border:none; outline:none }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-primary); font-weight:700; line-height:1.2 }
.container { max-width:1280px; margin:0 auto; padding:0 24px }

/* ---- Utility ---- */
.section-padding { padding:100px 0 }
.section-title { text-align:center; margin-bottom:60px }
.section-title .subtitle { display:inline-block; font-family:var(--font-secondary); font-size:.8rem; font-weight:700; letter-spacing:5px; text-transform:uppercase; color:var(--secondary); margin-bottom:14px; position:relative; padding:0 24px }
.section-title .subtitle::before,.section-title .subtitle::after { content:''; position:absolute; top:50%; width:36px; height:1px; background:var(--secondary) }
.section-title .subtitle::before { left:-20px }
.section-title .subtitle::after  { right:-20px }
.section-title h2 { font-size:clamp(2rem,4vw,3rem); color:var(--dark); margin-bottom:16px }
.section-title p  { font-size:1rem; color:var(--gray); max-width:580px; margin:0 auto; line-height:1.8 }
.section-title.text-left { text-align:left }
.section-title.text-left .subtitle { padding-left:0 }
.section-title.text-left .subtitle::before { display:none }

/* ---- Buttons ---- */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 36px; border-radius:50px; font-weight:600; font-size:.92rem; letter-spacing:.4px; cursor:pointer; transition:var(--transition); border:2px solid transparent; position:relative; overflow:hidden; white-space:nowrap }
.btn::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent); transition:.5s }
.btn:hover::before { left:100% }
.btn-primary { background:linear-gradient(135deg,var(--primary),var(--primary-light)); color:var(--white); box-shadow:0 4px 20px rgba(26,92,58,.28) }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(26,92,58,.38) }
.btn-secondary { background:linear-gradient(135deg,var(--secondary),var(--accent)); color:var(--dark); box-shadow:0 4px 20px rgba(200,164,94,.28) }
.btn-secondary:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(200,164,94,.38) }
.btn-outline { background:transparent; border:2px solid rgba(255,255,255,.8); color:var(--white) }
.btn-outline:hover { background:var(--white); color:var(--dark); transform:translateY(-3px) }
.btn-outline-dark { background:transparent; border:2px solid var(--primary); color:var(--primary) }
.btn-outline-dark:hover { background:var(--primary); color:var(--white); transform:translateY(-3px) }

/* ---- Preloader ---- */
.preloader { position:fixed; top:0; left:0; width:100%; height:100%; background:var(--dark); display:flex; align-items:center; justify-content:center; z-index:99999; transition:opacity .6s,visibility .6s }
.preloader.hidden { opacity:0; visibility:hidden; pointer-events:none }
.preloader-inner { text-align:center }
.preloader-inner .logo-text { font-family:var(--font-primary); font-size:2rem; color:var(--secondary); letter-spacing:6px; margin-bottom:30px }
.spinner { width:48px; height:48px; border:3px solid rgba(200,164,94,.2); border-top-color:var(--secondary); border-radius:50%; animation:spin 1s linear infinite; margin:0 auto }
@keyframes spin { to { transform:rotate(360deg) } }

/* ---- Navigation ---- */
.navbar { position:fixed; top:0; left:0; width:100%; z-index:9999; padding:18px 0; transition:var(--transition) }
.navbar.scrolled { background:rgba(8,8,8,.96); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); padding:10px 0; box-shadow:0 2px 20px rgba(0,0,0,.25) }
.navbar .container { display:flex; align-items:center; justify-content:space-between; gap:16px }
.nav-logo { display:flex; align-items:center; gap:12px; flex-shrink:0 }
.nav-logo .logo-icon { width:42px; height:42px; background:linear-gradient(135deg,var(--secondary),var(--accent)); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; transform:rotate(-5deg); flex-shrink:0 }
.nav-logo .logo-text { font-family:var(--font-primary); font-size:1.2rem; color:var(--white); letter-spacing:3px; font-weight:700 }
.nav-logo .logo-text span { color:var(--secondary) }
.nav-menu { display:flex; align-items:center; gap:6px }
.nav-menu a { color:rgba(255,255,255,.82); font-size:.8rem; font-weight:500; letter-spacing:.3px; position:relative; padding:6px 10px; border-radius:6px; transition:var(--transition) }
.nav-menu a:hover { color:var(--secondary); background:rgba(255,255,255,.06) }
.nav-menu a.active { color:var(--secondary) }
.nav-menu a::after { content:''; position:absolute; bottom:2px; left:10px; right:10px; height:2px; background:var(--secondary); transform:scaleX(0); transition:transform .3s }
.nav-menu a:hover::after,.nav-menu a.active::after { transform:scaleX(1) }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:10001; padding:4px }
.hamburger span { display:block; width:26px; height:2px; background:var(--white); transition:var(--transition); border-radius:2px }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px) }
.hamburger.active span:nth-child(2) { opacity:0; transform:translateX(-8px) }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px) }
.mobile-menu { position:fixed; top:0; right:-100%; width:300px; height:100vh; background:rgba(8,8,8,.98); backdrop-filter:blur(24px); z-index:10000; padding:90px 32px 40px; transition:right .45s cubic-bezier(.77,0,.175,1); overflow-y:auto }
.mobile-menu.active { right:0 }
.mobile-menu a { display:flex; align-items:center; color:rgba(255,255,255,.8); font-size:1rem; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.06); font-weight:500; gap:10px; transition:var(--transition) }
.mobile-menu a:hover { color:var(--secondary); padding-left:8px }
.mobile-overlay { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.6); z-index:9999; opacity:0; visibility:hidden; transition:var(--transition) }
.mobile-overlay.active { opacity:1; visibility:visible }

/* ---- Hero ---- */
.hero { position:relative; height:100vh; min-height:680px; display:flex; align-items:center; overflow:hidden }
.hero-bg { position:absolute; top:0; left:0; width:100%; height:110%; z-index:-2 }
.hero-bg img { width:100%; height:100%; object-fit:cover }
.hero-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(160deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.38) 55%,rgba(26,92,58,.28) 100%); z-index:-1 }
.hero-content { text-align:center; max-width:860px; margin:0 auto; padding:0 24px }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:8px 22px; background:rgba(200,164,94,.12); border:1px solid rgba(200,164,94,.35); border-radius:50px; color:var(--secondary); font-size:.78rem; font-weight:600; letter-spacing:4px; text-transform:uppercase; margin-bottom:28px; backdrop-filter:blur(12px) }
.hero-content h1 { font-size:clamp(2.4rem,6vw,5rem); color:var(--white); margin-bottom:22px; font-weight:800; line-height:1.08 }
.hero-content h1 span { background:linear-gradient(135deg,var(--secondary),var(--accent)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.hero-content p { font-size:clamp(.95rem,2vw,1.15rem); color:rgba(255,255,255,.78); margin-bottom:44px; max-width:620px; margin-left:auto; margin-right:auto; line-height:1.8 }
.hero-buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap }
.hero-scroll { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); text-align:center; color:rgba(255,255,255,.6); font-size:.65rem; letter-spacing:4px; text-transform:uppercase }
.hero-scroll .scroll-line { width:1px; height:52px; background:linear-gradient(to bottom,var(--secondary),transparent); margin:10px auto 0; animation:scrollDown 2.2s infinite }
@keyframes scrollDown { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ---- Search Box ---- */
.search-section { margin-top:-70px; position:relative; z-index:100; padding:0 24px }
.search-box { max-width:1080px; margin:0 auto; background:var(--white); border-radius:20px; padding:32px 36px; box-shadow:0 20px 60px rgba(0,0,0,.13); display:grid; grid-template-columns:repeat(4,1fr) auto; gap:20px; align-items:end }
.search-field label { display:block; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--primary); margin-bottom:8px }
.search-field select,.search-field input { width:100%; padding:13px 16px; border:2px solid var(--light-2); border-radius:10px; background:var(--light); color:var(--dark); font-size:.9rem; transition:var(--transition) }
.search-field select:focus,.search-field input:focus { border-color:var(--primary); background:var(--white); outline:none }

/* ---- Page Header ---- */
.page-header { position:relative; height:52vh; min-height:380px; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden; padding-top:70px }
.page-header .header-bg { position:absolute; top:0; left:0; width:100%; height:100%; z-index:-2 }
.page-header .header-bg img { width:100%; height:100%; object-fit:cover }
.page-header .header-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(160deg,rgba(0,0,0,.78),rgba(26,92,58,.45)); z-index:-1 }
.page-header h1 { font-size:clamp(2.2rem,5vw,3.8rem); color:var(--white); margin-bottom:14px }
.breadcrumb { display:flex; justify-content:center; gap:8px; color:rgba(255,255,255,.65); font-size:.9rem; align-items:center }
.breadcrumb a { color:var(--secondary) }

/* ---- Destination Cards ---- */
.destinations-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:24px }
.destination-card { position:relative; border-radius:var(--radius); overflow:hidden; height:380px; cursor:pointer; box-shadow:var(--shadow) }
.destination-card img { width:100%; height:100%; object-fit:cover; transition:transform .9s cubic-bezier(.25,.46,.45,.94) }
.destination-card:hover img { transform:scale(1.08) }
.destination-card .card-overlay { position:absolute; bottom:0; left:0; width:100%; padding:28px; background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.4) 60%,transparent 100%); transition:var(--transition) }
.destination-card:hover .card-overlay { background:linear-gradient(to top,rgba(14,61,37,.92) 0%,rgba(14,61,37,.5) 60%,transparent 100%) }
.destination-card .card-overlay h3 { font-size:1.35rem; color:var(--white); margin-bottom:4px }
.destination-card .card-overlay .location { font-size:.8rem; color:var(--secondary); display:flex; align-items:center; gap:4px }
.destination-card .card-overlay .card-desc { color:rgba(255,255,255,.8); font-size:.88rem; margin-top:10px; max-height:0; overflow:hidden; transition:max-height .5s ease }
.destination-card:hover .card-overlay .card-desc { max-height:120px }
.destination-card .card-badge { position:absolute; top:18px; left:18px; padding:5px 14px; background:var(--secondary); color:var(--dark); font-size:.72rem; font-weight:700; border-radius:50px; text-transform:uppercase; letter-spacing:1px }

/* ---- Destination Detail ---- */
.dest-detail { padding:60px 0 }
.dest-hero { position:relative; height:55vh; min-height:380px; display:flex; align-items:flex-end; overflow:hidden; border-radius:0 }
.dest-hero img { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover }
.dest-hero .dest-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.25) 55%,rgba(0,0,0,.06) 100%) }
.dest-hero .dest-hero-content { position:relative; z-index:2; padding:48px 24px; max-width:800px }
.dest-hero .dest-hero-content h2 { font-size:clamp(2.2rem,5vw,3.8rem); color:var(--white); margin-bottom:8px }
.dest-hero .dest-hero-content .dest-tagline { color:var(--secondary); font-family:var(--font-accent); font-style:italic; font-size:1.2rem }
.dest-info-bar { background:var(--primary-dark); padding:24px 0 }
.dest-info-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); gap:20px; text-align:center; color:var(--white) }
.dest-info-item .info-label { font-size:.68rem; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,.55); margin-bottom:6px }
.dest-info-item .info-value { font-family:var(--font-primary); font-size:1rem; font-weight:600; color:var(--secondary) }

/* ---- Content Sections ---- */
.content-section { padding:70px 0 }
.content-section.alt-bg { background:var(--light) }
.content-block { max-width:880px; margin:0 auto }
.content-block h2 { font-size:1.9rem; margin-bottom:20px; color:var(--dark); position:relative; padding-bottom:14px }
.content-block h2::after { content:''; position:absolute; bottom:0; left:0; width:56px; height:3px; background:var(--secondary); border-radius:2px }
.content-block h3 { font-size:1.25rem; margin:26px 0 12px; color:var(--primary) }
.content-block p { color:var(--gray); margin-bottom:16px; line-height:1.85; font-size:.97rem }
.content-block ul,.content-block ol { margin-bottom:20px; padding-left:22px }
.content-block ul li,.content-block ol li { color:var(--gray); margin-bottom:10px; line-height:1.7; list-style:disc; padding-left:6px }
.content-block ol li { list-style:decimal }
.content-block .highlight-box { background:linear-gradient(135deg,rgba(26,92,58,.06),rgba(200,164,94,.06)); border-left:4px solid var(--secondary); padding:22px 28px; border-radius:0 var(--radius-sm) var(--radius-sm) 0; margin:24px 0 }
.content-block .highlight-box p { color:var(--dark); margin-bottom:0; font-weight:500 }
.content-block .two-col { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:20px 0 }
.content-block .info-card { background:var(--white); border-radius:var(--radius-sm); padding:20px; box-shadow:0 2px 14px rgba(0,0,0,.07); border:1px solid var(--light-2) }
.content-block .info-card h4 { font-size:.95rem; margin-bottom:8px; color:var(--dark) }
.content-block .info-card p { font-size:.88rem; margin-bottom:0 }

/* ---- Itinerary ---- */
.itinerary { max-width:880px; margin:0 auto }
.itinerary-day { margin-bottom:36px }
.itinerary-day .day-header { display:flex; align-items:center; gap:16px; margin-bottom:22px; cursor:pointer }
.itinerary-day .day-number { width:52px; height:52px; background:linear-gradient(135deg,var(--primary),var(--primary-light)); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-primary); font-size:1.1rem; font-weight:700; flex-shrink:0 }
.itinerary-day .day-title { font-family:var(--font-primary); font-size:1.25rem; color:var(--dark) }
.itinerary-day .day-subtitle { font-size:.88rem; color:var(--gray); margin-top:3px }
.itinerary-day .day-content { padding-left:68px }
.itinerary-day .day-content .time-block { margin-bottom:22px; position:relative; padding-left:22px }
.itinerary-day .day-content .time-block::before { content:''; position:absolute; left:0; top:0; width:2px; height:100%; background:var(--light-2) }
.itinerary-day .day-content .time-block:last-child::before { height:50% }
.itinerary-day .day-content .time-label { font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--secondary); margin-bottom:8px; display:flex; align-items:center; gap:8px }
.itinerary-day .day-content .time-label::before { content:''; width:8px; height:8px; background:var(--secondary); border-radius:50%; flex-shrink:0 }
.itinerary-day .day-content .time-text { color:var(--gray); line-height:1.85; font-size:.92rem }
.itinerary-day .day-content .activity-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px }
.itinerary-day .day-content .activity-tags span { padding:4px 13px; background:var(--light); border-radius:50px; font-size:.78rem; color:var(--primary); font-weight:500; border:1px solid var(--light-2) }

/* ---- Package Cards ---- */
.packages-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:28px }
.package-card { background:var(--white); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:var(--transition); border:1px solid transparent }
.package-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:rgba(200,164,94,.2) }
.package-card .card-image { position:relative; height:220px; overflow:hidden }
.package-card .card-image img { width:100%; height:100%; object-fit:cover; transition:transform .65s }
.package-card:hover .card-image img { transform:scale(1.06) }
.package-card .card-image .duration-tag { position:absolute; top:16px; left:16px; background:linear-gradient(135deg,var(--secondary),var(--accent)); color:var(--dark); padding:5px 14px; border-radius:50px; font-weight:700; font-size:.78rem; box-shadow:0 2px 10px rgba(200,164,94,.4) }
.package-card .card-body { padding:22px 22px 0 }
.package-card .card-body h3 { font-size:1.2rem; margin-bottom:10px; color:var(--dark) }
.package-card .card-body p { font-size:.88rem; color:var(--gray); margin-bottom:16px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; line-height:1.7 }
.package-card .card-features { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:18px }
.package-card .card-features span { padding:4px 11px; background:rgba(26,92,58,.07); border-radius:50px; font-size:.74rem; color:var(--primary); font-weight:600 }
.quote-cta { padding:16px 22px 22px; border-top:1px solid var(--light-2); display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap }
.quote-cta p { color:var(--gray); font-size:.83rem; margin:0; line-height:1.4 }
.quote-cta .btn { padding:9px 20px; font-size:.8rem }

/* ---- Experience Cards ---- */
.experience-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:24px }
.experience-card { display:flex; flex-direction:column; background:var(--white); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:var(--transition); border:1px solid transparent }
.experience-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(200,164,94,.2) }
.experience-card .exp-image { width:100%; height:200px; flex-shrink:0; overflow:hidden }
.experience-card .exp-image img { width:100%; height:100%; object-fit:cover; transition:transform .6s }
.experience-card:hover .exp-image img { transform:scale(1.07) }
.experience-card .exp-body { padding:20px; display:flex; flex-direction:column; flex:1 }
.experience-card .exp-body .category { font-size:.72rem; text-transform:uppercase; letter-spacing:2px; color:var(--secondary); font-weight:700; margin-bottom:8px }
.experience-card .exp-body h3 { font-size:1.1rem; color:var(--dark); margin-bottom:8px; font-family:var(--font-primary) }
.experience-card .exp-body p { font-size:.85rem; color:var(--gray); line-height:1.7; margin-bottom:14px; flex:1 }
.experience-card .exp-body .exp-meta { display:flex; gap:10px; font-size:.78rem; color:var(--primary); font-weight:600; flex-wrap:wrap; padding-top:12px; border-top:1px solid var(--light-2); margin-top:auto }
.experience-card .exp-body .exp-meta span { display:flex; align-items:center; gap:4px }

/* ---- Trek Detail ---- */
.trek-stats { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:14px; margin:28px 0 }
.trek-stat { background:var(--white); border-radius:var(--radius-sm); padding:18px 14px; text-align:center; box-shadow:0 2px 12px rgba(0,0,0,.07); border:1px solid var(--light-2) }
.trek-stat .stat-icon { font-size:1.4rem; margin-bottom:8px }
.trek-stat .stat-val { font-family:var(--font-primary); font-size:1.15rem; font-weight:700; color:var(--dark) }
.trek-stat .stat-lbl { font-size:.72rem; color:var(--gray); text-transform:uppercase; letter-spacing:1px; margin-top:4px }
.trek-packing { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:22px 0 }
.trek-packing .pack-group { background:var(--light); padding:20px; border-radius:var(--radius-sm); border:1px solid var(--light-2) }
.trek-packing .pack-group h4 { font-size:.92rem; margin-bottom:12px; color:var(--primary) }
.trek-packing .pack-group ul li { font-size:.88rem; color:var(--gray); margin-bottom:8px; list-style:none; padding-left:22px; position:relative }
.trek-packing .pack-group ul li::before { content:'✔'; position:absolute; left:0; color:var(--primary-light); font-size:.8rem }

/* ---- Accordion ---- */
.accordion { max-width:880px; margin:0 auto }
.accordion-item { border:1px solid var(--light-2); border-radius:var(--radius-sm); margin-bottom:10px; overflow:hidden }
.accordion-item .accordion-trigger { width:100%; background:var(--white); padding:18px 22px; text-align:left; font-size:.97rem; font-weight:600; color:var(--dark); cursor:pointer; display:flex; justify-content:space-between; align-items:center; transition:var(--transition) }
.accordion-item .accordion-trigger:hover { background:var(--light) }
.accordion-item .accordion-trigger .icon { font-size:1.1rem; transition:transform .3s; color:var(--primary) }
.accordion-item.active .accordion-trigger { background:rgba(26,92,58,.04) }
.accordion-item.active .accordion-trigger .icon { transform:rotate(45deg) }
.accordion-item .accordion-body { max-height:0; overflow:hidden; transition:max-height .4s ease }
.accordion-item.active .accordion-body { max-height:2000px }
.accordion-item .accordion-body-inner { padding:0 22px 22px; color:var(--gray); line-height:1.85; font-size:.92rem }

/* ---- Gallery ---- */
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:240px; gap:14px }
.gallery-grid .gallery-item:nth-child(1) { grid-column:span 2; grid-row:span 2 }
.gallery-grid .gallery-item:nth-child(5) { grid-column:span 2 }
.gallery-item { position:relative; border-radius:var(--radius-sm); overflow:hidden; cursor:pointer }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s }
.gallery-item:hover img { transform:scale(1.08) }
.gallery-item .gallery-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:rgba(14,61,37,.7); display:flex; align-items:center; justify-content:center; opacity:0; transition:var(--transition) }
.gallery-item:hover .gallery-overlay { opacity:1 }
.gallery-item .gallery-overlay span { color:var(--white); font-size:2rem }
.gallery-filter { display:flex; justify-content:center; gap:10px; margin-bottom:36px; flex-wrap:wrap }
.filter-btn { padding:9px 22px; border-radius:50px; background:var(--light); color:var(--dark); font-weight:600; font-size:.83rem; cursor:pointer; transition:var(--transition); border:2px solid transparent }
.filter-btn.active,.filter-btn:hover { background:var(--primary); color:var(--white) }
.gallery-page-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
.gallery-page-grid .gallery-item { height:280px }
.gallery-page-grid .gallery-item:nth-child(4) { grid-column:span 2 }
.gallery-page-grid .gallery-item:nth-child(7) { grid-column:span 2 }

/* ---- Testimonials ---- */
.testimonials-slider { position:relative; max-width:820px; margin:0 auto }
.testimonial-card { position:relative; text-align:center; padding:48px 44px; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-md); border:1px solid var(--light-2) }
.testimonial-card .quote-icon { font-size:6rem; color:var(--primary); opacity:.07; position:absolute; top:12px; left:24px; font-family:serif; line-height:1 }
.testimonial-card .stars { color:var(--accent); font-size:1.1rem; margin-bottom:20px; letter-spacing:2px }
.testimonial-card .testimonial-text { font-size:1.05rem; font-style:italic; color:#444; line-height:1.9; margin-bottom:28px; font-family:var(--font-accent); position:relative; z-index:1 }
.testimonial-card .author { display:flex; align-items:center; justify-content:center; gap:16px }
.testimonial-card .author-avatar { width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--secondary)); display:flex; align-items:center; justify-content:center; color:var(--white); font-size:1.1rem; font-weight:700; font-family:var(--font-primary); flex-shrink:0; box-shadow:0 4px 14px rgba(26,92,58,.25) }
.testimonial-card .author-info h4 { font-size:.97rem; color:var(--dark) }
.testimonial-card .author-info span { font-size:.82rem; color:var(--gray) }
.testimonials-nav { display:flex; justify-content:center; gap:10px; margin-top:28px }
.testimonials-nav button { width:10px; height:10px; border-radius:50%; background:var(--light-2); cursor:pointer; transition:var(--transition); border:none }
.testimonials-nav button.active { background:var(--primary); width:32px; border-radius:5px }

/* ---- Why Choose Us ---- */
.why-section { background:linear-gradient(150deg,#0e1a2b 0%,#0e3d25 100%); color:var(--white); padding:100px 0; position:relative; overflow:hidden }
.why-section::before { content:''; position:absolute; top:-60%; right:-20%; width:600px; height:600px; background:radial-gradient(circle,rgba(200,164,94,.08) 0%,transparent 65%); pointer-events:none }
.why-section .section-title h2 { color:var(--white) }
.why-section .section-title p { color:rgba(255,255,255,.58) }
.why-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:24px }
.why-card { text-align:center; padding:36px 28px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); transition:var(--transition); position:relative; overflow:hidden }
.why-card::before { content:''; position:absolute; bottom:0; left:0; width:100%; height:2px; background:linear-gradient(90deg,transparent,var(--secondary),transparent); opacity:0; transition:opacity .4s }
.why-card:hover { transform:translateY(-8px); background:rgba(255,255,255,.09); border-color:rgba(200,164,94,.3) }
.why-card:hover::before { opacity:1 }
.why-card .icon { width:72px; height:72px; margin:0 auto 20px; background:linear-gradient(135deg,rgba(26,92,58,.6),rgba(45,138,94,.6)); border:1px solid rgba(200,164,94,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.8rem; transition:var(--transition) }
.why-card:hover .icon { transform:scale(1.1); background:linear-gradient(135deg,var(--primary),var(--primary-light)) }
.why-card h3 { font-size:1.15rem; margin-bottom:12px; color:var(--secondary) }
.why-card p { font-size:.88rem; color:rgba(255,255,255,.65); line-height:1.75 }

/* ---- Stats ---- */
.stats-section { padding:80px 0; background:linear-gradient(135deg,var(--primary-dark),var(--primary)); position:relative; overflow:hidden }
.stats-section::before { content:''; position:absolute; top:0; left:0; width:100%; height:100%; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 20'%3E%3Cpath d='M0 10 Q25 2 50 10 T100 10 V20 H0Z' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E") bottom/100% auto no-repeat }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative }
.stat-item { text-align:center; color:var(--white) }
.stat-item .stat-icon-wrap { font-size:2rem; margin-bottom:10px; opacity:.8 }
.stat-item .stat-number { font-family:var(--font-primary); font-size:clamp(2.2rem,4vw,3.2rem); font-weight:800; color:var(--secondary); line-height:1; margin-bottom:8px }
.stat-item .stat-label { font-size:.82rem; opacity:.75; text-transform:uppercase; letter-spacing:2.5px; font-weight:500 }

/* ---- Newsletter ---- */
.newsletter-section { padding:80px 0; background:var(--light) }
.newsletter-box { max-width:640px; margin:0 auto; text-align:center }
.newsletter-box h2 { font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:12px }
.newsletter-box p { color:var(--gray); margin-bottom:28px; line-height:1.8 }
.newsletter-form { display:flex; gap:10px; max-width:480px; margin:0 auto }
.newsletter-form input { flex:1; padding:14px 22px; border-radius:50px; border:2px solid var(--light-2); background:var(--white); font-size:.92rem; transition:border-color .3s }
.newsletter-form input:focus { border-color:var(--primary); outline:none }

/* ---- Contact ---- */
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:56px; align-items:start }
.contact-info-item { display:flex; gap:18px; margin-bottom:24px; align-items:flex-start }
.contact-info-item .info-icon { width:52px; height:52px; flex-shrink:0; background:linear-gradient(135deg,var(--primary),var(--primary-light)); border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; color:var(--white); font-size:1.1rem; box-shadow:0 4px 14px rgba(26,92,58,.25) }
.contact-info-item h4 { font-size:.95rem; color:var(--dark); margin-bottom:3px }
.contact-info-item p,.contact-info-item a { color:var(--gray); font-size:.88rem; transition:color .2s }
.contact-info-item a:hover { color:var(--primary) }
.form-container { padding:44px; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-lg); border:1px solid var(--light-2) }
.form-group { margin-bottom:20px }
.form-group label { display:block; font-size:.78rem; font-weight:700; color:var(--dark); margin-bottom:7px; text-transform:uppercase; letter-spacing:.8px }
.form-group input,.form-group select,.form-group textarea { width:100%; padding:13px 16px; border:2px solid var(--light-2); border-radius:var(--radius-sm); background:var(--light); color:var(--dark); font-size:.92rem; transition:var(--transition) }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--primary); background:var(--white); box-shadow:0 0 0 4px rgba(26,92,58,.08); outline:none }
.form-group textarea { resize:vertical; min-height:110px; line-height:1.7 }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px }
.form-container h2 { text-align:center; margin-bottom:6px; font-size:1.9rem }
.form-container .form-subtitle { text-align:center; color:var(--gray); margin-bottom:28px; font-size:.92rem }
.form-container .form-footer { text-align:center; margin-top:18px; color:var(--gray); font-size:.88rem }
.form-container .form-footer a { color:var(--primary); font-weight:600 }
.alert { padding:13px 18px; border-radius:var(--radius-sm); margin-bottom:18px; font-size:.88rem; display:none; font-weight:500 }
.alert.show { display:block; animation:fadeIn .4s }
.alert-success { background:#d4edda; color:#155724; border:1px solid #c3e6cb }
.alert-error   { background:#f8d7da; color:#721c24; border:1px solid #f5c6cb }

/* ---- About ---- */
.about-intro { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center }
.about-intro .about-image { position:relative; border-radius:var(--radius); overflow:visible }
.about-intro .about-image img { width:100%; height:440px; object-fit:cover; border-radius:var(--radius) }
.about-intro .about-image .experience-badge { position:absolute; bottom:28px; right:-16px; background:linear-gradient(135deg,var(--secondary),var(--accent)); color:var(--dark); padding:18px 26px; border-radius:var(--radius-sm); text-align:center; box-shadow:var(--shadow-md) }
.about-intro .about-image .experience-badge .number { font-family:var(--font-primary); font-size:2.4rem; font-weight:800; line-height:1 }
.about-intro .about-image .experience-badge .text { font-size:.75rem; text-transform:uppercase; letter-spacing:2px; font-weight:700; margin-top:4px }
.about-text h3 { font-size:1.75rem; margin-bottom:16px; color:var(--dark) }
.about-text p { color:var(--gray); margin-bottom:16px; line-height:1.85 }
.founders-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:32px; max-width:780px; margin:0 auto }
.founder-card { text-align:center; padding:36px 28px; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); transition:var(--transition); border:1px solid var(--light-2) }
.founder-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); border-color:rgba(200,164,94,.25) }
.founder-card .founder-avatar { width:110px; height:110px; border-radius:50%; background:linear-gradient(135deg,var(--primary),var(--secondary)); display:flex; align-items:center; justify-content:center; margin:0 auto 18px; font-size:2.2rem; color:var(--white); font-family:var(--font-primary); font-weight:700; box-shadow:0 8px 24px rgba(26,92,58,.25) }
.founder-card h3 { font-size:1.25rem; color:var(--dark); margin-bottom:4px }
.founder-card .role { color:var(--secondary); font-weight:600; font-size:.85rem; margin-bottom:12px }
.founder-card p { color:var(--gray); font-size:.88rem; line-height:1.75 }

/* ---- Lightbox ---- */
.lightbox { position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.96); z-index:99999; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:var(--transition) }
.lightbox.active { opacity:1; visibility:visible }
.lightbox img { max-width:90%; max-height:86vh; border-radius:var(--radius-sm); box-shadow:0 20px 60px rgba(0,0,0,.6) }
.lightbox-close { position:absolute; top:20px; right:28px; color:rgba(255,255,255,.7); font-size:2rem; cursor:pointer; background:rgba(255,255,255,.1); border:none; width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:var(--transition) }
.lightbox-close:hover { background:rgba(255,255,255,.2); color:var(--white) }

/* ---- Footer ---- */
.footer { background:#080808; color:rgba(255,255,255,.6); padding:80px 0 0 }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.07) }
.footer-about .footer-logo { font-family:var(--font-primary); font-size:1.45rem; color:var(--white); letter-spacing:3px; margin-bottom:14px; font-weight:700 }
.footer-about .footer-logo span { color:var(--secondary) }
.footer-about p { font-size:.88rem; line-height:1.85; margin-bottom:22px; color:rgba(255,255,255,.5) }
.footer-social { display:flex; gap:10px }
.footer-social a { width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.65); font-size:.82rem; transition:var(--transition); text-decoration:none }
.footer-social a:hover { background:var(--secondary); color:var(--dark); border-color:var(--secondary); transform:translateY(-4px) }
.footer h4 { color:var(--white); font-size:1rem; margin-bottom:22px; position:relative; padding-bottom:12px }
.footer h4::after { content:''; position:absolute; bottom:0; left:0; width:36px; height:2px; background:var(--secondary); border-radius:1px }
.footer-links a { display:block; padding:5px 0; font-size:.88rem; color:rgba(255,255,255,.5); transition:var(--transition) }
.footer-links a:hover { color:var(--secondary); padding-left:8px }
.footer-contact li { display:flex; gap:12px; margin-bottom:14px; font-size:.88rem; color:rgba(255,255,255,.55); align-items:flex-start }
.footer-contact li .icon { color:var(--secondary); font-size:.95rem; margin-top:2px; flex-shrink:0 }
.footer-bottom { padding:22px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px }
.footer-bottom p { font-size:.82rem; color:rgba(255,255,255,.35) }
.footer-bottom a { color:var(--secondary) }

/* ---- WhatsApp Float ---- */
.whatsapp-float { position:fixed; bottom:28px; right:28px; z-index:9998 }
.whatsapp-float a { display:flex; align-items:center; justify-content:center; width:58px; height:58px; background:#25D366; border-radius:50%; box-shadow:0 4px 20px rgba(37,211,102,.45); transition:var(--transition); animation:wasPulse 2.5s infinite }
.whatsapp-float a:hover { transform:scale(1.12); box-shadow:0 6px 28px rgba(37,211,102,.55) }
.whatsapp-float svg { width:30px; height:30px; fill:white }
@keyframes wasPulse { 0%{box-shadow:0 0 0 0 rgba(37,211,102,.45)} 70%{box-shadow:0 0 0 14px rgba(37,211,102,0)} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0)} }

/* ---- Back to Top ---- */
.back-to-top { position:fixed; bottom:98px; right:32px; width:44px; height:44px; background:var(--primary); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; opacity:0; visibility:hidden; transform:translateY(16px); transition:var(--transition); border:none; box-shadow:0 4px 16px rgba(26,92,58,.35); z-index:9997; font-size:1.2rem }
.back-to-top.visible { opacity:1; visibility:visible; transform:translateY(0) }
.back-to-top:hover { background:var(--primary-light); transform:translateY(-4px) }

/* ---- Animations ---- */
.reveal { opacity:0; transform:translateY(36px); transition:opacity .75s ease,transform .75s ease }
.reveal.visible { opacity:1; transform:translateY(0) }
.reveal-left  { opacity:0; transform:translateX(-36px); transition:opacity .75s ease,transform .75s ease }
.reveal-left.visible  { opacity:1; transform:translateX(0) }
.reveal-right { opacity:0; transform:translateX(36px);  transition:opacity .75s ease,transform .75s ease }
.reveal-right.visible { opacity:1; transform:translateX(0) }
.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}.delay-4{transition-delay:.4s}.delay-5{transition-delay:.5s}
@keyframes fadeIn    { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeInUp  { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

/* ---- Responsive ---- */
@media(max-width:1200px) {
  .nav-menu { gap:2px }
  .nav-menu a { padding:6px 8px; font-size:.76rem }
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr 1fr }
}
@media(max-width:1024px) {
  .nav-menu { display:none }
  .hamburger { display:flex }
  .search-box { grid-template-columns:1fr 1fr }
  .footer-grid { grid-template-columns:1fr 1fr }
  .about-intro { grid-template-columns:1fr; gap:36px }
  .about-intro .about-image .experience-badge { right:12px }
  .contact-grid { grid-template-columns:1fr; gap:36px }
  .stats-grid { grid-template-columns:repeat(2,1fr) }
  .gallery-grid { grid-template-columns:repeat(2,1fr) }
  .gallery-grid .gallery-item:nth-child(1) { grid-column:span 2; grid-row:span 1 }
  .gallery-grid .gallery-item:nth-child(5) { grid-column:span 1 }
  .gallery-page-grid { grid-template-columns:repeat(2,1fr) }
  .gallery-page-grid .gallery-item:nth-child(4),.gallery-page-grid .gallery-item:nth-child(7) { grid-column:span 1 }
  .experience-card { flex-direction:column }
  .experience-card .exp-image { width:100%; min-height:200px }
  .packages-grid { grid-template-columns:1fr 1fr }
}
@media(max-width:768px) {
  .section-padding { padding:70px 0 }
  .hero { min-height:580px }
  .hero-content h1 { font-size:2rem }
  .search-box { grid-template-columns:1fr; padding:24px 20px }
  .destinations-grid { grid-template-columns:1fr }
  .founders-grid { grid-template-columns:1fr }
  .why-grid { grid-template-columns:1fr 1fr }
  .footer-grid { grid-template-columns:1fr }
  .footer-bottom { flex-direction:column; text-align:center }
  .form-container { padding:28px 20px }
  .form-row { grid-template-columns:1fr }
  .newsletter-form { flex-direction:column }
  .gallery-grid { grid-template-columns:1fr 1fr; grid-auto-rows:180px }
  .gallery-page-grid { grid-template-columns:1fr }
  .testimonial-card { padding:32px 22px }
  .content-block .two-col { grid-template-columns:1fr }
  .trek-packing { grid-template-columns:1fr }
  .experience-grid { grid-template-columns:1fr }
  .packages-grid { grid-template-columns:1fr }
  .dest-detail { padding:40px 0 }
  .dest-hero { height:45vh; min-height:300px }
  .contact-grid { gap:24px }
}
@media(max-width:480px) {
  .hero-content h1 { font-size:1.75rem }
  .hero-buttons { flex-direction:column; align-items:center }
  .btn { padding:12px 26px; font-size:.88rem }
  .why-grid { grid-template-columns:1fr }
  .stats-grid { grid-template-columns:1fr 1fr; gap:18px }
  .stat-item .stat-number { font-size:2rem }
  .gallery-grid { grid-template-columns:1fr; grid-auto-rows:200px }
  .gallery-grid .gallery-item:nth-child(1) { grid-column:span 1 }
  .mobile-menu { width:100% }
}
