/* ===========================================================
   PULSO STUDIO — estilos v2 (cinematic premium)
   =========================================================== */

:root{
  --bg:#050505;
  --bg-2:#0a0a0a;
  --ink:#F0EBE3;
  --acid:#CFFF04;
  --grafito:#1C1C1C;
  --panel:#121212;
  --panel-2:#161616;
  --card-line:#2A2A2A;
  --muted:#8E8A82;
  --rule:#1e1e1e;
  --black:#0A0A0A;
  --wa:#25D366;
  --max:1200px;
  --max-wide:1400px;
  --radius:28px;
  --radius-lg:40px;
  --radius-sm:14px;
  --shadow-card:0 40px 120px -30px rgba(0,0,0,0.85);
  --shadow-acid:0 30px 80px -20px rgba(207,255,4,0.25);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-scrolling iframe{pointer-events:none}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:400;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none; /* ocultamos cursor nativo solo en desktop */
}
@media(max-width:1024px){body{cursor:auto}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

h1,h2,h3,h4{font-family:'Archivo Black',sans-serif;font-weight:normal;letter-spacing:-0.02em;line-height:1}
h1{font-size:clamp(3rem,9vw,9rem)}
h2{font-size:clamp(2.4rem,5.5vw,5rem);line-height:1.02}
h3{font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.1}

.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.container-wide{max-width:var(--max-wide);margin:0 auto;padding:0 24px}
section{position:relative}

.eyebrow{
  font-family:'Archivo Black',sans-serif;
  font-size:0.78rem;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--acid);margin-bottom:22px;display:inline-block;
}
.muted{color:var(--muted)}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--muted);max-width:60ch;line-height:1.65}
em,h1 em,h2 em,h3 em{font-style:normal;color:var(--acid)}

/* =========================================================
   CURSOR PERSONALIZADO
   ========================================================= */
.cursor-dot{
  position:fixed;left:0;top:0;
  width:6px;height:6px;
  background:var(--acid);
  border-radius:50%;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .1s, opacity .2s;
  will-change:transform;
}
.cursor-ring{
  position:fixed;left:0;top:0;
  width:38px;height:38px;
  border:1.5px solid rgba(207,255,4,0.55);
  border-radius:50%;
  pointer-events:none;
  z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s, height .3s, border-color .3s;
  will-change:transform;
}
body.cursor-hover .cursor-ring{
  width:56px;height:56px;
  border-color:var(--acid);
}
@media(max-width:1024px){
  .cursor-dot,.cursor-ring{display:none}
}

/* =========================================================
   NAVBAR
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:border-color .4s, background .4s, backdrop-filter .4s;
}
.nav.scrolled{
  border-bottom-color:rgba(255,255,255,0.05);
  background:rgba(5,5,5,0.28);
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
}
.nav-inner{
  max-width:var(--max-wide);margin:0 auto;padding:22px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;font-family:'Archivo Black',sans-serif;letter-spacing:-0.01em;line-height:1}
.brand-mark{display:block;width:46px;height:34px;flex-shrink:0}
.brand-mark rect{fill:var(--acid)}
.brand-lockup{display:flex;flex-direction:column;line-height:0.92}
.brand-lockup .p{font-size:1.25rem;color:var(--ink)}
.brand-lockup .s{font-size:0.78rem;color:var(--muted);letter-spacing:0.12em;text-transform:uppercase;margin-top:3px;font-family:'Inter',sans-serif;font-weight:600}
.nav-menu{display:flex;align-items:center;gap:6px}
.nav-link{font-family:'Inter',sans-serif;font-size:0.9rem;color:var(--ink);padding:8px 14px;border-radius:999px;transition:color .2s}
.nav-link:hover,.nav-link.active{color:var(--acid)}
.nav-cta{
  background:var(--acid);color:var(--black);
  font-family:'Archivo Black',sans-serif;font-size:0.78rem;
  letter-spacing:0.06em;text-transform:uppercase;
  padding:13px 22px;border-radius:999px;
  transition:transform .2s, box-shadow .2s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-acid)}

/* =========================================================
   SCROLL STAGE — hero + manifiesto sobre imagen fija
   ========================================================= */
.scroll-stage{position:relative;z-index:1;background:var(--bg)}
.stage-pin{
  position:relative;
  height:100vh;min-height:680px;
  overflow:hidden;
  background:var(--bg);
}

/* Textura de ruido cinematográfico */
.stage-noise{
  position:absolute;inset:0;z-index:20;
  pointer-events:none;opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}

.stage-bg{position:absolute;inset:0;z-index:1;pointer-events:none}
.stage-bg-img{
  position:absolute;inset:0;
  background:url('img/hand-green.jpg') center/cover no-repeat;
  clip-path:inset(30% 33% round 10px);
  -webkit-clip-path:inset(30% 33% round 10px);
  will-change:clip-path,transform;
}
.stage-bg-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 90% 70% at center 50%, rgba(5,5,5,0.2) 0%, rgba(5,5,5,0.55) 60%, rgba(5,5,5,0.85) 100%),
    linear-gradient(180deg, rgba(5,5,5,0.5) 0%, rgba(5,5,5,0.1) 35%, rgba(5,5,5,0.7) 100%);
  pointer-events:none;
  opacity:0;
  will-change:opacity;
}
.stage-frame{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  padding:90px 32px 60px;
  will-change:transform,opacity,filter;
}

/* ---------- FRAME A ---------- */
.frame-a{
  justify-content:space-between;
  gap:0;
  padding:90px 32px 50px;
}

/* Labels esquinas (estilo Mateo) */
.hero-corner-label{
  position:absolute;z-index:10;top:94px;
  display:flex;align-items:center;gap:12px;
  font-family:'Inter',sans-serif;font-size:0.72rem;
  letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(240,235,227,0.45);
  opacity:0;
  transition:opacity .6s;
}
.no-js .hero-corner-label{opacity:1}
.hero-corner-label--tl{left:40px}
.hero-corner-label--tr{right:40px}
.hero-corner-line{
  display:block;width:40px;height:1px;
  background:rgba(207,255,4,0.4);
  flex-shrink:0;
}

