/* ========== HERO ========== */
.hero{position:relative;padding:120px 32px 0;background:var(--bg)}
.hero-grid{display:grid;grid-template-columns:1fr;max-width:1600px;margin:0 auto}
.hero-video-wrap{position:relative;width:100%;aspect-ratio:1600/866;min-height:500px;max-height:78vh;border-radius:10px;overflow:hidden;background:#0a0a0a;box-shadow:0 20px 50px rgba(10,29,48,0.15)}
.hero-video-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.55) 0%,rgba(0,0,0,0.2) 28%,rgba(0,0,0,0.15) 55%,rgba(0,0,0,0.65) 100%);pointer-events:none;z-index:1}
.hero-overlay-top{position:absolute;top:32px;left:48px;right:48px;z-index:3;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;color:#fff}
.hero-eyebrow{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.4em;text-transform:uppercase;color:#fff;font-weight:600;display:flex;align-items:center;gap:12px}
.hero-eyebrow::before{content:"";width:32px;height:1px;background:#fff}
.hero-meta-top{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.85);text-align:right}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.hero-bottom{position:absolute;left:48px;right:48px;bottom:40px;z-index:2;display:flex;flex-direction:column;align-items:flex-start;gap:24px}
.hero-headline{font-family:'Bebas Neue',sans-serif;font-size:clamp(64px,11vw,170px);line-height:0.85;letter-spacing:-0.01em;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,0.45)}
.hero-headline em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;color:#fff;font-size:0.85em;opacity:0.92}
.hero-scroll{position:absolute;right:48px;bottom:40px;z-index:3;font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:0.3em;color:rgba(255,255,255,0.85);display:flex;align-items:center;gap:10px;writing-mode:vertical-rl;transform:rotate(180deg);transition:opacity .35s ease,transform .35s ease;pointer-events:none}
.hero-scroll::after{content:"";width:1px;height:40px;background:rgba(255,255,255,0.6)}
.hero-scroll.gone{opacity:0;transform:rotate(180deg) translateY(-8px)}

/* audio toggle — colocado encima del headline dentro de .hero-bottom */
.hero-audio{display:inline-flex;align-items:center;gap:12px;padding:10px 18px 10px 14px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.35);backdrop-filter:blur(10px);border-radius:999px;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:0.22em;cursor:pointer;transition:all .25s;user-select:none}
.hero-audio:hover{background:rgba(255,255,255,0.22);border-color:#fff}
.hero-audio.on{background:var(--accent);border-color:var(--accent)}
.hero-audio .ico{width:22px;height:22px;border-radius:50%;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-audio .ico svg{width:14px;height:14px;display:block}
.hero-audio .ico .ico-on{display:none}
.hero-audio.on .ico{background:#fff;color:var(--accent)}
.hero-audio.on .ico .ico-off{display:none}
.hero-audio.on .ico .ico-on{display:block}
.hero-audio .bars{display:inline-flex;gap:2px;align-items:flex-end;height:14px;margin-left:2px}
.hero-audio .bars i{display:block;width:2px;background:#fff;border-radius:1px;height:4px;animation:none}
.hero-audio.on .bars i{animation:eq 0.9s ease-in-out infinite}
.hero-audio.on .bars i:nth-child(1){animation-delay:0s}
.hero-audio.on .bars i:nth-child(2){animation-delay:0.15s}
.hero-audio.on .bars i:nth-child(3){animation-delay:0.3s}
.hero-audio.on .bars i:nth-child(4){animation-delay:0.45s}
@keyframes eq{0%,100%{height:3px}50%{height:14px}}

.hero-foot{display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;margin-top:48px;padding:32px 16px 64px;border-top:1px solid var(--line)}
.hf-text{font-size:16px;color:var(--ink);line-height:1.6;max-width:420px}
.hf-text strong{color:var(--accent)}
.hf-stat{text-align:center}
.hf-stat .num{font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:1;color:var(--ink);letter-spacing:-0.005em}
.hf-stat .num em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;color:var(--accent);font-size:0.7em}
.hf-stat .label{font-size:11px;letter-spacing:0.22em;color:var(--ink-mute);text-transform:uppercase;margin-top:8px}

/* ========== MARQUEE ========== */
.marquee{padding:24px 0;background:var(--accent);overflow:hidden;white-space:nowrap}
.marquee-track{display:inline-flex;gap:48px;animation:scroll 32s linear infinite;font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:0.06em;color:#fff}
.marquee-track span{display:inline-flex;align-items:center;gap:48px}
.marquee-track span::after{content:"◆";color:rgba(255,255,255,0.6);font-size:14px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ========== SECTION ========== */
section{padding:120px 48px}
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-bottom:72px;align-items:end}
.section-num{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:0.3em;color:var(--accent);font-weight:500}
.section-head h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(54px,8vw,120px);line-height:0.92;letter-spacing:-0.005em;color:var(--ink)}
.section-head h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;color:var(--accent)}
.section-head .lead{font-size:17px;color:var(--ink-mute);line-height:1.7;max-width:480px;justify-self:end}

.services{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.service{background:var(--bg);padding:40px 28px;min-height:340px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;cursor:pointer;transition:background .35s;color:inherit;text-decoration:none}
.service:hover{background:var(--bg-soft)}
.service-icon{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:0.2em;color:var(--accent)}
.service h3{font-family:'Bebas Neue',sans-serif;font-size:38px;line-height:1;letter-spacing:0.005em;margin-top:auto;color:var(--ink)}
.service p{font-size:13px;color:var(--ink-mute);margin-top:14px;line-height:1.55}
.service .arrow{position:absolute;top:32px;right:28px;width:36px;height:36px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--ink);transition:all .3s}
.service:hover .arrow{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg)}

/* ========== SHOWCASE ========== */
.showcase-wrap{padding:0 48px}
.showcase{display:grid;grid-template-columns:1.3fr 1fr;gap:0;background:var(--bg-card);border:1px solid var(--line);border-radius:12px;overflow:hidden;align-items:stretch}
.showcase-visual{position:relative;overflow:hidden;background:#0a0a0a;min-height:100%}
.showcase-visual img,.showcase-visual video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.showcase-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,0.15) 0%,rgba(10,130,189,0.18) 100%);pointer-events:none}
.showcase-vtag{position:absolute;top:20px;left:20px;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);padding:6px 12px;border-radius:999px;font-family:'Bebas Neue',sans-serif;font-size:10px;letter-spacing:0.22em;color:#fff;z-index:2;display:flex;align-items:center;gap:8px}
.showcase-vtag::before{content:"";width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}
.showcase-text{padding:48px 52px;display:flex;flex-direction:column;justify-content:center}
.showcase-tag{font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:0.3em;color:var(--accent);margin-bottom:16px}
.showcase-text h3{font-family:'Bebas Neue',sans-serif;font-size:54px;line-height:0.9;margin-bottom:18px;color:var(--ink)}
.showcase-text h3 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:0.85em;color:var(--accent)}
.showcase-text p{font-size:15px;color:var(--ink-mute);line-height:1.65;margin-bottom:24px}
.showcase-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;border-top:1px solid var(--line);padding-top:20px;margin-top:24px}
.stat .num{font-family:'Bebas Neue',sans-serif;font-size:34px;color:var(--ink);line-height:1}
.stat .label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-mute);margin-top:4px}

