/* === MARVIA TRAVEL — DESIGN SYSTEM === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Poppins:wght@500;600;700;800&display=swap');
:root{--color-primary:#0057b8;--color-primary-dark:#003d82;--color-primary-light:#3380cc;--color-accent:#ffd60a;--color-accent-dark:#e6c000;--color-turquoise:#00b4d8;--color-turquoise-dark:#0096b7;--color-turquoise-light:#48cae4;--color-dark:#0a1628;--color-dark-blue:#0d1f3c;--color-gray-900:#1a2332;--color-gray-800:#2d3748;--color-gray-700:#4a5568;--color-gray-600:#718096;--color-gray-400:#a0aec0;--color-gray-300:#cbd5e0;--color-gray-200:#e2e8f0;--color-gray-100:#f7fafc;--color-white:#fff;--color-success:#38a169;--color-error:#e53e3e;--gradient-hero:linear-gradient(135deg,#0a1628 0%,#0d1f3c 30%,#003d82 70%,#00b4d8 100%);--gradient-turquoise:linear-gradient(135deg,#00b4d8,#0077b6);--gradient-accent:linear-gradient(135deg,#ffd60a,#ffaa00);--gradient-dark:linear-gradient(180deg,#001248 0%,#0044cc 100%);--font-heading:'Poppins',sans-serif;--font-body:'Inter',sans-serif;--section-padding:100px 0;--container-width:1200px;--container-padding:0 24px;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 2px 8px rgba(0,0,0,.1);--shadow-md:0 4px 16px rgba(0,0,0,.15);--shadow-lg:0 8px 32px rgba(0,0,0,.2);--shadow-xl:0 16px 48px rgba(0,0,0,.3);--transition-fast:.2s ease;--transition-normal:.3s ease;--transition-slow:.5s ease;--transition-spring:.4s cubic-bezier(.175,.885,.32,1.275)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--color-gray-800);background:var(--color-white);overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:var(--font-body);border:none;outline:none}
input,textarea,select{font-family:var(--font-body);outline:none}
ul{list-style:none}
.container{max-width:var(--container-width);margin:0 auto;padding:var(--container-padding)}
.section-title{text-align:center;margin-bottom:60px}
.section-title .subtitle{display:inline-block;font-family:var(--font-heading);font-size:14px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--color-turquoise);margin-bottom:12px}
.section-title h2{font-size:clamp(28px,4vw,42px);color:var(--color-dark);margin-bottom:16px}
.section-title p{font-size:17px;color:var(--color-gray-600);max-width:600px;margin:0 auto}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;font-size:15px;font-weight:600;border-radius:var(--radius-full);transition:all var(--transition-normal);letter-spacing:.3px}
.btn-primary{background:var(--gradient-turquoise);color:var(--color-white);box-shadow:0 4px 15px rgba(0,180,216,.4)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,180,216,.5)}
.btn-accent{background:var(--gradient-accent);color:var(--color-dark);box-shadow:0 4px 15px rgba(255,214,10,.4)}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(255,214,10,.5)}
.btn-outline{background:transparent;color:var(--color-white);border:2px solid rgba(255,255,255,.4)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7);transform:translateY(-2px)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-turquoise);border-radius:4px}
@media(max-width:768px){:root{--section-padding:60px 0}.section-title{margin-bottom:40px}.section-title h2{font-size:28px}.btn{padding:12px 24px;font-size:14px}}

/* === NAVBAR === */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:all var(--transition-normal)}
.navbar.scrolled{background:rgba(10,22,40,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:10px 0;box-shadow:0 4px 30px rgba(0,0,0,.3)}
.navbar-container{display:flex;align-items:center;justify-content:space-between}
.navbar-logo img{height:48px;width:auto;transition:height var(--transition-normal)}
.navbar.scrolled .navbar-logo img{height:38px}
.navbar-menu{display:flex;align-items:center;gap:8px}
.navbar-menu li a{padding:8px 16px;font-size:14px;font-weight:500;color:rgba(255,255,255,.85);border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer}
.navbar-menu li a:hover{color:var(--color-white);background:rgba(255,255,255,.1)}
.navbar-cta{padding:10px 24px!important;font-size:13px!important;font-weight:600!important;color:var(--color-dark)!important;background:var(--gradient-accent)!important;border-radius:var(--radius-full)!important}
.navbar-cta:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(255,214,10,.4)}
.navbar-cta svg{flex-shrink:0}
.navbar-toggle{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer;z-index:1001}
.navbar-toggle span{display:block;width:24px;height:2px;background:var(--color-white);border-radius:2px;transition:all var(--transition-normal)}
.navbar-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.navbar-toggle.active span:nth-child(2){opacity:0}
.navbar-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
@media(max-width:900px){.navbar-toggle{display:flex}.navbar-menu{position:fixed;top:0;right:-100%;width:280px;height:100vh;flex-direction:column;align-items:flex-start;padding:100px 32px 40px;background:rgba(10,22,40,.98);backdrop-filter:blur(30px);transition:right var(--transition-normal);gap:4px}.navbar-menu.open{right:0}.navbar-menu li{width:100%}.navbar-menu li a{display:block;padding:14px 16px;font-size:16px;border-radius:var(--radius-md)}.navbar-cta{margin-top:16px;text-align:center}}