/* Logo central */
.hero-logo-block{
  display:flex;flex-direction:column;align-items:center;
  gap:18px;
  position:relative;z-index:10;
  /* centrado absoluto en el stage */
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
}
.hero-logo{
  display:flex;align-items:flex-end;justify-content:center;
  gap:clamp(12px,1.8vw,24px);
  font-family:'Archivo Black',sans-serif;line-height:1;
}
.hero-logo-mark{
  display:block;
  width:clamp(64px,7.5vw,110px);
  height:clamp(50px,5.8vw,85px);
  flex-shrink:0;
  position:relative;top:-6px;
}
.hero-logo-mark rect{fill:var(--acid);transform-box:fill-box;transform-origin:center bottom}
.hero-logo-mark rect.eq{animation:eqPulse 1.4s ease-in-out infinite}
@keyframes eqPulse{
  0%,100%{transform:scaleY(0.3)}
  50%{transform:scaleY(1)}
}
.hero-logo-text{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.hero-pulso{
  font-size:clamp(3.6rem,10vw,11rem);
  color:var(--ink);
  letter-spacing:-0.04em;line-height:1;
  text-transform:lowercase;
  display:block;
}
.hero-studio{
  font-size:clamp(0.8rem,1vw,1rem);
  color:var(--ink);background:transparent;
  border:1.5px solid rgba(240,235,227,0.5);
  letter-spacing:0.32em;text-transform:uppercase;
  padding:5px 14px;
  font-family:'Archivo Black',sans-serif;
  align-self:flex-start;
}

/* Línea de brillo bajo el logo */
.hero-glow-line{
  width:clamp(180px,30vw,340px);
  height:1px;
  background:linear-gradient(90deg,transparent,var(--acid),transparent);
  opacity:0.5;
  filter:blur(1px);
}

/* Bloque inferior */
.hero-bottom-group{
  display:flex;flex-direction:column;align-items:center;
  gap:16px;text-align:center;
  position:absolute;bottom:72px;left:0;right:0;
  z-index:10;
}
.hero-eyebrow{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  font-family:'Inter',sans-serif;font-weight:300;
  font-size:clamp(0.82rem,1vw,0.95rem);
  color:var(--ink);opacity:0.75;letter-spacing:0.02em;
}
.hero-eyebrow span:last-child{color:var(--acid);opacity:1;font-weight:500}
.hero-question{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1rem,1.6vw,1.5rem);
  color:var(--ink);letter-spacing:-0.01em;line-height:1.1;
}

/* CTA texto con flecha */
.hero-text-cta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Archivo Black',sans-serif;
  font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--acid);
  padding-bottom:5px;border-bottom:1px solid rgba(207,255,4,0.4);
  transition:gap .25s, border-color .25s;
}
.hero-text-cta:hover{gap:18px;border-color:var(--acid)}
.hero-text-cta svg{width:14px;height:14px}

/* Scroll hint */
.hero-scroll-hint{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  z-index:10;
  opacity:0;
}
.scroll-hint-line{
  display:block;width:1px;height:32px;
  background:linear-gradient(180deg,var(--acid),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}100%{transform:scaleY(0);transform-origin:bottom}}
.scroll-hint-text{
  font-family:'Archivo Black',sans-serif;
  font-size:0.6rem;letter-spacing:0.28em;text-transform:uppercase;
  color:rgba(240,235,227,0.3);
}

/* ---------- FRAME B ---------- */
.frame-b{justify-content:center}
.stage-big-title{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(2.8rem,9vw,9rem);
  line-height:0.95;letter-spacing:-0.03em;color:var(--ink);
  max-width:18ch;
  text-shadow:0 4px 50px rgba(0,0,0,0.6);
}
.stage-big-title em{font-style:normal;color:var(--ink);opacity:0.45}
.acid-text{color:var(--acid);position:relative;display:inline-block}
.acid-text .acid-dot{color:var(--acid)}
.acid-text::after{
  content:"";position:absolute;left:0;right:0;bottom:-8px;height:14px;
  background:linear-gradient(90deg,transparent,var(--acid),transparent);
  filter:blur(18px);opacity:0.55;
}

/* ---------- FRAME C (manifiesto) ---------- */
.frame-c{padding:90px 32px 40px;justify-content:center;gap:24px}
.frame-c-inner{
  width:100%;max-width:1200px;
  display:flex;flex-direction:column;gap:24px;align-items:center;
}
.frame-c .float-title{text-align:center}
.frame-c .float-title .eyebrow{margin-bottom:8px;font-size:0.7rem}
.frame-c .float-title h2{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1.4rem,2.8vw,2.4rem);
  color:var(--ink);letter-spacing:-0.02em;
  text-shadow:0 4px 30px rgba(0,0,0,0.6);
}
.frame-c .float-title h2 em{color:var(--acid)}
.frame-c .float-cards-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:14px;width:100%;
}
.frame-c .float-card{
  position:relative;padding:18px 20px;
  min-height:0;border-radius:var(--radius-sm);
  box-shadow:var(--shadow-card);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  background:rgba(10,10,10,0.78);
  border:1px solid rgba(207,255,4,0.16);
  color:var(--ink);
}
.frame-c .float-num{
  display:block;margin-bottom:10px;
  font-family:'Archivo Black',sans-serif;
  font-size:0.78rem;letter-spacing:0.22em;color:var(--acid);
}
.frame-c .float-card h3{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1rem,1.4vw,1.35rem);
  line-height:1.1;margin-bottom:8px;color:var(--ink);
}
.frame-c .float-card p{
  font-size:clamp(0.82rem,0.95vw,0.95rem);
  line-height:1.55;color:var(--muted);
}

/* =========================================================
   STACK SERVICES — cards sticky superpuestas
   ========================================================= */
