:root{
  --bg:#020305;
  --ink:#f7f5ef;
  --muted:rgba(247,245,239,.58);
  --dim:rgba(247,245,239,.34);
  --line:rgba(247,245,239,.11);
  --cyan:#34f5e6;
  --cyan-soft:rgba(52,245,230,.58);
  --panel:rgba(2,3,5,.52);
  --max:1240px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  min-height:100vh;
  color:var(--ink);
  font-family:"Helvetica Neue", Helvetica, Arial, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:#020305;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
button{font:inherit;color:inherit}
::selection{background:var(--cyan);color:#020305}

/* BACKGROUND VIDEO + ANIMATION LAYERS */
.site-bg-video{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-8;
  pointer-events:none;
  opacity:.76;
  filter:saturate(.72) contrast(1.22) brightness(.56) blur(.06px);
  transform:scale(1.025);
}
.site-bg-overlay{
  position:fixed;
  inset:0;
  z-index:-7;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(5,5,10,.38), rgba(5,5,10,.16), rgba(5,5,10,.36)),
    radial-gradient(circle at 50% 26%, rgba(45,211,227,.20), transparent 24rem),
    radial-gradient(circle at 50% 74%, rgba(45,211,227,.14), transparent 25rem),
    linear-gradient(180deg, rgba(0,0,0,.86), rgba(0,0,0,.22) 45%, rgba(0,0,0,.92));
}
.site-bg-vignette{
  position:fixed;
  inset:0;
  z-index:-6;
  pointer-events:none;
  background:
    radial-gradient(ellipse at center, transparent 0 30%, rgba(0,0,0,.50) 66%, rgba(0,0,0,.98) 100%),
    linear-gradient(180deg, rgba(0,0,0,.42), transparent 18%, rgba(0,0,0,.74));
}
#bg-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:-5;
  pointer-events:none;
  opacity:.48;
}
.noise{
  position:fixed;
  inset:0;
  z-index:999;
  pointer-events:none;
  opacity:.052;
  mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.62'/%3E%3C/svg%3E");
}
.scanline{
  position:fixed;
  inset:0;
  z-index:-4;
  pointer-events:none;
  opacity:.16;
  background:repeating-linear-gradient(180deg, rgba(255,255,255,.025) 0 1px, transparent 1px 5px);
}