/* === HERO === */
.hero{position:relative;min-height:calc(100vh - 100px);display:flex;align-items:center;overflow:hidden;padding-top:80px}
.hero-bg-image{position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1510097467424-192d713fd8b2?w=1920&q=80');background-size:cover;background-position:center;z-index:0}
.hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,18,72,.95) 0%,rgba(0,40,130,.88) 40%,rgba(0,68,204,.82) 70%,rgba(0,85,255,.75) 100%);z-index:1}
.hero-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:2}
.shape{position:absolute;border-radius:50%;opacity:.08}
.shape-1{width:600px;height:600px;background:var(--color-turquoise);top:-200px;right:-150px;animation:float 8s ease-in-out infinite}
.shape-2{width:400px;height:400px;background:var(--color-accent);bottom:-100px;left:-100px;animation:float 6s ease-in-out infinite reverse}
.shape-3{width:250px;height:250px;background:var(--color-turquoise-light);top:40%;left:55%;animation:float 10s ease-in-out infinite}
.hero-content{position:relative;z-index:3;width:100%;display:flex;align-items:center;justify-content:space-between;gap:40px}
.hero-left{flex:1;max-width:600px}
.hero-text{animation:fadeInUp .8s ease}
.hero-badge{display:inline-block;padding:8px 20px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);color:var(--color-turquoise-light);font-size:14px;font-weight:500;margin-bottom:24px;backdrop-filter:blur(10px)}
.hero-text h1{font-size:clamp(36px,5vw,56px);color:var(--color-white);font-weight:800;line-height:1.1;margin-bottom:20px}
.hero-highlight{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-text p{font-size:18px;color:rgba(255,255,255,.8);line-height:1.7;margin-bottom:36px;max-width:520px;text-shadow:0 1px 3px rgba(0,0,0,.3)}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;align-items:center;gap:32px;margin-top:48px;padding:28px 36px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);backdrop-filter:blur(15px);max-width:fit-content;animation:fadeInUp .8s ease .3s both}
.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}
.stat-number{font-family:var(--font-heading);font-size:28px;font-weight:800;color:var(--color-accent)}
.stat-label{font-size:13px;color:rgba(255,255,255,.6);font-weight:400}
.stat-divider{width:1px;height:40px;background:rgba(255,255,255,.15)}
.hero-image{position:absolute;right:0;bottom:0;top:0;width:55%;display:flex;align-items:flex-end;justify-content:flex-end;z-index:3;pointer-events:none;animation:fadeInUp 1s ease .2s both}
.hero-image-glow{display:none}
.hero-image img{position:relative;z-index:1;height:100%;width:auto;max-width:110%;object-fit:contain;object-position:bottom right;filter:drop-shadow(0 0 20px rgba(255,255,255,.15)) drop-shadow(0 10px 30px rgba(0,0,0,.3))}
.hero-wave{position:absolute;bottom:-2px;left:0;right:0;z-index:4}
.hero-wave svg{display:block;width:100%;height:80px}
@media(max-width:1024px){.hero-image{width:45%}}
@media(max-width:768px){.hero{min-height:auto;padding:120px 0 100px}.hero-content{flex-direction:column;text-align:center}.hero-left{max-width:100%}.hero-text h1{font-size:32px}.hero-text p{font-size:16px;max-width:100%}.hero-stats{flex-direction:column;gap:16px;padding:20px 24px;width:100%;max-width:100%}.stat-divider{width:60px;height:1px}.hero-buttons{flex-direction:column}.hero-buttons .btn{text-align:center;justify-content:center}.hero-image{position:relative;width:100%;top:auto;right:auto;bottom:auto;height:350px;margin-top:30px}}