.stack-services{
  position:relative;
  background:var(--bg);
  padding:140px 0 60px;
  border-top:1px solid var(--rule);
}
.stack-services-intro{
  text-align:center;padding:0 24px 90px;
  max-width:780px;margin:0 auto;
}
.stack-services-intro h2{margin-top:14px;color:var(--ink)}
.stack-services-intro p{margin-top:18px;color:var(--muted);max-width:560px;margin-left:auto;margin-right:auto;font-size:1.05rem}

.stack-list{
  position:relative;
  padding:0 24px;
  max-width:1500px;margin:0 auto;
}
.stack-card{
  position:sticky;top:6vh;
  height:82vh;margin:0 auto 22vh;
  border-radius:var(--radius-lg);overflow:hidden;
  background:#1a1a1a center/cover no-repeat;
  display:block;
  box-shadow:0 60px 140px -40px rgba(0,0,0,0.9);
  will-change:transform,opacity,filter;
  transform-origin:center top;
  transition:box-shadow .4s;
}
.stack-card:hover{box-shadow:0 60px 140px -40px rgba(0,0,0,0.9),0 0 0 1px rgba(207,255,4,0.12)}
.stack-card:last-child{margin-bottom:0}

.stack-card.web  {background-image:url('https://images.unsplash.com/photo-1581291518857-4e27b48ff24e?w=2000&auto=format&fit=crop&q=80')}
.stack-card.redes{background-image:url('https://images.unsplash.com/photo-1611162617213-7d7a39e9b1d7?w=2000&auto=format&fit=crop&q=80')}
.stack-card.auto {background-image:url('https://images.unsplash.com/photo-1620712943543-bcc4688e7485?w=2000&auto=format&fit=crop&q=80')}

.stack-card::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:rgba(5,5,5,0.18);
  transition:background .4s;
}
.stack-card:hover::before{background:rgba(5,5,5,0.1)}
.stack-card::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(5,5,5,0.15) 0%, rgba(5,5,5,0.35) 50%, rgba(5,5,5,0.88) 100%),
    radial-gradient(ellipse at 25% 100%, rgba(207,255,4,0.06) 0%, transparent 60%);
}
.stack-pill{
  position:absolute;top:36px;right:36px;z-index:3;
  background:rgba(5,5,5,0.82);
  border:1px solid rgba(207,255,4,0.45);
  color:var(--ink);
  font-family:'Archivo Black',sans-serif;font-size:0.82rem;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:12px 24px;border-radius:999px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.stack-num{
  position:absolute;top:38px;left:42px;z-index:3;
  font-family:'Archivo Black',sans-serif;
  font-size:1rem;letter-spacing:0.22em;color:var(--acid);
}
.stack-info{
  position:absolute;left:48px;right:150px;bottom:60px;z-index:3;
  display:flex;flex-direction:column;gap:14px;
}
.stack-info h3{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(2rem,4.5vw,4rem);
  line-height:0.95;color:var(--ink);
  letter-spacing:-0.025em;max-width:18ch;
}
.stack-info p{
  color:rgba(240,235,227,0.85);
  font-size:clamp(0.95rem,1.2vw,1.15rem);line-height:1.55;
  max-width:50ch;
}
.stack-arrow{
  position:absolute;right:48px;bottom:60px;z-index:4;
  width:76px;height:76px;border-radius:50%;
  background:var(--acid);color:var(--black);
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s cubic-bezier(0.34,1.56,0.64,1), box-shadow .3s;
  box-shadow:0 10px 30px -8px rgba(207,255,4,0.45);
}
.stack-card:hover .stack-arrow{
  transform:rotate(-45deg) scale(1.08);
  box-shadow:0 16px 40px -10px rgba(207,255,4,0.55);
}
.stack-arrow svg{width:30px;height:30px;stroke:var(--black);fill:none;stroke-width:2.5}

/* =========================================================
   PROCESO — storytelling pinned
   ========================================================= */
.process-section{
  position:relative;
  background:var(--bg);
  padding:140px 0;
  border-top:1px solid var(--rule);
}
.process-header{
  text-align:center;
  max-width:820px;margin:0 auto;
  padding:0 24px 100px;
}
.process-header h2{margin-top:14px;color:var(--ink)}
.process-header .lead{margin-top:22px;margin-left:auto;margin-right:auto}

/* Zona que se pinea */
.process-scroll-wrap{
  position:relative;
}
.process-sticky-stage{
  max-width:1300px;margin:0 auto;padding:0 40px;
  display:grid;
  grid-template-columns:160px 1fr;
  gap:60px;
  align-items:start;
}

/* Columna izquierda: número gigante */
.process-left{
  position:sticky;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:24px;
  height:auto;
}
.process-big-num{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(6rem,12vw,11rem);
  line-height:1;
  color:transparent;
  -webkit-text-stroke:1.5px rgba(207,255,4,0.3);
  letter-spacing:-0.06em;
  transition:color .5s, -webkit-text-stroke-color .5s;
  user-select:none;
}
.process-big-num.is-active{
  color:var(--acid);
  -webkit-text-stroke-color:var(--acid);
}
.process-v-line{
  width:1px;height:200px;
  background:var(--rule);
  position:relative;overflow:hidden;
}
.process-v-progress{
  position:absolute;top:0;left:0;right:0;
  background:var(--acid);
  height:0%;
  transition:height .15s linear;
  box-shadow:0 0 12px rgba(207,255,4,0.4);
}

/* Columna derecha: pasos */
.process-right{
  display:flex;flex-direction:column;gap:0;
}
.process-step{
  padding:60px 0;
  border-bottom:1px solid var(--rule);
  opacity:0.25;
  transition:opacity .5s;
}
.process-step:first-child{padding-top:0}
.process-step:last-child{border-bottom:none;padding-bottom:0}
.process-step.is-active{opacity:1}

.process-step-inner{
  display:flex;gap:32px;align-items:flex-start;
}
.process-step-num{
  font-family:'Archivo Black',sans-serif;
  font-size:0.78rem;letter-spacing:0.26em;
  color:var(--acid);flex-shrink:0;margin-top:6px;
  opacity:0;
  transition:opacity .4s;
}
.process-step.is-active .process-step-num{opacity:1}
.process-step-content h3{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1.6rem,3vw,2.6rem);
  color:var(--ink);margin-bottom:16px;line-height:1.05;
}
.process-step-content p{
  color:var(--muted);font-size:1.05rem;line-height:1.7;max-width:56ch;margin-bottom:24px;
}
.process-tags{
  display:flex;flex-wrap:wrap;gap:10px;list-style:none;
}
.process-tags li{
  font-family:'Archivo Black',sans-serif;
  font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink);opacity:0.55;
  padding:7px 14px;
  border:1px solid var(--card-line);
  border-radius:999px;
  transition:border-color .3s,opacity .3s;
}
.process-step.is-active .process-tags li{opacity:0.75}
.process-step.is-active .process-tags li:hover{border-color:var(--acid);opacity:1}

