:root{
  --bg:#090b0b;
  --bg-2:#0d100f;
  --panel:#101412;
  --card:#151a17;
  --card-2:#1a201d;
  --olive:#8ca532;
  --olive-2:#a6bf46;
  --white:#f2f3ed;
  --muted:#b8beb7;
  --line:#2b332c;
  --max:1320px;
  --radius:22px;
  --shadow:0 18px 50px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--white);font-family:Manrope,Arial,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.skip-link{position:absolute;left:12px;top:-60px;z-index:1000;background:var(--olive);color:#080a09;padding:10px 14px;font:700 12px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.08em;transition:.2s}
.skip-link:focus{top:12px}
:focus-visible{outline:2px solid var(--olive);outline-offset:4px}

.topbar{position:fixed;top:0;left:0;z-index:50;width:100%;height:92px;padding:0 max(5vw,calc((100vw - var(--max))/2));display:flex;align-items:center;justify-content:space-between;background:rgba(9,11,11,.88);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.08)}
.logo{display:flex;align-items:center;width:max-content}
.logo img{width:265px;height:auto;object-fit:contain}
.main-nav{display:flex;align-items:center;gap:clamp(14px,1.6vw,28px);text-transform:uppercase;font:700 12px/1 Montserrat,sans-serif;letter-spacing:.08em}
.main-nav a{transition:.25s}
.main-nav>a:not(.nav-button){padding:36px 0;border-bottom:1px solid transparent}
.main-nav>a:hover,.main-nav a.active{color:var(--olive);border-color:var(--olive)}
.nav-button{border:1px solid #505850;padding:14px 16px;border-radius:999px;display:flex;align-items:center;gap:16px}
.nav-button:hover{border-color:var(--olive);color:var(--olive)}
.menu-toggle{display:none;background:none;border:0;padding:0}
.menu-toggle i{display:block;width:24px;height:2px;background:var(--olive);margin:5px 0}

.hero{min-height:100svh;position:relative;display:flex;align-items:center;padding:150px max(5vw,calc((100vw - var(--max))/2)) 85px;isolation:isolate}
.hero-bg,.hero-shade,.hero-grid{position:absolute;inset:0}
.hero-bg{background:url("assets/hero-dark.webp") 66% 52%/cover no-repeat;z-index:-4}
.hero-shade{background:linear-gradient(90deg,rgba(4,6,6,.97) 0%,rgba(4,6,6,.86) 38%,rgba(4,6,6,.28) 70%,rgba(4,6,6,.55) 100%),linear-gradient(0deg,rgba(4,6,6,.94),transparent 36%);z-index:-3}
.hero-grid{background-image:linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);background-size:90px 90px;z-index:-2}
.hero-content{max-width:760px}
.kicker,.section-tag,.center-title>span{font:700 12px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.16em;color:#d7dbd2}
.kicker{display:flex;align-items:center;gap:12px;margin:0 0 22px}
.kicker span{display:block;width:34px;height:2px;background:var(--olive)}
.hero-logo{width:min(760px,88vw);height:auto;margin:12px 0 20px;object-fit:contain}
em{font-style:normal;color:var(--olive)}
.hero h1{font:800 clamp(38px,4vw,74px)/1.02 Montserrat,sans-serif;letter-spacing:.02em;text-transform:uppercase;margin:0 0 22px;max-width:840px}
.hero-text,.hero-proof{max-width:720px;font-size:20px;line-height:1.7;color:#d4d8d3;margin:0}
.hero-proof{margin-top:18px;color:#b9c0b7;font-size:18px}
.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn{min-width:210px;padding:18px 20px;border-radius:999px;border:1px solid transparent;text-transform:uppercase;font:700 12px Montserrat,sans-serif;letter-spacing:.08em;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:.3s}
.btn-primary{background:var(--olive);color:#090b0b}
.btn-primary:hover{background:var(--olive-2);transform:translateY(-2px)}
.btn-outline{border-color:#677067;color:var(--white)}
.btn-outline:hover{border-color:var(--olive);color:var(--olive)}
.btn-whatsapp{border-color:#7a8f33;color:#dfe8bf}
.btn-whatsapp:hover{border-color:var(--olive);color:#eff6d5}
.hero-stats{position:absolute;left:max(5vw,calc((100vw - var(--max))/2));right:max(5vw,calc((100vw - var(--max))/2));bottom:42px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hero-stats article{border:1px solid rgba(255,255,255,.09);background:rgba(10,13,12,.62);backdrop-filter:blur(10px);padding:24px 26px;border-radius:20px}
.hero-stats strong{display:block;font:800 clamp(32px,3vw,50px)/1 Montserrat,sans-serif;color:var(--olive)}
.hero-stats span{display:block;margin-top:8px;font-size:17px;color:#dbe0db}
.hero-bottom{position:absolute;bottom:195px;right:max(5vw,calc((100vw - var(--max))/2));display:flex;align-items:center;gap:16px;text-transform:uppercase;font:700 10px Montserrat,sans-serif;letter-spacing:.14em;color:#bcc1bc}
.hero-bottom i{width:52px;height:1px;background:var(--olive)}

.section{max-width:var(--max);margin:auto;padding:120px 0}
.section-tag{display:block;color:var(--olive);margin-bottom:18px}
h2{font:800 clamp(40px,4vw,68px)/1.03 Montserrat,sans-serif;text-transform:uppercase;letter-spacing:-.02em;margin:0}
.split-title,.about-layout,.scope,.contact,.ceo{display:grid;gap:clamp(28px,4vw,70px)}
.split-title{grid-template-columns:1fr auto;align-items:end;margin-bottom:60px}
.split-title>p{max-width:450px;color:var(--muted);font-size:18px;line-height:1.75;margin:0}
.center-title{text-align:center}
.center-title>span{display:block;color:var(--olive);margin-bottom:18px}

.about-layout{grid-template-columns:.95fr 1.05fr;align-items:center}
.about-copy .lead{font-size:24px;color:#fff;font-weight:600;margin:0 0 18px}
.about-copy p,.ceo-copy p,.scope-copy p,.contact-copy>p,.final-cta p{color:var(--muted);font-size:18px;line-height:1.85;margin:0 0 16px}
.inline-link{display:flex;justify-content:space-between;align-items:center;width:min(360px,100%);border:1px solid #4b514c;padding:18px 20px;margin-top:26px;border-radius:999px;text-transform:uppercase;font:700 12px Montserrat,sans-serif;letter-spacing:.08em}
.inline-link:hover{border-color:var(--olive);color:var(--olive)}
.framed-image{height:610px;position:relative;padding:18px}
.framed-image::before{content:"";position:absolute;inset:0;border:1px solid var(--olive);clip-path:polygon(70% 0,100% 0,100% 35%,99.8% 35%,99.8% .2%,70% .2%,70% 0,30% 100%,0 100%,0 65%,.2% 65%,.2% 99.8%,30% 99.8%)}
.mission-grid,.value-grid,.services-grid,.benefits-grid,.project-cards,.testimonial-grid{display:grid;gap:16px}
.mission-grid{grid-template-columns:1fr 1fr;margin-top:70px}
.glass-card,.service-card,.project-card,blockquote,.contact-form,.video-invite,.video-frame,.hero-stats article,.choice-panel{border:1px solid var(--line);background:linear-gradient(135deg,#171b18,#101310);border-radius:var(--radius);box-shadow:var(--shadow)}
.glass-card,.service-card{padding:34px;position:relative;transition:.35s}
.glass-card:hover,.service-card:hover,.project-card:hover{border-color:var(--olive);transform:translateY(-4px)}
.glass-card i{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;background:#252b1d;color:var(--olive);font-style:normal;font-size:25px}
.glass-card h3,.service-card h3,.project-card h3,.reason-list h3,.process-line h3,.contact-form h3{font:800 22px/1.3 Montserrat,sans-serif;text-transform:uppercase;margin:24px 0 10px}
.glass-card p,.service-card p,.project-card p,.reason-list p,.process-line p,blockquote{font-size:17px;line-height:1.75;color:var(--muted)}
.glass-card b,.service-card>span,.audience-grid b{position:absolute;right:22px;top:18px;color:#6e756e;font:700 10px Montserrat,sans-serif}

.ceo{grid-template-columns:1.12fr .88fr;align-items:center}
.video-stack{display:grid;gap:18px}
.video-invite{padding:28px 30px}
.video-cta-text{margin-top:14px;color:#d7dcd7;font-size:17px;line-height:1.75}
.video-frame{padding:12px;background:#000;height:560px}
.ceo-video{width:100%;height:100%;object-fit:contain;background:#000}

.services-grid{grid-template-columns:repeat(3,1fr)}
.service-card{min-height:290px}
.service-icon{font-size:48px;color:var(--olive);margin-top:24px}

.value{max-width:none;background:var(--panel);padding-left:max(5vw,calc((100vw - var(--max))/2));padding-right:max(5vw,calc((100vw - var(--max))/2))}
.benefits-grid{grid-template-columns:repeat(3,1fr);margin-top:64px}
.benefits-grid article{min-height:150px;padding:30px 30px 28px;border:1px solid var(--line);background:var(--card);border-radius:22px;display:flex;align-items:flex-end;text-transform:uppercase;font:800 16px/1.55 Montserrat,sans-serif;position:relative}
.benefits-grid article::before{content:"✓";position:absolute;top:24px;color:var(--olive);font-size:24px}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:320px 320px;gap:12px}
.gallery-item{padding:0;border:0;background:var(--card);position:relative;overflow:hidden;border-radius:22px;color:white;text-align:left;cursor:pointer}
.gallery-item.tall{grid-row:1/3}
.gallery-item img{filter:brightness(.58);transition:.5s}
.gallery-item:hover img{filter:brightness(.82);transform:scale(1.04)}
.gallery-item span{position:absolute;left:22px;bottom:20px;text-transform:uppercase;font:700 12px Montserrat,sans-serif;letter-spacing:.1em}
code{color:var(--olive)}

.reasons{max-width:none;padding:0;display:grid;grid-template-columns:1fr 1fr;background:#0c0e0d}
.reasons-image{min-height:900px}
.reasons-image img{filter:brightness(.5);object-position:center}
.reasons-copy{padding:120px max(5vw,calc((100vw - var(--max))/2)) 120px 8vw}
.reason-list{display:grid;gap:0;margin-top:50px}
.reason-list article{display:grid;grid-template-columns:58px 1fr;gap:10px;border-top:1px solid var(--line);padding:24px 0}
.reason-list b,.process-line b{color:var(--olive);font:700 12px Montserrat,sans-serif}
.reason-list h3{margin:0 0 8px}
.reason-list p{margin:0}

.process-line{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.process-line article{padding:34px 26px;border-right:1px solid var(--line);position:relative}
.process-line i{display:block;width:10px;height:10px;border-radius:50%;background:var(--olive);position:absolute;top:-5px;left:24px;box-shadow:0 0 0 6px rgba(140,165,50,.12)}
.projects{max-width:none;padding-left:max(5vw,calc((100vw - var(--max))/2));padding-right:max(5vw,calc((100vw - var(--max))/2));background:var(--panel)}
.project-cards{grid-template-columns:repeat(3,1fr)}
.project-card{overflow:hidden;transition:.35s}
.project-card img{height:360px;filter:brightness(.72)}
.project-card div{padding:24px}
.project-card span{color:var(--olive);font:700 11px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.08em}
.testimonials{max-width:none;padding-left:max(5vw,calc((100vw - var(--max))/2));padding-right:max(5vw,calc((100vw - var(--max))/2));background:var(--panel)}
.testimonial-grid{grid-template-columns:repeat(3,1fr);margin-top:60px}
.testimonial-grid blockquote{margin:0;padding:34px;font:600 19px/1.7 Montserrat,sans-serif}
.testimonial-grid footer{border:0;padding:28px 0 0;color:var(--olive);font:700 11px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.08em}

.faq-list{border-top:1px solid var(--line)}
.faq-list details{border-bottom:1px solid var(--line);padding:0 12px}
.faq-list summary{cursor:pointer;padding:28px 0;display:flex;justify-content:space-between;gap:18px;align-items:center;font:800 20px/1.45 Montserrat,sans-serif;text-transform:uppercase;list-style:none}
.faq-list summary span{color:var(--olive);font-size:30px;line-height:1}
.faq-list p{max-width:900px;color:var(--muted);font-size:18px;line-height:1.85;padding:0 0 28px;margin:0}

.final-cta{max-width:none;background:linear-gradient(135deg,#11160f,#070909);padding-left:max(5vw,calc((100vw - var(--max))/2));padding-right:max(5vw,calc((100vw - var(--max))/2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.final-cta-inner{max-width:980px}
.final-cta h2{font-size:clamp(40px,4vw,66px);max-width:980px}
.contact{grid-template-columns:1fr 1fr;align-items:start}
.contact-highlight{margin:28px 0 24px;padding:24px 24px 20px;border-left:4px solid var(--olive);background:var(--panel);border-radius:0 18px 18px 0}
.contact-highlight strong{display:block;font:800 24px/1.35 Montserrat,sans-serif;margin-bottom:10px}
.contact-highlight p{margin:0;color:#d5d9d5;font-size:18px}
.contact-data{margin-top:40px;display:grid;gap:16px}
.contact-data a,.contact-data p{margin:0;display:grid;grid-template-columns:110px 1fr;color:#eef0ed;font-size:24px;line-height:1.4}
.contact-data span{color:var(--olive);text-transform:uppercase;font:700 12px Montserrat,sans-serif;letter-spacing:.12em}
.socials{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.socials a{border:1px solid var(--line);padding:14px 18px;border-radius:999px;text-transform:uppercase;font:700 12px Montserrat,sans-serif;letter-spacing:.08em}
.socials a:hover{border-color:var(--olive);color:var(--olive)}

.contact-form{padding:34px}
.form-heading{display:grid;gap:16px;margin-bottom:24px}
.form-heading p{margin:4px 0 0;color:var(--muted);font-size:16px;line-height:1.7}
.form-progress{width:100%;height:12px;background:#0b0e0c;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.form-progress span{display:block;width:0;height:100%;background:linear-gradient(90deg,var(--olive),var(--olive-2));transition:.3s}
.choice-panel{padding:20px 22px;margin-bottom:24px}
.choice-title{margin:0 0 16px;font:700 15px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.06em;color:#e8ece7}
.quick-choices{display:flex;flex-wrap:wrap;gap:10px}
.choice-btn{padding:12px 16px;border-radius:999px;border:1px solid var(--line);background:#0d100f;color:#e6eae5;font:700 12px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.06em}
.choice-btn:hover,.choice-btn.active{background:var(--olive);border-color:var(--olive);color:#090b0b}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:grid;gap:10px;margin-bottom:18px;font:700 12px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.09em;color:#c3c9c3}
.field input,.field select,.field textarea{width:100%;padding:16px 16px;border:1px solid #313932;border-radius:16px;background:#0a0d0b;color:#fff;font-size:16px;line-height:1.45;outline:none}
.field textarea{min-height:170px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:#7f867f}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--olive);box-shadow:0 0 0 3px rgba(140,165,50,.12)}
.consent{display:flex;gap:10px;align-items:flex-start;margin:12px 0 22px;color:#d8ddd8;font-size:15px;line-height:1.6}
.consent input{margin-top:4px;accent-color:var(--olive)}
.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-status{font-size:15px;color:var(--olive);min-height:20px;margin-top:12px}

.site-footer{border-top:1px solid var(--line);padding:40px max(5vw,calc((100vw - var(--max))/2));display:flex;justify-content:space-between;align-items:center;gap:26px;color:#98a099;font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.site-footer .logo img{width:220px}
.whatsapp{position:fixed;z-index:40;right:24px;bottom:24px;display:flex;align-items:center;gap:12px;background:var(--olive);color:#080a09;padding:12px 12px 12px 18px;border-radius:999px;text-transform:uppercase;font:800 11px Montserrat,sans-serif;box-shadow:0 12px 32px rgba(0,0,0,.45)}
.whatsapp svg{width:30px;height:30px;fill:white;background:#101410;border-radius:50%;padding:5px}
.lightbox{position:fixed;z-index:100;inset:0;background:rgba(3,5,4,.95);display:none;place-items:center;padding:5vw}
.lightbox.open{display:grid}
.lightbox img{max-width:1000px;max-height:80vh;object-fit:contain}
.lightbox p{font:700 12px Montserrat,sans-serif;text-transform:uppercase;letter-spacing:.08em;color:#fff}
.lightbox-close{position:absolute;right:25px;top:18px;background:none;border:0;color:white;font-size:42px}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:none}

@media(max-width:1400px){.section{padding-left:5vw;padding-right:5vw}.reasons,.projects,.testimonials,.value,.final-cta{padding-left:5vw;padding-right:5vw}}
@media(max-width:1100px){
  .topbar{height:82px}
  .logo img{width:225px}
  .main-nav{gap:14px;font-size:11px}
  .hero-bottom{display:none}
  .ceo,.about-layout,.contact,.reasons{grid-template-columns:1fr}
  .reasons-image{min-height:560px}
  .reasons-copy{padding:85px 5vw}
  .hero-stats{position:static;margin-top:34px}
  .hero{display:block;padding-bottom:80px}
}
@media(max-width:900px){
  .main-nav{display:none;position:absolute;top:82px;left:0;width:100%;padding:24px 5vw 30px;background:#0b0d0c;flex-direction:column;align-items:flex-start;max-height:calc(100vh - 82px);overflow:auto}
  .main-nav.open{display:flex}
  .main-nav>a:not(.nav-button){padding:8px 0;border-bottom:0}
  .menu-toggle{display:block}
  .hero h1{font-size:clamp(34px,6vw,58px)}
  .hero-text,.hero-proof,.split-title>p,.about-copy p,.ceo-copy p,.contact-copy>p,.faq-list p,.glass-card p,.service-card p,.project-card p,.reason-list p,.process-line p,.contact-highlight p{font-size:17px}
  .split-title{grid-template-columns:1fr;align-items:start}
  .services-grid,.benefits-grid,.project-cards,.testimonial-grid{grid-template-columns:1fr 1fr}
  .mission-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,320px)}
  .gallery-item.tall{grid-row:auto}
  .process-line{grid-template-columns:1fr 1fr}
  .field-row,.form-actions{grid-template-columns:1fr}
  .contact-data a,.contact-data p{font-size:21px;grid-template-columns:100px 1fr}
}
@media(max-width:640px){
  .topbar{height:74px}
  .logo img{width:180px}
  .main-nav{top:74px;max-height:calc(100vh - 74px)}
  .hero{padding:112px 5vw 70px}
  .hero-logo{width:92vw}
  .hero h1{font-size:10vw}
  h2{font-size:clamp(32px,8vw,46px)}
  .btn{width:100%;min-width:0}
  .actions{flex-direction:column}
  .hero-text,.hero-proof{font-size:17px}
  .hero-stats{grid-template-columns:1fr}
  .hero-stats strong{font-size:38px}
  .section{padding-top:82px;padding-bottom:82px}
  .services-grid,.benefits-grid,.project-cards,.testimonial-grid,.gallery-grid,.process-line{grid-template-columns:1fr}
  .gallery-grid{grid-template-rows:repeat(6,280px)}
  .project-card img{height:280px}
  .video-frame{height:340px}
  .framed-image{height:400px}
  .contact-data a,.contact-data p{font-size:18px;grid-template-columns:1fr}
  .contact-data span{margin-bottom:6px}
  .faq-list summary{font-size:16px}
  .contact-form{padding:22px}
  .site-footer{display:grid;justify-items:start}
  .site-footer .logo img{width:190px}
  .whatsapp span{display:none}
  .whatsapp{padding:10px}
}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}

/* Technical optimization and accessibility */
.consent a{color:var(--olive);text-decoration:underline;text-underline-offset:3px}
.legal{max-width:780px;margin:0 auto;padding:80px 5vw;color:var(--muted);font-size:15px;line-height:1.8}.legal h1{color:var(--white);font:700 clamp(30px,5vw,58px)/1.1 Montserrat,sans-serif;text-transform:uppercase}.legal a{color:var(--olive)}
@supports(content-visibility:auto){main>section:not(.hero){content-visibility:auto;contain-intrinsic-size:900px}}

/* Optimización premium 2: galería categorizada en HD */
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;margin:-32px 0 36px}
.filter-btn{border:1px solid var(--line);background:#0d100f;color:#e4e8e2;border-radius:999px;padding:13px 18px;text-transform:uppercase;font:800 12px Montserrat,sans-serif;letter-spacing:.08em;transition:.25s}
.filter-btn:hover,.filter-btn.active{background:var(--olive);border-color:var(--olive);color:#080a09;transform:translateY(-1px)}
.gallery-premium{grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:285px;grid-template-rows:none;grid-auto-flow:dense;gap:14px}
.gallery-premium .gallery-item{border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 45px rgba(0,0,0,.28)}
.gallery-premium .gallery-item.tall{grid-row:span 2}
.gallery-premium .gallery-item.wide{grid-column:span 2}
.gallery-premium .gallery-item::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,7,7,0) 35%,rgba(5,7,7,.82) 100%);z-index:1;pointer-events:none}
.gallery-premium .gallery-item img{filter:brightness(.64) saturate(1.05);transition:.55s}
.gallery-premium .gallery-item:hover img{filter:brightness(.88) saturate(1.06);transform:scale(1.045)}
.gallery-premium .gallery-item span{z-index:2;font-size:12px;line-height:1.45;right:20px}
.gallery-item.is-hidden{display:none}
.logo,.hero-logo{background:transparent!important;box-shadow:none!important}
.logo img,.hero-logo{background:transparent!important}
@media(max-width:1000px){.gallery-premium{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:285px}.gallery-premium .gallery-item.wide{grid-column:span 2}}
@media(max-width:640px){.gallery-filters{margin-top:-20px}.filter-btn{width:100%;justify-content:center}.gallery-premium{grid-template-columns:1fr;grid-auto-rows:270px}.gallery-premium .gallery-item.tall,.gallery-premium .gallery-item.wide{grid-column:auto;grid-row:auto}}



/* === Últimos cambios LASERLE: equipo, footer completo, estadísticas con iconos === */
.hero h1 {
  max-width: 1080px;
}

.hero .hero-logo,
.logo img,
.footer-logo img {
  background: transparent !important;
  box-shadow: none !important;
}

.hero-stats article {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 16px;
  align-items: center;
}

.hero-stats article .stat-icon {
  grid-row: span 2;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(140,165,50,.55);
  border-radius: 18px;
  display: grid;
  place-items: center;
  color: var(--olive);
  font: 800 30px/1 Montserrat, sans-serif;
  background: rgba(140,165,50,.10);
  box-shadow: inset 0 0 22px rgba(140,165,50,.08);
}

.team {
  position: relative;
}

.team-layout {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: clamp(34px,5vw,78px);
  align-items: center;
}

.team-copy {
  border: 1px solid var(--line);
  background: linear-gradient(135deg,#171b18,#101310);
  border-radius: var(--radius);
  padding: clamp(26px,3vw,42px);
  box-shadow: var(--shadow);
}

.team-copy h3 {
  font: 800 clamp(28px,3vw,42px)/1.1 Montserrat, sans-serif;
  text-transform: uppercase;
  margin: 0 0 18px;
}

.team-copy p {
  color: var(--muted);
  font-size: 18px;
  line-height: 1.85;
  margin: 0 0 18px;
}

.team-pillars {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.team-pillars span {
  border: 1px solid rgba(140,165,50,.35);
  background: rgba(140,165,50,.08);
  color: #e8efcf;
  border-radius: 999px;
  padding: 11px 14px;
  font: 700 12px Montserrat, sans-serif;
  text-transform: uppercase;
  letter-spacing: .07em;
}

.team-image {
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: #f3f2ed;
  padding: 14px;
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
}

.team-image img {
  border-radius: 20px;
  object-fit: contain;
  background: #f3f2ed;
  height: auto;
}

.team-image figcaption {
  color: #242a25;
  text-align: center;
  font: 800 12px Montserrat, sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 14px 8px 4px;
}

.site-footer {
  display: block !important;
  border-top: 1px solid var(--line);
  padding: 72px max(5vw,calc((100vw - var(--max))/2)) 34px !important;
  background:
    radial-gradient(circle at 20% 10%, rgba(140,165,50,.14), transparent 28%),
    linear-gradient(135deg,#070908,#111610 70%,#070908);
  color: var(--white);
}

.footer-main {
  display: grid;
  grid-template-columns: minmax(260px, 420px) 1fr;
  gap: clamp(28px,5vw,72px);
  align-items: center;
  padding-bottom: 42px;
  border-bottom: 1px solid rgba(255,255,255,.09);
}

.footer-logo img {
  width: min(420px, 100%);
  height: auto;
  object-fit: contain;
}

.footer-slogan h2 {
  font-size: clamp(36px,4.6vw,76px);
  line-height: 1.02;
  margin: 0 0 16px;
  letter-spacing: -.035em;
}

.footer-slogan p {
  margin: 0;
  color: #d7ddd6;
  font-size: 20px;
  line-height: 1.6;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.footer-contact {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 34px 0;
  border-bottom: 1px solid rgba(255,255,255,.09);
}

.footer-contact div {
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  border-radius: 18px;
  padding: 20px;
  min-height: 130px;
}

.footer-contact span {
  display: block;
  color: var(--olive);
  font: 800 12px Montserrat, sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.footer-contact a,
.footer-contact p {
  margin: 0;
  color: #f0f3ec;
  font-size: 18px;
  line-height: 1.5;
  word-break: break-word;
  text-transform: none;
  letter-spacing: 0;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding-top: 26px;
  color: #9fa79d;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.footer-bottom p {
  margin: 0;
}

.footer-bottom a:hover,
.footer-contact a:hover {
  color: var(--olive);
}

/* Ajuste de correo comercial visible en contacto */
.contact-data a[href^="mailto:"] {
  word-break: break-word;
}

@media(max-width: 1000px) {
  .team-layout,
  .footer-main,
  .footer-contact {
    grid-template-columns: 1fr;
  }

  .footer-logo img {
    width: min(360px,100%);
  }

  .footer-contact div {
    min-height: auto;
  }
}

@media(max-width: 640px) {
  .hero-stats article {
    grid-template-columns: auto 1fr;
  }

  .hero-stats article .stat-icon {
    width: 48px;
    height: 48px;
    font-size: 24px;
    border-radius: 15px;
  }

  .team-copy p {
    font-size: 16px;
  }

  .team-pillars span {
    font-size: 10px;
  }

  .site-footer {
    padding-top: 56px !important;
  }

  .footer-slogan h2 {
    font-size: clamp(31px,9vw,42px);
  }

  .footer-slogan p,
  .footer-contact a,
  .footer-contact p {
    font-size: 16px;
  }

  .footer-bottom {
    display: grid;
  }
}


/* Ajustes finales conservando el diseño aprobado de LASERLE WEB ÚLTIMOS CAMBIOS */
.hero-content .kicker{display:none!important}
#equipo .team-layout{display:flex;justify-content:center;align-items:center}
#equipo .team-image{max-width:min(760px,100%);margin:0 auto}
#equipo .team-image img{width:100%;height:auto;max-height:760px;object-fit:contain}
#equipo .split-title{margin-bottom:38px}
#galeria .split-title{margin-bottom:36px}
#galeria .gallery-filters{margin-top:0}


/* === Ajustes premium de conversión LASERLE === */
.hero-trust-line{
  position:absolute;
  left:max(5vw,calc((100vw - var(--max))/2));
  bottom:168px;
  max-width:760px;
  margin:0;
  color:#d8ddd6;
  font-size:18px;
  line-height:1.65;
  border-left:3px solid var(--olive);
  padding:12px 0 12px 18px;
  background:linear-gradient(90deg,rgba(9,11,11,.55),transparent);
}

.video-play-label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:18px;
  padding:14px 18px;
  border:1px solid rgba(140,165,50,.45);
  border-radius:999px;
  color:#eef5d3;
  text-transform:uppercase;
  font:800 12px Montserrat,sans-serif;
  letter-spacing:.08em;
  background:rgba(140,165,50,.09);
}
.video-play-label:hover{background:var(--olive);color:#090b0b}

.sales-specialist{
  max-width:none;
  padding-left:max(5vw,calc((100vw - var(--max))/2));
  padding-right:max(5vw,calc((100vw - var(--max))/2));
  background:
    radial-gradient(circle at 85% 5%, rgba(140,165,50,.12), transparent 28%),
    linear-gradient(135deg,#0b0e0c,#101412);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.specialist-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.specialist-card{
  position:relative;
  min-height:270px;
  padding:34px 28px 30px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(135deg,#171b18,#101310);
  box-shadow:var(--shadow);
  transition:.35s;
}
.specialist-card:hover{border-color:var(--olive);transform:translateY(-4px)}
.specialist-card span{
  display:inline-flex;
  width:46px;
  height:46px;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:rgba(140,165,50,.11);
  border:1px solid rgba(140,165,50,.38);
  color:var(--olive);
  font:800 13px Montserrat,sans-serif;
  margin-bottom:24px;
}
.specialist-card h3{
  font:800 20px/1.35 Montserrat,sans-serif;
  text-transform:uppercase;
  margin:0 0 14px;
}
.specialist-card p{
  color:var(--muted);
  font-size:16px;
  line-height:1.75;
  margin:0;
}
.section-mini-cta{
  margin-top:28px;
  padding:24px;
  border:1px solid rgba(140,165,50,.32);
  border-radius:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  background:rgba(140,165,50,.06);
}
.section-mini-cta p{
  margin:0;
  max-width:720px;
  font:800 clamp(22px,2.2vw,34px)/1.18 Montserrat,sans-serif;
  text-transform:uppercase;
}

.deliverables{
  max-width:none;
  padding-left:max(5vw,calc((100vw - var(--max))/2));
  padding-right:max(5vw,calc((100vw - var(--max))/2));
}
.deliverables-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:54px;
}
.deliverables-grid article{
  min-height:155px;
  border:1px solid var(--line);
  background:var(--card);
  border-radius:22px;
  padding:26px;
  display:grid;
  align-content:space-between;
  transition:.3s;
}
.deliverables-grid article:hover{border-color:var(--olive);transform:translateY(-3px)}
.deliverables-grid i{
  font-style:normal;
  color:var(--olive);
  font-size:34px;
  line-height:1;
}
.deliverables-grid span{
  display:block;
  font:800 15px/1.45 Montserrat,sans-serif;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.client-needs{
  max-width:none;
  padding-left:max(5vw,calc((100vw - var(--max))/2));
  padding-right:max(5vw,calc((100vw - var(--max))/2));
  background:var(--panel);
}
.needs-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  margin-top:58px;
}
.needs-grid article{
  border:1px solid var(--line);
  background:linear-gradient(135deg,#171b18,#101310);
  border-radius:22px;
  padding:28px 24px;
  min-height:270px;
  box-shadow:var(--shadow);
}
.needs-grid b{
  color:var(--olive);
  font:800 12px Montserrat,sans-serif;
}
.needs-grid h3{
  font:800 18px/1.35 Montserrat,sans-serif;
  text-transform:uppercase;
  margin:22px 0 12px;
}
.needs-grid p{
  color:var(--muted);
  margin:0;
  font-size:15px;
  line-height:1.75;
}

.closing-sales-line{
  margin:28px 0 6px;
  padding:26px 28px;
  border-left:4px solid var(--olive);
  border-radius:0 20px 20px 0;
  background:rgba(140,165,50,.08);
}
.closing-sales-line strong,
.closing-sales-line span{
  display:block;
  font:800 clamp(24px,2.6vw,42px)/1.12 Montserrat,sans-serif;
  text-transform:uppercase;
}
.closing-sales-line span{color:var(--olive);margin-top:6px}

.fixed-quote{
  position:fixed;
  z-index:39;
  left:24px;
  bottom:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-width:230px;
  padding:16px 18px;
  border-radius:999px;
  border:1px solid rgba(140,165,50,.45);
  background:rgba(12,15,13,.86);
  backdrop-filter:blur(14px);
  color:#eef5d3;
  text-transform:uppercase;
  font:800 11px Montserrat,sans-serif;
  letter-spacing:.08em;
  box-shadow:0 12px 32px rgba(0,0,0,.45);
}
.fixed-quote:hover{background:var(--olive);color:#090b0b}

.legal-notice{
  margin:4px 0 14px;
  padding:14px 16px;
  border:1px solid rgba(140,165,50,.28);
  background:rgba(140,165,50,.06);
  border-radius:16px;
  color:#d7ddd4;
  font-size:14px;
  line-height:1.6;
}

@media(max-width:1100px){
  .hero-trust-line{position:static;margin-top:22px}
  .specialist-grid,.deliverables-grid{grid-template-columns:repeat(2,1fr)}
  .needs-grid{grid-template-columns:repeat(2,1fr)}
  .section-mini-cta{align-items:flex-start;flex-direction:column}
}
@media(max-width:640px){
  .specialist-grid,.deliverables-grid,.needs-grid{grid-template-columns:1fr}
  .fixed-quote{left:14px;right:80px;bottom:18px;min-width:0;padding:13px 14px;font-size:10px}
  .whatsapp{right:14px;bottom:18px}
  .section-mini-cta .btn{width:100%}
  .hero-trust-line{font-size:16px}
}


/* === Ajustes puntuales: línea de confianza, lightbox navegable y responsive === */
.hero{
  padding-bottom:260px;
}
.hero-stats{
  align-items:stretch;
}
.hero-stats .hero-trust-line{
  position:static!important;
  grid-column:1 / -1;
  max-width:none;
  margin:0;
  color:#d8ddd6;
  font-size:18px;
  line-height:1.65;
  border:1px solid rgba(140,165,50,.28);
  border-left:4px solid var(--olive);
  border-radius:0 18px 18px 0;
  padding:14px 18px;
  background:linear-gradient(90deg,rgba(140,165,50,.10),rgba(9,11,11,.18));
}
.lightbox-nav{
  position:absolute;
  z-index:101;
  top:50%;
  transform:translateY(-50%);
  width:58px;
  height:58px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(12,15,13,.78);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:48px;
  line-height:1;
  backdrop-filter:blur(10px);
  transition:.25s;
}
.lightbox-nav:hover{
  background:var(--olive);
  color:#090b0b;
  border-color:var(--olive);
}
.lightbox-prev{left:28px}
.lightbox-next{right:28px}
.lightbox img{
  max-width:min(1100px,82vw);
  max-height:80vh;
}
@media(max-width:1100px){
  .hero{
    padding-bottom:80px;
  }
  .hero-stats .hero-trust-line{
    grid-column:1 / -1;
    font-size:17px;
  }
}
@media(max-width:900px){
  .hero-stats{
    grid-template-columns:1fr;
  }
  .hero-stats .hero-trust-line{
    grid-column:auto;
  }
  .lightbox img{
    max-width:88vw;
    max-height:74vh;
  }
  .lightbox-nav{
    width:48px;
    height:48px;
    font-size:38px;
  }
  .lightbox-prev{left:14px}
  .lightbox-next{right:14px}
}
@media(max-width:640px){
  .hero{
    padding-bottom:70px;
  }
  .hero-stats .hero-trust-line{
    font-size:15.5px;
    padding:12px 14px;
  }
  .lightbox{
    padding:70px 12px 44px;
  }
  .lightbox img{
    max-width:92vw;
    max-height:68vh;
  }
  .lightbox-nav{
    top:auto;
    bottom:82px;
    transform:none;
    width:44px;
    height:44px;
    font-size:34px;
  }
  .lightbox-prev{left:22px}
  .lightbox-next{right:22px}
}


/* === Ajustes finales solicitados: subtítulo centrado, posición hero y foto contacto === */
.hero-stats{
  bottom:24px!important;
  gap:14px!important;
}
.hero-stats .hero-trust-line{
  position:static!important;
  grid-column:1 / -1!important;
  max-width:980px!important;
  margin:0 auto!important;
  text-align:center!important;
  color:#d8ddd6!important;
  font-size:18px!important;
  line-height:1.65!important;
  border:1px solid rgba(140,165,50,.28)!important;
  border-radius:18px!important;
  border-left:1px solid rgba(140,165,50,.28)!important;
  padding:14px 22px!important;
  background:linear-gradient(90deg,rgba(140,165,50,.10),rgba(9,11,11,.18))!important;
}
.hero-bottom{
  bottom:270px!important;
}
.contact-visual{
  margin:22px 0 0;
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  overflow:hidden;
  background:#0c0f0d;
  box-shadow:0 18px 48px rgba(0,0,0,.28);
}
.contact-visual img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
}
.contact-visual figcaption{
  padding:16px 18px 18px;
  color:#d9ded8;
  font:700 13px/1.6 Montserrat,sans-serif;
  text-transform:uppercase;
  letter-spacing:.06em;
  border-top:1px solid rgba(255,255,255,.08);
}

@media(max-width:1100px){
  .hero-bottom{
    display:none!important;
  }
  .hero-stats{
    position:static!important;
    margin-top:32px!important;
  }
  .hero-stats .hero-trust-line{
    max-width:none!important;
    font-size:17px!important;
  }
}
@media(max-width:640px){
  .hero-stats .hero-trust-line{
    font-size:15.5px!important;
    padding:12px 14px!important;
  }
  .contact-visual figcaption{
    font-size:11px;
  }
}
