/* ─── Tour Cards ──────────────────────────────────────────────── */
.tours-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.tour-card { background:var(--bg-surface); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-card); border:1px solid var(--border-color); transition:all var(--transition-normal); }
.tour-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); }
.tour-card-image { position:relative; height:240px; overflow:hidden; }
.tour-card-image img { width:100%; height:100%; object-fit:cover; transition:transform var(--transition-slow); }
.tour-card:hover .tour-card-image img { transform:scale(1.08); }
.tour-card-image .tour-badge { position:absolute; top:16px; left:16px; padding:6px 14px; background:var(--gradient-primary); color:var(--text-inverse); font-size:12px; font-weight:600; border-radius:var(--radius-full); text-transform:uppercase; }
.tour-card-image .tour-price { position:absolute; bottom:16px; right:16px; padding:8px 16px; background:rgba(0,0,0,0.7); backdrop-filter:blur(10px); color:var(--text-inverse); font-family:'Poppins',sans-serif; font-size:18px; font-weight:700; border-radius:var(--radius-sm); }
.tour-card-image .tour-price small { font-size:12px; font-weight:400; opacity:0.8; }
.tour-card-body { padding:24px; }
.tour-card-location { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--primary-500); font-weight:500; margin-bottom:8px; }
.tour-card-title { font-size:20px; font-weight:700; margin-bottom:10px; color:var(--text-primary); transition:color var(--transition-fast); }
.tour-card:hover .tour-card-title { color:var(--primary-600); }
.tour-card-desc { font-size:14px; color:var(--text-secondary); line-height:1.6; margin-bottom:20px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.tour-card-meta { display:flex; justify-content:space-between; align-items:center; padding-top:16px; border-top:1px solid var(--border-color); }
.tour-card-meta span { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text-tertiary); }
.tour-card-meta span i { color:var(--primary-400); }

/* ─── Features Grid ──────────────────────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.feature-card { background:var(--bg-surface); border-radius:var(--radius-lg); padding:36px 28px; text-align:center; border:1px solid var(--border-color); transition:all var(--transition-normal); position:relative; overflow:hidden; }
.feature-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:4px; background:var(--gradient-primary); transform:scaleX(0); transition:transform var(--transition-normal); }
.feature-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-lg); }
.feature-card:hover::after { transform:scaleX(1); }
.feature-icon { width:72px; height:72px; margin:0 auto 20px; display:flex; align-items:center; justify-content:center; background:var(--gradient-primary); border-radius:var(--radius-lg); font-size:28px; color:var(--text-inverse); transition:transform var(--transition-normal); }
.feature-card:hover .feature-icon { transform:scale(1.1) rotate(-5deg); }
.feature-card h3 { font-size:18px; margin-bottom:10px; font-weight:700; }
.feature-card p { font-size:14px; color:var(--text-secondary); line-height:1.6; }

/* ─── Gallery ────────────────────────────────────────────────── */
.gallery-filters { display:flex; justify-content:center; gap:8px; margin-bottom:40px; flex-wrap:wrap; }
.gallery-filter-btn { padding:10px 24px; background:var(--bg-surface-2); border:1px solid var(--border-color); border-radius:var(--radius-full); font-size:14px; font-weight:500; color:var(--text-secondary); cursor:pointer; transition:all var(--transition-fast); }
.gallery-filter-btn:hover, .gallery-filter-btn.active { background:var(--gradient-primary); color:var(--text-inverse); border-color:transparent; }
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.gallery-item { position:relative; border-radius:var(--radius-md); overflow:hidden; cursor:pointer; aspect-ratio:1; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform var(--transition-slow); }
.gallery-item:hover img { transform:scale(1.1); }
.gallery-item .gallery-overlay { position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.7) 100%); display:flex; align-items:flex-end; padding:20px; opacity:0; transition:opacity var(--transition-normal); }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay span { color:var(--text-inverse); font-weight:600; font-size:15px; }