/* =========================================================
   PORTFOLIO — grilla alineada (2 cols reales + CTA)
   ========================================================= */
.portfolio-section{
  position:relative;
  background:var(--bg);
  padding:140px 0 100px;
  border-top:1px solid var(--rule);
}
.portfolio-header{
  max-width:1300px;margin:0 auto;padding:0 40px 70px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:40px;
  flex-wrap:wrap;
}
.portfolio-header-left h2{margin-top:14px;color:var(--ink)}
.portfolio-header-right{
  max-width:420px;
  display:flex;flex-direction:column;gap:22px;align-items:flex-start;
}

/* Grilla principal — 2 columnas iguales */
.port-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  max-width:1300px;margin:0 auto;
  padding:0 40px;
}

/* Card base */
.port-card{
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--panel);
  border:1px solid var(--card-line);
  display:flex;flex-direction:column;
  height:520px;           /* altura fija → alineación perfecta */
  transition:border-color .35s, transform .4s cubic-bezier(0.34,1.56,0.64,1);
}
.port-card:hover{
  border-color:rgba(207,255,4,0.35);
  transform:translateY(-7px);
}

/* El link ocupa toda la card */
.port-card-link{
  display:flex;flex-direction:column;
  height:100%;text-decoration:none;
}

/* Imagen superior — crece para ocupar espacio restante */
.port-card-img{
  flex:1;
  background:center/cover no-repeat;
  position:relative;
  overflow:hidden;
  min-height:300px;
  transition:transform .8s cubic-bezier(0.16,1,0.3,1);
}
.port-card:hover .port-card-img{transform:scale(1.04)}
.port-card-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(5,5,5,0.6) 100%);
  transition:opacity .3s;
}

/* CTA superpuesto en hover */
.port-hover-cta{
  position:absolute;inset:0;z-index:2;
  background:rgba(5,5,5,0.72);
  display:flex;align-items:center;justify-content:center;
  gap:10px;
  opacity:0;transition:opacity .3s;
  font-family:'Archivo Black',sans-serif;
  font-size:0.9rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--acid);
}
.port-hover-cta svg{width:20px;height:20px;stroke:var(--acid);fill:none;stroke-width:2}
.port-card:hover .port-hover-cta{opacity:1}

/* Info inferior */
.port-card-info{
  padding:22px 26px 24px;
  flex-shrink:0;
  display:flex;flex-direction:column;gap:6px;
}
.port-cat{
  font-family:'Archivo Black',sans-serif;
  font-size:0.68rem;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--acid);
}
.port-card-info h3{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1.2rem,1.8vw,1.55rem);
  color:var(--ink);line-height:1.05;
}
.port-link-text{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:6px;
  font-family:'Archivo Black',sans-serif;
  font-size:0.75rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--muted);
  transition:color .25s, gap .25s;
}
.port-link-text svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.port-card:hover .port-link-text{color:var(--acid);gap:14px}

/* Card "¿El próximo?" — span 2 columnas */
.port-card--cta{
  grid-column:1 / -1;
  height:auto;min-height:200px;
  background:var(--panel-2);
  border-color:var(--card-line);
  align-items:center;justify-content:center;
  flex-direction:row;gap:40px;
  padding:48px 56px;
  flex-wrap:wrap;
}
.port-card--cta:hover{transform:none;border-color:rgba(207,255,4,0.3)}
.port-cta-text{display:flex;flex-direction:column;gap:10px}
.port-cta-text .port-cat{margin:0}
.port-cta-text h3{font-size:clamp(1.6rem,3vw,2.6rem);color:var(--ink)}
.port-cta-text p{color:var(--muted);font-size:1rem;max-width:46ch;line-height:1.6}

.portfolio-footer{
  text-align:center;margin-top:60px;padding:0 24px;
}

/* =========================================================
   PAIN POINTS — rediseñado
   ========================================================= */
.pain-section{
  background:linear-gradient(180deg, var(--bg) 0%, #060606 100%);
  border-top:1px solid var(--rule);
  padding:160px 0 140px;
}
.pain-head{text-align:center;margin-bottom:100px;padding:0 24px}
.pain-head .eyebrow{color:var(--acid)}
.pain-head h2{margin-top:14px;color:var(--ink);max-width:880px;margin-left:auto;margin-right:auto;line-height:1.05}
.pain-head h2 em{color:var(--acid)}
.pain-list{max-width:1200px;margin:0 auto;padding:0 24px}
.pain-item{
  display:grid;grid-template-columns:200px 1fr;gap:60px;align-items:center;
  padding:70px 0;
  border-bottom:1px solid var(--rule);
  transition:padding-left .4s;
  position:relative;
}
/* Línea decorativa izquierda al hacer hover */
.pain-item::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;
  width:2px;
  background:var(--acid);
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .4s;
}
.pain-item:hover::before{transform:scaleY(1);transform-origin:top}
.pain-item:last-child{border-bottom:none}
.pain-item:hover{padding-left:20px}
.pain-num{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(7rem,16vw,14rem);
  line-height:0.85;
  color:transparent;-webkit-text-stroke:1.5px rgba(240,235,227,0.1);
  letter-spacing:-0.06em;text-align:center;
  transition:color .4s,-webkit-text-stroke-color .4s;
}
.pain-item:hover .pain-num{
  color:var(--acid);
  -webkit-text-stroke-color:transparent;
}
.pain-body h3{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(1.6rem,3.2vw,2.6rem);
  color:var(--ink);margin-bottom:16px;line-height:1.05;
}
.pain-body p{color:var(--muted);font-size:1.05rem;max-width:60ch;line-height:1.7;margin-bottom:18px}
.pain-tag{
  display:inline-block;
  font-family:'Inter',sans-serif;font-size:0.82rem;
  color:var(--muted);border:1px solid var(--card-line);
  padding:6px 14px;border-radius:999px;
  transition:border-color .3s,color .3s;
}
.pain-item:hover .pain-tag{border-color:rgba(207,255,4,0.35);color:var(--acid)}
.pain-tag em{font-style:normal;color:inherit}
.pain-cta{margin-top:80px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:22px;padding:0 24px}
.pain-cta h3{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--ink)}