/* ========== PRESS ========== */
.press{text-align:center;padding:140px 48px;background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.press-eyebrow{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:0.35em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:36px;font-weight:600}
.press-quote{max-width:1100px;margin:0 auto 64px;min-height:240px;display:flex;align-items:center;justify-content:center}
.press-quote h2{font-family:'Fraunces',serif !important;font-weight:300;font-style:italic;font-size:clamp(38px,5.4vw,68px);color:var(--ink);line-height:1.18;letter-spacing:-0.005em;transition:opacity .4s ease, transform .4s ease}
.press-quote h2 .mark{color:var(--accent);font-style:italic}
.press-quote.fading h2{opacity:0;transform:translateY(10px)}
.press-logos{display:flex;justify-content:center;align-items:center;gap:64px;flex-wrap:wrap;min-height:50px}
.press-logos span{font-size:26px;letter-spacing:0.05em;color:var(--ink);font-family:'Fraunces',serif;font-weight:600;opacity:0.14;transition:opacity .5s ease, transform .5s ease;cursor:pointer;position:relative;padding:8px 4px}
.press-logos span:nth-child(2){font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:0.1em}
.press-logos span:nth-child(4){font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-0.02em;font-style:italic}
.press-logos span:nth-child(6){font-family:'Inter',sans-serif;font-weight:300;letter-spacing:0.3em;text-transform:uppercase;font-size:18px}
.press-logos span.active{opacity:1;transform:translateY(-2px);color:var(--accent)}
.press-logos span.active::after{content:"";position:absolute;left:50%;bottom:-12px;transform:translateX(-50%);width:28px;height:2px;background:var(--accent);border-radius:2px}
.press-logos span:hover{opacity:0.45}
.press-logos span.active:hover{opacity:1}

/* ========== CTA SPLIT ========== */
.cta-block{display:grid;grid-template-columns:1fr 1fr;gap:0}
.cta-side{padding:120px 64px;position:relative}
.cta-side.left{background:var(--bg);border-right:1px solid var(--line)}
.cta-side.right{background:var(--accent);color:#fff}
.cta-side h2{font-family:'Bebas Neue',sans-serif;font-size:96px;line-height:0.9;margin-bottom:24px}
.cta-side h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;display:block;font-size:0.7em;color:var(--ink-mute)}
.cta-side.right h2 em{color:rgba(255,255,255,0.7)}
.cta-side p{font-size:17px;line-height:1.7;max-width:420px;margin-bottom:40px;color:var(--ink-mute)}
.cta-side.right p{color:rgba(255,255,255,0.85)}
.cta-side.right .cta-btn{border-color:#fff;color:#fff;background:transparent}
.cta-side.right .cta-btn:hover{background:#fff;color:var(--accent)}

@media(max-width:1024px){
  .hero{padding:90px 12px 0}
  .hero-video-wrap{min-height:380px;aspect-ratio:auto;height:62vh;border-radius:8px}
  .hero-overlay-top{top:20px;left:20px;right:20px;flex-direction:column;align-items:flex-start;gap:8px}
  .hero-eyebrow{font-size:9.5px;letter-spacing:0.28em;gap:8px}
  .hero-eyebrow::before{width:20px}
  .hero-meta-top{font-size:10px;text-align:left;line-height:1.5}
  .hero-bottom{left:20px;right:20px;top:50%;bottom:auto;transform:translateY(-50%);gap:16px;align-items:flex-start;text-align:left}
  .hero-headline{font-size:72px;text-align:left;width:100%}
  .hero-audio{font-size:10px;padding:7px 12px 7px 10px;gap:8px}
  .hero-audio .ico{width:18px;height:18px;font-size:10px}
  .hero-scroll{display:none}
  .hero-foot{grid-template-columns:1fr 1fr;gap:32px 16px;padding:24px 8px 48px;text-align:center}
  .hf-text{grid-column:1/-1}
  .hf-stat .num{font-size:54px}
  .section-head{grid-template-columns:1fr;gap:24px}
  .section-head .lead{justify-self:start;font-size:15px}
  .services{grid-template-columns:repeat(2,1fr)}
  .service{min-height:auto;padding:32px 24px}
  .service h3{font-size:32px}
  .showcase-wrap{padding:0 24px}
  .showcase{grid-template-columns:1fr}
  .showcase-text{padding:48px 32px}
  .showcase-text h3{font-size:48px}
  .showcase-stats{margin-top:32px;padding-top:24px}
  .stat .num{font-size:32px}
  .press{padding:80px 24px}
  .press-quote{min-height:160px;margin-bottom:40px}
  .press-quote h2{font-size:28px;line-height:1.25}
  .press-logos{gap:24px 32px}
  .press-logos span{font-size:18px}
  .press-logos span:nth-child(2){font-size:22px}
  .marquee-track{font-size:24px;gap:36px}
  .marquee-track span{gap:36px}
  section{padding:64px 24px}
  .cta-block{grid-template-columns:1fr}
  .cta-side{padding:64px 32px}
}

@media(max-width:520px){
  .hero-headline{font-size:60px}
  .services{grid-template-columns:1fr}
  .service h3{font-size:44px}
  .cta-btn{padding:16px 28px;font-size:14px}
  .hf-stat .num{font-size:44px}
  .showcase-text{padding:36px 24px}
  .showcase-text h3{font-size:38px}
  .press-quote h2{font-size:22px}
  section{padding:56px 18px}
  .cta-side{padding:48px 22px}
}
