/* =========================
   RESET / BASE
========================= */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;font-weight:400;color:#1e1e1e;background:#f7f5f2}
html{scroll-behavior:smooth}
h1,h2,h3{font-family:'Playfair Display',serif;font-weight:700}
img{max-width:100%;display:block}

/* =========================
   BOTÓN SCROLL TOP
========================= */
#btn-top{position:fixed;right:22px;bottom:90px;width:44px;height:44px;border-radius:50%;background:#27a9b2;color:#fff;border:0;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease;z-index:1000}
#btn-top.show{opacity:1;visibility:visible;transform:translateY(0)}

/* =========================
   WHATSAPP FLOAT
========================= */
.btn-whatsapp{position:fixed;right:22px;bottom:22px;width:54px;height:54px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;text-decoration:none;box-shadow:0 10px 25px rgba(0,0,0,.25);z-index:1000}
.btn-whatsapp:hover{transform:scale(1.05)}

/* =========================
   VARIABLES
========================= */
:root{--verde:#0f7f7a;--verde-oscuro:#0b5f5b}

/* =========================
   CONTAINER
========================= */
.container{width:1440px;max-width:80%;margin:0 auto}

/* =========================
   HEADER
========================= */
.site-header{position:relative;z-index:1000}

/* TOP BAR */
.top-bar{background:#f4f5f9;padding:13px 0;font-size:13px;font-family:'Google Sans Code',sans-serif}
.top-bar-inner{display:flex;justify-content:space-between;align-items:center;color:#6c6c6c}
.top-right.social{display:flex;align-items:center;gap:10px}
.top-right.social a i{color:#34a0a7;font-size:14px}

/* HEADER PRINCIPAL */
.main-header{background:#156d73;position:relative}
.header-flex{display:flex;justify-content:space-between;align-items:center;padding:15px 0}
.nav-left{display:flex;gap:26px}
.nav-left a{color:#fff;text-decoration:none;font-size:14px}
.header-contact{display:flex;align-items:center;gap:18px;font-size:13px}
.contact-item{display:flex;align-items:center;gap:8px}
.icon-circle{width:22px;height:22px;background:#34a0a7;border-radius:50%;display:flex;align-items:center;justify-content:center}
.icon-circle i{color:#fff;font-size:12px}
.header-contact a{color:#fff;text-decoration:none}

/* LOGO FLOTANTE DESKTOP */
.logo-container{position:relative}
.logo-float{position:absolute;left:50%;bottom:-40px;transform:translateX(-50%);background:linear-gradient(90deg,#50b4bb,#74ced4);padding:22px 34px 30px;border-radius:0 0 28px 28px;box-shadow:0 15px 30px rgba(0,0,0,.18);z-index:10}
.logo-float img{height:84px;display:block}

/* =========================
   HEADER RESPONSIVE
========================= */
.mobile-header{display:none}

/* MOBILE */
@media (max-width:768px){
.top-bar,.main-header{display:none}
.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(90deg,#50b4bb,#74ced4);position:relative;z-index:1002}
.menu-toggle{background:none;border:0;color:#fff;font-size:22px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.mobile-social{display:flex;gap:16px}
.mobile-social a{color:#fff;font-size:16px}
.mobile-logo img{height:42px}
}

/* =========================
   MOBILE MENU
========================= */
.mobile-menu{position:fixed;top:0;right:0;width:60%;max-width:320px;height:150vh;background:linear-gradient(180deg,#50b4bb,#74ced4);padding:90px 30px;transform:translateX(100%);opacity:0;transition:transform .4s ease,opacity .4s ease;will-change:transform;pointer-events:none;z-index:1003}
.mobile-menu.active{transform:translateX(0);opacity:1;pointer-events:auto}
.menu-close{position:absolute;top:22px;right:22px;background:none;border:0;color:#fff;font-size:22px;cursor:pointer}
.mobile-menu nav{display:flex;flex-direction:column;gap:26px}
.mobile-menu nav a{color:#fff;font-size:18px;text-decoration:none}
@media (min-width:769px){.mobile-menu{display:none}}

/* =========================
   BLUR BACKDROP
========================= */
body.menu-open{overflow:hidden}
body.menu-open .site-content,
body.menu-open .mobile-header{filter:blur(6px);transition:filter .3s ease}
.menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.25);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:1001}
.menu-backdrop.active{opacity:1;pointer-events:auto}

/* =========================
   HERO
========================= */
.hero{position:relative;min-height:720px;background:url("../img/hero-bg.jpg") center/cover no-repeat;display:flex;align-items:center}
.hero-inner{display:flex;justify-content:flex-end}
.hero-content{max-width:420px;margin-bottom:30px}
.hero-content h1{font-size:46px;letter-spacing:2px;color:#1f3d2b}
.hero-content h2{font-family:'Great Vibes',cursive;font-size:45px;font-weight:400;margin-bottom:10px;color:#1f3d2b}
.hero-content p,.hero-content strong{font-size:16px;letter-spacing:2px;line-height:1.6;text-transform:uppercase;color:#1f3d2b}
.hero-content strong{font-family:'Playfair Display',serif;font-weight:700}
.btn-hero{display:inline-block;margin-top:26px;padding:14px 36px;background:var(--verde);color:#fff;text-decoration:none;border-radius:6px;font-size:13px;font-weight:700}

/* =========================
   HERO RESPONSIVE
========================= */
@media (max-width:1024px){
.hero{min-height:600px;padding:80px 0}
.hero-inner{justify-content:center}
.hero-content{text-align:center;max-width:520px;margin-bottom:0}
.hero-content h1{font-size:40px}
.hero-content h2{font-size:40px}
}
@media (max-width:768px){
.hero{min-height:auto;padding:30px 0 110px;background-position:center top}
.hero::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.65)}
.hero-content{max-width:100%;padding:0 16px;position:relative;z-index:1}
.hero-content h1{font-size:32px;letter-spacing:1.5px}
.hero-content h2{font-size:34px}
.hero-content p,.hero-content strong{font-size:14px;letter-spacing:1.5px}
.btn-hero{padding:14px 28px;font-size:12px}
}

/* =========================
   FEATURES
========================= */
.features-float{position:relative;margin-top:-90px;margin-bottom:-70px;z-index:20}
.features-box{background:#2098a1;display:flex;justify-content:space-between;align-items:center;gap:80px;padding:32px 70px;border-radius:18px;max-width:850px;margin:0 auto;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.feature-item{display:flex;align-items:center;gap:18px;color:#fff}
.feature-icon{width:90px;height:90px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}
.feature-text h4{font-size:16px;margin-bottom:4px}
.feature-text p{font-size:13px;line-height:1.4}

/* =========================
   FEATURES RESPONSIVE
========================= */
@media (max-width:1024px){
.features-float{margin-top:-70px;margin-bottom:-50px}
.features-box{gap:40px;padding:28px 40px;max-width:720px}
.feature-icon{width:80px;height:80px}
.feature-text h4{font-size:15px}
}
@media (max-width:768px){
.features-float{margin-top:-60px;margin-bottom:-40px;padding:0 16px}
.features-box{flex-direction:column;gap:26px;padding:26px 24px;max-width:100%;border-radius:16px}
.feature-item+.feature-item{padding-top:20px;border-top:1px solid rgba(255,255,255,.25)}
.feature-icon{width:72px;height:72px;flex-shrink:0}
.feature-text h4{font-size:15px}
.feature-text p{font-size:13px}
}

/* =========================
   EXPERIENCE
========================= */
.experience{background:linear-gradient(180deg,#0f7f7a 0%,#0b6a68 100%);padding:150px 0 0;color:#fff}
.experience-grid{display:grid;grid-template-columns:55% 45%;gap:60px;align-items:center}
.experience-text h2{font-size:38px;margin-bottom:30px}
.experience-text p{font-size:14px;line-height:1.8;margin-bottom:16px;max-width:520px}
.experience-logo{margin-top:40px}
.experience-logo img{width:200px}
.experience-image{position:relative}
.experience-image img{width:90%;height:570px;object-fit:cover;border-radius:200px 200px 0 0;border:3px solid #27a9b2;border-bottom:none}
.services-bubble{position:absolute;top:100%;left:-125px;transform:translateY(-100%);background:#fff;padding:28px 30px;border-radius:200px 200px 0 0;width:260px;box-shadow:0 18px 40px rgba(0,0,0,.25)}
.bubble-title{display:block;margin:-35px auto 45px;background:#2098a1;color:#fff;font-size:13px;padding:6px 18px;border-radius:5px;width:fit-content}
.services-list{display:grid;grid-template-columns:1fr 1fr;row-gap:8px;list-style:none;padding:0}
.services-list li{position:relative;padding-left:18px;font-size:13px;color:#555;text-align:left}
.services-list li::before{content:"✓";position:absolute;left:0;color:#27a9b2;font-weight:700}

/* =========================
   EXPERIENCE RESPONSIVE
========================= */
@media (max-width:1024px){
.experience{padding:120px 0 0}
.experience-grid{grid-template-columns:1fr 1fr;gap:40px}
.experience-text h2{font-size:34px}
.experience-image img{height:480px;width:100%}
.services-bubble{left:-80px;width:240px}
}
@media (max-width:768px){
.experience{padding-top:90px;overflow:hidden}
.experience-grid{grid-template-columns:1fr;gap:50px;text-align:center}
.experience-text p{margin-left:auto;margin-right:auto;text-align:justify}
.experience-logo{margin-top:30px;text-align:center}
.experience-logo img{margin:0 auto}
.experience-image{position:relative;display:flex;flex-direction:column;align-items:center}
.experience-image img{width:90%;height:370px;object-fit:cover;border-radius:200px 200px 0 0;border:3px solid #27a9b2;border-bottom:none;z-index:1}
.services-bubble{position:absolute;top:0;bottom:0;left:95px;transform:translate(-50%,55%);width:260px;min-height:100px;background:#fff;padding:28px 30px;border-radius:200px 200px 0 0;box-shadow:0 18px 40px rgba(0,0,0,.25);z-index:2}
.bubble-title{margin:-28px auto 30px}
.services-list{grid-template-columns:1fr 1fr;justify-items:start}
}

/* =========================
   GALLERY
========================= */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:280px 280px}
.g1{grid-column:1/2}
.g2{grid-column:2/3;grid-row:1/3}
.g3{grid-column:3/4}
.g4{grid-column:4/5}
.g5{grid-column:1/2;grid-row:2/3}
.g6{grid-column:3/4;grid-row:2/3}
.g7{grid-column:4/5;grid-row:2/3}
.g-item img{width:100%;height:100%;object-fit:cover}

/* =========================
   GALLERY ANIMATIONS
========================= */
.gallery-grid .g-item{opacity:0;transform:translateY(10px);transition:opacity .35s ease,transform .35s ease}
.gallery-grid .g-item.is-visible{opacity:1;transform:translateY(0)}
.gallery-wrapper{position:relative;overflow:hidden}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:#27a9b2;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .25s ease,opacity .25s ease}
.gallery-nav.prev{left:10px}
.gallery-nav.next{right:10px}
.gallery-nav:hover{transform:translateY(-50%) scale(1.08)}
.gallery-nav.hidden{display:none}

/* =========================
   GALLERY MODAL
========================= */
.gallery-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:2000}
.gallery-modal.active{opacity:1;pointer-events:auto}
.modal-image{max-width:90vw;max-height:90vh;transform:scale(.96);transition:transform .35s ease,opacity .35s ease}
.gallery-modal.active .modal-image{transform:scale(1)}
.modal-close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:26px;cursor:pointer}
.modal-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:36px;cursor:pointer}
.modal-nav.prev{left:30px}
.modal-nav.next{right:30px}
.modal-nav.hidden{display:none}

/* =========================
   GALLERY RESPONSIVE
========================= */
@media (max-width:1024px){
.gallery-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,240px)}
.g1,.g3,.g4,.g5,.g6,.g7{grid-column:auto;grid-row:auto}
.g2{grid-column:span 2;grid-row:span 2}
}
@media (max-width:768px){
.gallery-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
.gallery-grid .g-item{grid-column:auto!important;grid-row:auto!important;height:200px}
}

/* =========================
   REVIEWS
========================= */
.reviews{background:#f6f6f6;padding:80px 0}
.reviews-wrapper{display:flex;align-items:center;gap:20px;padding:80px 0}
.reviews-btn{width:48px;height:48px;border-radius:50%;background:#27a9b2;color:#fff;border:none;cursor:pointer;flex-shrink:0}
.reviews-viewport{overflow:hidden;width:100%}
.reviews-track{display:flex;gap:24px;transition:transform .4s ease;will-change:transform}
.review-card{flex:0 0 calc(33.333% - 16px);background:#fff;padding:24px;border-radius:14px}
.review-header{display:flex;gap:12px;align-items:center;margin-bottom:10px}
.review-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;line-height:1;color:#fff;text-transform:uppercase;flex-shrink:0}
.review-stars{color:#fbbc04;margin-bottom:8px}

/* =========================
   REVIEWS RESPONSIVE
========================= */
@media (max-width:1024px){
.review-card{flex:0 0 calc(50% - 12px)}
}
@media (max-width:768px){
.reviews-wrapper{gap:0;padding:20px 0}
.reviews-viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.reviews-btn{display:none}
.review-card{flex:0 0 100%}
.reviews-track{gap:16px;padding:20px 0}
}

/* =========================
   CONTACT
========================= */
.contact{position:relative;padding:70px 0;color:#fff;background-color:#21989f;background-image:radial-gradient(circle at 20% 30%,rgba(30,139,146,.35),transparent 40%),radial-gradient(circle at 80% 70%,rgba(30,139,146,.35),transparent 40%)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.contact-info h2{font-family:'DM Sans';margin-bottom:25px}
.contact-item-info{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.contact-item-info i{font-size:35px;color:#fff;margin-top:2px}
.contact-item-info div{display:flex;flex-direction:column}
.contact-label{font-size:13px;font-weight:600;color:#fff;margin-bottom:2px}
.contact-value{font-size:14px;opacity:.95}
.contact-form-box{background:#fff;border-radius:14px;padding:36px;box-shadow:0 25px 60px rgba(0,0,0,.25);max-width:520px;margin-left:auto}
.contact-form-box h3{color:#333;margin-bottom:10px;font-family:'DM Sans'}
.form-label{display:block;font-size:11px;letter-spacing:1px;color:#888;margin-bottom:16px}
.contact-form-box form{width:100%;display:grid;grid-template-columns:1fr;gap:14px}
.field{display:flex;align-items:stretch;background:#e6fdff;border-radius:2px;overflow:hidden}
.field-icon{width:48px;min-width:48px;background:#e6fdff;display:flex;align-items:center;justify-content:center}
.field-icon i{color:#34a0a7;font-size:16px}
.field input,.field textarea{border-top:2px solid #e6fdff;background:#fff;padding:12px;font-size:13px;width:100%;color:#333;border-bottom:2px solid #e6fdff;border-left:1px solid #e6fdff;border-right:1px solid #e6fdff;transition:border-color .3s ease}
.field input:focus,.field textarea:focus{border:2px solid #34a0a7;outline:none}
.field input::placeholder,.field textarea::placeholder{color:#7fbfc5}
.field textarea{resize:none;height:90px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-submit{width:100%;margin-top:10px;padding:14px;background:#6ecad0;color:#fff;border:none;border-radius:6px;font-size:13px;letter-spacing:1px;cursor:pointer}

/* =========================
   CONTACT RESPONSIVE
========================= */
@media (max-width:768px){
.contact{padding:80px 0}
.contact-grid{grid-template-columns:1fr;gap:50px;text-align:center}
.contact-info h2{margin-bottom:30px}
.contact-item-info{text-align:left}
.contact-item-info i{font-size:28px}
.contact-form-box{margin-left:0;max-width:100%;padding:28px}
.field-row{grid-template-columns:1fr}
.field textarea{height:100px}
.btn-submit{margin-top:16px}
}

/* =========================
   FOOTER
========================= */
.footer{background:var(--verde-oscuro);color:#d9ffff;text-align:center;padding:40px 0;display:flex;flex-direction:column;align-items:center;gap:20px}
.footer img{max-width:160px}
.footer-contact{display:flex;align-items:center;justify-content:center;gap:30px;font-size:13px}
.footer-contact .contact-item{display:flex;align-items:center;gap:10px}
.footer-contact a{color:#fff;text-decoration:none}
.footer p{font-size:12px;opacity:.85}

/* =========================
   FOOTER RESPONSIVE
========================= */
@media (max-width:768px){
.footer{padding:50px 20px;gap:24px}
.footer img{max-width:140px}
.footer-contact{flex-direction:column;gap:16px;align-items:flex-start}
.footer-contact .contact-item{justify-content:center}
.footer p{max-width:300px;line-height:1.6}
}