/* =========================================================
   Botones
   ========================================================= */
.btn-pill{
  background:transparent;color:var(--ink);
  border:1.5px solid rgba(240,235,227,0.35);
  padding:14px 28px;border-radius:999px;
  font-family:'Archivo Black',sans-serif;font-size:0.82rem;
  letter-spacing:0.08em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .25s, color .25s, border-color .25s, transform .25s;
}
.btn-pill:hover{background:var(--acid);color:var(--black);border-color:var(--acid);transform:translateY(-2px)}
.btn-pill.solid{background:var(--acid);color:var(--black);border-color:var(--acid)}
.btn-pill.solid:hover{background:transparent;color:var(--ink);border-color:rgba(240,235,227,0.35)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* =========================================================
   MARQUEE BAND
   ========================================================= */
.marquee-band{
  position:relative;
  padding:120px 0 0;
  background:linear-gradient(180deg, #060606 0%, var(--bg) 100%);
  border-top:1px solid var(--rule);
  overflow:hidden;
}
.marquee-band-inner{
  text-align:center;padding:0 24px 80px;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.marquee-kicker{
  font-family:'Archivo Black',sans-serif;
  font-size:0.82rem;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--muted);
}
.marquee-headline{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(2rem,5vw,4.4rem);
  color:var(--ink);letter-spacing:-0.02em;line-height:1;
  max-width:18ch;
}
.marquee-headline em{font-style:normal;color:var(--acid)}
.marquee-track{
  display:flex;width:100%;overflow:hidden;
  padding:40px 0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--bg);
  mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.marquee-row{
  display:flex;align-items:center;gap:48px;
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(2.6rem,7vw,6rem);
  line-height:1;letter-spacing:-0.02em;
  white-space:nowrap;flex-shrink:0;
  color:var(--ink);
  animation:marqueeScroll 28s linear infinite;
  padding-right:48px;
}
.marquee-row .dot-sep{color:var(--acid)}
.marquee-row span:not(.dot-sep):nth-child(6n+1){color:var(--ink)}
.marquee-row span:not(.dot-sep):nth-child(6n+3){color:transparent;-webkit-text-stroke:1.5px var(--ink)}
.marquee-row span:not(.dot-sep):nth-child(6n+5){color:var(--acid)}
@keyframes marqueeScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =========================================================
   CONTACTO — cinematic redesign
   ========================================================= */
.contacto{
  padding:0 0 140px;
  border-top:1px solid var(--rule);
  overflow:hidden;
}

/* Headline cinematográfico full-width */
.contacto-headline-wrap{
  padding:140px 40px 100px;
  text-align:center;
  position:relative;
  background:linear-gradient(180deg, var(--bg) 0%, #080808 100%);
}
.contacto-headline-wrap::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at center 40%, rgba(207,255,4,0.04) 0%, transparent 70%);
  pointer-events:none;
}
.contacto-big-title{
  font-family:'Archivo Black',sans-serif;
  font-size:clamp(2.8rem,7vw,7rem);
  line-height:0.95;letter-spacing:-0.03em;
  color:var(--ink);
  max-width:22ch;margin:14px auto 0;
}
.contacto-big-title em{color:var(--acid)}
.contacto-sub{
  margin:28px auto 0;
  max-width:56ch;
  font-size:clamp(1rem,1.4vw,1.2rem);
  color:var(--muted);line-height:1.65;
}

.contacto-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.contacto-text h2{margin-bottom:18px;color:var(--ink)}
.contacto-text .lead{margin-bottom:36px}

/* WhatsApp botón grande */
.btn-wa-big{
  display:flex;align-items:center;gap:18px;
  background:var(--wa);
  padding:22px 28px;border-radius:var(--radius-sm);
  margin-bottom:20px;
  transition:transform .3s, box-shadow .3s;
  box-shadow:0 20px 60px -15px rgba(37,211,102,0.4);
}
.btn-wa-big:hover{transform:translateY(-3px);box-shadow:0 28px 80px -15px rgba(37,211,102,0.5)}
.btn-wa-big svg{width:32px;height:32px;fill:#fff;flex-shrink:0}
.btn-wa-big-text{display:flex;flex-direction:column;gap:3px}
.btn-wa-big-text strong{font-family:'Archivo Black',sans-serif;font-size:1rem;color:#fff;letter-spacing:-0.01em}
.btn-wa-big-text span{font-size:0.84rem;color:rgba(255,255,255,0.75)}
.btn-wa-big-arrow{margin-left:auto;font-size:1.4rem;color:#fff;opacity:0.7}

.contacto-alt{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.contacto-alt a,.contacto-alt div.alt{
  display:flex;align-items:center;gap:14px;padding:16px 18px;
  background:var(--panel);border:1px solid var(--card-line);
  border-radius:var(--radius-sm);
  transition:border-color .25s, transform .2s;
}
.contacto-alt a:hover{border-color:var(--acid);transform:translateX(4px)}
.contacto-alt svg{width:20px;height:20px;stroke:var(--acid);fill:none;stroke-width:2;flex-shrink:0}
.contacto-alt strong{font-family:'Archivo Black',sans-serif;font-size:0.78rem;letter-spacing:0.1em;color:var(--ink);display:block}
.contacto-alt span{color:var(--muted);font-size:0.88rem}

/* Trust badges */
.trust-badges{
  display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;
}
.trust-badge{
  display:flex;flex-direction:column;gap:4px;
  padding:18px 20px;
  background:var(--panel);border:1px solid var(--card-line);
  border-radius:var(--radius-sm);
  flex:1;min-width:90px;text-align:center;
  transition:border-color .3s;
}
.trust-badge:hover{border-color:rgba(207,255,4,0.3)}
.trust-num{
  font-family:'Archivo Black',sans-serif;
  font-size:1.6rem;color:var(--acid);letter-spacing:-0.02em;line-height:1;
}
.trust-label{font-size:0.76rem;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase}

/* Form */
form.contact-form{
  background:var(--panel);border:1px solid var(--card-line);
  border-radius:var(--radius);padding:36px 32px;
  display:flex;flex-direction:column;gap:18px;
  box-shadow:0 40px 100px -30px rgba(0,0,0,0.6);
}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:'Archivo Black',sans-serif;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  background:var(--bg);border:1px solid var(--card-line);color:var(--ink);
  padding:14px 16px;border-radius:10px;
  font-family:'Inter',sans-serif;font-size:0.96rem;transition:border-color .2s;
}
.field textarea{resize:vertical;min-height:110px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--acid)}
.form-submit{
  background:var(--acid);color:var(--black);
  padding:18px 28px;border-radius:999px;
  font-family:'Archivo Black',sans-serif;font-size:0.86rem;
  letter-spacing:0.06em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:center;gap:12px;
  transition:transform .25s, box-shadow .25s;margin-top:6px;
}
.form-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-acid)}
.form-submit svg{width:18px;height:18px;transition:transform .25s}
.form-submit:hover svg{transform:translateX(4px)}

/* =========================================================
   FOOTER
   ========================================================= */
footer{border-top:1px solid var(--rule);padding:60px 0 36px;color:var(--muted);font-size:0.9rem}
.foot-grid{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.foot-bottom{display:flex;justify-content:space-between;gap:12px;padding-top:28px;margin-top:28px;border-top:1px solid var(--rule);font-size:0.82rem}
.foot-bottom a:hover{color:var(--acid)}

/* =========================================================
   FIXED BUTTONS
   ========================================================= */
.fab-wa{
  position:fixed;right:22px;bottom:22px;z-index:90;
  width:58px;height:58px;border-radius:50%;
  background:var(--wa);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px -8px rgba(37,211,102,0.5);
  transition:transform .25s;
}
.fab-wa:hover{transform:scale(1.1)}
.fab-wa svg{width:30px;height:30px;fill:#fff}
.fab-call{
  position:fixed;right:22px;bottom:92px;z-index:90;
  background:var(--acid);color:var(--black);
  padding:14px 20px;border-radius:999px;
  font-family:'Archivo Black',sans-serif;font-size:0.78rem;
  letter-spacing:0.06em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  box-shadow:var(--shadow-acid);transition:transform .2s;
}
.fab-call:hover{transform:translateY(-3px)}
.fab-call svg{width:16px;height:16px;stroke:var(--black);fill:none;stroke-width:2.5}

/* =========================================================
   PAGINA-WEB — hero interno y secciones
   ========================================================= */

/* Hero sub-page web design */
.sub-hero-web{
  position:relative;
  padding:180px 0 120px;
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  background:var(--bg);
}
.sub-hero-noise{
  position:absolute;inset:0;pointer-events:none;opacity:0.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
.sub-hero-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 20% 60%, rgba(207,255,4,0.04) 0%, transparent 65%);
}
.sub-hero-inner{display:flex;flex-direction:column;gap:28px;max-width:900px}
.sub-hero-inner h1{font-size:clamp(3rem,9vw,8rem);line-height:0.92;letter-spacing:-0.04em;color:var(--ink)}
.sub-hero-inner h1 em{color:var(--acid)}
.sub-hero-lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--muted);max-width:58ch;line-height:1.65}
.sub-hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.sub-hero-stats{
  display:flex;align-items:center;gap:0;
  margin-top:12px;
  border:1px solid var(--card-line);
  border-radius:var(--radius-sm);
  background:var(--panel);
  overflow:hidden;
  width:fit-content;
}
.stat-item{padding:18px 28px;display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:'Archivo Black',sans-serif;font-size:1.4rem;color:var(--acid);letter-spacing:-0.02em;line-height:1}
.stat-label{font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.stat-sep{width:1px;background:var(--card-line);align-self:stretch}

/* Secciones internas */
.pw-section{padding:120px 0;border-top:1px solid var(--rule)}
.pw-dark{background:#070707}

/* Tipos de web — 3 cards */
.pw-types-grid{
  display:grid;
  grid-template-columns:1.15fr 1fr 1fr;
  gap:20px;align-items:start;
}
.pw-type-card{
  background:var(--panel);border:1px solid var(--card-line);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .3s, transform .35s;
}
.pw-type-card:hover{border-color:rgba(207,255,4,0.3);transform:translateY(-5px)}
.pw-type-card--featured{border-color:rgba(207,255,4,0.25)}
.pw-type-media{aspect-ratio:16/9;background:center/cover no-repeat;position:relative}
.pw-type-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(5,5,5,0.5) 100%)}
.pw-type-body{padding:28px;display:flex;flex-direction:column;gap:14px;flex:1}
.pw-type-tag{font-family:'Archivo Black',sans-serif;font-size:0.72rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--acid)}
.pw-type-card h3{font-size:clamp(1.3rem,2vw,1.7rem);color:var(--ink);line-height:1.05}
.pw-type-card p{color:var(--muted);font-size:0.96rem;line-height:1.65}
.pw-includes{list-style:none;display:flex;flex-direction:column;gap:8px;margin:4px 0 8px}
.pw-includes li{
  font-size:0.9rem;color:var(--ink);opacity:0.8;
  display:flex;gap:10px;align-items:flex-start;
}
.pw-includes li::before{
  content:"";display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--acid);margin-top:8px;flex-shrink:0;
}