/* === PROMOTIONS === */
.promotions{padding:var(--section-padding);background:var(--color-white)}
.promos-carousel-wrapper{position:relative;display:flex;align-items:center;gap:16px}
.promos-track-container{overflow:hidden;flex:1;border-radius:var(--radius-lg)}
.promos-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.promo-slide{flex-shrink:0;animation:fadeInUp .6s ease both}
.carousel-arrow{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:2px solid var(--color-primary);background:var(--color-white);color:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md);z-index:2}
.carousel-arrow:hover:not(.disabled){background:var(--color-primary);color:var(--color-white);transform:scale(1.1);box-shadow:var(--shadow-lg)}
.carousel-arrow.disabled{opacity:.3;cursor:not-allowed}
.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:32px}
.carousel-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--color-primary);background:transparent;cursor:pointer;transition:all var(--transition-fast);padding:0}
.carousel-dot.active{background:var(--color-primary);transform:scale(1.2)}
.carousel-dot:hover:not(.active){background:rgba(0,61,130,.3)}
.promo-card{background:var(--color-white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--transition-normal);height:100%;display:flex;flex-direction:column}
.promo-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}
.promo-img-wrapper{position:relative;height:240px;overflow:hidden}
.promo-img-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.promo-card:hover .promo-img-wrapper img{transform:scale(1.08)}
.promo-stars{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:2px;padding:6px 12px;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:var(--radius-full);box-shadow:var(--shadow-md)}
.promo-body{padding:24px;display:flex;flex-direction:column;flex:1}
.promo-location{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-turquoise);font-weight:500;margin-bottom:8px}
.promo-body h3{font-size:20px;color:var(--color-dark);margin-bottom:10px}
.promo-body p{font-size:14px;color:var(--color-gray-600);line-height:1.6;margin-bottom:20px;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.promo-cta{width:100%;padding:12px 20px;font-size:14px;margin-top:auto}
@media(max-width:1024px){.carousel-arrow{width:40px;height:40px}}
@media(max-width:640px){.promos-carousel-wrapper{gap:8px}.carousel-arrow{width:36px;height:36px}.carousel-arrow svg{width:16px;height:16px}}
/* === DESTINATIONS === */
.destinations{position:relative;padding:var(--section-padding);background:var(--gradient-dark);overflow:hidden}
.destinations-bg{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(0,180,216,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,214,10,.06) 0%,transparent 50%)}
.destinations-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;position:relative}
.dest-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;height:380px;cursor:pointer;animation:fadeInUp .6s ease both}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.dest-card:hover img{transform:scale(1.1)}
.dest-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.9) 0%,rgba(10,22,40,.3) 40%,transparent 70%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px;transition:all var(--transition-normal)}
.dest-card:hover .dest-overlay{background:linear-gradient(to top,rgba(10,22,40,.95) 0%,rgba(10,22,40,.5) 50%,rgba(10,22,40,.2) 100%)}
.dest-overlay h3{font-size:24px;color:var(--color-white);margin-bottom:8px}
.dest-overlay p{font-size:14px;color:rgba(255,255,255,.75);line-height:1.5;margin-bottom:0;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;max-height:0;opacity:0;transition:all var(--transition-normal)}
.dest-card:hover .dest-overlay p{max-height:100px;opacity:1}
@media(max-width:1024px){.destinations-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.destinations-grid{grid-template-columns:1fr}.dest-card{height:300px}}

