/* =========================================
   CSS VARIABLES & RESET
   ========================================= */
:root {
  --green-deep:    #0D2B1A;
  --green-dark:    #1B4332;
  --green-mid:     #2D6A4F;
  --green-soft:    #40916C;
  --green-light:   #74C69D;
  --green-pale:    #B7E4C7;
  --gold:          #C9A84C;
  --gold-light:    #E8C97A;
  --white:         #FFFFFF;
  --off-white:     #F8FAF8;
  --gray-50:       #F4F6F4;
  --gray-100:      #E8EDE8;
  --gray-300:      #B8C4B8;
  --gray-500:      #6B7C6B;
  --gray-700:      #3D4D3D;
  --text-dark:     #0D1F0D;
  --glass-bg:      rgba(255,255,255,0.12);
  --glass-border:  rgba(255,255,255,0.25);
  --glass-shadow:  0 8px 32px rgba(13,43,26,0.18);
  --glass-dark:    rgba(13,43,26,0.45);
  --glass-border-dark: rgba(255,255,255,0.1);
  --radius-sm:     8px;
  --radius-md:     16px;
  --radius-lg:     24px;
  --radius-xl:     40px;
  --shadow-sm:     0 2px 12px rgba(13,43,26,0.08);
  --shadow-md:     0 8px 30px rgba(13,43,26,0.14);
  --shadow-lg:     0 20px 60px rgba(13,43,26,0.20);
  --nav-h:         76px;
  --transition:    0.35s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:'Outfit',sans-serif;background:#fff;color:var(--text-dark);overflow-x:hidden;line-height:1.6;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,select,textarea{font-family:inherit;}

/* =========================================
   SCROLLBAR
   ========================================= */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:#f1f1f1;}
::-webkit-scrollbar-thumb{background:var(--green-mid);border-radius:10px;}

/* =========================================
   UTILITIES
   ========================================= */
.container{max-width:1280px;margin:0 auto;padding:0 24px;}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:0.78rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--green-soft);margin-bottom:12px;}
.section-label::before{content:'';display:block;width:28px;height:2px;background:var(--gold);}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:800;line-height:1.15;color:var(--green-deep);}
.section-title span{color:var(--green-soft);}
.section-subtitle{font-size:1.05rem;color:var(--gray-500);max-width:560px;margin-top:12px;font-weight:300;}
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:var(--green-dark);color:#fff;border-radius:var(--radius-xl);font-weight:600;font-size:0.95rem;transition:var(--transition);letter-spacing:0.3px;}
.btn-primary:hover{background:var(--green-mid);transform:translateY(-2px);box-shadow:0 8px 24px rgba(27,67,50,0.35);}
.btn-outline{display:inline-flex;align-items:center;gap:10px;padding:13px 30px;border:2px solid var(--green-dark);color:var(--green-dark);border-radius:var(--radius-xl);font-weight:600;font-size:0.95rem;transition:var(--transition);}
.btn-outline:hover{background:var(--green-dark);color:#fff;transform:translateY(-2px);}
.btn-gold{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:var(--gold);color:#fff;border-radius:var(--radius-xl);font-weight:600;font-size:0.95rem;transition:var(--transition);}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,0.4);}
.tag{display:inline-block;padding:4px 14px;border-radius:20px;font-size:0.78rem;font-weight:600;letter-spacing:0.5px;}
.tag-green{background:var(--green-pale);color:var(--green-deep);}
.tag-gold{background:rgba(201,168,76,0.15);color:var(--gold);}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.glass-card{background:rgba(255,255,255,0.7);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);}
.glass-card-dark{background:var(--glass-dark);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-dark);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);}
.page{display:block;}
.page.active{display:block;}
.fade-in{animation:fadeIn 0.5s ease forwards;}
@keyframes fadeIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.stars{color:var(--gold);font-size:0.9rem;}

/* =========================================
   NAVBAR
   ========================================= */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,0.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--gray-100);box-shadow:0 4px 20px rgba(13,43,26,0.08);transition:var(--transition);}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:20px;}
.logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:800;color:var(--green-dark);cursor:pointer;transition:var(--transition);}
.logo-img{width:170px;height:60px;border-radius:10px;object-fit:contain;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-link{padding:8px 14px;border-radius:var(--radius-sm);font-size:0.9rem;font-weight:500;color:var(--gray-700);transition:var(--transition);cursor:pointer;position:relative;}
.nav-link:hover{color:var(--green-dark);background:var(--gray-50);}
.nav-link.active{color:var(--green-dark);background:var(--gray-50);border:1px solid var(--green-mid);}
.nav-cta{display:flex;align-items:center;gap:10px;}
.nav-book-btn{padding:10px 22px;background:var(--green-dark);color:#fff;border-radius:var(--radius-xl);font-size:0.88rem;font-weight:600;transition:var(--transition);}
.nav-book-btn:hover{background:var(--green-mid);box-shadow:0 4px 16px rgba(27,67,50,0.3);}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;}
.hamburger span{display:block;width:24px;height:2px;background:var(--green-dark);border-radius:2px;transition:var(--transition);}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);border-bottom:1px solid var(--gray-100);padding:16px 24px 24px;z-index:999;box-shadow:0 8px 24px rgba(13,43,26,0.12);}
.mobile-menu.open{display:block;}
.mobile-menu .nav-link{display:block;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:4px;color:var(--gray-700);}
.mobile-menu .nav-link:hover{background:var(--gray-50);color:var(--green-dark);}

/* =========================================
   HERO SECTION
   ========================================= */
