:root{
  --ink:#111217;--ink-2:#242633;--muted:#686b78;--paper:#f7f5f2;--white:#fff;--line:#e7e2dc;
  --violet:#4b20a7;--violet-2:#6b35d8;--blue:#172d8c;--blue-2:#2449c8;--metal:#8d929b;--champagne:#ece7df;
  --shadow:0 24px 70px rgba(20,20,28,.12);--shadow-soft:0 14px 38px rgba(20,20,28,.08);--radius:28px;--max:1180px
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}.container{width:min(var(--max),calc(100% - 32px));margin:auto}
.top{font-size:.86rem;background:#0d0e14;color:#ffffffc7}.top .container{display:flex;gap:18px;justify-content:space-between;flex-wrap:wrap;padding:8px 0}.top a:hover{color:white}
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,245,242,.78);backdrop-filter:blur(20px);border-bottom:1px solid rgba(17,18,23,.07)}
.nav-shell{min-height:84px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px}.brand{display:inline-flex;align-items:center}.logo{width:188px;background:white;border:1px solid rgba(17,18,23,.06);border-radius:18px;padding:8px 12px;box-shadow:var(--shadow-soft)}
.menu{justify-self:center;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.72);border:1px solid rgba(17,18,23,.08);border-radius:999px;padding:7px;box-shadow:0 10px 30px rgba(17,18,23,.045)}
.menu>a,.nav-parent{height:40px;display:inline-flex;align-items:center;padding:0 15px;border-radius:999px;border:0;background:transparent;font:inherit;font-weight:800;font-size:.91rem;color:#2d2e3a;cursor:pointer;white-space:nowrap}.menu>a:hover,.nav-parent:hover,.menu>a.active{background:#f0ecff;color:var(--violet)}
.nav-group{position:relative}.nav-parent:after{content:"⌄";font-size:.78rem;margin-left:7px;color:var(--violet)}.submenu{position:absolute;top:48px;left:50%;transform:translateX(-50%) translateY(8px);min-width:250px;padding:10px;background:rgba(255,255,255,.96);border:1px solid rgba(17,18,23,.08);border-radius:22px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:.22s ease}.nav-group:hover .submenu,.nav-group:focus-within .submenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.submenu a{display:block;padding:11px 13px;border-radius:14px;font-weight:760;color:#333342}.submenu a:hover{background:#f2efff;color:var(--violet)}
.header-actions{display:flex;align-items:center;gap:10px}.phone-chip{height:42px;display:inline-flex;align-items:center;padding:0 15px;border-radius:999px;background:#111217;color:white;font-weight:850;font-size:.92rem;box-shadow:0 12px 24px rgba(17,18,23,.16)}.hamb{display:none;border:0;background:#fff;border-radius:14px;width:44px;height:44px;font-size:1.5rem;box-shadow:var(--shadow-soft)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 21px;border-radius:999px;font-weight:850;border:1px solid transparent;transition:.25s ease}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--violet),var(--blue));color:white;box-shadow:0 14px 34px rgba(75,32,167,.24)}.btn-light{background:#fff;border-color:var(--line);color:var(--ink)}.btn-dark{background:#15151d;color:#fff}
.hero{position:relative;isolation:isolate;min-height:680px;display:grid;align-items:center;overflow:hidden;background:#111}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,9,14,.82),rgba(18,16,34,.55),rgba(18,16,34,.18));z-index:-1}.hero:after{content:"";position:absolute;inset:auto -15% -28% -15%;height:360px;background:radial-gradient(circle,rgba(75,32,167,.38),transparent 62%);z-index:-1}.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transform:scale(1.02);animation:slowZoom 16s ease-in-out infinite alternate}.hero .content{max-width:790px;color:white;padding:100px 0}.eyebrow{font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#d8d1ff;font-size:.78rem}.hero h1,.page-title{font-size:clamp(2.7rem,6vw,5.8rem);line-height:.94;letter-spacing:-.07em;margin:18px 0}.hero p{font-size:clamp(1.05rem,2vw,1.25rem);color:#ffffffd1;max-width:690px}.actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:28px}.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:34px;max-width:650px}.metric{padding:18px;border:1px solid rgba(255,255,255,.18);border-radius:22px;background:rgba(255,255,255,.08);backdrop-filter:blur(10px)}.metric b{display:block;font-size:1.45rem}
section{padding:88px 0}.head{display:flex;justify-content:space-between;align-items:end;gap:28px;margin-bottom:34px}.head h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.04;letter-spacing:-.055em;margin:8px 0 0;max-width:760px}.head p{max-width:500px;color:var(--muted)}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{background:white;border:1px solid var(--line);border-radius:var(--radius);padding:25px;box-shadow:0 12px 44px rgba(0,0,0,.045);transition:.25s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.icon{width:48px;height:48px;border-radius:16px;background:#f0ecff;color:var(--violet);display:grid;place-items:center;font-weight:900;margin-bottom:16px}.card h3{margin:0 0 8px}.card p{color:var(--muted);margin:0}.split{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}.video{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:#000;box-shadow:var(--shadow)}.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.gallery{background:#111118;color:white}.gallery .head p{color:#ffffffa8}.grid-gallery{display:grid;grid-template-columns:1.1fr .9fr .9fr;grid-auto-rows:260px;gap:16px}.work{position:relative;border-radius:24px;overflow:hidden;background:#222}.work img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease,filter .7s ease}.work:hover img{transform:scale(1.05);filter:saturate(1.04) contrast(1.02)}.work.big{grid-row:span 2}.work span{position:absolute;left:14px;bottom:14px;right:14px;padding:10px 14px;border-radius:999px;background:rgba(15,15,22,.62);backdrop-filter:blur(12px);font-weight:800}.service-hero{min-height:520px}.list{display:grid;gap:12px;padding:0;margin:0;list-style:none}.list li{padding:16px 18px;border-radius:18px;background:#fff;border:1px solid var(--line)}.list li:before{content:"✓";color:var(--violet);font-weight:900;margin-right:10px}.contact{background:linear-gradient(135deg,#f2f0ed,#fff)}.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px}.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}input,select,textarea{width:100%;border:1px solid #ddd8d2;border-radius:16px;padding:14px 15px;font:inherit;background:#fff;transition:border .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--violet);box-shadow:0 0 0 4px rgba(75,32,167,.1)}textarea{min-height:128px;resize:vertical}form{display:grid;gap:12px}.small{font-size:.84rem;color:var(--muted)}footer{background:#101018;color:#ffffffb0;padding:44px 0}.foot{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:28px}footer strong{color:white}footer ul{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:7px}.wa{position:fixed;right:18px;bottom:18px;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:#25d366;color:#08160d;font-size:1.55rem;z-index:40;box-shadow:0 16px 34px rgba(0,0,0,.24)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s ease}.reveal.in{opacity:1;transform:none}.page-pad{padding:68px 0}.breadcrumbs{font-size:.9rem;color:var(--muted);margin-bottom:18px}.legal-note{font-size:.82rem;color:var(--muted)}@keyframes slowZoom{from{transform:scale(1.02)}to{transform:scale(1.08)}}
@media(max-width:1080px){.phone-chip{display:none}.menu{gap:2px}.menu>a,.nav-parent{padding:0 11px}}
@media(max-width:980px){.nav-shell{display:flex;justify-content:space-between}.hamb{display:block}.menu{display:none;position:absolute;top:84px;left:16px;right:16px;background:rgba(255,255,255,.98);padding:12px;flex-direction:column;align-items:stretch;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow)}.menu.open{display:flex}.menu>a,.nav-parent{width:100%;justify-content:flex-start;height:44px}.nav-group{width:100%}.submenu{position:static;opacity:1;visibility:visible;transform:none;min-width:auto;box-shadow:none;border:0;padding:0 0 0 12px;background:transparent}.nav-group:hover .submenu,.nav-group:focus-within .submenu{transform:none}.header-actions{display:none}.hide-tablet{display:none}.split,.contact-grid,.foot{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}.grid-gallery{grid-template-columns:1fr 1fr}.work.big{grid-row:span 1}.head{align-items:start;flex-direction:column}}
@media(max-width:620px){.top .container{justify-content:center;text-align:center}.logo{width:168px}.hero{min-height:auto}.hero .content{padding:64px 0}.metrics,.cards,.grid-gallery{grid-template-columns:1fr}.grid-gallery{grid-auto-rows:230px}section{padding:62px 0}.page-title,.hero h1{font-size:2.75rem}.contact-card{padding:22px}}



/* ==== V6 LIMPIA: servicios, trabajos e imágenes ==== */
html,body{overflow-x:hidden}
body{background:var(--paper)}
.site-header{z-index:1000}

/* Hero de todas las páginas interiores: imagen de fondo contenida y bien recortada */
.hero.service-hero{
  width:min(var(--max),calc(100% - 32px));
  margin:28px auto 0;
  min-height:560px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero.service-hero img.bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transform:none;
  animation:none;
}
.hero.service-hero .content{
  padding:90px 0;
  max-width:760px;
}
.hero.service-hero h1{
  font-size:clamp(2.8rem,6vw,5.4rem);
}
.hero.service-hero p{
  max-width:650px;
}

/* Galerías uniformes */
.gallery{overflow:hidden}
.gallery .container{width:min(var(--max),calc(100% - 32px))}
.grid-gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  grid-auto-rows:280px;
  gap:18px;
}
.grid-gallery .work{
  display:block;
  height:100%;
  min-height:0;
  border-radius:24px;
  overflow:hidden;
  position:relative;
  background:#20202a;
  cursor:zoom-in;
}
.grid-gallery .work.big{
  grid-column:span 2;
  grid-row:span 2;
}
.grid-gallery .work img{
  width:100%;
  height:100%;
  max-width:none;
  object-fit:cover;
  object-position:center;
  display:block;
  transition:transform .55s ease,filter .55s ease;
}
.grid-gallery .work:hover img{
  transform:scale(1.045);
  filter:brightness(.86) saturate(1.05);
}
.grid-gallery .work span{
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  z-index:2;
}

/* Página trabajos: evita imágenes gigantes aunque cambie el HTML */
.trabajos-grid,
.projects-grid,
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.trabajos-grid img,
.projects-grid img,
.portfolio-grid img{
  width:100%;
  height:280px;
  object-fit:cover;
  border-radius:24px;
}

/* Lightbox */
#lightbox{
  position:fixed;
  inset:0;
  z-index:99999;
  background:rgba(5,6,10,.92);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
#lightbox.is-open{display:flex}
#lightbox-img{
  width:auto;
  height:auto;
  max-width:94vw;
  max-height:90vh;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 24px 90px rgba(0,0,0,.55);
}
.lightbox-close{
  position:absolute;
  top:18px;
  right:20px;
  width:46px;
  height:46px;
  border:0;
  border-radius:999px;
  background:#fff;
  color:#111217;
  font-size:30px;
  line-height:1;
  cursor:pointer;
}

/* Ajustes responsive */
@media(max-width:980px){
  .hero.service-hero{
    width:min(100% - 24px,var(--max));
    min-height:500px;
    border-radius:26px;
  }
  .grid-gallery{
    grid-template-columns:1fr 1fr;
    grid-auto-rows:240px;
  }
  .grid-gallery .work.big{
    grid-column:span 1;
    grid-row:span 1;
  }
}
@media(max-width:620px){
  .hero.service-hero{
    min-height:460px;
  }
  .hero.service-hero .content{
    padding:56px 0;
  }
  .grid-gallery{
    grid-template-columns:1fr;
    grid-auto-rows:240px;
  }
}
