:root{--color-primary:#D4A533;--color-primary-dark:#B8901F;--color-secondary:#4A4A4A;--color-accent:#D4A533;--color-bg:#FFFFFF;--color-bg-alt:#F7F6F3;--color-bg-dark:#1A1A1A;--color-text:#2C2C2C;--color-text-light:#6B6B6B;--color-text-white:#F5F5F5;--color-border:#E0DDD6;--font-heading:'Montserrat',sans-serif;--font-body:'Source Serif 4',serif;--radius-sm:4px;--radius-md:8px;--radius-lg:12px}
html{color-scheme:light;scroll-behavior:smooth}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}
button,a,input,textarea,select{touch-action:manipulation;-webkit-tap-highlight-color:transparent}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
img{max-width:100%;height:auto;display:block}
section[id]{scroll-margin-top:80px}
.skip-link{position:absolute;top:-100%;left:0;z-index:9999;background:var(--color-primary);color:#fff;padding:12px 24px;font-family:var(--font-heading);font-weight:600;text-decoration:none}
.skip-link:focus{top:0}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 40px}}
@media(min-width:1240px){.container{padding:0}}
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background-color 0.4s ease,box-shadow 0.4s ease}
.navbar.scrolled{background:rgba(255,255,255,0.98);box-shadow:0 2px 20px rgba(0,0,0,0.08)}
.navbar-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:80px}
@media(min-width:768px){.navbar-inner{padding:0 40px}}
@media(min-width:1240px){.navbar-inner{padding:0}}
.navbar-logo img{height:48px;width:auto;transition:filter 0.3s ease}
.navbar:not(.scrolled) .navbar-logo img{filter:brightness(0) invert(1)}
.nav-links{display:none;list-style:none;gap:32px;align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{font-family:var(--font-heading);font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;text-decoration:none;color:#fff;transition:color 0.3s ease;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-primary);transition:width 0.3s ease}
.nav-links a:hover::after{width:100%}
.navbar.scrolled .nav-links a{color:var(--color-text)}
.navbar.scrolled .nav-links a:hover{color:var(--color-primary)}
.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
@media(min-width:1024px){.hamburger{display:none}}
.hamburger span{width:24px;height:2px;background:#fff;transition:transform 0.3s ease,opacity 0.3s ease,background-color 0.3s ease}
.navbar.scrolled .hamburger span{background:var(--color-text)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(26,26,26,0.97);z-index:999;align-items:center;justify-content:center;overscroll-behavior:contain}
.mobile-menu.open{display:flex}
.mobile-menu-links{list-style:none;text-align:center}
.mobile-menu-links li{margin-bottom:24px}
.mobile-menu-links a{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:#fff;text-decoration:none;transition:color 0.3s ease}
.mobile-menu-links a:hover{color:var(--color-primary)}
.hero{position:relative;min-height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:120px 0 60px}
.hero-bg{position:absolute;top:0;left:0;width:100%;height:120%;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease-in-out}
.hero-slide.active{opacity:1}
.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(rgba(0,0,0,0.45),rgba(0,0,0,0.65));z-index:1}
.hero-shape-1{position:absolute;width:300px;height:300px;border-radius:50%;background:var(--color-primary);filter:blur(100px);opacity:0.08;top:10%;right:-5%;z-index:2;animation:float 7s ease-in-out infinite}
.hero-shape-2{position:absolute;width:200px;height:200px;border-radius:50%;background:var(--color-primary);filter:blur(80px);opacity:0.06;bottom:20%;left:-3%;z-index:2;animation:float 8s ease-in-out infinite 1s}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(3deg)}}
.hero-content{position:relative;z-index:3;text-align:center;max-width:800px;padding:0 24px}
.hero-content h1{font-family:var(--font-heading);font-size:2.5rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:3px;line-height:1.15;text-wrap:balance;margin-bottom:8px;animation:fadeInUp 0.8s ease forwards;opacity:0}
.hero-accent{color:var(--color-primary)}
.hero-tagline{font-family:var(--font-heading);font-size:1rem;font-weight:500;color:var(--color-primary);text-transform:uppercase;letter-spacing:4px;margin-bottom:24px;animation:fadeInUp 0.8s ease 0.2s forwards;opacity:0}
.hero-desc{font-family:var(--font-body);font-size:1.125rem;color:rgba(255,255,255,0.85);line-height:1.7;margin-bottom:40px;animation:fadeInUp 0.8s ease 0.3s forwards;opacity:0}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.btn-primary{display:inline-block;font-family:var(--font-heading);font-size:0.85rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;padding:16px 40px;background:var(--color-primary);color:var(--color-bg-dark);border:none;border-radius:var(--radius-sm);text-decoration:none;cursor:pointer;transition:background-color 0.3s ease,transform 0.3s ease,box-shadow 0.3s ease;animation:fadeInUp 0.8s ease 0.5s forwards,pulse 2.5s infinite 1.5s;opacity:0}
.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-2px)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(212,165,51,0.4)}50%{box-shadow:0 0 20px 4px rgba(212,165,51,0.15)}}
@media(min-width:768px){.hero-content h1{font-size:3.5rem;letter-spacing:4px}.hero-tagline{font-size:1.1rem}}
@media(min-width:1024px){.hero-content h1{font-size:4rem}}
.section-title{font-family:var(--font-heading);font-size:2rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;text-align:center;color:var(--color-text);margin-bottom:16px;text-wrap:balance}
@media(min-width:768px){.section-title{font-size:2.25rem}}
.section-subtitle{font-family:var(--font-body);font-size:1.0625rem;color:var(--color-text-light);text-align:center;max-width:600px;margin:0 auto 56px;line-height:1.7}
.section-line{width:60px;height:3px;background:var(--color-primary);margin:0 auto 20px;border-radius:2px}
.separator{height:1px;background:linear-gradient(to right,transparent,rgba(212,165,51,0.2),transparent);border:none}
.section-padding{padding:80px 0}
@media(min-width:768px){.section-padding{padding:100px 0}}
.porque-section{background:var(--color-bg-alt);position:relative;overflow:hidden}
.porque-section .deco-shape-1{position:absolute;width:250px;height:250px;border-radius:50%;background:var(--color-primary);filter:blur(100px);opacity:0.05;top:-50px;left:-50px;animation:float 8s ease-in-out infinite}
.porque-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.porque-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.porque-grid{grid-template-columns:repeat(4,1fr)}}
.porque-card{background:#fff;padding:40px 28px;border-radius:var(--radius-md);border:1px solid var(--color-border);text-align:center;transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;position:relative}
.porque-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.08);border-color:var(--color-primary)}
.porque-card .icon-circle{width:64px;height:64px;border-radius:50%;background:rgba(212,165,51,0.1);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.porque-card .material-icons{font-size:28px;color:var(--color-primary)}
.porque-card h3{font-family:var(--font-heading);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;color:var(--color-text)}
.porque-card p{font-size:0.9375rem;color:var(--color-text-light);line-height:1.7}
.counters-section{background:var(--color-bg-dark);padding:64px 0;position:relative;overflow:hidden}
.counters-shape{position:absolute;width:200px;height:200px;border-radius:50%;background:var(--color-primary);filter:blur(80px);opacity:0.06;bottom:-40px;right:10%;animation:float 7s ease-in-out infinite 0.5s}
.counters-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;text-align:center}
@media(min-width:768px){.counters-grid{grid-template-columns:repeat(4,1fr)}}
.counter-item .counter-number{font-family:var(--font-heading);font-size:2.75rem;font-weight:800;color:var(--color-primary);display:block;font-variant-numeric:tabular-nums}
.counter-item .counter-label{font-family:var(--font-heading);font-size:0.75rem;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,0.6);margin-top:4px}
.proceso-section{background:var(--color-bg);position:relative;overflow:hidden}
.proceso-section .deco-shape-2{position:absolute;width:200px;height:200px;border-radius:50%;background:var(--color-primary);filter:blur(80px);opacity:0.04;bottom:10%;right:-5%;animation:float 6s ease-in-out infinite 2s}
.proceso-layout{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.proceso-layout{grid-template-columns:1fr 1fr;gap:80px}}
.proceso-image-wrap{overflow:hidden;border-radius:var(--radius-lg);position:relative}
.proceso-image-wrap img{transition:transform 0.5s ease;width:100%;display:block}
.proceso-image-wrap:hover img{transform:scale(1.03)}
.timeline{position:relative;padding-left:32px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--color-primary),rgba(212,165,51,0.2))}
.timeline-item{position:relative;margin-bottom:40px}
.timeline-item:last-child{margin-bottom:0}
.timeline-item::before{content:'';position:absolute;left:-37px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--color-primary);border:3px solid var(--color-bg);box-shadow:0 0 0 2px var(--color-primary)}
.timeline-item h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-text);margin-bottom:8px}
.timeline-item p{font-size:0.9375rem;color:var(--color-text-light);line-height:1.7}
.servicios-section{background:var(--color-bg-alt);position:relative;overflow:hidden}
.servicios-section .deco-shape-3{position:absolute;width:280px;height:280px;border-radius:50%;background:var(--color-primary);filter:blur(100px);opacity:0.04;top:-60px;right:-80px;animation:float 8s ease-in-out infinite}
.servicios-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.servicios-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.servicios-grid{grid-template-columns:repeat(3,1fr)}}
.servicio-card{background:#fff;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}
.servicio-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,0.08);border-color:var(--color-primary)}
.servicio-card-img{overflow:hidden;height:220px;position:relative}
.servicio-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.servicio-card:hover .servicio-card-img img{transform:scale(1.05)}
.card-carousel{position:relative}
.card-carousel .card-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s ease-in-out, transform 0.5s ease}
.card-carousel .card-slide.active{opacity:1}
.servicio-card-body{padding:28px 24px}
.servicio-card-body .material-icons{font-size:28px;color:var(--color-primary);margin-bottom:12px}
.servicio-card-body h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;color:var(--color-text)}
.servicio-card-body p{font-size:0.9375rem;color:var(--color-text-light);line-height:1.7;margin-bottom:20px}
.btn-secondary{display:inline-block;font-family:var(--font-heading);font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;padding:12px 28px;border:2px solid var(--color-primary);color:var(--color-primary);background:transparent;border-radius:var(--radius-sm);text-decoration:none;transition:background-color 0.3s ease,color 0.3s ease,transform 0.3s ease;cursor:pointer}
.btn-secondary:hover{background:var(--color-primary);color:var(--color-bg-dark);transform:translateY(-2px)}
.galeria-section{background:var(--color-bg);position:relative}
.galeria-section::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 70%,rgba(212,165,51,0.03),transparent 60%);pointer-events:none}
.galeria-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.galeria-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.galeria-grid{grid-template-columns:repeat(3,1fr)}}
.galeria-item{overflow:hidden;border-radius:var(--radius-md);height:280px;position:relative;background:#1a1a1a}
.galeria-item img,.galeria-item video{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s ease}
.galeria-item:hover img,.galeria-item:hover video{transform:scale(1.08)}
.galeria-item.is-video::after{content:'\e039';font-family:'Material Icons';position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(212,165,51,0.95);color:#1a1a1a;display:flex;align-items:center;justify-content:center;font-size:18px;pointer-events:none;z-index:2}
.testimonios-section{background:var(--color-bg-alt);position:relative;overflow:hidden}
.testimonios-section .deco-shape-4{position:absolute;width:220px;height:220px;border-radius:50%;background:var(--color-primary);filter:blur(90px);opacity:0.05;top:10%;left:-5%;animation:float 7s ease-in-out infinite 1.5s}
.testimonios-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.testimonios-grid{grid-template-columns:repeat(3,1fr)}}
.testimonio-card{background:#fff;padding:36px 28px;border-radius:var(--radius-md);border:1px solid var(--color-border);transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease;position:relative}
.testimonio-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,0.06);border-color:var(--color-primary)}
.testimonio-quote{font-family:var(--font-heading);font-size:3rem;color:var(--color-primary);opacity:0.3;line-height:1;margin-bottom:8px}
.testimonio-text{font-size:0.9375rem;color:var(--color-text-light);line-height:1.7;margin-bottom:24px;font-style:italic}
.testimonio-stars{margin-bottom:16px;display:flex;gap:2px}
.testimonio-stars .material-icons{font-size:18px;color:var(--color-primary)}
.testimonio-author{display:flex;align-items:center;gap:12px}
.testimonio-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}
.testimonio-name{font-family:var(--font-heading);font-size:0.875rem;font-weight:700;color:var(--color-text)}
.testimonio-role{font-size:0.8125rem;color:var(--color-text-light)}
.faq-section{background:var(--color-bg)}
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--color-border)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:20px 0;background:none;border:none;cursor:pointer;font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--color-text);text-align:left;gap:16px;transition:color 0.3s ease}
.faq-question:hover{color:var(--color-primary)}
.faq-question .material-icons{font-size:24px;transition:transform 0.3s ease;flex-shrink:0;color:var(--color-primary)}
.faq-question[aria-expanded="true"] .material-icons{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease}
.faq-answer.open{max-height:200px;padding-bottom:20px}
.faq-answer p{font-size:0.9375rem;color:var(--color-text-light);line-height:1.7}
.contacto-section{background:var(--color-bg-alt);position:relative;overflow:hidden}
.contacto-section .deco-shape-5{position:absolute;width:180px;height:180px;border-radius:50%;background:var(--color-primary);filter:blur(80px);opacity:0.04;bottom:5%;right:-3%;animation:float 6s ease-in-out infinite}
.contacto-layout{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:1024px){.contacto-layout{grid-template-columns:1fr 1fr;gap:64px}}
.contacto-form .form-group{margin-bottom:20px}
.contacto-form label{display:block;font-family:var(--font-heading);font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text);margin-bottom:8px}
.contacto-form input,.contacto-form textarea{width:100%;font-family:var(--font-body);font-size:1rem;padding:14px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-text);transition:border-color 0.3s ease,box-shadow 0.3s ease}
.contacto-form input:focus,.contacto-form textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(212,165,51,0.1)}
.contacto-form textarea{min-height:120px;resize:vertical}
.contacto-form .btn-submit{display:inline-block;font-family:var(--font-heading);font-size:0.85rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;padding:16px 40px;background:var(--color-primary);color:var(--color-bg-dark);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color 0.3s ease,transform 0.3s ease;width:100%}
@media(min-width:768px){.contacto-form .btn-submit{width:auto}}
.contacto-form .btn-submit:hover{background:var(--color-primary-dark);transform:translateY(-2px)}
.form-success{display:none;padding:16px 20px;background:rgba(212,165,51,0.1);border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-heading);font-size:0.9rem;font-weight:600;margin-top:16px}
.contacto-info-item{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.contacto-info-item .icon-wrap{width:48px;height:48px;border-radius:50%;background:rgba(212,165,51,0.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contacto-info-item .material-icons,.contacto-info-item .fab{font-size:22px;color:var(--color-primary)}
.contacto-info-item h4{font-family:var(--font-heading);font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text);margin-bottom:4px}
.contacto-info-item p,.contacto-info-item a{font-size:0.9375rem;color:var(--color-text-light);text-decoration:none;transition:color 0.3s ease}
.contacto-info-item a:hover{color:var(--color-primary)}
.contacto-map{margin-top:24px}
.footer{background:var(--color-bg-dark);color:rgba(255,255,255,0.7);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.1)}
@media(min-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand img{height:40px;margin-bottom:16px;filter:brightness(0) invert(1)}
.footer-brand p{font-size:0.9375rem;line-height:1.7;color:rgba(255,255,255,0.5)}
.footer h4{font-family:var(--font-heading);font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#fff;margin-bottom:20px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:10px}
.footer-links a{font-size:0.9375rem;color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.3s ease}
.footer-links a:hover{color:var(--color-primary)}
.footer-contact-item{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:0.875rem}
.footer-contact-item .material-icons,.footer-contact-item .fab{font-size:18px;color:var(--color-primary)}
.footer-contact-item a{color:rgba(255,255,255,0.5);text-decoration:none;transition:color 0.3s ease}
.footer-contact-item a:hover{color:var(--color-primary)}
.footer-social{display:flex;gap:12px;margin-top:16px}
.footer-social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);text-decoration:none;transition:background-color 0.3s ease,color 0.3s ease,border-color 0.3s ease}
.footer-social a:hover{background:var(--color-primary);color:var(--color-bg-dark);border-color:var(--color-primary)}
.footer-bottom{padding:24px 0;text-align:center;font-size:0.8125rem;color:rgba(255,255,255,0.35)}
.footer-bottom a{color:var(--color-primary);text-decoration:none}
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;text-decoration:none;z-index:900;box-shadow:0 4px 16px rgba(37,211,102,0.4);animation:whatsappPulse 2s infinite;transition:transform 0.3s ease,box-shadow 0.3s ease}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(37,211,102,0.5)}
@keyframes whatsappPulse{0%,100%{box-shadow:0 4px 16px rgba(37,211,102,0.4)}50%{box-shadow:0 4px 24px rgba(37,211,102,0.6),0 0 0 8px rgba(37,211,102,0.1)}}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}.reveal{opacity:1;transform:none}}