/* STRUCTURE */
.page-shell{position:relative;min-height:100vh;isolation:isolate}
.container{width:min(var(--max), calc(100% - 56px));margin:0 auto}
.header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:50;
  border-top:1px solid rgba(255,255,255,.16);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(0,0,0,.42), rgba(0,0,0,.12));
  transition:background .45s var(--ease), backdrop-filter .45s var(--ease), border-color .45s var(--ease);
}
.header.is-scrolled{
  background:rgba(2,3,5,.76);
  backdrop-filter:blur(24px);
  border-bottom-color:rgba(255,255,255,.10);
}
.nav{
  height:98px;
  width:min(100%, 1540px);
  margin:0 auto;
  padding:0 clamp(28px, 4vw, 52px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
.brand{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:0;
  font-size:15px;
  line-height:1;
  font-weight:500;
  letter-spacing:.52em;
  color:rgba(255,255,255,.86);
  text-transform:uppercase;
  white-space:nowrap;
  text-shadow:0 0 24px rgba(255,255,255,.18);
}
.brand .accent{color:var(--cyan);text-shadow:0 0 22px rgba(52,245,230,.42)}
.nav-links{display:flex;align-items:center;gap:clamp(34px, 5.2vw, 78px)}
.nav-links a{
  position:relative;
  padding:18px 0;
  color:rgba(255,255,255,.78);
  font-size:12px;
  font-weight:800;
  letter-spacing:.46em;
  text-transform:uppercase;
  transition:color .34s var(--ease), text-shadow .34s var(--ease), transform .34s var(--ease);
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;right:.46em;bottom:8px;
  height:2px;
  background:var(--cyan);
  transform:scaleX(0);
  transform-origin:right;
  box-shadow:0 0 22px rgba(52,245,230,.54);
  transition:transform .34s var(--ease);
}
.nav-links a:hover,
.nav-links a[aria-current="page"]{color:#fff;text-shadow:0 0 22px rgba(52,245,230,.26)}
.nav-links a:hover::after,
.nav-links a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav-links a:hover{transform:translateY(-1px)}
.menu-toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:999px;padding:12px 16px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.76)}

/* ENTRY INDEX */
.main-content{position:relative;z-index:1}
.entry-hero{
  min-height:100svh;
  display:grid;
  place-items:center;
  position:relative;
  padding:142px 0 84px;
  overflow:hidden;
}
.entry-center{
  width:min(1060px, calc(100% - 42px));
  text-align:center;
  position:relative;
  transform:translateY(3vh);
}
.mark-large{
  margin:0;
  font-weight:300;
  font-size:clamp(48px, 7.6vw, 112px);
  line-height:1;
  letter-spacing:clamp(.36em, 1.15vw, .66em);
  text-indent:.56em;
  text-transform:uppercase;
  color:rgba(255,255,255,.94);
  text-shadow:0 0 18px rgba(255,255,255,.25), 0 0 82px rgba(255,255,255,.10);
  animation:markIn 1.25s var(--ease) both;
}
.mark-large .accent{
  color:var(--cyan);
  text-shadow:0 0 28px rgba(52,245,230,.50), 0 0 82px rgba(52,245,230,.18);
}
.tagline{
  margin:30px 0 0;
  color:var(--cyan-soft);
  text-transform:uppercase;
  letter-spacing:.68em;
  font-size:15px;
  font-weight:500;
  animation:fadeUp 1.05s .22s var(--ease) both;
}
.enter-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:34vh;
  background:transparent;
  border:0;
  color:rgba(255,255,255,.88);
  padding:20px 28px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.56em;
  text-transform:uppercase;
  cursor:pointer;
  position:relative;
  text-shadow:0 0 26px rgba(255,255,255,.22);
  transition:color .35s var(--ease), text-shadow .35s var(--ease), transform .35s var(--ease);
}
.enter-link::after{
  content:"";
  position:absolute;
  top:100%;
  left:50%;
  width:1px;height:76px;
  background:linear-gradient(180deg, var(--cyan), transparent);
  box-shadow:0 0 20px rgba(52,245,230,.58);
  animation:lineDrop 1.5s .5s var(--ease) both;
}
.enter-link:hover{color:#fff;text-shadow:0 0 28px rgba(52,245,230,.46);transform:translateY(-2px)}

/* CONTENT */
.section{padding:128px 0;border-top:1px solid rgba(255,255,255,.075)}
.section.compact{padding:94px 0}
.page-hero{padding:198px 0 112px;min-height:62svh;display:flex;align-items:end;border-bottom:1px solid rgba(255,255,255,.08)}
.kicker{
  display:block;
  margin-bottom:26px;
  color:var(--cyan-soft);
  text-transform:uppercase;
  letter-spacing:.52em;
  font-size:11px;
  font-weight:900;
}
h1,h2,h3,p{margin-top:0}
.display-title,
.page-title{
  max-width:1050px;
  margin-bottom:0;
  font-weight:300;
  font-size:clamp(30px, 5vw, 70px);
  line-height:.92;
  letter-spacing:-.052em;
  text-wrap:balance;
  text-shadow:0 0 60px rgba(0,0,0,.62);
}
.page-title{font-size:clamp(30px, 5vw, 70px)}
.lead{
  color:rgba(255,255,255,.82);
  font-size:clamp(20px, 2.3vw, 34px);
  line-height:1.25;
  font-weight:300;
  letter-spacing:-.035em;
}
.muted{color:var(--muted);font-size:17px;line-height:1.75}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px, 7vw, 100px);align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card,
.work-card,
.contact-card{
  background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  border:1px solid rgba(255,255,255,.11);
  border-radius:0;
  padding:34px;
  min-height:260px;
  backdrop-filter:blur(18px);
  box-shadow:0 30px 90px rgba(0,0,0,.25);
  transition:transform .34s var(--ease), border-color .34s var(--ease), background .34s var(--ease), box-shadow .34s var(--ease);
}
.card:hover,
.work-card:hover,
.contact-card:hover{
  transform:translateY(-5px);
  border-color:rgba(52,245,230,.28);
  background:linear-gradient(180deg, rgba(52,245,230,.08), rgba(255,255,255,.018));
  box-shadow:0 38px 105px rgba(0,0,0,.34), 0 0 60px rgba(52,245,230,.05);
}
.number{color:var(--cyan);letter-spacing:.36em;font-size:11px;font-weight:900;margin-bottom:64px;text-transform:uppercase}
.card h3,
.work-card h3,
.contact-card h3{font-size:24px;font-weight:400;letter-spacing:-.04em;margin-bottom:16px}
.card p,
.work-card p,
.contact-card p{color:var(--muted);line-height:1.7;margin-bottom:0}
.quote-block{
  max-width:1060px;
  font-size:clamp(26px, 4vw, 64px);
  line-height:1.08;
  font-weight:300;
  letter-spacing:-.055em;
  color:rgba(255,255,255,.90);
  text-wrap:balance;
}
.cta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:34px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 22px;
  border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.86);
  background:rgba(255,255,255,.025);
  text-transform:uppercase;
  font-size:11px;
  font-weight:900;
  letter-spacing:.34em;
  transition:background .32s var(--ease), color .32s var(--ease), border-color .32s var(--ease), transform .32s var(--ease), box-shadow .32s var(--ease);
}
.btn:hover{transform:translateY(-2px);border-color:rgba(52,245,230,.42);color:#fff;box-shadow:0 0 40px rgba(52,245,230,.10)}
.btn.primary{background:rgba(52,245,230,.12);border-color:rgba(52,245,230,.42);color:#fff}
.btn.primary:hover{background:rgba(52,245,230,.20)}

/* WORK */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.work-card{padding:0;overflow:hidden;min-height:0;background:rgba(0,0,0,.30)}
.work-media{aspect-ratio:9/13;background:#030407;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.08)}
.work-media.horizontal{aspect-ratio:16/10}
.work-media img,
.work-media video{width:100%;height:100%;object-fit:cover;filter:saturate(.86) contrast(1.05) brightness(.82);transition:transform .55s var(--ease), filter .55s var(--ease)}
.work-card:hover .work-media img,
.work-card:hover .work-media video{transform:scale(1.035);filter:saturate(.98) contrast(1.10) brightness(5.96)}
.work-copy{padding:25px 25px 28px}
.work-copy span{display:block;color:var(--cyan-soft);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.34em;margin-bottom:14px}
.work-copy h3{font-size:22px;margin-bottom:10px}
.work-copy p{font-size:14px;line-height:1.65;color:var(--muted)}

/* CONTACT / FOOTER */
.contact-list{display:grid;gap:14px}
.contact-link{display:flex;justify-content:space-between;gap:18px;align-items:center;border-top:1px solid var(--line);padding:18px 0;color:rgba(255,255,255,.82);letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:800}
.contact-link span:last-child{color:var(--cyan)}
.footer{border-top:1px solid rgba(255,255,255,.08);padding:34px 0;color:rgba(255,255,255,.38);font-size:11px;letter-spacing:.26em;text-transform:uppercase}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.whatsapp-float{
  position:fixed;
  right:24px;bottom:22px;
  z-index:60;
  display:grid;place-items:center;
  width:48px;height:48px;
  border:1px solid rgba(52,245,230,.38);
  background:rgba(2,3,5,.54);
  backdrop-filter:blur(18px);
  color:var(--cyan);
  font-size:11px;font-weight:900;letter-spacing:.16em;
  transition:transform .32s var(--ease), background .32s var(--ease), box-shadow .32s var(--ease);
}
.whatsapp-float:hover{transform:translateY(-3px);background:rgba(52,245,230,.10);box-shadow:0 0 42px rgba(52,245,230,.14)}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease), transform .85s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
@keyframes markIn{from{opacity:0;letter-spacing:.92em;filter:blur(10px);transform:translateY(18px)}to{opacity:1;filter:blur(0);transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px);filter:blur(5px)}to{opacity:1;transform:none;filter:blur(0)}}
@keyframes lineDrop{from{height:0;opacity:0}to{height:76px;opacity:1}}

@media (max-width:980px){
  .nav{height:86px}
  .menu-toggle{display:inline-flex}
  .nav-links{
    position:fixed;
    top:86px;left:18px;right:18px;
    display:grid;
    gap:0;
    padding:20px;
    background:rgba(2,3,5,.90);
    border:1px solid rgba(255,255,255,.10);
    backdrop-filter:blur(20px);
    transform:translateY(-12px);
    opacity:0;
    pointer-events:none;
    transition:opacity .32s var(--ease), transform .32s var(--ease);
  }
  .nav-links.is-open{opacity:1;transform:none;pointer-events:auto}
  .nav-links a{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.07)}
  .grid-2,.grid-3,.work-grid{grid-template-columns:1fr}
  .entry-center{transform:none}
  .enter-link{margin-top:24vh}
  .page-hero{padding-top:158px}
}
@media (max-width:640px){
  .container{width:min(100% - 32px, var(--max))}
  .nav{padding:0 18px}
  .brand{font-size:12px;letter-spacing:.42em}
  .mark-large{font-size:clamp(42px, 14vw, 72px);letter-spacing:.28em;text-indent:.28em}
  .tagline{font-size:11px;letter-spacing:.44em}
  .enter-link{margin-top:22vh}
  .section{padding:86px 0}
  .page-hero{min-height:52svh}
  .display-title,.page-title{font-size:clamp(42px, 14vw, 68px)}
  .quote-block{font-size:clamp(28px, 9vw, 44px)}
  .card,.contact-card{padding:26px}
}