/* === BENEFITS === */
.benefits{padding:var(--section-padding);background:var(--color-white)}
.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.benefit-card{text-align:center;padding:40px 24px;border-radius:var(--radius-lg);background:var(--color-gray-100);border:1px solid transparent;transition:all var(--transition-normal);animation:fadeInUp .6s ease both}
.benefit-card:hover{background:var(--color-white);border-color:var(--color-turquoise-light);box-shadow:var(--shadow-md);transform:translateY(-6px)}
.benefit-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-lg);background:var(--gradient-turquoise);color:var(--color-white);margin-bottom:20px;transition:transform var(--transition-spring)}
.benefit-card:hover .benefit-icon{transform:scale(1.1) rotate(-5deg)}
.benefit-card h3{font-size:17px;color:var(--color-dark);margin-bottom:10px}
.benefit-card p{font-size:14px;color:var(--color-gray-600);line-height:1.6}
@media(max-width:1024px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.benefits-grid{grid-template-columns:1fr;gap:16px}.benefit-card{padding:28px 20px}}

/* === RNT BADGE === */
.rnt-section{padding:var(--section-padding);background:linear-gradient(135deg,var(--color-dark) 0%,#0d1f3c 100%);position:relative;overflow:hidden}
.rnt-section::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(0,180,216,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.rnt-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.rnt-info h2{color:var(--color-white);font-size:clamp(28px,3.5vw,40px);margin-bottom:20px}
.rnt-info p{color:rgba(255,255,255,.75);font-size:16px;line-height:1.7;margin-bottom:32px}
.rnt-features{display:flex;flex-direction:column;gap:16px}
.rnt-feature{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);transition:all var(--transition-normal)}
.rnt-feature:hover{background:rgba(255,255,255,.08);border-color:rgba(0,180,216,.3)}
.rnt-feature span{color:rgba(255,255,255,.85);font-size:14px;font-weight:500}
.rnt-image-wrapper{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1);transition:transform var(--transition-normal)}
.rnt-image-wrapper:hover{transform:scale(1.02)}
.rnt-image-wrapper img{width:100%;height:auto;display:block}
@media(max-width:768px){.rnt-grid{grid-template-columns:1fr;gap:32px}.rnt-info{text-align:center}.rnt-features{align-items:center}.rnt-feature{width:100%;justify-content:center}}

/* === TESTIMONIALS === */
.testimonials{position:relative;padding:var(--section-padding);background:var(--gradient-dark);overflow:hidden}
.testimonials-bg{position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(0,180,216,.06) 0%,transparent 50%),radial-gradient(circle at 30% 70%,rgba(255,214,10,.04) 0%,transparent 50%)}
.fb-reviews-card{position:relative;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:40px 48px;box-shadow:0 8px 32px rgba(0,0,0,.25);max-width:1000px;margin:0 auto;animation:fadeInUp .7s ease}
.fb-reviews-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.fb-reviews-title{display:flex;align-items:center;gap:8px}
.fb-title-text{font-family:'Helvetica Neue',Arial,sans-serif;font-size:24px;font-weight:700;color:#5b9bd5}
.fb-reviews-label{font-family:var(--font-heading);font-size:24px;font-weight:700;color:rgba(255,255,255,.9)}
.fb-write-review{padding:10px 24px;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-full);color:rgba(255,255,255,.85);font-size:14px;font-weight:600;transition:all var(--transition-fast)}
.fb-write-review:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5);color:var(--color-white)}
.fb-rating-summary{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.fb-rating-number{font-family:var(--font-heading);font-size:36px;font-weight:800;color:var(--color-white)}
.fb-rating-stars{display:flex;gap:2px}
.fb-reviews-carousel{display:flex;align-items:stretch;gap:16px}
.fb-arrow{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);align-self:center}
.fb-arrow:hover:not(:disabled){background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);color:var(--color-white)}
.fb-arrow:disabled{opacity:.3;cursor:not-allowed}
.fb-reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;flex:1}
.fb-review-card{border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:14px;transition:all var(--transition-normal);animation:fadeInUp .5s ease both;background:rgba(255,255,255,.04)}
.fb-review-card:hover{box-shadow:0 4px 20px rgba(0,180,216,.15);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.07)}
.fb-review-author{display:flex;align-items:center;gap:12px}
.fb-author-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#00b4d8,#0077b6);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--color-white);flex-shrink:0}
.fb-author-info{display:flex;flex-direction:column}
.fb-author-name{font-size:14px;font-weight:600;color:var(--color-white)}
.fb-author-via{display:flex;align-items:center;gap:4px;font-size:12px;color:rgba(255,255,255,.5)}
.fb-review-stars{display:flex;gap:2px}
.fb-review-text{font-size:14px;color:rgba(255,255,255,.75);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:5;line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.fb-dots{display:flex;justify-content:center;gap:10px;margin-top:28px}
.fb-dot{width:12px;height:12px;border-radius:50%;border:none;background:rgba(255,255,255,.2);cursor:pointer;transition:all var(--transition-fast);padding:0}
.fb-dot.active{background:var(--color-turquoise);transform:scale(1.2)}
.fb-dot:hover:not(.active){background:rgba(255,255,255,.35)}
@media(max-width:900px){.fb-reviews-card{padding:28px 24px}.fb-reviews-grid{grid-template-columns:repeat(2,1fr)}.fb-reviews-header{flex-direction:column;align-items:flex-start;gap:16px}}
@media(max-width:600px){.fb-reviews-grid{grid-template-columns:1fr}.fb-arrow{display:none}.fb-reviews-card{padding:20px 16px}.fb-title-text,.fb-reviews-label{font-size:20px}.fb-rating-number{font-size:28px}}

/* === CONTACT === */
.contact{padding:var(--section-padding);background:var(--color-gray-100)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.contact-info h2{font-size:clamp(28px,3vw,36px);color:var(--color-dark);margin-bottom:16px;margin-top:12px}
.contact-info>p{font-size:16px;color:var(--color-gray-600);line-height:1.7;margin-bottom:32px}
.contact-channels{display:flex;flex-direction:column;gap:16px}
.channel-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}
.channel-item:hover{box-shadow:var(--shadow-md);transform:translateX(4px)}
.channel-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}
.whatsapp-icon{background:#25d366}
.email-icon{background:var(--color-primary)}
.channel-item strong{display:block;font-size:14px;color:var(--color-dark);margin-bottom:2px}
.channel-item span{font-size:13px;color:var(--color-gray-600)}
.contact-form{background:var(--color-white);padding:40px;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.form-group{margin-bottom:16px}
.form-row .form-group{margin-bottom:0}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--color-gray-700);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;font-size:14px;border:1.5px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-gray-100);color:var(--color-dark);transition:all var(--transition-fast)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-turquoise);background:var(--color-white);box-shadow:0 0 0 3px rgba(0,180,216,.1)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;padding:16px;font-size:16px;margin-top:8px}
.form-message{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;margin-top:16px;animation:fadeInUp .3s ease}
.form-message.success{background:#f0fff4;color:var(--color-success);border:1px solid #c6f6d5}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}}
@media(max-width:600px){.form-row,.form-row.three{grid-template-columns:1fr}.contact-form{padding:24px}}

/* === FOOTER === */
.footer{position:relative;background:var(--color-gray-100)}
.footer-wave{position:relative;margin-bottom:-2px}
.footer-wave svg{display:block;width:100%;height:60px}
.footer-content{background:linear-gradient(180deg,#001248 0%,#002280 100%);padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo{height:50px;width:auto;margin-bottom:16px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all var(--transition-fast)}
.footer-social a:hover{background:var(--color-turquoise);color:var(--color-white);transform:translateY(-3px)}
.footer-links h4{font-size:15px;color:var(--color-white);margin-bottom:20px;font-weight:600}
.footer-links ul{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:14px;color:rgba(255,255,255,.55);transition:all var(--transition-fast);cursor:pointer}
.footer-links a:hover{color:var(--color-turquoise);padding-left:4px}
.footer-bottom{padding:24px 0;text-align:center}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,.35)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr;gap:28px}}

/* === WHATSAPP BUTTON === */
.whatsapp-float{position:fixed;bottom:28px;right:28px;width:60px;height:60px;border-radius:50%;background:#25d366;color:white;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:999;transition:all var(--transition-normal);animation:pulse 2s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(37,211,102,.6);animation:none}
.whatsapp-tooltip{position:absolute;right:72px;background:var(--color-dark);color:var(--color-white);padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}
.whatsapp-tooltip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:6px solid var(--color-dark);border-top:6px solid transparent;border-bottom:6px solid transparent}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;right:76px}
@media(max-width:768px){.whatsapp-float{bottom:20px;right:20px;width:52px;height:52px}.whatsapp-tooltip{display:none}}