#hero{height:100vh;min-height:700px;position:relative;overflow:hidden;display:flex;align-items:center;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg-gradient{position:absolute;inset:0;background:linear-gradient(135deg,#0D2B1A 0%,#1B4332 40%,#2D6A4F 70%,#1B4332 100%);z-index:1;}
.hero-bg-pattern{position:absolute;inset:0;z-index:2;opacity:0.06;background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);background-size:40px 40px;}

/* Hero Slideshow */
.hero-slideshow{position:absolute;inset:0;z-index:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease-in-out,transform 1s ease-in-out;min-height:100vh;display:flex;align-items:center;}
.hero-slide .container{position:relative;z-index:10;}
.hero-slide.active{opacity:1;transform:scale(1);}
.hero-slide:not(.active){transform:scale(1.1);}

/* Hero Slide Image - Top priority */
.hero-slide-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1;background-size:cover;background-position:center;background-repeat:no-repeat;min-height:100vh;}
.hero-slide .hero-bg-gradient{position:absolute;inset:0;z-index:0;background:none !important;}
.hero-slide .hero-bg-pattern{position:absolute;inset:0;z-index:2;}
.hero-slide .hero-orb{z-index:4;}
.hero-slide .container{z-index:5;}

/* Force hero images to display */
.hero-slide .hero-slide-img{opacity:0 !important;}
.hero-slide.active .hero-slide-img{opacity:1 !important;background-size:cover !important;background-position:center !important;background-repeat:no-repeat !important;}

/* Hero Controls */
.hero-controls{position:absolute;inset:0;z-index:15;pointer-events:none;}
.hero-control{position:absolute;width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.3);color:#fff;display:flex;align-items:center;justify-content:center;transition:all 0.3s ease;cursor:pointer;pointer-events:auto;top:50%;transform:translateY(-50%);}
.hero-control:hover{background:rgba(255,255,255,0.25);transform:translateY(-50%) scale(1.1);}
.hero-control.prev{left:20px;}
.hero-control.next{right:20px;}

/* Hero Indicators */
.hero-indicators{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:15;display:flex;gap:12px;}
.indicator{width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,0.4);cursor:pointer;transition:all 0.3s ease;}
.indicator.active{background:var(--gold-light);transform:scale(1.3);}
.indicator:hover{background:rgba(255,255,255,0.6);}

/* Responsive Hero Slideshow */
@media (max-width:768px){
  .hero-slide{background-attachment:scroll;}
  .hero-controls{inset:0;}
  .hero-control{width:40px;height:40px;}
  .hero-control.prev{left:10px;}
  .hero-control.next{right:10px;}
  .hero-indicators{bottom:30px;gap:8px;}
  .indicator{width:10px;height:10px;}
  .hero-content{max-width:100%;padding:0 20px;}
  .hero-title{font-size:clamp(2rem,8vw,3.5rem);}
  .hero-desc{font-size:1rem;}
  .hero-actions{gap:10px;}
  .hero-btn-main{padding:14px 28px;font-size:0.9rem;}
  .hero-btn-secondary{padding:14px 24px;font-size:0.9rem;}
}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);z-index:2;}
.hero-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(116,198,157,0.4) 0%,transparent 70%);top:-100px;right:-100px;}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(201,168,76,0.25) 0%,transparent 70%);bottom:-80px;left:200px;}
.hero-orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(45,106,79,0.6) 0%,transparent 70%);top:50%;left:-80px;}
.hero-img-right{position:absolute;right:0;top:0;bottom:0;width:50%;z-index:3;opacity:0.35;}
.hero-img-right::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--green-deep) 0%,transparent 60%);}
.hero-content{position:relative;z-index:10;max-width:700px;width:100%;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-xl);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.9);font-size:0.82rem;font-weight:500;margin-bottom:24px;backdrop-filter:blur(10px);}
.hero-badge i{color:var(--gold-light);}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.8rem,7vw,5.2rem);font-weight:800;line-height:1.08;color:#fff;margin-bottom:20px;}
.hero-title .line-2{color:var(--gold-light);font-style:italic;}
.hero-desc{font-size:1.1rem;color:rgba(255,255,255,0.75);max-width:500px;margin-bottom:36px;font-weight:300;line-height:1.7;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px;}
.hero-btn-main{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:#fff;color:var(--green-dark);border-radius:var(--radius-xl);font-weight:700;font-size:1rem;transition:var(--transition);}
.hero-btn-main:hover{background:var(--green-pale);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.25);}
.hero-btn-secondary{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border:2px solid rgba(255,255,255,0.35);color:#fff;border-radius:var(--radius-xl);font-weight:600;font-size:1rem;transition:var(--transition);backdrop-filter:blur(8px);}
.hero-btn-secondary:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.6);}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;}
.hero-stat{}
.hero-stat-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;color:#fff;line-height:1;}
.hero-stat-num span{color:var(--gold-light);}
.hero-stat-label{font-size:0.82rem;color:rgba(255,255,255,0.6);margin-top:4px;font-weight:400;}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.5);font-size:0.75rem;letter-spacing:2px;text-transform:uppercase;}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.5),transparent);animation:scrollPulse 2s ease-in-out infinite;}
@keyframes scrollPulse{0%,100%{opacity:0.5;transform:scaleY(1);}50%{opacity:1;transform:scaleY(1.2);}}