/* =========================================================
   FIX FINAL REAL — VIDEO VISIBLE EN PC Y MOBILE
   No usar z-index negativo: algunos navegadores lo dejan detrás
   del background negro del body. Video queda en capa 0.
   ========================================================= */

html,
body {
  width: 100% !important;
  min-height: 100% !important;
  margin: 0 !important;
  background: #020305 !important;
  overflow-x: hidden !important;
}

/* Video visible, full screen, sin deformarse */
.site-bg-video,
.fullscreen-bg-video,
.video-background,
.video-bg-cover {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  min-width: 100vw !important;
  min-height: 100vh !important;
  max-width: none !important;
  max-height: none !important;

  object-fit: cover !important;
  object-position: center center !important;

  z-index: 0 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: none !important;

  background: #020305 !important;
  transform: none !important;
  filter: saturate(1.08) contrast(1.02) brightness(1.32) !important;
}

/* Overlay sobre el video, pero bajo el contenido */
.site-bg-overlay,
.fullscreen-bg-overlay,
.video-background-overlay,
.video-bg-overlay {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  min-width: 100vw !important;
  min-height: 100vh !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(5,5,10,.38), rgba(5,5,10,.16), rgba(5,5,10,.36)),
    radial-gradient(circle at 50% 34%, rgba(52,245,230,.10), transparent 34rem),
    radial-gradient(circle at 50% 100%, rgba(52,245,230,.08), transparent 30rem),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.30)) !important;
}

