:root{--primary: #1E3A8A;--primary-light: rgba(30, 58, 138, .85);--secondary: #0F172A;--accent: #3B82F6;--bg-color: #FFFFFF;--bg-alt: #F8FAFC;--text-main: #334155;--text-light: #64748B;--white: #FFFFFF;--font-heading: "Outfit", sans-serif;--font-body: "Inter", sans-serif;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .025);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .05), 0 10px 10px -5px rgba(0, 0, 0, .02);--radius: 12px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text-main);background-color:var(--bg-color);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--secondary);font-weight:600;line-height:1.2}a{text-decoration:none;color:inherit;transition:var(--transition)}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;border-radius:8px;font-weight:500;font-family:var(--font-heading);cursor:pointer;transition:var(--transition);border:2px solid transparent;text-align:center}.btn-primary{background-color:var(--primary);color:var(--white);box-shadow:var(--shadow-md)}.btn-primary:hover{background-color:var(--secondary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--white);color:var(--primary)}.btn-secondary:hover{background-color:var(--bg-alt);transform:translateY(-2px)}.btn-outline{background-color:transparent;border-color:var(--primary);color:var(--primary)}.btn-outline:hover{background-color:var(--primary);color:var(--white)}.btn-sm{padding:8px 16px;font-size:.875rem}.btn-block{width:100%}.whatsapp-float{position:fixed;width:60px;height:60px;bottom:30px;right:30px;background-color:#25d366;color:#fff;border-radius:50px;text-align:center;font-size:30px;box-shadow:2px 2px 10px #00000026;z-index:1000;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.whatsapp-float:hover{transform:scale(1.1)}.navbar{position:fixed;top:0;left:0;width:100%;background-color:#ffffffe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100;padding:20px 0;transition:var(--transition);border-bottom:1px solid rgba(0,0,0,.05)}.navbar.scrolled{padding:12px 0;box-shadow:var(--shadow-sm)}.nav-container{display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:12px;font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--secondary);letter-spacing:-.5px}.nav-logo-img{height:52px;width:auto;object-fit:contain;border-radius:8px;box-shadow:0 2px 10px #1e3a8a2e;background:#fff;padding:2px;transition:var(--transition)}.navbar.scrolled .nav-logo-img{height:44px;box-shadow:0 2px 8px #1e3a8a26}.logo span{color:var(--primary);font-weight:300}.nav-menu ul{display:flex;list-style:none;gap:32px}.nav-menu a{font-weight:500;color:var(--text-main);font-size:.95rem}.nav-menu a:hover{color:var(--primary)}.nav-right{display:flex;align-items:center;gap:16px}.nav-phone{display:flex;align-items:center;gap:8px;padding:10px 20px}.hamburger{display:none;background:none;border:none;cursor:pointer;width:30px;height:20px;position:relative;z-index:101}.hamburger span{display:block;width:100%;height:2px;background-color:var(--secondary);position:absolute;transition:var(--transition)}.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:9px}.hamburger span:nth-child(3){top:18px}.hamburger.active span:nth-child(1){transform:rotate(45deg);top:9px}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg);top:9px}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding-top:80px;overflow:hidden}.hero-bg{position:absolute;top:0;left:0;width:100%;height:120%;background-size:cover;background-position:center;z-index:-2;will-change:transform;filter:brightness(1.18) contrast(1.06) saturate(1.12)}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0000,#0000 55%,#0000002e);z-index:-1}.hero-content{color:var(--white);max-width:800px;text-align:left;position:relative}.hero-content h1{font-size:clamp(2.4rem,5vw,4.8rem);color:#fff;margin-bottom:20px;letter-spacing:-1.5px;font-weight:700;line-height:1.08;text-shadow:0 1px 0 rgba(0,0,0,.12),0 4px 32px rgba(0,0,0,.55),0 8px 48px rgba(0,0,0,.3)}.hero-content p{font-size:clamp(1rem,1.8vw,1.35rem);margin-bottom:40px;font-weight:400;max-width:560px;color:#fffffff5;text-shadow:0 2px 16px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.4);letter-spacing:.01em}.hero-actions{display:flex;gap:16px}.section-header{text-align:center;margin-bottom:64px;max-width:600px;margin-left:auto;margin-right:auto}.section-header h2{font-size:2.5rem;margin-bottom:16px;color:var(--secondary)}.section-header p{color:var(--text-light);font-size:1.1rem}.services{padding:100px 0;background-color:var(--bg-alt)}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}.service-card{background-color:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition)}.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}.service-img{height:240px;overflow:hidden}.service-img img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.service-card:hover .service-img img{transform:scale(1.05)}.service-info{padding:32px}.service-info h3{margin-bottom:12px;font-size:1.25rem}.service-info p{color:var(--text-light);margin-bottom:24px;font-size:.95rem}.before-after{padding:100px 0;background-color:var(--white)}.ba-grid{display:flex;flex-direction:column;gap:48px}.ba-pair{display:grid;grid-template-columns:1fr 56px 1fr;height:440px;border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px #00000021}.ba-side{position:relative;overflow:hidden}.ba-photo{width:100%;height:100%;object-fit:cover;object-position:center;display:block;max-width:none!important;filter:brightness(1.06) contrast(1.14) saturate(1.18);transition:transform .7s cubic-bezier(.4,0,.2,1);will-change:transform}.ba-pair:hover .ba-photo{transform:scale(1.04)}.ba-label{position:absolute;top:18px;padding:5px 14px;font-family:var(--font-heading);font-size:.7rem;font-weight:700;letter-spacing:.14em;color:#fff;border-radius:4px;z-index:2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:none;-webkit-user-select:none;user-select:none}.ba-before .ba-label{left:18px;background:#0f172ab8;border:1px solid rgba(255,255,255,.18)}.ba-after .ba-label{right:18px;background:#1e3a8ad1;border:1px solid rgba(255,255,255,.22)}.ba-divider{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--primary) 0%,#2563eb 45%,#60a5fa 50%,#2563eb 55%,var(--primary) 100%);z-index:3;flex-shrink:0}.ba-divider:before,.ba-divider:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:1px;background:#ffffff40}.ba-divider:before{top:0;height:calc(50% - 36px)}.ba-divider:after{bottom:0;height:calc(50% - 36px)}.ba-divider-badge{width:46px;height:46px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 3px #1e3a8a4d,0 0 0 6px #1e3a8a1a,0 6px 24px #00000047;flex-shrink:0;z-index:4}.ba-divider-badge svg{width:20px;height:20px;color:var(--primary)}.filter-premium{filter:brightness(1.06) contrast(1.14) saturate(1.18)}.filter-cocina{filter:brightness(1.14) contrast(1.22) saturate(1.25)}.filter-tpo{filter:brightness(1.08) contrast(1.18) saturate(.85) hue-rotate(-8deg)}.filter-tpo-service{filter:brightness(1.05) contrast(1.2) saturate(1.1)}.tpo-card{border-top:3px solid var(--primary);position:relative}.tpo-card:before{content:"TPO";position:absolute;top:14px;right:16px;background:var(--primary);color:#fff;font-family:var(--font-heading);font-size:.65rem;font-weight:700;letter-spacing:.12em;padding:3px 9px;border-radius:4px;z-index:2}@media (max-width: 768px){.ba-pair{grid-template-columns:1fr;grid-template-rows:1fr 50px 1fr;height:auto}.ba-side{height:240px}.ba-divider{flex-direction:row;background:linear-gradient(90deg,var(--primary) 0%,#2563eb 45%,#60a5fa 50%,#2563eb 55%,var(--primary) 100%);height:50px;width:100%}.ba-divider:before{top:50%;left:0;transform:translateY(-50%);width:calc(50% - 36px);height:1px}.ba-divider:after{top:50%;left:auto;right:0;transform:translateY(-50%);width:calc(50% - 36px);height:1px}.ba-divider-badge{width:40px;height:40px}.ba-divider-badge svg{width:18px;height:18px;transform:rotate(90deg)}.ba-label{top:12px;font-size:.65rem}.ba-before .ba-label{left:12px}.ba-after .ba-label{right:12px}.ba-grid{gap:32px}}.project-gallery{padding:0 0 100px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.gallery-grid img{width:100%;height:280px;object-fit:cover;border-radius:var(--radius);transition:var(--transition);box-shadow:var(--shadow-sm);cursor:pointer}.gallery-grid img:hover{transform:scale(1.03);box-shadow:var(--shadow-md)}.reviews-banner{background-color:#fff;color:var(--secondary);padding:72px 0;border-top:1px solid rgba(30,58,138,.08);border-bottom:1px solid rgba(30,58,138,.08);box-shadow:0 4px 32px #1e3a8a0f}.reviews-banner-container{display:flex;align-items:center;gap:56px}.reviews-logo-col{flex-shrink:0;display:flex;align-items:center;justify-content:center}.reviews-logo-img{width:200px;height:200px;object-fit:contain;border-radius:20px;box-shadow:0 8px 32px #1e3a8a21,0 2px 8px #0000000f;border:3px solid rgba(30,58,138,.08);background:#fff;padding:8px;transition:var(--transition)}.reviews-logo-img:hover{transform:scale(1.03);box-shadow:0 16px 48px #1e3a8a2e}.reviews-divider-col{width:1px;height:160px;background:linear-gradient(to bottom,transparent,rgba(30,58,138,.2),transparent);flex-shrink:0}.reviews-content{flex:1}.reviews-eyebrow{display:inline-block;font-family:var(--font-heading);font-size:.72rem;font-weight:700;letter-spacing:.16em;color:var(--primary);text-transform:uppercase;margin-bottom:12px;padding:4px 12px;border-radius:4px;background:#1e3a8a12;border:1px solid rgba(30,58,138,.12)}.reviews-content h2{color:var(--secondary);margin-bottom:14px;font-size:2.4rem}.reviews-content p{font-size:1.1rem;margin-bottom:20px;color:var(--text-light)}.stars{font-size:1.8rem;color:#f59e0b;margin-bottom:8px;letter-spacing:4px}.reviews-text{display:inline-block;font-family:var(--font-heading);font-size:.82rem;font-weight:600;color:var(--text-light);letter-spacing:.06em;text-transform:uppercase}@media (max-width: 768px){.reviews-banner-container{flex-direction:column;gap:32px;text-align:center}.reviews-divider-col{width:120px;height:1px;background:linear-gradient(to right,transparent,rgba(30,58,138,.2),transparent)}.reviews-logo-img{width:140px;height:140px}.reviews-content h2{font-size:1.8rem}}.service-area{padding:100px 0;background-color:var(--bg-alt)}.area-container{display:flex;gap:64px;align-items:center}.area-content{flex:1}.area-content h2{font-size:2.5rem;margin-bottom:24px}.area-content p{font-size:1.1rem;color:var(--text-light);margin-bottom:32px}.features-list ul{list-style:none}.features-list li{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-weight:500;color:var(--secondary)}.features-list svg{color:var(--primary)}.area-map{flex:1;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md)}.contact{padding:100px 0;background-color:var(--white)}.contact-container{display:flex;gap:64px}.contact-info{flex:1}.contact-info h2{font-size:2.5rem;margin-bottom:16px}.contact-info p{color:var(--text-light);margin-bottom:40px;font-size:1.1rem}.contact-methods{display:flex;flex-direction:column;gap:32px}.method{display:flex;align-items:flex-start;gap:16px}.method-icon{width:48px;height:48px;background-color:var(--bg-alt);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.method-details h4{margin-bottom:4px;font-size:1.1rem}.method-details a,.method-details p{color:var(--text-light);font-size:1.1rem}.method-details a:hover{color:var(--primary)}.contact-form-wrapper{flex:1;background-color:var(--bg-alt);padding:40px;border-radius:var(--radius);box-shadow:var(--shadow-sm)}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid #CBD5E1;border-radius:8px;font-family:var(--font-body);font-size:1rem;transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1e3a8a1a}footer{position:relative;background-color:#f8fafc;color:var(--text-main);padding:0;overflow:hidden;border-top:4px solid var(--primary)}footer:before{content:"";display:block;height:1px;background:linear-gradient(to right,transparent,rgba(30,58,138,.15),transparent);margin:0}.footer-logo-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none}.footer-logo-watermark img{width:520px;height:520px;object-fit:contain;opacity:.055;filter:none;mix-blend-mode:multiply}.section-logo-watermark{position:absolute;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none}.section-logo-watermark img{width:360px;height:360px;object-fit:contain;opacity:.04;filter:none;mix-blend-mode:multiply}.footer-inner{padding:72px 0 0;position:relative;z-index:1}.footer-content{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1.8fr .9fr;gap:56px;margin-bottom:64px;padding-top:72px}.footer-brand{min-width:0}.footer-brand-logo-wrap{display:flex;align-items:center;gap:14px;margin-bottom:20px}.footer-brand-logo{width:68px;height:68px;object-fit:contain;border-radius:14px;border:2px solid rgba(30,58,138,.1);box-shadow:0 4px 20px #1e3a8a1f;background:#fff;padding:4px;flex-shrink:0}.footer-brand-name{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--secondary);line-height:1.2}.footer-brand-name span{display:block;color:var(--primary);font-weight:400;font-size:1rem}.footer-brand .logo{color:var(--secondary);margin-bottom:16px;display:inline-flex;align-items:center;gap:10px}.footer-brand .logo span{color:var(--primary)}.footer-brand p{color:var(--text-light);font-size:.9rem;line-height:1.7}.footer-contact-mini{margin-top:24px;display:flex;flex-direction:column;gap:10px}.footer-contact-mini a{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500;color:var(--primary);transition:var(--transition)}.footer-contact-mini a:hover{color:var(--secondary)}.footer-contact-mini svg{flex-shrink:0}.footer-about{min-width:0}.footer-col-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-size:.68rem;font-weight:700;letter-spacing:.15em;color:var(--primary);text-transform:uppercase;margin-bottom:16px;padding:3px 10px 3px 0;border-bottom:2px solid var(--primary)}.footer-about h4{color:var(--secondary);margin-bottom:14px;font-size:1rem;letter-spacing:.04em}.footer-about p{color:var(--text-light);font-size:.875rem;line-height:1.8}.footer-values{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.footer-value-badge{font-family:var(--font-heading);font-size:.7rem;font-weight:600;letter-spacing:.06em;color:var(--primary);background:#1e3a8a0f;border:1px solid rgba(30,58,138,.12);border-radius:20px;padding:4px 12px}.footer-links h4{color:var(--secondary);margin-bottom:20px}.footer-links ul{list-style:none}.footer-links li{margin-bottom:10px}.footer-links a{color:var(--text-light);font-size:.9rem;display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}.footer-links a:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary);opacity:.4;flex-shrink:0;transition:var(--transition)}.footer-links a:hover{color:var(--primary);transform:translate(4px)}.footer-links a:hover:before{opacity:1}.footer-bottom{position:relative;z-index:1;border-top:1px solid rgba(30,58,138,.1);padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-bottom p{color:var(--text-light);font-size:.82rem;margin:0}.footer-bottom-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-size:.72rem;font-weight:600;color:var(--primary);letter-spacing:.06em;opacity:.7}@media (max-width: 900px){.footer-content{grid-template-columns:1fr;gap:40px;padding-top:56px;margin-bottom:40px}.footer-brand,.footer-about,.footer-links{text-align:center}.footer-brand-logo-wrap{justify-content:center}.footer-contact-mini{align-items:center}.footer-col-label{justify-content:center;margin-left:auto;margin-right:auto}.footer-values{justify-content:center}.footer-links ul{display:flex;flex-direction:column;align-items:center;gap:4px}.footer-links a{justify-content:center;font-size:.95rem;padding:6px 0}.footer-links a:before{display:none}.footer-links a:hover{transform:none}.footer-logo-watermark img{width:280px;height:280px}.footer-bottom{flex-direction:column;text-align:center;gap:8px}.footer-about,.footer-links{border-top:1px solid rgba(30,58,138,.09);padding-top:36px}}.lang-toggle{background:transparent;border:1px solid rgba(255,255,255,.35);color:var(--white);padding:5px 11px;border-radius:5px;font-size:.72rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:var(--transition);font-family:var(--font-heading);flex-shrink:0}.lang-toggle:hover{background:#ffffff1f;border-color:#ffffffb3}.navbar.scrolled .lang-toggle{border-color:#1e3a8a80;color:var(--primary)}.navbar.scrolled .lang-toggle:hover{background:#1e3a8a14}.reveal{opacity:0;visibility:hidden;transition:all .8s cubic-bezier(.5,0,0,1)}.reveal.active{opacity:1;visibility:visible}.fade-up{transform:translateY(40px)}.fade-up.active{transform:translateY(0)}.delay-1{transition-delay:.2s}.delay-2{transition-delay:.4s}@media (max-width: 992px){.area-container,.contact-container{flex-direction:column}.hero-content h1{font-size:3rem}}@media (max-width: 768px){.nav-menu{position:fixed;top:0;right:-100%;width:80%;max-width:400px;height:100vh;background-color:var(--white);box-shadow:-5px 0 15px #0000001a;padding:100px 40px;transition:.4s ease-in-out}.nav-menu.active{right:0}.nav-menu ul{flex-direction:column;gap:24px}.nav-menu a{font-size:1.25rem}.hamburger{display:block}.nav-phone span{display:none}.nav-phone{padding:8px}.hero-actions{flex-direction:column}.services,.before-after,.project-gallery,.service-area,.contact{padding:60px 0}.reveal{opacity:1!important;visibility:visible!important;transform:none!important;transition:none!important}}@media (max-width: 480px){.hero-content h1{font-size:2.25rem}.ba-slider{height:400px}}
