*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;max-width:100vw}:root{--verde-selva: #2E5E3A;--beige-tierra: #E6D2AA;--azul-cielo: #87CEEB;--blanco-natural: #FAFAFA;--marron-madera: #8B4513;--shadow-soft: 0 20px 60px rgba(46, 94, 58, .15);--shadow-hover: 0 30px 80px rgba(46, 94, 58, .25)}body{font-family:Georgia,serif;line-height:1.6;color:var(--verde-selva);background-color:var(--blanco-natural);overflow-x:hidden;font-size:16px}@media (max-width: 768px){body{font-size:15px}}@media (max-width: 480px){body{font-size:14px}}.container{max-width:1200px;margin:0 auto;padding:0 20px}::-webkit-scrollbar-thumb{background:var(--verde-selva);border-radius:4px}.fade-in{opacity:0;transform:translateY(50px);transition:all .8s cubic-bezier(.4,0,.2,1)}.fade-in.visible{opacity:1;transform:translateY(0)}.slide-in-left{opacity:0;transform:translate(-60px);transition:all .8s cubic-bezier(.4,0,.2,1)}.slide-in-left.visible{opacity:1;transform:translate(0)}.slide-in-right{opacity:0;transform:translate(60px);transition:all .8s cubic-bezier(.4,0,.2,1)}.slide-in-right.visible{opacity:1;transform:translate(0)}.scale-in{opacity:0;transform:scale(.8);transition:all .8s cubic-bezier(.4,0,.2,1)}.scale-in.visible{opacity:1;transform:scale(1)}.stagger-animation{transition-delay:.1s}.stagger-animation:nth-child(2){transition-delay:.2s}.stagger-animation:nth-child(3){transition-delay:.3s}.stagger-animation:nth-child(4){transition-delay:.4s}.stagger-animation:nth-child(5){transition-delay:.5s}.stagger-animation:nth-child(6){transition-delay:.6s}.floating-element{animation:float-gentle 6s ease-in-out infinite}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.shimmer-effect{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}.pulse-on-hover:hover{animation:pulse-glow 1.5s ease-in-out 2;opacity:1!important;visibility:visible!important}.pulse-on-hover:active{transform:scale(.98)!important;animation:none;transition:transform .1s ease;opacity:1!important;visibility:visible!important}.magnetic-effect{transition:transform .2s cubic-bezier(.4,0,.2,1);will-change:transform}@keyframes text-reveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.text-reveal{animation:text-reveal .8s ease-out forwards}@keyframes pattern-move{0%{background-position:0 0}to{background-position:50px 50px}}.animated-pattern{background-image:radial-gradient(circle at 25% 25%,rgba(230,210,170,.1) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(135,206,235,.1) 0%,transparent 50%);background-size:50px 50px;animation:pattern-move 20s linear infinite}section{padding:8rem 0;position:relative;background:var(--blanco-natural)}.section-title{text-align:center;font-size:3.5rem;margin-bottom:4rem;color:var(--verde-selva);position:relative;font-weight:300;letter-spacing:1px}.section-title:after{content:"";display:block;width:120px;height:4px;background:linear-gradient(45deg,var(--azul-cielo),var(--beige-tierra));margin:2rem auto;border-radius:2px}.scroll-progress{position:fixed;top:0;left:0;width:0%;height:4px;background:linear-gradient(90deg,var(--azul-cielo),var(--beige-tierra));z-index:1001;transition:width .1s ease}@keyframes fadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0)}}@media (hover: none) and (pointer: coarse){.nav-links a:hover,.nav-social a:hover,.cta-button:hover,.whatsapp-cta-btn:hover,.submit-btn:hover{transform:none}.nav-links a:active,.nav-social a:active,.cta-button:active,.whatsapp-cta-btn:active,.submit-btn:active{transform:scale(.95)}.accommodation-card:hover,.service-item:hover{transform:none}.accommodation-card:active,.service-item:active{transform:scale(.98)}.gallery-nav{pointer-events:auto;cursor:pointer}.gallery-nav:active{background:#000000f2;transform:scale(.9);transition:all .1s ease}.image-overlay-band{opacity:0;animation:touchAutoShow .8s ease-in-out 2s forwards,touchAutoHide .8s ease-in-out 5s forwards}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.logo-image img,.gallery-thumbnail img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (max-height: 500px) and (orientation: landscape){.hero{height:100vh;padding:2rem 0}.hero-content h1{font-size:2rem}.hero-content p{font-size:1rem;margin:.5rem 0 1rem}section{padding:2rem 0}.gallery-modal-content{height:98%;margin:1% auto}}@media print{.nav-social,.whatsapp-float,.gallery-modal,.cta-button,.whatsapp-cta-btn,.submit-btn{display:none!important}.hero{background:none!important;color:#000!important}body{background:#fff!important;color:#000!important}.section-title{color:#000!important}}html{scroll-behavior:smooth}@media (max-width: 360px){.section-title{font-size:1.3rem;line-height:1.2}.contact-hero h2{font-size:1.3rem}.contact-hero p{font-size:.8rem;line-height:1.4}.about-text p{font-size:.8rem;line-height:1.5}.service-item h3{font-size:.9rem}.service-item p{font-size:.75rem;line-height:1.4}.contact-item{font-size:.8rem}.contact-item strong{font-size:.85rem}.contact-item small{font-size:.75rem}.loader-text{font-size:.85rem;margin-bottom:1.5rem;padding:0 .5rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes ripple{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes wiggle{0%,7%{transform:rotate(0)}15%{transform:rotate(-15deg)}20%{transform:rotate(10deg)}25%{transform:rotate(-10deg)}30%{transform:rotate(6deg)}35%{transform:rotate(-4deg)}40%,to{transform:rotate(0)}}@keyframes glow{0%,to{box-shadow:0 0 5px #87ceeb80}50%{box-shadow:0 0 20px #87ceebcc,0 0 30px #87ceeb99}}.fade-in{animation:fadeIn 1s ease-out both}.fade-in-up{animation:fadeInUp 1s ease-out both}.fade-in-down{animation:fadeInDown 1s ease-out both}.slide-in-left{animation:slideInLeft .8s ease-out both}.slide-in-right{animation:slideInRight .8s ease-out both}.scale-in{animation:scaleIn .6s ease-out both}.stagger-animation{opacity:0;animation-fill-mode:both}.stagger-animation.fade-in-up{animation:fadeInUp .8s ease-out both}.stagger-animation.slide-in-left{animation:slideInLeft .8s ease-out both}.stagger-animation.slide-in-right{animation:slideInRight .8s ease-out both}.stagger-animation.scale-in{animation:scaleIn .6s ease-out both}.floating-element{animation:float 6s ease-in-out infinite}::selection{background:#87ceeb4d;color:var(--verde-selva)}::-moz-selection{background:#87ceeb4d;color:var(--verde-selva)}button:focus,a:focus,input:focus,textarea:focus,select:focus{outline:2px solid var(--azul-cielo);outline-offset:2px}@keyframes touchAutoShow{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes touchAutoHide{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--beige-tierra)}::-webkit-scrollbar-thumb{background:var(--azul-cielo);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--verde-selva)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{body{font-size:12pt;line-height:1.4;color:#000;background:#fff}.accommodation-card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}.card-thumbnails-preview,.view-gallery-btn,.whatsapp-float,.discount-banner{display:none!important}}@media (prefers-contrast: high){:root{--verde-selva: #000000;--azul-cielo: #0066cc;--blanco-natural: #ffffff}}header{background:#2e5e3af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);color:#fff;padding:1rem 0;position:fixed;width:100%;top:0;z-index:1000;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:70px}nav{display:flex;justify-content:space-between;align-items:center;gap:2rem;min-height:60px;position:relative}.logo{display:flex;align-items:center;gap:.8rem;transition:transform .3s ease;flex-shrink:0;min-width:200px}.logo:hover{transform:scale(1.05)}.logo-image{width:42px;height:42px;border-radius:50%;overflow:hidden;position:relative;border:2px solid var(--beige-tierra);box-shadow:0 0 0 3px #e6d2aa33,0 3px 10px #0000004d;transition:all .3s ease;flex-shrink:0}.logo-image img{width:100%;height:100%;object-fit:cover;border-radius:50%;background:transparent;clip-path:circle(50% at center)}.logo:hover .logo-image{transform:rotate(5deg);box-shadow:0 0 0 3px #e6d2aa66,0 5px 14px #0006}.logo-text{color:var(--beige-tierra);text-shadow:2px 2px 4px rgba(0,0,0,.3);line-height:1.1;white-space:nowrap}.logo-text .brand-name{font-size:1.3rem;font-weight:700;letter-spacing:.5px;margin:0;display:block}.nav-links{display:flex;list-style:none;gap:2rem;margin:0;padding:0;flex:1;justify-content:center;align-items:center}.nav-links a{color:#fff;text-decoration:none;transition:all .3s ease;position:relative;padding:.6rem 1rem;white-space:nowrap;font-weight:500;font-size:.95rem;border-radius:6px}.nav-links a:after{content:"";position:absolute;bottom:4px;left:50%;width:0;height:2px;background:var(--beige-tierra);transition:all .3s ease;transform:translate(-50%)}.nav-links a:hover{background:#ffffff1a;transform:translateY(-1px)}.nav-links a:hover:after{width:60%}.nav-social{display:flex;align-items:center;gap:.5rem;flex-shrink:0;min-width:150px;justify-content:flex-end}.nav-social a{color:#ffffffe6;text-decoration:none;padding:.4rem;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);width:36px;height:36px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.nav-social a:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .5s}.nav-social a:hover:before{transform:translate(100%)}.nav-social a:hover{background:#fff3;transform:translateY(-2px) scale(1.1);box-shadow:0 5px 15px #0000004d}.nav-social a.facebook:hover{background:linear-gradient(45deg,#1877f2,#42a5f5);color:#fff}.nav-social a.instagram:hover{background:linear-gradient(45deg,#e1306c,#fd1d1d,#fcb045);color:#fff}.nav-social a.whatsapp:hover{background:linear-gradient(45deg,#25d366,#128c7e);color:#fff}.nav-social a i{width:14px;height:14px;transition:all .3s ease}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:space-around;width:44px;height:44px;background:#00000080;border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;padding:8px;z-index:1001;position:relative;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;touch-action:manipulation;backdrop-filter:blur(10px);transition:all .3s ease}.mobile-menu-toggle:hover{background:#000000b3;border-color:#fff6;transform:scale(1.05)}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-menu-toggle span{width:100%;height:2px;background:#fff;border-radius:1px;transition:all .3s ease;transform-origin:center}.mobile-menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.mobile-menu-toggle.active span:nth-child(2){opacity:0}.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (min-width: 1200px){nav{gap:2.5rem}.nav-links{gap:2rem}.nav-social{min-width:160px}}@media (max-width: 1199px) and (min-width: 768px){nav{gap:1.5rem}.nav-links{gap:1.2rem}.nav-links a{padding:.5rem .8rem;font-size:.9rem}.logo{min-width:180px}.nav-social{gap:.4rem;min-width:140px}.nav-social a{width:34px;height:34px}}@media (max-width: 767px) and (min-width: 640px){header{padding:.7rem 0;min-height:60px}nav{gap:1rem;min-height:50px}.logo{min-width:140px;gap:.5rem}.logo-image{width:34px;height:34px}.logo-text .brand-name{font-size:1rem}.nav-links{gap:.8rem}.nav-links a{font-size:.8rem;padding:.3rem .5rem}.nav-social{gap:.25rem;min-width:100px}.nav-social a{width:30px;height:30px}.nav-social a i{width:11px;height:11px}}@media (max-width: 639px){header{padding:.5rem 0;min-height:60px}nav{gap:.5rem;position:relative;min-height:50px}.mobile-menu-toggle{display:flex;order:3}.nav-links{position:fixed;inset:0;width:100%;height:100vh;background:linear-gradient(135deg,#2e5e3afa,#8b4513fa);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:2rem;opacity:0;visibility:hidden;transform:translateY(-100%);transition:all .4s cubic-bezier(.4,0,.2,1);z-index:999;box-shadow:0 0 50px #00000080}.nav-links.active{opacity:1;visibility:visible;transform:translateY(0)}.nav-links li{width:100%;max-width:300px}.nav-links a{display:block;padding:1.2rem 2rem;font-size:1.1rem;font-weight:500;text-align:center;border:2px solid transparent;border-radius:15px;background:#ffffff1a;backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);min-width:200px;text-transform:uppercase;letter-spacing:1px}.nav-links a:hover,.nav-links a:active{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px) scale(1.02);box-shadow:0 8px 25px #0000004d}.logo{order:1;min-width:auto;flex:1}.logo-image{width:32px;height:32px}.logo-text .brand-name{font-size:1rem}.nav-social{order:2;min-width:auto;gap:.3rem}.nav-social a{width:28px;height:28px}.nav-social a i{width:10px;height:10px}}@media (max-width: 360px){nav{gap:.3rem;padding:0 .5rem}.mobile-menu-toggle{width:40px;height:40px;padding:6px}.nav-links a{padding:1rem 1.5rem;font-size:1rem;min-width:180px}.logo{gap:.3rem}.logo-image{width:28px;height:28px}.logo-text .brand-name{font-size:.9rem}.nav-social{gap:.2rem}.nav-social a{width:26px;height:26px}.nav-social a i{width:9px;height:9px}}@media (max-height: 500px) and (orientation: landscape) and (max-width: 900px){header{padding:.4rem 0;min-height:50px}nav{min-height:42px}.logo-image{width:30px;height:30px}.logo-text .brand-name{font-size:.9rem}.nav-links a{padding:.3rem .5rem;font-size:.8rem}.nav-social a{width:26px;height:26px}}@media (hover: none) and (pointer: coarse){.nav-links a:hover,.nav-social a:hover{transform:none;background:#ffffff1a}.nav-links a:active,.nav-social a:active{background:#fff3;transform:scale(.95)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.logo-image img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.cta-button{background:linear-gradient(45deg,var(--azul-cielo),#7BC4E8);color:var(--verde-selva);padding:18px 40px;text-decoration:none;border-radius:50px;font-size:1.3rem;font-weight:600;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1);display:inline-block;position:relative;overflow:hidden;box-shadow:0 10px 30px #87ceeb66;animation:fadeInUp 1s ease-out .6s both;opacity:1;visibility:visible;will-change:transform,box-shadow;transform:translateY(0);border:none;cursor:pointer}.cta-button.loaded{animation:none}.cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}.cta-button:hover:before{left:100%}.cta-button:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 20px 40px #87ceeb80;opacity:1;visibility:visible}.cta-button:active{transform:translateY(-1px) scale(1.02);box-shadow:0 10px 25px #87ceeb66;transition:all .1s ease;opacity:1;visibility:visible}.cta-button:focus{outline:none;box-shadow:0 0 0 3px #87ceeb4d;opacity:1;visibility:visible}.cta-button.secondary{background:transparent;border:2px solid var(--verde-selva);color:var(--verde-selva)}.cta-button.secondary:hover{background:var(--verde-selva);color:#fff}.discount-banner{background:linear-gradient(135deg,var(--marron-madera),#654321);color:#fff;text-align:center;padding:4rem 2rem;margin:-6rem 2rem 6rem;border-radius:25px;position:relative;overflow:hidden;box-shadow:var(--shadow-soft);z-index:10}.discount-banner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(230,210,170,.1) 0%,transparent 70%);animation:rotate 15s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.discount-content{position:relative;z-index:2}.discount-banner h2{font-size:2.5rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.rating{background:linear-gradient(135deg,var(--verde-selva),#1a3d24);color:#fff;padding:2.5rem;border-radius:20px;text-align:center;margin:3rem 0;position:relative;overflow:hidden;box-shadow:var(--shadow-soft)}.rating:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(135,206,235,.1) 0%,transparent 70%);animation:rotate 10s linear infinite}.rating-content{position:relative;z-index:2}.rating-score{font-size:3rem;font-weight:700;color:var(--azul-cielo);margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem;margin-top:4rem}.service-item{text-align:center;padding:3rem 2rem;background:#fff;border-radius:20px;box-shadow:var(--shadow-soft);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.service-item:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(45deg,var(--azul-cielo),var(--beige-tierra));transform:scaleX(0);transition:transform .4s ease}.service-item:hover:before{transform:scaleX(1)}.service-item:hover{transform:translateY(-10px);box-shadow:var(--shadow-hover)}.service-icon{width:60px;height:60px;margin:0 auto 1.5rem;color:var(--verde-selva);transition:all .4s ease}.service-item:hover .service-icon{transform:scale(1.1);color:var(--azul-cielo)}@keyframes float-gentle{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-8px) rotate(.5deg)}66%{transform:translateY(4px) rotate(-.5deg)}}.floating-element{animation:float-gentle 6s ease-in-out infinite;will-change:transform}@media (prefers-reduced-motion: reduce){.floating-element{animation:none}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.whatsapp-cta-btn{background:linear-gradient(45deg,#25d366,#128c7e);color:#fff;padding:1.2rem 3rem;text-decoration:none;border-radius:50px;font-size:1.2rem;font-weight:600;display:inline-flex;align-items:center;gap:.8rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;z-index:2;box-shadow:0 10px 30px #25d36666;border:none;cursor:pointer}.whatsapp-cta-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}.whatsapp-cta-btn:hover:before{left:100%}.whatsapp-cta-btn:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 20px 40px #25d36699;background:linear-gradient(45deg,#128c7e,#25d366)}.contact-cta{margin-top:4rem;text-align:center;position:relative;z-index:2}.cta-card{background:#25d3661a;border:1px solid rgba(37,211,102,.3);border-radius:20px;padding:2.5rem;max-width:500px;margin:0 auto;backdrop-filter:blur(10px);transition:all .3s ease;text-align:center}.cta-card:hover{background:#25d36626;transform:translateY(-5px)}.cta-card h3{font-size:1.8rem;margin-bottom:1rem;color:#fff}.cta-card p{font-size:1.1rem;margin-bottom:2rem;opacity:.9}.contact-map{background:#ffffff14;padding:2.5rem;border-radius:20px;backdrop-filter:blur(10px);border:1px solid rgba(230,210,170,.2)}.contact-map h3{color:var(--beige-tierra);margin-bottom:1.5rem;font-size:1.6rem;text-align:center}.map-container{border-radius:15px;overflow:hidden;box-shadow:0 8px 25px #0003;margin-bottom:1rem}.hero{height:100vh;background:linear-gradient(135deg,#2e5e3a99,#8b451300),url(/images/vista-desde-el-patio-a-coral.webp);background-size:cover;background-position:center center;background-attachment:fixed;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;overflow:hidden;transition:all .3s ease;will-change:transform;contain:layout style paint;transform:translateZ(0);-webkit-transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.hero{image-rendering:auto;-webkit-image-rendering:auto}}@media (min-width: 1920px){.hero{background-size:100% auto;background-position:center top}}@media (min-width: 1200px) and (max-width: 1919px){.hero{background-position:center center;background-size:cover}}@media (max-width: 1199px){.hero{background-attachment:scroll;background-position:center center;background-size:cover}}@media (max-width: 768px){.hero{background-image:linear-gradient(135deg,#2e5e3a99,#8b451366),url(/images/vista-desde-el-patio-a-coral.webp);background-attachment:scroll}}.hero.scrolled{transform:scale(1.05)}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(230,210,170,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(135,206,235,.1) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(46,94,58,.1) 0%,transparent 50%);animation:floating 6s ease-in-out infinite}@keyframes floating{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-10px) rotate(1deg)}66%{transform:translateY(5px) rotate(-1deg)}}.hero-content{position:relative;z-index:2;max-width:800px;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.hero-content h1{font-size:4rem;margin-bottom:1.5rem;text-shadow:3px 3px 6px rgba(0,0,0,.7);font-weight:300;letter-spacing:2px;animation:fadeInUp 1s ease-out .2s both}.hero-content p{font-size:1.6rem;margin-bottom:2.5rem;color:var(--beige-tierra);font-style:italic;text-shadow:3px 3px 8px rgba(0,0,0,.8);background:#2e5e3ab3;padding:1rem 2rem;border-radius:50px;backdrop-filter:blur(10px);border:2px solid rgba(230,210,170,.3);animation:fadeInUp 1s ease-out .4s both}.card{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;box-shadow:var(--shadow-soft);transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.2)}.card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#87ceeb0d,#2e5e3a0d);opacity:0;transition:opacity .3s ease;pointer-events:none}.card:hover:before{opacity:1}.card:hover{transform:translateY(-10px) scale(1.02);box-shadow:var(--shadow-hover)}.card-image{width:100%;height:250px;object-fit:cover;transition:transform .4s ease;background-color:#f0f0f0;background-size:cover;background-position:center}.lazy-bg{position:relative}.lazy-img{transition:opacity .5s ease,filter .5s ease}.bg-loaded,.img-loaded{opacity:1;filter:none}.card:hover .card-image{transform:scale(1.05)}.card-content{padding:2rem}.card-title{font-size:1.5rem;color:var(--verde-selva);margin-bottom:1rem;font-weight:700}.card-text{color:var(--verde-selva);line-height:1.6;margin-bottom:1.5rem;opacity:.8}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:10000;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal-overlay.active{opacity:1;visibility:visible}.modal-content{background:#fff;border-radius:20px;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative;transform:scale(.9);transition:transform .3s cubic-bezier(.4,0,.2,1)}.modal-overlay.active .modal-content{transform:scale(1)}.modal-close{position:absolute;top:1rem;right:1rem;background:#0000001a;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;color:var(--verde-selva);transition:all .3s ease;z-index:10}.modal-close:hover{background:#0003;transform:rotate(90deg)}.contact-form{background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:3rem;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.contact-form:hover{border-color:#ffffff4d}.contact-form h3{color:#fff;margin-bottom:2rem;font-size:1.8rem}.form-message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-radius:10px;margin-bottom:1.5rem;font-weight:500;animation:slideInDown .3s ease-out}.form-message.success{background:linear-gradient(135deg,#22c55e26,#22c55e0d);border:1px solid rgba(34,197,94,.3);color:#22c55e}.form-message.error{background:linear-gradient(135deg,#ef444426,#ef44440d);border:1px solid rgba(239,68,68,.3);color:#ef4444}.form-message i{font-size:1.2rem;flex-shrink:0}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:2rem}.form-group label{display:block;color:#fff;margin-bottom:.5rem;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:1rem 1.5rem;border:2px solid rgba(255,255,255,.2);border-radius:12px;background:#ffffff1a;color:#fff;font-size:1rem;transition:all .3s ease;backdrop-filter:blur(10px)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--azul-cielo);background:#ffffff26;box-shadow:0 0 0 3px #87ceeb1a;transform:translateY(-2px)}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff9}.form-group textarea{min-height:120px;resize:vertical}.submit-btn{width:100%;padding:1.2rem 2rem;background:linear-gradient(135deg,var(--azul-cielo),#5dade2);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:.5rem}.submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.submit-btn:hover:before{left:100%}.submit-btn:hover{transform:translateY(-3px);box-shadow:0 15px 35px #87ceeb66;background:linear-gradient(135deg,#5dade2,var(--azul-cielo))}.submit-btn:active{transform:translateY(-1px)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.submit-btn:disabled:hover{transform:none;box-shadow:none}.btn-loading i{animation:spin 1s linear infinite}.hidden{display:none!important}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin:2rem 0}.gallery-item{position:relative;overflow:hidden;border-radius:15px;cursor:pointer;transition:all .3s ease}.gallery-item:hover{transform:scale(1.05)}.gallery-item img{width:100%;height:250px;object-fit:cover;transition:transform .3s ease}.gallery-item:hover img{transform:scale(1.1)}.gallery-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-overlay i{color:#fff;font-size:2rem}.pricing-card{background:#fff;border-radius:20px;padding:2.5rem 2rem;text-align:center;position:relative;box-shadow:var(--shadow-soft);transition:all .4s ease;overflow:hidden;border:1px solid rgba(0,0,0,.1)}.pricing-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(45deg,var(--azul-cielo),var(--verde-selva));transform:scaleX(0);transition:transform .4s ease}.pricing-card:hover:before{transform:scaleX(1)}.pricing-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-hover);border-color:var(--azul-cielo)}.pricing-title{font-size:1.5rem;color:var(--verde-selva);margin-bottom:1rem}.pricing-amount{font-size:2.5rem;font-weight:700;color:var(--azul-cielo);margin-bottom:.5rem}.pricing-period{color:var(--verde-selva);opacity:.7;margin-bottom:2rem}.pricing-feature{margin:1rem 0;color:var(--verde-selva)}.pricing-feature:last-child{margin-bottom:0}@media (max-width: 768px){.hero-content h1{font-size:2.5rem}.hero-content p{font-size:1.2rem}.cta-button{padding:1rem 2rem;font-size:1rem}.card-content{padding:1.5rem}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.contact-form{padding:2rem}}@media (max-width: 480px){.hero-content h1{font-size:2rem}.hero-content p{font-size:1rem}.cta-button{padding:.8rem 1.5rem;font-size:.9rem}.card-content{padding:1rem}.gallery-grid{grid-template-columns:1fr}.modal-content{margin:1rem}}.page-loader{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--verde-selva),#1a3d24);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease,visibility .5s ease}.page-loader.hidden{opacity:0;visibility:hidden}.loader-content{text-align:center;color:#fff}.loader-logo{width:min(340px,60vw);height:min(340px,60vw);max-width:300px;max-height:300px;margin:0 auto 2rem;position:relative;animation:pulse-glow 2s ease-in-out infinite;border-radius:50%;overflow:hidden;background:transparent}.loader-logo img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:4px solid var(--beige-tierra);background:transparent;box-shadow:0 0 0 8px #e6d2aa4d,0 0 0 16px #e6d2aa1a,0 20px 40px #0000004d;transition:all .3s ease;clip-path:circle(50% at center)}.loader-logo:before{content:"";position:absolute;inset:-12px;border:2px solid transparent;border-radius:50%;background:linear-gradient(45deg,var(--azul-cielo),transparent,var(--beige-tierra),transparent);background-size:200% 200%;animation:rotate-border 3s linear infinite;z-index:-1}@keyframes rotate-border{0%{transform:rotate(0);background-position:0% 50%}50%{background-position:100% 50%}to{transform:rotate(360deg);background-position:0% 50%}}.loader-text{font-size:clamp(1rem,2.5vw,1.2rem);margin-bottom:2rem;opacity:.8;padding:0 1rem;text-align:center}.loader-spinner{width:min(50px,10vw);height:min(50px,10vw);min-width:30px;min-height:30px;border:3px solid rgba(230,210,170,.3);border-top:3px solid var(--beige-tierra);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.gallery-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;display:none;align-items:center;justify-content:center;opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.gallery-modal.active{display:flex;opacity:1}.gallery-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000f2;background:#000000fa;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);transition:all .4s ease}.gallery-modal-content{position:relative;width:95%;max-width:1200px;height:95%;max-height:900px;background:#fff;border-radius:25px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 80px #0000004d,0 0 0 1px #ffffff1a;z-index:10000;transform:scale(.9);transition:all .4s cubic-bezier(.4,0,.2,1)}.gallery-modal.active .gallery-modal-content{transform:scale(1)}.gallery-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,var(--verde-selva),var(--marron-madera));color:#fff;position:relative;overflow:hidden}.gallery-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.gallery-modal.active .gallery-header:before{left:100%}.gallery-title{font-size:1.5rem;margin:0;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3)}.gallery-close{background:#ffffff1a;background:#fff3;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.75rem;border-radius:50%;transition:all .3s ease;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.gallery-close:hover{background:#fff3;transform:rotate(90deg) scale(1.1)}.gallery-main{flex:1;display:flex;flex-direction:column;position:relative;min-height:0}.gallery-main-image{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);overflow:hidden;min-height:400px}.gallery-main-image img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:15px;box-shadow:0 15px 40px #0003;transition:all .5s cubic-bezier(.4,0,.2,1);opacity:1;transform:scale(1)}.gallery-main-image img.loaded{opacity:1;transform:scale(1)}.gallery-main-image img.ken-burns{animation:kenBurnsEffect 20s ease-in-out infinite alternate}@keyframes kenBurnsEffect{0%{transform:scale(1) translate(0) translateY(0)}25%{transform:scale(1.05) translate(-1%) translateY(-1%)}50%{transform:scale(1.08) translate(1%) translateY(1%)}75%{transform:scale(1.03) translate(-.5%) translateY(.5%)}to{transform:scale(1.06) translate(.5%) translateY(-.5%)}}.gallery-thumbnail-overlay{position:absolute;bottom:0;left:0;right:0;height:100px;z-index:25;opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);pointer-events:none}.gallery-thumbnail-overlay.show,.gallery-thumbnail-overlay.auto-show{opacity:1;transform:translateY(0);pointer-events:auto}.thumbnail-overlay-backdrop{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.4) 30%,rgba(0,0,0,.8) 70%,rgba(0,0,0,.95) 100%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:0 0 15px 15px}.thumbnail-overlay-container{position:relative;z-index:26;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:20px 24px;height:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.thumbnail-overlay-container::-webkit-scrollbar{display:none}.gallery-thumbnail-overlay-item{flex-shrink:0;width:70px;height:60px;border-radius:12px;background-size:cover;background-position:center;background-repeat:no-repeat;border:2px solid rgba(255,255,255,.3);cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);opacity:.7;position:relative;overflow:hidden;box-shadow:0 6px 20px #0006}.gallery-thumbnail-overlay-item:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);transition:transform .6s ease}.gallery-thumbnail-overlay-item:hover:before{transform:translate(100%)}.gallery-thumbnail-overlay-item.active{border-color:#87ceebe6;box-shadow:0 0 0 2px #87ceeb80,0 8px 25px #00000080;opacity:1;transform:scale(1.1) translateY(-4px)}.gallery-thumbnail-overlay-item:hover{transform:scale(1.15) translateY(-6px);opacity:1;border-color:#fffc;box-shadow:0 10px 30px #00000080}.gallery-thumbnail-overlay-item.active:hover{transform:scale(1.2) translateY(-8px)}.image-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:none;z-index:10}.image-loader.active{display:block}.image-loader .loader-spinner{width:50px;height:50px;border:4px solid rgba(46,94,58,.2);border-left:4px solid var(--verde-selva);border-radius:50%;animation:spin 1s linear infinite}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:#2e5e3acc;color:#fff;border:none;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(15px);border:2px solid rgba(255,255,255,.2);font-size:1.2rem;z-index:20}.gallery-prev{left:2rem}.gallery-next{right:2rem}.gallery-nav:hover{background:var(--verde-selva);transform:translateY(-50%) scale(1.15);box-shadow:0 8px 25px #2e5e3a66}.gallery-nav:active{transform:translateY(-50%) scale(1.05)}.gallery-info{padding:1.5rem 2rem;background:linear-gradient(135deg,#f8f9fa,#fff);border-top:1px solid rgba(0,0,0,.1);position:relative}.gallery-counter{display:inline-flex;align-items:center;background:var(--verde-selva);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;margin-bottom:1rem}.gallery-description{color:var(--verde-selva);line-height:1.6;font-size:1rem}@media (max-width: 1024px){.gallery-modal-content{width:96%;height:94%;max-height:85vh;border-radius:20px}.gallery-nav{width:55px;height:55px;font-size:1.1rem}.gallery-prev{left:1.5rem}.gallery-next{right:1.5rem}.gallery-thumbnail-overlay{height:90px}.gallery-thumbnail-overlay-item{width:65px;height:55px}.thumbnail-overlay-container{gap:10px;padding:18px 22px}}@media (max-width: 768px){.gallery-modal-content{width:98%;height:95%;max-height:90vh;margin:1% auto;border-radius:15px}.gallery-main-image{min-height:300px}.gallery-nav{width:50px;height:50px;font-size:1rem}.gallery-prev{left:1rem}.gallery-next{right:1rem}.gallery-header{padding:1rem 1.5rem}.gallery-title{font-size:1.2rem}.gallery-info{padding:1rem 1.5rem}.gallery-thumbnail-overlay{height:80px}.gallery-thumbnail-overlay-item{width:55px;height:45px;border-radius:10px}.thumbnail-overlay-container{gap:8px;padding:15px 18px}}@media (max-width: 480px){.gallery-modal-content{width:95%;height:92%;max-height:88vh;border-radius:12px}.gallery-main-image{min-height:250px}.gallery-nav{width:45px;height:45px;font-size:.9rem}.gallery-prev{left:.5rem}.gallery-next{right:.5rem}.gallery-header{padding:.8rem 1rem}.gallery-title{font-size:1rem}.gallery-close{padding:.6rem;font-size:1.2rem}.gallery-info{padding:.8rem 1rem}.gallery-counter{padding:.3rem .8rem;font-size:.8rem}.gallery-description{font-size:.9rem}.gallery-thumbnail-overlay{height:70px}.gallery-thumbnail-overlay-item{width:45px;height:35px;border-radius:8px}.thumbnail-overlay-container{gap:6px;padding:12px 15px}}@media (max-width: 360px){.gallery-modal-content{width:98%;height:90%;border-radius:10px}.gallery-main-image{min-height:220px}.gallery-nav{width:40px;height:40px;font-size:.8rem}.gallery-prev{left:.3rem}.gallery-next{right:.3rem}.gallery-header{padding:.6rem .8rem}.gallery-title{font-size:.9rem}.gallery-close{padding:.5rem;font-size:1rem}.gallery-info{padding:.6rem .8rem}.gallery-counter{padding:.2rem .6rem;font-size:.7rem}.gallery-description{font-size:.8rem}.gallery-thumbnail-overlay{height:60px}.gallery-thumbnail-overlay-item{width:40px;height:30px;border-radius:6px}.thumbnail-overlay-container{gap:4px;padding:10px 12px}}@media (hover: none) and (pointer: coarse){.gallery-thumbnail-overlay{opacity:0;animation:galleryTouchAutoShow 1s ease-in-out 2s forwards,galleryTouchAutoHide 1s ease-in-out 8s forwards}.gallery-thumbnail-overlay-item:hover{transform:none}.gallery-thumbnail-overlay-item:active{transform:scale(.95);opacity:.9}.gallery-thumbnail-overlay-item.active:active{transform:scale(1.05) translateY(-2px)}.gallery-main-image:hover .gallery-thumbnail-overlay{opacity:1;transform:translateY(0)}.gallery-thumbnail-overlay-item{min-width:44px;min-height:44px}}@media (orientation: landscape) and (max-height: 600px){.gallery-modal-content{height:98%;max-height:95vh}.gallery-main-image{min-height:200px}.gallery-header,.gallery-info{padding:.8rem 1.5rem}.gallery-thumbnail-overlay{height:70px}.gallery-thumbnail-overlay-item{width:50px;height:40px}.thumbnail-overlay-container{padding:12px 18px}}@keyframes galleryTouchAutoShow{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes galleryTouchAutoHide{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.gallery-thumbnail-overlay-item,.gallery-nav{border-width:1px}}@supports not (backdrop-filter: blur(1px)){.gallery-backdrop{background:#000000fa!important}.gallery-close{background:#ffffff40!important}.gallery-nav{background:#ffffffe6!important}}@supports (-ms-ime-align: auto){.gallery-modal,.gallery-modal.active{display:block}.gallery-modal-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-height:90vh;max-width:90vw}}.accommodation-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:3rem;margin-top:4rem}.accommodation-card{background:#fff;border-radius:25px;overflow:hidden;box-shadow:var(--shadow-soft);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer}.accommodation-card:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#87ceeb1a,#2e5e3a1a);opacity:0;transition:opacity .4s ease;pointer-events:none}.accommodation-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(46,94,58,.05) 100%);opacity:0;transition:opacity .4s ease}.accommodation-card:hover:before{opacity:1}.accommodation-card:hover:after{opacity:1}.accommodation-card:hover{transform:translateY(-20px) scale(1.03);box-shadow:var(--shadow-hover)}.accommodation-card:hover .card-image{transform:scale(1.1)}.card-image{height:250px;background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;overflow:hidden;transition:transform .4s cubic-bezier(.4,0,.2,1)}.card-image:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,.3),transparent)}.card-image:before{content:"🖼️ Ver Galería";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;color:var(--verde-selva);padding:.8rem 1.5rem;border-radius:25px;font-size:1rem;font-weight:600;opacity:0;transition:all .3s ease;backdrop-filter:blur(10px);z-index:5;pointer-events:none}.accommodation-card:hover .card-image:before{opacity:1}.image-overlay-band{position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.75) 100%);opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);z-index:3;pointer-events:none}.accommodation-card:hover .image-overlay-band{opacity:1;transform:translateY(0)}.accommodation-card .image-overlay-band.auto-hide{animation:autoFadeIn .6s ease-in-out forwards,autoFadeOut .6s ease-in-out 3s forwards}@keyframes autoFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes autoFadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.card-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .3s ease;display:none}.accommodation-card:hover .card-overlay{opacity:1}.view-gallery-btn{background:#ffffffe6;color:var(--verde-selva);border:none;padding:1rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;backdrop-filter:blur(10px);display:none}.view-gallery-btn:hover{background:#fff;transform:scale(1.05)}.card-content{padding:2.5rem;position:relative}.card-title{font-size:1.5rem;margin-bottom:1.5rem;color:var(--verde-selva);font-weight:600}.card-cta-btn{background:linear-gradient(45deg,var(--azul-cielo),#7BC4E8);color:var(--verde-selva);border:none;padding:.8rem 1.5rem;border-radius:25px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;margin-top:1rem;transition:all .3s ease}.card-cta-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #87ceeb66}@media (max-width: 1024px){.accommodation-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}}@media (max-width: 768px){.accommodation-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.accommodation-card{margin-bottom:1.5rem}.card-image{height:220px}.card-content{padding:1.5rem}.card-title{font-size:1.3rem;margin-bottom:1rem}.card-cta-btn{font-size:.85rem;padding:.7rem 1.2rem}}@media (max-width: 480px){.accommodation-grid{grid-template-columns:1fr;gap:1.2rem}.accommodation-card{margin-bottom:1.5rem}.card-image{height:200px}.card-content{padding:1rem}.card-title{font-size:1.2rem;margin-bottom:.8rem}.view-gallery-btn{padding:.8rem 1.5rem;font-size:.9rem}.card-cta-btn{font-size:.8rem;padding:.6rem 1rem}}body{margin-top:70px}.whatsapp-float{position:fixed;width:70px;height:70px;bottom:30px;right:30px;background:linear-gradient(45deg,#25d366,#128c7e);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:35px;z-index:1000;box-shadow:0 8px 25px #25d36666;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none}.whatsapp-float:before{content:"";position:absolute;width:100%;height:100%;border-radius:50%;background:#25d366;animation:ripple 2s infinite}@keyframes ripple{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.4);opacity:0}to{transform:scale(1.4);opacity:0}}.whatsapp-float:hover{transform:translateY(-5px) scale(1.1);box-shadow:0 15px 35px #25d36699}.about{background:linear-gradient(135deg,#e6d2aa4d,#e6d2aa1a),var(--blanco-natural);padding:8rem 0;position:relative;overflow:hidden}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:2}.about-text{font-size:1.2rem;line-height:2;color:var(--verde-selva)}.about-text p{margin-bottom:2rem;opacity:0;animation:fadeInLeft 1s ease-out forwards}.about-text p:nth-child(2){animation-delay:.2s}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.about-text .highlight{color:var(--azul-cielo);font-weight:700}.about-image{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-soft);transition:all .4s ease}.about-image:hover{transform:translateY(-10px);box-shadow:var(--shadow-hover)}.about-image img{width:100%;height:400px;object-fit:cover;transition:transform .4s ease}.about-image:hover img{transform:scale(1.05)}.accommodations{background:var(--blanco-natural);padding:8rem 0}.accommodations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:3rem;margin:4rem 0}.contact{background:linear-gradient(135deg,var(--verde-selva) 0%,#1a3d24 100%);color:#fff;padding:8rem 0;position:relative;overflow:hidden}.contact:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(230,210,170,.1) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(135,206,235,.08) 0%,transparent 50%);opacity:.7}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;position:relative;z-index:2;margin-bottom:4rem}.contact-left{display:flex;flex-direction:column;gap:3rem}.contact-info{padding:2rem 0}.contact-hero{text-align:center;margin-bottom:5rem;position:relative;z-index:2}.contact-hero h2{font-size:4rem;margin-bottom:2rem;background:linear-gradient(45deg,var(--beige-tierra),var(--azul-cielo));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.contact-hero p{font-size:1.4rem;opacity:.9;max-width:600px;margin:0 auto;line-height:1.8}.contact-info h3{color:var(--beige-tierra);margin-bottom:2rem;font-size:1.8rem}.contact-details{background:#ffffff1a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:15px;padding:2rem;margin-top:2rem}.contact-item{margin-bottom:1.5rem;display:flex;align-items:center;gap:1.2rem;padding:1.5rem;background:#ffffff14;border-radius:15px;border-left:4px solid var(--beige-tierra);transition:all .3s ease;backdrop-filter:blur(10px)}.contact-item:hover{background:#ffffff1f;transform:translate(8px);border-left-color:var(--azul-cielo)}.contact-item .contact-icon{width:20px;height:20px;color:var(--beige-tierra);transition:all .3s ease;flex-shrink:0}.contact-item:hover .contact-icon{color:var(--azul-cielo);transform:scale(1.1)}.contact-item i{width:24px;height:24px;color:var(--azul-cielo);font-size:1.2rem}.contact-item span{font-size:1rem;opacity:.9}footer{background:linear-gradient(135deg,var(--marron-madera),#654321);color:#fff;padding:4rem 0 2rem;text-align:center;position:relative}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.footer-section h3{color:var(--beige-tierra);margin-bottom:1rem;font-size:1.2rem}.footer-section p,.footer-section a{color:#fffc;text-decoration:none;line-height:1.6;transition:color .3s ease}.footer-section a:hover{color:#fff}.footer-social,.social-links{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.footer-social a,.social-links a{color:#fff;font-size:1.8rem;transition:all .3s ease;padding:1rem;border-radius:50%;background:#ffffff1a;text-decoration:none;width:60px;height:60px;display:flex;align-items:center;justify-content:center}.footer-social a:hover,.social-links a:hover{color:var(--azul-cielo);transform:translateY(-5px) scale(1.1);background:#fff3}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;text-align:center;opacity:.8}@media (max-width: 1024px){.about-content,.contact-content{grid-template-columns:1fr;gap:2.5rem}.accommodations-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (max-width: 768px){section{padding:5rem 0}.section-title{font-size:2.5rem}.about-image img{height:300px}.contact-hero h2{font-size:2.5rem}.accommodations-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.whatsapp-float{width:60px;height:60px;font-size:30px;bottom:25px;right:25px}}@media (max-width: 480px){body{margin-top:60px}section{padding:3rem 0}.section-title{font-size:2rem}.about-text{font-size:1rem;line-height:1.6}.contact-hero h2{font-size:2rem}.contact-form{padding:1.5rem}.footer-content{grid-template-columns:1fr}}:root{--verde-selva: #2E5E3A;--beige-tierra: #E6D2AA;--azul-cielo: #87CEEB;--blanco-natural: #FAFAFA;--marron-madera: #8B4513;--shadow-soft: 0 10px 30px rgba(0, 0, 0, .1);--shadow-hover: 0 20px 40px rgba(0, 0, 0, .15)}[data-astro-cid-sckkx6r4]{margin:0;padding:0;box-sizing:border-box}body{font-family:Georgia,serif;line-height:1.6;color:var(--verde-selva);background-color:var(--blanco-natural);overflow-x:hidden;font-size:16px;margin-top:70px}header[data-astro-cid-sckkx6r4]{background:#2e5e3af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);color:#fff;padding:1rem 0;position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,background-color;contain:layout style paint;transform:translateZ(0)}.container[data-astro-cid-sckkx6r4]{max-width:1200px;margin:0 auto;padding:0 2rem}nav[data-astro-cid-sckkx6r4]{display:flex;justify-content:space-between;align-items:center}.logo[data-astro-cid-sckkx6r4]{display:flex;align-items:center;gap:1rem;font-weight:700;font-size:1.1rem}.logo-image[data-astro-cid-sckkx6r4] img[data-astro-cid-sckkx6r4]{width:60px;height:60px;border-radius:8px;object-fit:cover}.hero[data-astro-cid-sckkx6r4]{min-height:100vh;background:linear-gradient(135deg,#2e5e3acc,#2e5e3a99);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;overflow:hidden;will-change:background-image;contain:layout style paint;transform:translateZ(0);backface-visibility:hidden}.hero[data-astro-cid-sckkx6r4]:before{content:"";position:absolute;inset:0;background-image:url(/images/vista-desde-el-patio-a-las-cabanas.webp);background-size:cover;background-position:center;background-attachment:fixed;z-index:-1;opacity:0;transition:opacity .5s ease}.hero[data-astro-cid-sckkx6r4].image-loaded:before{opacity:1}.hero-content[data-astro-cid-sckkx6r4]{position:relative;z-index:2;max-width:800px;padding:2rem}.hero-content[data-astro-cid-sckkx6r4] h1[data-astro-cid-sckkx6r4]{font-size:clamp(2.5rem,5vw,4rem);margin-bottom:1.5rem;font-weight:300;text-shadow:0 4px 8px rgba(0,0,0,.3);line-height:1.2}.hero-content[data-astro-cid-sckkx6r4] p[data-astro-cid-sckkx6r4]{font-size:clamp(1.1rem,2.5vw,1.4rem);margin-bottom:2.5rem;opacity:.95;text-shadow:0 2px 4px rgba(0,0,0,.3);max-width:600px;margin-left:auto;margin-right:auto}.cta-button[data-astro-cid-sckkx6r4]{display:inline-flex;align-items:center;gap:.8rem;background:linear-gradient(45deg,var(--azul-cielo),#5fb3d4);color:#fff;padding:1rem 2.5rem;border-radius:50px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #87ceeb66;border:2px solid transparent;position:relative;overflow:hidden}.cta-button[data-astro-cid-sckkx6r4]:hover{transform:translateY(-3px);box-shadow:0 15px 35px #87ceeb99;border-color:#ffffff4d}.page-loader[data-astro-cid-sckkx6r4]{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--verde-selva) 0%,#1a3d24 100%);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease,visibility .5s ease}.page-loader[data-astro-cid-sckkx6r4].hidden{opacity:0;visibility:hidden}.loader-content[data-astro-cid-sckkx6r4]{text-align:center;color:#fff;padding:2rem}.loader-logo[data-astro-cid-sckkx6r4]{width:min(300px,60vw);height:min(300px,60vw);max-width:280px;max-height:280px;margin:0 auto 2rem;position:relative;animation:pulse-glow 2s ease-in-out infinite;border-radius:50%;overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center}.loader-logo[data-astro-cid-sckkx6r4] img[data-astro-cid-sckkx6r4]{width:100%;height:100%;object-fit:cover;border-radius:50%;border:4px solid var(--beige-tierra);background:transparent;box-shadow:0 0 0 8px #e6d2aa4d,0 0 0 16px #e6d2aa1a,0 20px 40px #0000004d;transition:all .3s ease;clip-path:circle(50% at center)}.loader-text[data-astro-cid-sckkx6r4]{font-size:clamp(1rem,2.5vw,1.2rem);margin-bottom:2rem;opacity:.8;padding:0 1rem;text-align:center;color:#fff}.loader-spinner[data-astro-cid-sckkx6r4]{width:min(50px,10vw);height:min(50px,10vw);min-width:30px;min-height:30px;border:3px solid rgba(230,210,170,.3);border-top:3px solid var(--beige-tierra);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes pulse-glow{0%,to{box-shadow:0 10px 30px #87ceeb66;transform:scale(1)}50%{box-shadow:0 15px 40px #87ceeb99;transform:scale(1.01)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scroll-progress[data-astro-cid-sckkx6r4]{position:fixed;top:0;left:0;width:0%;height:4px;background:linear-gradient(90deg,var(--azul-cielo),var(--beige-tierra));z-index:1001;transition:width .1s ease}@media (max-width: 768px){body{font-size:15px}.hero[data-astro-cid-sckkx6r4]{background-attachment:scroll}.hero-content[data-astro-cid-sckkx6r4] h1[data-astro-cid-sckkx6r4]{font-size:2.5rem}.hero-content[data-astro-cid-sckkx6r4] p[data-astro-cid-sckkx6r4]{font-size:1.2rem}.cta-button[data-astro-cid-sckkx6r4]{padding:12px 24px;font-size:1rem}}@media (max-width: 480px){body{font-size:14px}.hero-content[data-astro-cid-sckkx6r4] h1[data-astro-cid-sckkx6r4]{font-size:2rem}.hero-content[data-astro-cid-sckkx6r4] p[data-astro-cid-sckkx6r4]{font-size:1rem}.cta-button[data-astro-cid-sckkx6r4]{padding:10px 20px;font-size:.9rem}}