.site-bg-vignette {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 2 !important;
  pointer-events: none !important;
}

#bg-canvas {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 3 !important;
  pointer-events: none !important;
  opacity: .22 !important;
}

.scanline {
  z-index: 4 !important;
  pointer-events: none !important;
}

.noise {
  z-index: 90 !important;
  pointer-events: none !important;
}

/* Evita que fondos pseudo-elementos tapen el video */
body::before,
body::after {
  z-index: 5 !important;
  opacity: .08 !important;
  pointer-events: none !important;
}

/* Todo el sitio va encima del video */
.page-shell {
  position: relative !important;
  z-index: 10 !important;
  min-height: 100vh !important;
  isolation: auto !important;
}

.header,
.nav {
  position: relative !important;
  z-index: 60 !important;
}

.main-content,
main,
.footer,
footer {
  position: relative !important;
  z-index: 20 !important;
}

.whatsapp-float {
  position: fixed !important;
  z-index: 9999 !important;
}

/* Altura real en celulares modernos */
@supports (height: 100dvh) {
  .site-bg-video,
  .fullscreen-bg-video,
  .video-background,
  .video-bg-cover,
  .site-bg-overlay,
  .fullscreen-bg-overlay,
  .video-background-overlay,
  .video-bg-overlay,
  .site-bg-vignette {
    height: 100dvh !important;
    min-height: 100dvh !important;
  }

  .page-shell,
  .entry-hero,
  .page-hero {
    min-height: 100dvh !important;
  }
}