/* ─── Testimonials ───────────────────────────────────────────── */
.testimonials-section { background:var(--bg-surface-2); }
.testimonials-slider { position:relative; max-width:900px; margin:0 auto; overflow:hidden; }
.testimonials-track { display:flex; transition:transform var(--transition-slow); }
.testimonial-card { min-width:100%; padding:0 20px; }
.testimonial-content { background:var(--bg-surface); border-radius:var(--radius-xl); padding:48px; text-align:center; box-shadow:var(--shadow-md); position:relative; }
.testimonial-content::before { content:'"'; position:absolute; top:-10px; left:40px; font-size:120px; font-family:'Poppins',sans-serif; color:var(--primary-100); line-height:1; z-index:0; }
.testimonial-stars { display:flex; justify-content:center; gap:4px; margin-bottom:20px; color:#fbbf24; font-size:18px; }
.testimonial-text { font-size:18px; line-height:1.8; color:var(--text-secondary); margin-bottom:28px; position:relative; z-index:1; font-style:italic; }
.testimonial-author { display:flex; align-items:center; justify-content:center; gap:16px; }
.testimonial-avatar { width:56px; height:56px; border-radius:50%; object-fit:cover; border:3px solid var(--primary-200); }
.testimonial-info h4 { font-size:16px; font-weight:700; margin-bottom:2px; }
.testimonial-info span { font-size:13px; color:var(--text-tertiary); }
.testimonials-dots { display:flex; justify-content:center; gap:8px; margin-top:32px; }
.testimonials-dot { width:10px; height:10px; border-radius:50%; background:var(--border-color); cursor:pointer; transition:all var(--transition-fast); }
.testimonials-dot.active { background:var(--primary-500); width:30px; border-radius:var(--radius-full); }

/* ─── CTA Section ────────────────────────────────────────────── */
.cta-section { background:var(--gradient-hero); position:relative; overflow:hidden; padding:80px 0; }
.cta-section .cta-particles { position:absolute; inset:0; z-index:0; }
.cta-content { position:relative; z-index:2; text-align:center; color:var(--text-inverse); }
.cta-content h2 { font-size:42px; font-weight:800; margin-bottom:16px; color:var(--text-inverse); }
.cta-content p { font-size:18px; opacity:0.9; margin-bottom:32px; max-width:500px; margin-left:auto; margin-right:auto; }
.cta-content .btn { background:#fff; color:var(--primary-700); font-weight:700; }
.cta-content .btn:hover { background:#f0f9ff; transform:translateY(-2px); box-shadow:0 8px 30px rgba(255,255,255,0.3); }

/* ─── Footer ─────────────────────────────────────────────────── */
.footer { background:#0f172a; color:#94a3b8; padding:80px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { font-size:14px; line-height:1.7; margin-bottom:24px; color:#94a3b8; }
.footer-brand .logo { margin-bottom:16px; }
.footer-brand .logo .brand-name { color:#fff; -webkit-text-fill-color:#fff; background:none; }
.footer-social { display:flex; gap:12px; }
.footer-social a { width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,0.08); border-radius:var(--radius-sm); color:#94a3b8; font-size:16px; transition:all var(--transition-fast); }
.footer-social a:hover { background:var(--gradient-primary); color:#fff; transform:translateY(-3px); }
.footer-col h4 { font-size:16px; font-weight:700; color:#fff; margin-bottom:20px; position:relative; padding-bottom:12px; }
.footer-col h4::after { content:''; position:absolute; bottom:0; left:0; width:30px; height:3px; background:var(--gradient-primary); border-radius:2px; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:#94a3b8; font-size:14px; transition:all var(--transition-fast); display:flex; align-items:center; gap:8px; }
.footer-col ul li a:hover { color:var(--primary-400); transform:translateX(4px); }
.footer-contact li { display:flex; align-items:flex-start; gap:12px; margin-bottom:16px!important; }
.footer-contact li i { color:var(--primary-400); margin-top:3px; font-size:16px; }
.footer-contact li span { font-size:14px; line-height:1.5; }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding:24px 0; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-bottom p { font-size:13px; color:#64748b; }
.footer-bottom a { color:var(--primary-400); }

/* ─── WhatsApp Float ─────────────────────────────────────────── */
.whatsapp-float { position:fixed; bottom:30px; right:30px; width:60px; height:60px; background:#25d366; color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:28px; z-index:999; box-shadow:0 4px 20px rgba(37,211,102,0.4); transition:all var(--transition-normal); animation:whatsappPulse 2s infinite; }
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 8px 30px rgba(37,211,102,0.5); color:#fff; }
@keyframes whatsappPulse { 0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4)} 50%{box-shadow:0 4px 30px rgba(37,211,102,0.6),0 0 0 8px rgba(37,211,102,0.1)} }

/* ─── Scroll Top ─────────────────────────────────────────────── */
.scroll-top { position:fixed; bottom:100px; right:30px; width:48px; height:48px; background:var(--gradient-primary); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; z-index:998; opacity:0; visibility:hidden; transform:translateY(20px); transition:all var(--transition-normal); box-shadow:var(--shadow-lg); cursor:pointer; }
.scroll-top.visible { opacity:1; visibility:visible; transform:translateY(0); }
.scroll-top:hover { transform:translateY(-3px); box-shadow:var(--shadow-glow); }