/* Proceso 3 pasos */
.pw-proceso-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.pw-paso{
  background:var(--panel);border:1px solid var(--card-line);border-radius:var(--radius-sm);
  padding:36px 30px;
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .3s;
}
.pw-paso:hover{border-color:rgba(207,255,4,0.3)}
.pw-paso-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.pw-paso-num{
  font-family:'Archivo Black',sans-serif;font-size:2.8rem;
  color:var(--acid);letter-spacing:-0.04em;line-height:1;
}
.pw-paso-week{
  font-family:'Archivo Black',sans-serif;font-size:0.68rem;
  letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);
}
.pw-paso h3{font-size:clamp(1.2rem,1.8vw,1.5rem);color:var(--ink);line-height:1.05}
.pw-paso p{color:var(--muted);font-size:0.96rem;line-height:1.65}
.pw-paso-deliverable{
  display:flex;align-items:center;gap:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:0.75rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--acid);margin-top:4px;
}
.pw-paso-deliverable svg{width:16px;height:16px;flex-shrink:0}

/* 6 razones */
.pw-razones-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pw-razon{
  background:var(--panel);border:1px solid var(--card-line);border-radius:var(--radius-sm);
  padding:32px 26px;
  transition:border-color .3s,transform .3s;
}
.pw-razon:hover{border-color:var(--acid);transform:translateY(-4px)}
.pw-razon-num{
  display:block;margin-bottom:14px;
  font-family:'Archivo Black',sans-serif;font-size:0.78rem;
  letter-spacing:0.24em;color:var(--acid);
}
.pw-razon h3{font-size:1.15rem;color:var(--ink);margin-bottom:10px;line-height:1.15}
.pw-razon p{color:var(--muted);font-size:0.93rem;line-height:1.6}