/* Mobile: pantalla completa */
@media (max-width: 768px) {
  .site-bg-video,
  .fullscreen-bg-video,
  .video-background,
  .video-bg-cover {
    width: 100vw !important;
    height: 100vh !important;
    object-fit: cover !important;
    object-position: center center !important;
    opacity: 1 !important;
    filter: saturate(1.08) contrast(1.02) brightness(1.32) !important;
  }

  .site-bg-overlay,
  .fullscreen-bg-overlay,
  .video-background-overlay,
  .video-bg-overlay {
    background:
    linear-gradient(90deg, rgba(5,5,10,.38), rgba(5,5,10,.16), rgba(5,5,10,.36)),
    radial-gradient(circle at 50% 34%, rgba(52,245,230,.07), transparent 34rem),
    radial-gradient(circle at 50% 100%, rgba(52,245,230,.05), transparent 30rem),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.30)) !important;
}

  .entry-hero {
    min-height: 100vh !important;
  }
}

@supports (height: 100dvh) {
  @media (max-width: 768px) {
    .site-bg-video,
    .fullscreen-bg-video,
    .video-background,
    .video-bg-cover,
    .site-bg-overlay,
    .fullscreen-bg-overlay,
    .video-background-overlay,
    .video-bg-overlay,
    .site-bg-vignette {
      height: 100dvh !important;
      min-height: 100dvh !important;
    }

    .entry-hero {
      min-height: 100dvh !important;
    }
  }
}
/* En celular: video completo también */
@media (max-width: 760px) {
  body .fullscreen-bg-video,
  .fullscreen-bg-video {
    object-fit: contain !important;
    object-position: center center !important;
    filter: saturate(1.08) contrast(1.02) brightness(1.32) !important;
  }

  body .fullscreen-bg-overlay,
  .fullscreen-bg-overlay {
    background:
      linear-gradient(90deg, rgba(5,5,10,.38), rgba(5,5,10,.16), rgba(5,5,10,.36)),
      linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.30)) !important;
  }
}
/* HOME WORK CAROUSEL */
.work-strip{margin:70px auto 0;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03)}
.work-track{display:flex;width:max-content;animation:workscroll 38s linear infinite}
.work-track:hover{animation-play-state:paused}
.work-item{position:relative;width:420px;height:240px;flex:0 0 auto;overflow:hidden}
.work-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.work-item:hover img{transform:scale(1.05)}
.work-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.25))}
@keyframes workscroll{to{transform:translateX(-50%)}}
@media(max-width:768px){.work-item{width:280px;height:170px}}


/* =========================================================
   SERVICE ICONS — IN_HUMAN
   Íconos minimalistas en tarjetas 01–06 del Home
   ========================================================= */

.service-card {
  position: relative;
  overflow: hidden;
}

.service-card::after {
  content: "";
  position: absolute;
  right: -34px;
  bottom: -42px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(52,245,230,.085), transparent 68%);
  filter: blur(8px);
  pointer-events: none;
}

.card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 68px;
  margin: 0 0 24px;
  color: var(--cyan);
  background: linear-gradient(180deg, rgba(52,245,230,.085), rgba(255,255,255,.02));
  border: 1px solid rgba(52,245,230,.24);
  box-shadow:
    0 14px 34px rgba(0,0,0,.28),
    0 0 32px rgba(52,245,230,.12),
    inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.card-icon svg {
  width: 34px;
  height: 34px;
  display: block;
  filter: drop-shadow(0 0 12px rgba(52,245,230,.20));
}

.service-card h3 {
  max-width: 19ch;
}

.service-card .number {
  margin-bottom: 20px;
}

@media (max-width: 768px) {
  .card-icon {
    width: 62px;
    height: 62px;
    margin-bottom: 20px;
  }

  .card-icon svg {
    width: 30px;
    height: 30px;
  }
}