/* Hero floating cards */
.hero-float-cards{position:absolute;right:5%;top:50%;transform:translateY(-50%);z-index:10;display:flex;flex-direction:column;gap:16px;}
.float-card{background:rgba(255,255,255,0.13);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.2);border-radius:var(--radius-md);padding:14px 18px;color:#fff;min-width:200px;animation:floatCard 4s ease-in-out infinite;}
.float-card:nth-child(2){animation-delay:1.5s;}
.float-card:nth-child(3){animation-delay:3s;}
@keyframes floatCard{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.float-card-label{font-size:0.72rem;color:rgba(255,255,255,0.6);margin-bottom:4px;}
.float-card-value{font-size:1.1rem;font-weight:700;}
.float-card-meta{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:0.78rem;color:rgba(255,255,255,0.7);}
.float-card-meta i{color:var(--gold-light);}

/* =========================================
   SEARCH BAR
   ========================================= */
.search-section{position:relative;z-index:20;margin-top:-64px;padding:0 24px;}
.search-wrapper{max-width:1100px;margin:0 auto;}
.search-card{background:rgba(255,255,255,0.95);backdrop-filter:blur(30px);border:1px solid var(--gray-100);border-radius:var(--radius-lg);box-shadow:0 20px 60px rgba(13,43,26,0.18);padding:28px 32px;}
.search-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--gray-50);padding:4px;border-radius:var(--radius-sm);width:fit-content;}
.search-tab{padding:8px 20px;border-radius:6px;font-size:0.88rem;font-weight:600;color:var(--gray-500);cursor:pointer;transition:var(--transition);}
.search-tab.active{background:#fff;color:var(--green-dark);box-shadow:var(--shadow-sm);}
.search-fields{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:12px;align-items:end;}
.sf-group{display:flex;flex-direction:column;gap:6px;}
.sf-label{font-size:0.78rem;font-weight:600;color:var(--gray-700);letter-spacing:0.3px;}
.sf-input-wrap{position:relative;}
.sf-input-wrap i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--green-soft);font-size:0.9rem;}
.sf-input,.sf-select{width:100%;padding:11px 12px 11px 36px;border:1.5px solid var(--gray-100);border-radius:var(--radius-sm);font-size:0.9rem;color:var(--text-dark);background:#fff;transition:var(--transition);outline:none;}
.sf-input:focus,.sf-select:focus{border-color:var(--green-soft);box-shadow:0 0 0 3px rgba(64,145,108,0.1);}
.sf-select{cursor:pointer;appearance:none;-webkit-appearance:none;}
.search-btn{padding:13px 28px;background:var(--green-dark);color:#fff;border-radius:var(--radius-sm);font-weight:700;font-size:0.95rem;display:flex;align-items:center;gap:8px;transition:var(--transition);white-space:nowrap;}
.search-btn:hover{background:var(--green-mid);box-shadow:0 6px 20px rgba(27,67,50,0.3);}
.search-popular{margin-top:16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.search-popular-label{font-size:0.8rem;color:var(--gray-500);font-weight:500;}
.search-pill{padding:5px 14px;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-xl);font-size:0.8rem;color:var(--gray-700);cursor:pointer;transition:var(--transition);}
.search-pill:hover{background:var(--green-pale);border-color:var(--green-light);color:var(--green-dark);}

/* Autocomplete */
.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:100;max-height:240px;overflow-y:auto;display:none;}
.autocomplete-dropdown.open{display:block;}
.ac-item{padding:10px 14px;cursor:pointer;font-size:0.88rem;transition:var(--transition);display:flex;align-items:center;gap:10px;}
.ac-item:hover{background:var(--gray-50);color:var(--green-dark);}
.ac-item i{color:var(--green-soft);}

/* =========================================
   WHY SECTION
   ========================================= */
.why-section{padding:100px 0;background:#fff;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-top:60px;}
.why-visual{position:relative;}
.why-img-stack{position:relative;height:500px;}
.why-img-main{position:absolute;top:0;left:0;width:75%;height:420px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);}
.why-img-main img,.why-img-accent img{width:100%;height:100%;object-fit:cover;}
.why-img-accent{position:absolute;bottom:0;right:0;width:55%;height:280px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:4px solid #fff;}
.why-badge{position:absolute;top:50%;left:60%;transform:translate(-50%,-50%);background:var(--green-dark);color:#fff;border-radius:var(--radius-md);padding:16px 20px;text-align:center;box-shadow:var(--shadow-lg);}
.why-badge-num{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:800;line-height:1;}
.why-badge-text{font-size:0.75rem;margin-top:2px;opacity:0.8;}
.why-features{display:flex;flex-direction:column;gap:20px;margin-top:32px;}
.why-feature{display:flex;gap:16px;align-items:flex-start;}
.why-icon{width:48px;height:48px;background:var(--gray-50);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition);}
.why-feature:hover .why-icon{background:var(--green-pale);}
.why-icon i{font-size:1.1rem;color:var(--green-soft);}
.why-feature-title{font-weight:700;font-size:0.95rem;color:var(--green-deep);margin-bottom:4px;}
.why-feature-desc{font-size:0.88rem;color:var(--gray-500);}

/* Placeholder colored images */
.img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:rgba(255,255,255,0.4);}
.img-kili{background:linear-gradient(135deg,#1a3a2e 0%,#2d6a4f 50%,#74c69d 100%);}
.img-safari{background:linear-gradient(135deg,#2d4a1e 0%,#5a8a32 50%,#a8c870 100%);}
.img-beach{background:linear-gradient(135deg,#1a3a5c 0%,#1e6ba8 50%,#5cb8e4 100%);}
.img-zanzibar{background:linear-gradient(135deg,#3a1a2e 0%,#7a3a6a 50%,#c87ab8 100%);}
.img-serengeti{background:linear-gradient(135deg,#3a2a1a 0%,#8a6a30 50%,#c8a850 100%);}
.img-ngorongoro{background:linear-gradient(135deg,#1a2a3a 0%,#2a5a6a 50%,#5a9aa8 100%);}
.img-tarangire{background:linear-gradient(135deg,#2a3a1a 0%,#5a7a30 50%,#a0b870 100%);}
.img-ruaha{background:linear-gradient(135deg,#3a1a1a 0%,#8a3030 50%,#c87070 100%);}
.img-tour1{background:linear-gradient(135deg,#1B4332 0%,#40916C 100%);}
.img-tour2{background:linear-gradient(135deg,#2d4a1e 0%,#8a9a32 100%);}
.img-tour3{background:linear-gradient(135deg,#1a2a4a 0%,#3a6aaa 100%);}

/* =========================================
   DESTINATIONS
   ========================================= */
.destinations-section{padding:100px 0;background:var(--off-white);}
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;}
.dest-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;}
.dest-filter{padding:8px 20px;border:1.5px solid var(--gray-100);border-radius:var(--radius-xl);font-size:0.85rem;font-weight:500;color:var(--gray-500);cursor:pointer;transition:var(--transition);background:#fff;}
.dest-filter.active,.dest-filter:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark);}
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.dest-card{border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm);transition:var(--transition);}
.dest-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.dest-card-img{height:280px;position:relative;overflow:hidden;}
.dest-card-img .img-placeholder{transition:var(--transition);}
.dest-card:hover .img-placeholder{transform:scale(1.05);}
.dest-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,43,26,0.85) 0%,rgba(13,43,26,0.1) 60%,transparent 100%);}
.dest-card-content{position:absolute;bottom:0;left:0;right:0;padding:20px;}
.dest-card-name{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:4px;}
.dest-card-meta{display:flex;align-items:center;gap:12px;}
.dest-card-count{font-size:0.8rem;color:rgba(255,255,255,0.7);}
.dest-card-rating{display:flex;align-items:center;gap:4px;font-size:0.8rem;color:var(--gold-light);}
.dest-card-tag{position:absolute;top:14px;left:14px;padding:4px 12px;background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.25);border-radius:20px;color:#fff;font-size:0.75rem;font-weight:600;}
.dest-card.featured{grid-column:span 2;grid-row:span 2;}
.dest-card.featured .dest-card-img{height:100%;}

/* =========================================
   TOURS SECTION
   ========================================= */
.tours-section{padding:100px 0;background:#fff;}
.tour-card{border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);cursor:pointer;}
.tour-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.tour-card-img{height:240px;position:relative;overflow:hidden;}
.tour-card-img .img-placeholder{transition:var(--transition);}
.tour-card:hover .tour-card-img .img-placeholder{transform:scale(1.05);}
.tour-card-tags{position:absolute;top:12px;left:12px;display:flex;gap:6px;}
.tour-duration{position:absolute;bottom:12px;right:12px;background:rgba(13,43,26,0.75);backdrop-filter:blur(6px);color:#fff;padding:4px 10px;border-radius:20px;font-size:0.78rem;font-weight:600;}
.tour-card-body{padding:20px;}
.tour-card-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--green-deep);margin-bottom:8px;line-height:1.3;}
.tour-card-meta{display:flex;gap:16px;margin-bottom:12px;}
.tour-meta-item{display:flex;align-items:center;gap:5px;font-size:0.8rem;color:var(--gray-500);}
.tour-meta-item i{color:var(--green-soft);}
.tour-card-desc{font-size:0.85rem;color:var(--gray-500);margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.tour-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--gray-100);}
.tour-price{font-size:1.3rem;font-weight:800;color:var(--green-dark);}
.tour-price span{font-size:0.8rem;font-weight:400;color:var(--gray-500);}
.tour-book-btn{padding:8px 18px;background:var(--green-dark);color:#fff;border-radius:var(--radius-xl);font-size:0.82rem;font-weight:600;transition:var(--transition);}
.tour-book-btn:hover{background:var(--green-mid);}
.tour-reviews{display:flex;align-items:center;gap:6px;margin-bottom:12px;}
.tour-reviews span{font-size:0.8rem;color:var(--gray-500);}

/* =========================================
   KILIMANJARO SECTION
   ========================================= */
.kili-section{padding:100px 0;background:var(--green-deep);color:#fff;position:relative;overflow:hidden;}
.kili-bg{position:absolute;inset:0;opacity:0.05;background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);background-size:32px 32px;}
.kili-orb{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(116,198,157,0.15) 0%,transparent 70%);top:-200px;right:-200px;border-radius:50%;}
.kili-inner{position:relative;z-index:1;}
.kili-top{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:70px;}
.kili-section .section-label{color:var(--green-light);}
.kili-section .section-title{color:#fff;}
.kili-section .section-title span{color:var(--gold-light);}
.kili-section .section-subtitle{color:rgba(255,255,255,0.65);}
.kili-actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}
.kili-visual{position:relative;}
.kili-main-img{border-radius:var(--radius-lg);overflow:hidden;height:420px;box-shadow:0 20px 60px rgba(0,0,0,0.4);}
.kili-stats{position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);display:flex;gap:0;background:rgba(255,255,255,0.12);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-md);overflow:hidden;width:90%;}
.kili-stat{flex:1;padding:16px 12px;text-align:center;border-right:1px solid rgba(255,255,255,0.1);}
.kili-stat:last-child{border-right:none;}
.kili-stat-val{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:800;color:var(--gold-light);}
.kili-stat-lbl{font-size:0.72rem;color:rgba(255,255,255,0.6);margin-top:2px;}
.kili-routes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:50px;}
.kili-route-card{background:rgba(255,255,255,0.07);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius-md);padding:20px;transition:var(--transition);cursor:pointer;}
.kili-route-card:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.25);transform:translateY(-4px);}
.kili-route-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;}
.kili-route-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:#fff;}
.kili-route-badge{padding:3px 10px;border-radius:20px;font-size:0.72rem;font-weight:700;}
.badge-easy{background:rgba(116,198,157,0.2);color:var(--green-light);}
.badge-moderate{background:rgba(201,168,76,0.2);color:var(--gold-light);}
.badge-hard{background:rgba(200,112,80,0.2);color:#ff9a80;}
.kili-route-desc{font-size:0.82rem;color:rgba(255,255,255,0.6);margin-bottom:12px;}
.kili-route-details{display:flex;gap:12px;flex-wrap:wrap;}
.kili-route-detail{display:flex;align-items:center;gap:5px;font-size:0.78rem;color:rgba(255,255,255,0.5);}
.kili-route-detail i{color:var(--green-light);font-size:0.75rem;}

/* =========================================
   THINGS TO DO
   ========================================= */
.todo-section{padding:100px 0;background:var(--off-white);}
.todo-cats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;}
.todo-cat{padding:9px 20px;border:1.5px solid var(--gray-100);border-radius:var(--radius-xl);font-size:0.85rem;font-weight:600;color:var(--gray-700);background:#fff;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:6px;}
.todo-cat i{font-size:0.9rem;color:var(--green-soft);}
.todo-cat.active,.todo-cat:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark);}
.todo-cat.active i,.todo-cat:hover i{color:#fff;}
.todo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.todo-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);}
.todo-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.todo-card-img{height:200px;position:relative;}
.todo-card-icon{position:absolute;top:14px;right:14px;width:40px;height:40px;background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;}
.todo-card-body{padding:18px;}
.todo-card-cat{font-size:0.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--green-soft);margin-bottom:6px;}
.todo-card-title{font-weight:700;font-size:1rem;color:var(--green-deep);margin-bottom:6px;}
.todo-card-desc{font-size:0.83rem;color:var(--gray-500);margin-bottom:12px;}
.todo-card-footer{display:flex;align-items:center;justify-content:space-between;}
.todo-from{font-size:0.8rem;color:var(--gray-500);}
.todo-from strong{color:var(--green-dark);}

/* =========================================
   TESTIMONIALS
   ========================================= */
.reviews-section{padding:100px 0;background:#fff;overflow:hidden;}
.reviews-track{display:flex;gap:24px;margin-top:48px;}
.review-card{min-width:360px;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);flex-shrink:0;}
.review-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;}
.reviewer-info{display:flex;gap:12px;align-items:center;}
.reviewer-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:#fff;flex-shrink:0;}
.reviewer-name{font-weight:700;font-size:0.95rem;color:var(--green-deep);}
.reviewer-meta{font-size:0.78rem;color:var(--gray-500);}
.review-quote{font-size:0.9rem;color:var(--gray-700);line-height:1.7;font-style:italic;}
.review-tour{margin-top:14px;padding-top:14px;border-top:1px solid var(--gray-100);font-size:0.78rem;color:var(--gray-500);}
.review-tour strong{color:var(--green-soft);}
.reviews-controls{display:flex;gap:10px;margin-top:32px;justify-content:center;}
.rev-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--gray-100);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);}
.rev-btn:hover{background:var(--green-dark);border-color:var(--green-dark);color:#fff;}

/* =========================================
   BLOG SECTION
   ========================================= */
.blog-section{padding:100px 0;background:var(--off-white);}
.blog-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;margin-top:48px;}
.blog-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);cursor:pointer;}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.blog-card-img{overflow:hidden;position:relative;}
.blog-card.featured .blog-card-img{height:280px;}
.blog-card:not(.featured) .blog-card-img{height:160px;}
.blog-card-img .img-placeholder{transition:var(--transition);}
.blog-card:hover .blog-card-img .img-placeholder{transform:scale(1.06);}
.blog-card-body{padding:20px;}
.blog-card-cat{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--green-soft);margin-bottom:8px;}
.blog-card-title{font-family:'Playfair Display',serif;font-weight:700;color:var(--green-deep);line-height:1.3;margin-bottom:8px;}
.blog-card.featured .blog-card-title{font-size:1.4rem;}
.blog-card:not(.featured) .blog-card-title{font-size:1rem;}
.blog-card-excerpt{font-size:0.83rem;color:var(--gray-500);margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.blog-card-meta{display:flex;align-items:center;gap:12px;font-size:0.78rem;color:var(--gray-500);}
.blog-card-meta i{color:var(--green-soft);}

/* =========================================
   CTA SECTION
   ========================================= */
.cta-section{padding:100px 24px;background:linear-gradient(135deg,var(--green-deep) 0%,var(--green-dark) 50%,var(--green-mid) 100%);position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,0.05) 1px,transparent 0);background-size:30px 30px;}
.cta-inner{position:relative;z-index:1;max-width:700px;margin:0 auto;text-align:center;}
.cta-section .section-label{justify-content:center;color:var(--green-light);}
.cta-section .section-title{color:#fff;font-size:clamp(2rem,5vw,3.5rem);}
.cta-section .section-title span{color:var(--gold-light);}
.cta-section .section-subtitle{color:rgba(255,255,255,0.7);margin:12px auto 36px;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.cta-btn-white{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:#fff;color:var(--green-dark);border-radius:var(--radius-xl);font-weight:700;font-size:1rem;transition:var(--transition);}
.cta-btn-white:hover{background:var(--green-pale);transform:translateY(-2px);}
.cta-btn-outline{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border:2px solid rgba(255,255,255,0.3);color:#fff;border-radius:var(--radius-xl);font-weight:600;font-size:1rem;transition:var(--transition);}
.cta-btn-outline:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6);}
.cta-orb{position:absolute;border-radius:50%;filter:blur(100px);}
.cta-orb-1{width:400px;height:400px;background:rgba(116,198,157,0.2);bottom:-200px;left:-100px;}
.cta-orb-2{width:300px;height:300px;background:rgba(201,168,76,0.15);top:-100px;right:-50px;}

/* =========================================
   PAGE HERO (shared)
   ========================================= */
.page-hero{padding:120px 0 80px;background:linear-gradient(135deg,var(--green-deep),var(--green-dark));color:#fff;text-align:center;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,0.04) 1px,transparent 0);background-size:28px 28px;}
.page-hero-content{position:relative;z-index:1;}
.page-hero .section-label{justify-content:center;color:var(--green-light);}
.page-hero .section-title{color:#fff;}
.page-hero .section-subtitle{margin:12px auto 0;color:rgba(255,255,255,0.7);}

/* =========================================
   ABOUT PAGE
   ========================================= */
.about-mission{padding:80px 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-img-wrap{border-radius:var(--radius-lg);overflow:hidden;height:480px;box-shadow:var(--shadow-lg);}
.about-text p{font-size:1rem;color:var(--gray-700);margin-bottom:16px;line-height:1.8;}
.about-values{padding:80px 0;background:var(--off-white);}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.value-card{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm);transition:var(--transition);}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--green-pale);}
.value-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--green-pale),var(--green-light));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.value-icon i{font-size:1.3rem;color:var(--green-dark);}
.value-card h3{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--green-deep);margin-bottom:8px;}
.value-card p{font-size:0.88rem;color:var(--gray-500);}
.team-section{padding:80px 0;}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px;}
.team-card{text-align:center;}
.team-avatar{width:90px;height:90px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#fff;border:3px solid var(--gray-100);}
.team-name{font-weight:700;color:var(--green-deep);margin-bottom:4px;}
.team-role{font-size:0.82rem;color:var(--green-soft);margin-bottom:8px;}
.team-social{display:flex;gap:8px;justify-content:center;}
.team-social a{width:30px;height:30px;border-radius:50%;background:var(--gray-50);display:flex;align-items:center;justify-content:center;font-size:0.8rem;color:var(--gray-500);transition:var(--transition);}
.team-social a:hover{background:var(--green-dark);color:#fff;}

/* =========================================
   CONTACT PAGE
   ========================================= */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;padding:80px 0;}
.contact-info{}
.contact-info h2{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;color:var(--green-deep);margin-bottom:16px;}
.contact-info p{font-size:0.95rem;color:var(--gray-700);margin-bottom:28px;}
.contact-items{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;}
.contact-item{display:flex;gap:14px;align-items:flex-start;}
.contact-item-icon{width:44px;height:44px;background:var(--green-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-item-icon i{color:var(--green-dark);}
.contact-item-label{font-size:0.78rem;color:var(--gray-500);margin-bottom:2px;}
.contact-item-val{font-weight:600;color:var(--green-deep);}
.contact-form-card{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-md);}
.contact-form-card h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--green-deep);margin-bottom:24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-label{font-size:0.82rem;font-weight:600;color:var(--gray-700);}
.form-input,.form-select,.form-textarea{padding:12px 14px;border:1.5px solid var(--gray-100);border-radius:var(--radius-sm);font-size:0.9rem;color:var(--text-dark);outline:none;transition:var(--transition);background:#fff;width:100%;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--green-soft);box-shadow:0 0 0 3px rgba(64,145,108,0.1);}
.form-textarea{resize:vertical;min-height:120px;}
.form-submit{width:100%;padding:14px;background:var(--green-dark);color:#fff;border-radius:var(--radius-sm);font-weight:700;font-size:0.95rem;transition:var(--transition);}
.form-submit:hover{background:var(--green-mid);box-shadow:0 6px 20px rgba(27,67,50,0.3);}

/* =========================================
   BOOTSTRAP MODAL FIXES
   ========================================= */
.modal{z-index:1060 !important;}
.modal-backdrop{z-index:1050 !important;}
.modal-dialog{z-index:1060 !important;}
.modal-content{z-index:1060 !important;}

/* =========================================
   TOUR DETAIL MODAL
   ========================================= */
.modal-overlay{position:fixed;inset:0;background:rgba(13,43,26,0.7);backdrop-filter:blur(8px);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px;overflow-y:auto;}
.modal-overlay.open{display:flex;}
.modal-box{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:900px;max-height:90vh;overflow-y:auto;animation:modalIn 0.3s ease;position:relative;z-index:10000;box-shadow:0 25px 50px rgba(0,0,0,0.5);}
@keyframes modalIn{from{opacity:0;transform:scale(0.95);}to{opacity:1;transform:scale(1);}}
.modal-header-img{height:300px;position:relative;overflow:hidden;}
.modal-header-img img{width:100%;height:100%;object-fit:cover;display:block;}
.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;cursor:pointer;z-index:10;transition:var(--transition);}
.modal-close:hover{background:rgba(255,255,255,0.3);}

/* Modal Image Fixes */
.modal-box img{max-width:100%;height:auto;display:block;}
.modal-body img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);}
.modal-gallery img{width:100%;height:200px;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);}
.modal-gallery img:hover{transform:scale(1.05);box-shadow:var(--shadow-md);}
.modal-body{padding:32px;}
.modal-title{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;color:var(--green-deep);margin-bottom:10px;}
.modal-meta{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:24px;}
.modal-meta-item{display:flex;align-items:center;gap:6px;font-size:0.85rem;color:var(--gray-500);}
.modal-meta-item i{color:var(--green-soft);}
.modal-tabs{display:flex;gap:4px;border-bottom:2px solid var(--gray-100);margin-bottom:24px;}
.modal-tab{padding:10px 20px;font-size:0.9rem;font-weight:600;color:var(--gray-500);cursor:pointer;position:relative;transition:var(--transition);}
.modal-tab.active{color:var(--green-dark);}
.modal-tab.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--green-dark);}
.modal-tab-content{display:none;}
.modal-tab-content.active{display:block;}
.itinerary-day{display:flex;gap:16px;margin-bottom:20px;}
.itinerary-day-num{width:40px;height:40px;background:var(--green-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--green-dark);font-size:0.85rem;flex-shrink:0;}
.itinerary-day-title{font-weight:700;color:var(--green-deep);margin-bottom:4px;}
.itinerary-day-desc{font-size:0.85rem;color:var(--gray-500);}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px;}
.price-option{border:1.5px solid var(--gray-100);border-radius:var(--radius-md);padding:20px;text-align:center;transition:var(--transition);cursor:pointer;}
.price-option.selected,.price-option:hover{border-color:var(--green-dark);background:var(--green-pale);}
.price-option-name{font-size:0.85rem;font-weight:700;color:var(--green-deep);margin-bottom:8px;}
.price-option-price{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:800;color:var(--green-dark);}
.price-option-per{font-size:0.78rem;color:var(--gray-500);}
.inclusions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:16px;}
.inclusion-item,.exclusion-item{display:flex;align-items:center;gap:8px;font-size:0.85rem;}
.inclusion-item i{color:var(--green-soft);}
.exclusion-item i{color:#e74c3c;}
.modal-footer{display:flex;gap:14px;padding-top:24px;border-top:1px solid var(--gray-100);}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:16px;}
.cal-day-name{text-align:center;font-size:0.75rem;font-weight:700;color:var(--gray-500);padding:6px 0;}
.cal-day{text-align:center;padding:8px;border-radius:8px;font-size:0.82rem;cursor:pointer;transition:var(--transition);}
.cal-day.available{background:var(--green-pale);color:var(--green-dark);font-weight:600;}
.cal-day.available:hover{background:var(--green-soft);color:#fff;}
.cal-day.unavailable{color:var(--gray-300);}
.cal-day.today{font-weight:800;border:2px solid var(--green-dark);}

/* =========================================
   FOOTER
   ========================================= */
footer{background:var(--green-deep);color:rgba(255,255,255,0.8);padding:80px 0 32px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:60px;}
.footer-brand .logo{color:#fff;font-size:1.4rem;margin-bottom:12px;}
.footer-logo-img{width:140px;height:45px;border-radius:8px;object-fit:contain;filter:brightness(0) invert(1);transition:var(--transition);}
.footer-brand .logo:hover .footer-logo-img{filter:brightness(0) invert(0.9);}
.footer-brand p{font-size:0.88rem;line-height:1.7;color:rgba(255,255,255,0.55);max-width:280px;margin-bottom:20px;}
.footer-socials{display:flex;gap:10px;}
.footer-social{width:38px;height:38px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.6);font-size:0.85rem;transition:var(--transition);cursor:pointer;}
.footer-social:hover{background:var(--green-mid);border-color:var(--green-mid);color:#fff;}
.footer-col h4{font-weight:700;font-size:0.9rem;color:#fff;margin-bottom:16px;letter-spacing:0.3px;}
.footer-links li{margin-bottom:8px;}
.footer-links a{font-size:0.85rem;color:rgba(255,255,255,0.5);transition:var(--transition);}
.footer-links a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:gap;gap:16px;}
.footer-copy{font-size:0.82rem;color:rgba(255,255,255,0.4);}
.footer-legal{display:flex;gap:20px;}
.footer-legal a{font-size:0.82rem;color:rgba(255,255,255,0.4);transition:var(--transition);}
.footer-legal a:hover{color:rgba(255,255,255,0.8);}
.footer-newsletter{margin-top:16px;}
.footer-newsletter p{font-size:0.82rem;color:rgba(255,255,255,0.5);margin-bottom:10px;}
.newsletter-form{display:flex;gap:8px;}
.newsletter-input{flex:1;padding:10px 14px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-sm);color:#fff;font-size:0.85rem;outline:none;transition:var(--transition);}
.newsletter-input::placeholder{color:rgba(255,255,255,0.35);}
.newsletter-input:focus{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.12);}
.newsletter-btn{padding:10px 16px;background:var(--gold);color:#fff;border-radius:var(--radius-sm);font-size:0.85rem;font-weight:600;transition:var(--transition);}
.newsletter-btn:hover{background:var(--gold-light);}

/* =========================================
   MAP EMBED PLACEHOLDER
   ========================================= */
.map-section{padding:60px 0 80px;background:#fff;}
.map-wrapper{border-radius:var(--radius-lg);overflow:hidden;height:420px;box-shadow:var(--shadow-md);background:linear-gradient(135deg,#e8f5e9 0%,#c8e6c9 100%);display:flex;align-items:center;justify-content:center;position:relative;}
.map-placeholder{text-align:center;z-index:1;}
.map-placeholder i{font-size:4rem;color:var(--green-soft);margin-bottom:12px;display:block;}
.map-placeholder h3{font-size:1.2rem;font-weight:700;color:var(--green-deep);margin-bottom:6px;}
.map-placeholder p{font-size:0.88rem;color:var(--gray-500);}
.map-pins{position:absolute;inset:0;}
.map-pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;}
.map-pin-dot{width:14px;height:14px;background:var(--green-dark);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,0.3);}
.map-pin:hover .map-pin-label{opacity:1;transform:translateY(-4px);}
.map-pin-label{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--green-deep);color:#fff;padding:4px 10px;border-radius:var(--radius-sm);font-size:0.72rem;white-space:nowrap;opacity:0;transition:var(--transition);}

/* =========================================
   PARTNERS
   ========================================= */
.partners-section{padding:60px 0;background:var(--off-white);border-top:1px solid var(--gray-100);}
.partners-label{text-align:center;font-size:0.8rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gray-300);margin-bottom:28px;}
.partners-track{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;}
.partner-item{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--gray-300);transition:var(--transition);cursor:default;}
.partner-item:hover{color:var(--green-soft);}

/* =========================================
   PACKAGES PAGE
   ========================================= */
.packages-filters{background:#fff;border-bottom:1px solid var(--gray-100);position:sticky;top:var(--nav-h);z-index:100;}
.pf-inner{display:flex;align-items:center;gap:16px;padding:16px 0;overflow-x:auto;}
.pf-group{display:flex;flex-direction:column;gap:4px;}
.pf-label{font-size:0.72rem;font-weight:700;letter-spacing:0.5px;color:var(--gray-500);text-transform:uppercase;}
.pf-select{padding:7px 12px;border:1.5px solid var(--gray-100);border-radius:var(--radius-sm);font-size:0.85rem;color:var(--text-dark);outline:none;cursor:pointer;background:#fff;min-width:130px;}
.pf-select:focus{border-color:var(--green-soft);}
.pf-divider{width:1px;height:40px;background:var(--gray-100);}
.pf-result-count{font-size:0.85rem;color:var(--gray-500);margin-left:auto;white-space:nowrap;}

/* =========================================
   PRICE CALCULATOR
   ========================================= */
.price-calc{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:20px;margin-top:20px;}
.price-calc h4{font-weight:700;color:var(--green-deep);margin-bottom:16px;}
.calc-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.calc-label{font-size:0.85rem;color:var(--gray-700);}
.calc-controls{display:flex;align-items:center;gap:10px;}
.calc-btn{width:28px;height:28px;border:1.5px solid var(--gray-100);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);font-size:0.9rem;}
.calc-btn:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark);}
.calc-count{font-weight:700;font-size:0.95rem;min-width:20px;text-align:center;}
.calc-total{border-top:1px solid var(--gray-100);margin-top:14px;padding-top:14px;display:flex;justify-content:space-between;align-items:center;}
.calc-total-label{font-weight:700;color:var(--green-deep);}
.calc-total-price{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:800;color:var(--green-dark);}

