/*
Theme Name: P Adventures V15 Ultra Master
Description: Ultra-Elegant View-Peru style, Updated Itinerary Images, Branded Map, Full SEO.
Version: 15.0
*/
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400&family=Inter:wght@300;400;500;600;700;900&display=swap');

:root { 
    --forest: #1b4332; 
    --sand: #f9f7f2; 
    --gold: #c9a85c; 
    --white: #ffffff; 
    --text: #333333;
    --light-grey: #f0f0f0;
    --dark-grey: #1a1a1a;
}

body { margin: 0; font-family: 'Inter', sans-serif; background: var(--white); color: var(--text); line-height: 1.8; -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4 { font-family: 'Playfair Display', serif; color: var(--forest); font-weight: 700; margin: 0; }
p { margin-top: 0; margin-bottom: 1.5rem; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

/* Header - Refined & Minimalist */
header { background: var(--white); padding: 30px 0; position: sticky; top: 0; z-index: 1000; box-shadow: 0 1px 0 rgba(0,0,0,0.05); }
.header-flex { display: flex; justify-content: space-between; align-items: center; }
.logo img { height: 50px; width: auto; }
.nav-links a { margin-left: 40px; text-decoration: none; font-weight: 600; color: var(--forest); text-transform: uppercase; font-size: 0.75rem; letter-spacing: 2px; transition: color 0.3s; }
.nav-links a:hover { color: var(--gold); }

/* Hero - Cinematic */
.hero { 
    background: linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.3)), url('assets/images/hero.jpg'); 
    background-size: cover; background-position: center; height: 95vh; 
    display: flex; align-items: center; justify-content: center; text-align: center; color: var(--white); 
}
.hero-content { max-width: 900px; }
.hero h1 { color: var(--white); font-size: 6rem; text-transform: uppercase; line-height: 0.85; margin-bottom: 20px; letter-spacing: -3px; font-weight: 900; }
.hero p { font-size: 1.1rem; letter-spacing: 6px; text-transform: uppercase; font-weight: 400; opacity: 0.8; margin-bottom: 0; }

/* Section Titles - View Peru Style */
.section-header { text-align: center; margin-bottom: 100px; }
.section-header .pre-title { display: block; text-transform: uppercase; letter-spacing: 5px; font-size: 0.8rem; color: var(--gold); font-weight: 700; margin-bottom: 15px; }
.section-header h2 { font-size: 4rem; line-height: 1; }

/* Itinerary - Elegant Alternating Layout */
.itinerary-section { padding: 150px 0; }
.itinerary-row { display: flex; align-items: center; gap: 100px; margin-bottom: 150px; }
.itinerary-row:nth-child(even) { flex-direction: row-reverse; }
.itinerary-img { flex: 1.4; position: relative; }
.itinerary-img img { width: 100%; height: 600px; object-fit: cover; box-shadow: 40px 40px 0px var(--sand); transition: transform 0.5s; }
.itinerary-img:hover img { transform: scale(1.02); }
.itinerary-text { flex: 1; }
.day-tag { font-family: 'Inter'; font-weight: 900; color: var(--gold); font-size: 0.85rem; text-transform: uppercase; letter-spacing: 4px; margin-bottom: 20px; display: block; }
.itinerary-text h3 { font-size: 3.5rem; line-height: 1; margin-bottom: 30px; }
.itinerary-text p { font-size: 1.1rem; color: #555; }

/* Map Section - Clean & Informative */
.map-section { padding: 150px 0; background: var(--sand); }
.map-content { max-width: 900px; margin: 0 auto; text-align: center; }
.map-content p { font-size: 1.2rem; color: #666; margin-bottom: 60px; }
.map-wrapper { background: var(--white); padding: 30px; box-shadow: 0 30px 60px rgba(0,0,0,0.08); border-radius: 2px; }
.map-wrapper img { width: 100%; display: block; }

/* Summary Section - Dark & Bold */
.summary-section { padding: 150px 0; background: var(--forest); color: var(--white); text-align: center; }
.summary-section h2 { color: var(--white); font-size: 4rem; margin-bottom: 60px; }
.summary-box { max-width: 1100px; margin: 0 auto; border: 1px solid rgba(255,255,255,0.15); padding: 20px; background: rgba(0,0,0,0.1); }
.summary-box img { width: 100%; display: block; }
.summary-caption { margin-top: 50px; font-size: 1.2rem; max-width: 800px; margin-left: auto; margin-right: auto; opacity: 0.7; font-weight: 300; }

/* Offers - Minimalist Cards */
.offers-section { padding: 150px 0; }
.offers-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 40px; }
.offer-card { border: 1px solid var(--light-grey); padding: 80px 50px; text-align: center; transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1); }
.offer-card:hover { border-color: var(--gold); box-shadow: 0 40px 80px rgba(0,0,0,0.05); transform: translateY(-15px); }
.offer-card h3 { font-size: 2.5rem; margin-bottom: 15px; }
.offer-card .price { font-family: 'Inter'; font-weight: 900; color: var(--gold); font-size: 2rem; display: block; margin-bottom: 40px; }
.btn-action { background: var(--forest); color: var(--white); padding: 20px 45px; text-decoration: none; font-weight: 700; text-transform: uppercase; font-size: 0.85rem; letter-spacing: 3px; display: inline-block; transition: background 0.3s; }
.btn-action:hover { background: var(--gold); }

.wa-float { position: fixed; bottom: 50px; right: 50px; background: #25d366; width: 70px; height: 70px; border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index: 2000; box-shadow: 0 15px 35px rgba(37,211,102,0.4); transition: transform 0.3s; }
.wa-float:hover { transform: scale(1.1); }
.wa-float img { width: 35px; }

@media (max-width: 1024px) {
    .hero h1 { font-size: 4rem; }
    .itinerary-row, .itinerary-row:nth-child(even) { flex-direction: column; gap: 50px; }
    .itinerary-img img { height: 450px; box-shadow: 20px 20px 0px var(--sand); }
    .section-header h2 { font-size: 3rem; }
}
