/* ─── Tour Cards ──────────────────────────────────────────────── */
.tours-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.tour-card { background:var(--bg-surface); border-radius:calc(var(--radius-lg) + 4px); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--border-color); transition:all var(--transition-normal); position:relative; }
.tour-card:hover { transform:translateY(-10px) scale(1.02); box-shadow:var(--shadow-xl); z-index: 10; border-color: var(--primary-200); }
.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.1); }
.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; box-shadow: var(--shadow-md); letter-spacing: 0.5px; }
.tour-card-image .tour-price { position:absolute; bottom:16px; right:16px; padding:8px 16px; background:rgba(0,0,0,0.6); backdrop-filter:blur(12px); color:var(--text-inverse); font-family:'Outfit',sans-serif; font-size:18px; font-weight:700; border-radius:var(--radius-md); border: 1px solid rgba(255,255,255,0.2); }
.tour-card-image .tour-price small { font-size:12px; font-weight:400; opacity:0.8; }
.tour-card-body { padding:28px 24px; }
.tour-card-location { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--primary-600); font-weight:600; margin-bottom:12px; letter-spacing: 0.5px; text-transform: uppercase; }
.tour-card-title { font-size:22px; font-weight:700; margin-bottom:12px; color:var(--text-primary); transition:color var(--transition-fast); font-family: 'Outfit', sans-serif; line-height: 1.3; }
.tour-card:hover .tour-card-title { color:var(--primary-600); }
.tour-card-desc { font-size:15px; color:var(--text-secondary); line-height:1.7; margin-bottom:24px; 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 dashed var(--border-color); }
.tour-card-meta span { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text-secondary); font-weight: 500; }
.tour-card-meta span i { color:var(--primary-500); font-size: 14px; }

/* ─── Features Grid ──────────────────────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.feature-card { background:var(--bg-surface); border-radius:calc(var(--radius-lg) + 4px); padding:40px 32px; text-align:center; border:1px solid var(--border-color); transition:all var(--transition-normal); position:relative; overflow:hidden; z-index: 1; box-shadow: var(--shadow-sm); }
.feature-card::before { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, transparent, var(--primary-50)); opacity:0; transition:opacity var(--transition-normal); z-index: -1; }
.feature-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:6px; background:var(--gradient-primary); transform:scaleX(0); transition:transform var(--transition-normal); }
.feature-card:hover { transform:translateY(-10px) scale(1.02); box-shadow:var(--shadow-xl); border-color: var(--primary-200); }
.feature-card:hover::before { opacity: 1; }
.feature-card:hover::after { transform:scaleX(1); }
.feature-icon { width:80px; height:80px; margin:0 auto 24px; display:flex; align-items:center; justify-content:center; background:var(--primary-50); border-radius:var(--radius-full); font-size:32px; color:var(--primary-600); transition:all var(--transition-normal); border: 1px solid var(--primary-100); }
.feature-card:hover .feature-icon { transform:scale(1.15) rotate(5deg); background: var(--gradient-primary); color: white; border-color: transparent; box-shadow: var(--shadow-glow); }
.feature-card h3 { font-size:20px; font-family: 'Outfit', sans-serif; margin-bottom:12px; font-weight:700; color: var(--text-primary); }
.feature-card p { font-size:15px; color:var(--text-secondary); line-height:1.7; }


/* ─── 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); }