/* =========================================
   FAQ
   ========================================= */
.faq-section{padding:80px 0;}
.faq-list{max-width:760px;margin:40px auto 0;}
.faq-item{border:1px solid var(--gray-100);border-radius:var(--radius-md);margin-bottom:10px;overflow:hidden;transition:var(--transition);}
.faq-item.open{border-color:var(--green-pale);}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;cursor:pointer;font-weight:600;color:var(--green-deep);}
.faq-q i{transition:var(--transition);color:var(--green-soft);font-size:0.85rem;}
.faq-item.open .faq-q i{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.35s ease,padding 0.35s ease;}
.faq-item.open .faq-a{max-height:200px;padding:0 20px 18px;}
.faq-a p{font-size:0.88rem;color:var(--gray-500);line-height:1.7;}

/* =========================================
   RESPONSIVE
   ========================================= */
@media(max-width:1100px){
  .dest-grid{grid-template-columns:repeat(3,1fr);}
  .dest-card.featured{grid-column:span 1;grid-row:span 1;}
  .dest-card.featured .dest-card-img{height:280px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:900px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .hero-float-cards{display:none;}
  .search-fields{grid-template-columns:1fr 1fr;}
  .search-btn{grid-column:1/-1;}
  .why-grid,.kili-top,.about-grid,.contact-layout{grid-template-columns:1fr;gap:40px;}
  .kili-routes{grid-template-columns:1fr 1fr;}
  .grid-2,.grid-3,.grid-4,.todo-grid,.values-grid,.pricing-grid{grid-template-columns:1fr 1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .dest-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .hero-title{font-size:2.4rem;}
  .hero-actions{flex-direction:column;}
  .hero-actions a{text-align:center;justify-content:center;}
  .search-fields{grid-template-columns:1fr;}
  .search-btn{grid-column:auto;}
  .dest-grid{grid-template-columns:1fr;}
  .grid-2,.grid-3,.grid-4,.todo-grid,.values-grid,.pricing-grid,.inclusions,.kili-routes{grid-template-columns:1fr;}
  .section-header{flex-direction:column;align-items:flex-start;gap:16px;}
  .form-row{grid-template-columns:1fr;}
  .modal-tabs{overflow-x:auto;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .partners-track{gap:24px;}
  .hero-stats{gap:24px;}
  .kili-stats{position:static;transform:none;width:100%;margin-top:20px;}
}

/* =========================================
   LOADING ANIMATION
   ========================================= */
.page-loader{position:fixed;inset:0;background:var(--green-deep);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.5s ease,visibility 0.5s ease;}
.page-loader.loaded{opacity:0;visibility:hidden;}
.loader-inner{text-align:center;color:#fff;}
.loader-logo{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:800;margin-bottom:20px;}
.loader-logo span{color:var(--gold-light);}
.loader-bar{width:200px;height:3px;background:rgba(255,255,255,0.15);border-radius:2px;overflow:hidden;margin:0 auto;}
.loader-fill{height:100%;background:linear-gradient(to right,var(--green-light),var(--gold-light));border-radius:2px;animation:loadFill 1.8s ease forwards;}
@keyframes loadFill{from{width:0;}to{width:100%;}}
/* Notification toast */
.toast{position:fixed;bottom:30px;right:30px;z-index:3000;background:var(--green-dark);color:#fff;padding:14px 20px;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);font-size:0.88rem;display:flex;align-items:center;gap:10px;transform:translateY(20px);opacity:0;transition:var(--transition);}
.toast.show{transform:translateY(0);opacity:1;}
.toast i{color:var(--green-light);}