/* CTA final */
.pw-cta-final{
  padding:140px 0;
  background:linear-gradient(180deg,var(--bg) 0%,#060606 100%);
  border-top:1px solid var(--rule);
}
.pw-cta-inner{
  max-width:780px;margin:0 auto;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:28px;
}
.pw-cta-inner h2{font-size:clamp(2.8rem,7vw,6.5rem);line-height:0.92;letter-spacing:-0.04em;color:var(--ink)}
.pw-cta-inner h2 em{color:var(--acid)}
.pw-cta-inner p{color:var(--muted);font-size:1.1rem;max-width:52ch;line-height:1.65}
.pw-cta-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.pw-cta-trust{
  display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:center;
  font-family:'Inter',sans-serif;font-size:0.82rem;
  color:var(--muted);
}

/* Accordion */
.diferencia-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.diferencia-text h2{margin-bottom:20px}
.diferencia-text .lead{margin-bottom:28px}
.accordion{display:flex;flex-direction:column;gap:10px}
.acc-item{background:var(--panel);border:1px solid var(--card-line);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .25s}
.acc-item.open{border-color:var(--acid)}
.acc-btn{width:100%;text-align:left;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;font-family:'Archivo Black',sans-serif;font-size:1rem;color:var(--ink)}
.acc-btn .acc-num{color:var(--acid);font-size:0.78rem;letter-spacing:0.22em;margin-right:10px}
.acc-btn .acc-icon{width:30px;height:30px;border-radius:50%;border:1px solid var(--card-line);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;color:var(--acid);transition:transform .25s,background .25s}
.acc-item.open .acc-icon{transform:rotate(45deg);background:var(--acid);color:var(--black);border-color:var(--acid)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.acc-body-inner{padding:0 24px 22px;color:var(--muted);font-size:0.96rem;line-height:1.65}
.acc-item.open .acc-body{max-height:320px}

/* Responsive pagina-web */
@media(max-width:980px){
  .sub-hero-web{padding:130px 0 80px}
  .sub-hero-stats{flex-direction:column;width:100%}
  .stat-sep{width:100%;height:1px}
  .pw-types-grid{grid-template-columns:1fr}
  .pw-proceso-grid{grid-template-columns:1fr}
  .pw-razones-grid{grid-template-columns:1fr 1fr}
  .diferencia-inner{grid-template-columns:1fr;gap:40px}
}
@media(max-width:640px){
  .pw-razones-grid{grid-template-columns:1fr}
  .sub-hero-inner h1{font-size:clamp(2.8rem,10vw,4.5rem)}
}

/* =========================================================
   SUBPÁGINAS (antiguas)
   ========================================================= */
.subhero{padding:180px 24px 100px;text-align:center;position:relative;overflow:hidden;border-bottom:1px solid var(--rule)}
.subhero h1{font-size:clamp(2.6rem,8vw,7rem);line-height:0.95;color:var(--ink)}
.subhero p{margin-top:24px;color:var(--muted);font-size:clamp(1rem,1.4vw,1.2rem);max-width:680px;margin-left:auto;margin-right:auto}

.split-block{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin:0 auto;max-width:1100px;padding:120px 24px}
.split-block.reverse{direction:rtl}
.split-block.reverse > *{direction:ltr}
.split-text h2{margin-bottom:22px}
.split-text p{color:var(--muted);font-size:1rem;line-height:1.7;margin-bottom:14px}
.split-img{height:380px;border-radius:var(--radius);overflow:hidden;background:#1a1a1a center/cover no-repeat;border:1px solid var(--card-line)}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1100px;margin:0 auto;padding:0 24px}
.feature-card{background:var(--panel);border:1px solid var(--card-line);border-radius:var(--radius-sm);padding:30px 26px;transition:border-color .3s,transform .3s}
.feature-card:hover{border-color:var(--acid);transform:translateY(-4px)}
.feature-card .num{font-family:'Archivo Black',sans-serif;color:var(--acid);font-size:0.78rem;letter-spacing:0.22em;display:block;margin-bottom:14px}
.feature-card h3{font-size:1.2rem;margin-bottom:10px;color:var(--ink)}
.feature-card p{color:var(--muted);font-size:0.94rem}

.examples-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:1100px;margin:0 auto;padding:0 24px}
.example-row{display:flex;align-items:flex-start;gap:18px;background:var(--panel);border:1px solid var(--card-line);border-radius:var(--radius-sm);padding:24px 26px;transition:border-color .3s}
.example-row:hover{border-color:var(--acid)}
.example-row .ex-num{font-family:'Archivo Black',sans-serif;color:var(--acid);font-size:1.6rem;line-height:1;flex-shrink:0;width:38px}
.example-row h4{font-family:'Archivo Black',sans-serif;color:var(--ink);font-size:1rem;margin-bottom:6px}
.example-row p{color:var(--muted);font-size:0.92rem;line-height:1.55}

.cta-block{text-align:center;padding:80px 40px;background:var(--panel);border-radius:var(--radius);border:1px solid var(--card-line);max-width:1000px;margin:120px auto}
.cta-block h2{margin-bottom:18px;color:var(--ink)}
.cta-block p{color:var(--muted);font-size:1.05rem;margin-bottom:28px;max-width:48ch;margin-left:auto;margin-right:auto}

.dolor{background:linear-gradient(180deg, var(--bg) 0%, #060606 100%);border-top:1px solid var(--rule);padding:140px 0}
.dolor-head{text-align:center;margin-bottom:80px;padding:0 24px}
.dolor-head h2{margin-top:14px;color:var(--ink);max-width:880px;margin-left:auto;margin-right:auto;line-height:1.05}
.dolor-list{max-width:1100px;margin:0 auto;padding:0 24px}
.dolor-item{display:grid;grid-template-columns:200px 1fr;gap:50px;align-items:center;padding:50px 0;border-bottom:1px solid var(--rule);transition:padding .3s}
.dolor-item:last-child{border-bottom:none}
.dolor-item:hover{padding-left:14px}
.dolor-num{font-family:'Archivo Black',sans-serif;font-size:clamp(7rem,15vw,12rem);line-height:0.9;color:var(--ink);letter-spacing:-0.06em;text-align:center}
.dolor-item:hover .dolor-num{color:var(--acid)}
.dolor-body h3{font-family:'Archivo Black',sans-serif;font-size:clamp(1.4rem,2.6vw,2.2rem);color:var(--ink);margin-bottom:16px;line-height:1.1}
.dolor-body p{color:var(--muted);font-size:1.02rem;max-width:60ch;line-height:1.7}
.dolor-cta{margin-top:80px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px;padding:0 24px}
.dolor-cta h3{font-size:clamp(1.6rem,3vw,2.4rem);color:var(--ink)}

.section-head{margin-bottom:56px;max-width:760px}

/* =========================================================
   REVEALS genéricos
   ========================================================= */
.reveal{opacity:0}
.no-js .reveal{opacity:1}

/* =========================================================
   FALLBACK no-js
   ========================================================= */
.no-js .stack-card{position:relative;top:auto;height:80vh;opacity:1}
.no-js .process-step{opacity:1}
.no-js .hero-corner-label{opacity:1}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1100px){
  .process-sticky-stage{
    grid-template-columns:100px 1fr;
    gap:32px;padding:0 24px;
  }
  .process-big-num{font-size:clamp(4rem,10vw,8rem)}
  .portfolio-track-outer{padding:0 24px}
  .portfolio-header{padding:0 24px 60px}
}

@media(max-width:980px){
  .nav-menu{display:none}
  .nav-inner{padding:18px 22px}

  .frame-a{padding:80px 24px 50px}
  .hero-corner-label{display:none}
  .hero-logo-block{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
  .hero-bottom-group{bottom:48px}

  .stack-info{left:24px;right:24px;bottom:36px}
  .stack-info h3{font-size:clamp(1.5rem,5vw,2.2rem)}
  .stack-pill{top:24px;right:24px;font-size:0.74rem;padding:10px 18px}
  .stack-num{top:24px;left:24px;font-size:0.9rem}
  .stack-arrow{right:24px;bottom:36px;width:54px;height:54px}
  .stack-arrow svg{width:22px;height:22px}

  .process-sticky-stage{
    grid-template-columns:1fr;
    gap:0;
  }
  .process-left{display:none}
  .process-step{opacity:1}
  .process-step-num{opacity:1}

  .pain-item{grid-template-columns:1fr;gap:16px;text-align:left}
  .pain-num{text-align:left;font-size:clamp(5rem,15vw,8rem)}

  .contacto-inner{grid-template-columns:1fr;gap:40px}
  .contacto-big-title{font-size:clamp(2.4rem,6vw,4rem)}
  .contacto-headline-wrap{padding:100px 24px 70px}

  .split-block{grid-template-columns:1fr;gap:40px;padding:80px 24px}
  .feature-grid,.examples-grid{grid-template-columns:1fr}
  .dolor-item{grid-template-columns:1fr;gap:16px;text-align:left}
  .dolor-num{text-align:left}

  .portfolio-header{flex-direction:column;gap:24px;padding:0 24px 50px}
  .portfolio-header-right{max-width:100%}
  .port-grid{grid-template-columns:1fr;padding:0 24px}
  .port-card{height:auto;min-height:400px}
  .port-card-img{min-height:240px}
  .port-card--cta{grid-column:1;flex-direction:column;padding:36px 28px;text-align:center;align-items:center}

  .trust-badges{gap:10px}
}

@media(max-width:768px){
  .stack-card{
    position:relative;top:auto;
    height:520px;min-height:520px;
    margin-bottom:24px;
    transform:none !important;opacity:1 !important;filter:none !important;
  }
  .port-card{width:300px;height:400px}
  .port-card--featured{width:340px;height:440px}
  .frame-c .float-cards-grid{grid-template-columns:1fr}
}

@media(max-width:560px){
  .fab-call span{display:none}
  .fab-call{padding:14px}
  .nav-cta{padding:10px 14px;font-size:0.7rem}
  .contacto-headline-wrap{padding:80px 20px 60px}
}
