/* =========================================================
   HAY MOVIDA ESTUDIO — ESTILOS GLOBALES
   Estética: urbana oscura / neón. Negro + azul eléctrico.
   ========================================================= */

:root{
  --bg:        #05060a;
  --bg-2:      #0a0d16;
  --panel:     #0e1220;
  --panel-2:   #131a2c;
  --line:      rgba(120,160,255,.14);
  --blue:      #2e8bff;
  --blue-2:    #0a5cff;
  --blue-soft: #6db4ff;
  --cyan:      #36e6ff;
  --white:     #f4f7ff;
  --muted:     #9aa6c4;
  --muted-2:   #6b769a;
  --glow:      0 0 22px rgba(46,139,255,.55);
  --radius:    16px;
  --maxw:      1180px;
  --font-display: 'Anton', 'Arial Black', sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ambient neon glows fixed to bg */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(620px 420px at 12% -5%, rgba(46,139,255,.20), transparent 60%),
    radial-gradient(560px 460px at 105% 12%, rgba(54,230,255,.12), transparent 60%),
    radial-gradient(700px 520px at 50% 115%, rgba(10,92,255,.16), transparent 60%),
    var(--bg);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.04;
  background-image:linear-gradient(var(--blue-soft) 1px,transparent 1px),
                   linear-gradient(90deg,var(--blue-soft) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{position:relative}

/* ---------- Typography helpers ---------- */
.display{font-family:var(--font-display);font-weight:400;letter-spacing:.5px;line-height:.98;text-transform:uppercase}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--blue-soft);font-weight:600;margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--cyan),var(--blue));box-shadow:var(--glow)}
.text-blue{color:var(--blue-soft)}
.text-grad{background:linear-gradient(100deg,#fff 10%,var(--blue-soft) 55%,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;justify-content:center;
  font-weight:700;font-size:.95rem;letter-spacing:.02em;
  padding:15px 26px;border-radius:60px;border:1px solid transparent;
  cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s;
  white-space:nowrap;
}
.btn svg{width:19px;height:19px}
.btn-primary{
  background:linear-gradient(100deg,var(--blue),var(--blue-2));color:#fff;
  box-shadow:0 10px 30px rgba(10,92,255,.45), inset 0 0 0 1px rgba(255,255,255,.08);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(10,92,255,.6)}
.btn-wa{background:linear-gradient(100deg,#25d366,#128c4b);color:#fff;box-shadow:0 10px 30px rgba(18,140,75,.4)}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(18,140,75,.55)}
.btn-ghost{background:rgba(255,255,255,.03);border-color:var(--line);color:var(--white)}
.btn-ghost:hover{border-color:var(--blue);box-shadow:var(--glow);transform:translateY(-3px)}
.btn-lg{padding:18px 34px;font-size:1.02rem}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  transition:background .3s,backdrop-filter .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(6,8,14,.72);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:11px}
.nav-logo .brand-mark{height:38px;width:auto;filter:drop-shadow(0 0 10px rgba(46,139,255,.5))}
.brand-word{font-family:var(--font-display);font-size:1.2rem;line-height:.82;letter-spacing:.6px;color:#fff;text-transform:uppercase;display:flex;flex-direction:column}
.brand-word small{font-family:var(--font-body);font-size:.5rem;letter-spacing:.4em;color:var(--blue-soft);font-weight:700;margin-top:4px}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  position:relative;font-size:.92rem;font-weight:600;color:var(--muted);
  padding:9px 14px;border-radius:10px;transition:color .2s;
}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:#fff}
.nav-links a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--blue));box-shadow:var(--glow);border-radius:2px;
}
.nav-cta{margin-left:8px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;position:relative}
.nav-toggle span{position:absolute;left:9px;right:9px;height:2px;background:#fff;border-radius:2px;transition:.3s;transform-origin:center}
.nav-toggle span:nth-child(1){top:15px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:27px}
.nav-toggle.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

@media(max-width:860px){
  .nav-toggle{display:block}
  .nav-cta{display:none}
  .nav-links{
    position:fixed;top:72px;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(8,10,18,.97);backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);
    padding:14px 22px 26px;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.28s;
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{width:100%;padding:14px 6px;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .nav-links a.active::after{display:none}
  .nav-links .btn{margin-top:16px;width:100%}
}

/* ---------- Hero ---------- */
.hero{padding:150px 0 90px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.7rem,7vw,5.2rem);margin:6px 0 20px}
.hero p.lead{font-size:1.18rem;color:var(--muted);max-width:540px;margin-bottom:34px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px}
.hero-meta{display:flex;gap:28px;margin-top:38px;flex-wrap:wrap}
.hero-meta .num{font-family:var(--font-display);font-size:1.7rem;color:#fff;line-height:1}
.hero-meta .lbl{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin-top:6px}

.hero-visual{position:relative;display:flex;justify-content:center}
.hero-logo-card{
  width:min(420px,100%);background:linear-gradient(160deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:24px;padding:34px;position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.hero-logo-card::before{
  content:"";position:absolute;inset:0;border-radius:24px;padding:1px;
  background:linear-gradient(140deg,rgba(54,230,255,.5),transparent 40%,rgba(10,92,255,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.hero-logo-card{text-align:center}
.hero-logo-card .hero-mark{width:172px;max-width:56%;margin:4px auto 18px;filter:drop-shadow(0 0 26px rgba(46,139,255,.55))}
.hero-word{align-items:center;font-size:2.1rem;letter-spacing:1px}
.hero-word small{font-size:.62rem;letter-spacing:.5em;margin-top:7px}

/* equalizer / waveform */
.waveform{display:flex;align-items:flex-end;gap:5px;height:60px;margin-top:26px;justify-content:center}
.waveform span{width:6px;border-radius:4px;background:linear-gradient(180deg,var(--cyan),var(--blue-2));animation:eq 1.1s ease-in-out infinite;box-shadow:0 0 10px rgba(46,139,255,.5)}
.waveform span:nth-child(2){animation-delay:.15s}.waveform span:nth-child(3){animation-delay:.3s}
.waveform span:nth-child(4){animation-delay:.45s}.waveform span:nth-child(5){animation-delay:.2s}
.waveform span:nth-child(6){animation-delay:.5s}.waveform span:nth-child(7){animation-delay:.35s}
.waveform span:nth-child(8){animation-delay:.1s}.waveform span:nth-child(9){animation-delay:.42s}
.waveform span:nth-child(10){animation-delay:.27s}.waveform span:nth-child(11){animation-delay:.6s}
.waveform span:nth-child(12){animation-delay:.18s}
@keyframes eq{0%,100%{height:12px}50%{height:54px}}
@media(prefers-reduced-motion:reduce){.waveform span{animation:none;height:34px}}

@media(max-width:860px){
  .hero{padding:120px 0 60px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:-1}
  .hero p.lead{font-size:1.06rem}
}

/* ---------- Section heading ---------- */
.sec{padding:92px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head h2{font-size:clamp(2rem,5vw,3.3rem);margin-bottom:16px}
.sec-head p{color:var(--muted);font-size:1.08rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}

/* ---------- Cards / services ---------- */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{
  background:linear-gradient(160deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  position:relative;overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .3s;
}
.card:hover{transform:translateY(-6px);border-color:rgba(46,139,255,.5);box-shadow:0 24px 50px rgba(0,0,0,.5)}
.card::after{content:"";position:absolute;top:0;left:-40%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(109,180,255,.10),transparent);
  transform:skewX(-18deg);transition:left .6s}
.card:hover::after{left:130%}
.card .ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(140deg,rgba(46,139,255,.18),rgba(54,230,255,.08));
  border:1px solid rgba(109,180,255,.25);color:var(--blue-soft);
}
.card .ico svg{width:26px;height:26px}
.card h3{font-size:1.3rem;margin-bottom:10px;letter-spacing:.3px}
.card .num-tag{position:absolute;top:20px;right:22px;font-family:var(--font-display);font-size:2.4rem;color:rgba(109,180,255,.10)}
.card p{color:var(--muted);font-size:.97rem}
.card ul{list-style:none;margin:16px 0 0;display:grid;gap:9px}
.card ul li{position:relative;padding-left:24px;font-size:.93rem;color:var(--muted)}
.card ul li::before{content:"";position:absolute;left:0;top:8px;width:11px;height:11px;border-radius:50%;
  background:radial-gradient(circle,var(--cyan),var(--blue-2));box-shadow:0 0 8px rgba(54,230,255,.6)}
.card .card-cta{margin-top:22px}
.card .card-cta a{display:inline-flex;align-items:center;gap:8px;color:var(--blue-soft);font-weight:700;font-size:.92rem}
.card .card-cta a:hover{color:#fff}

/* ---------- Service feature row ---------- */
.svc{display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center;
  background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:30px;transition:border-color .3s,transform .3s}
.svc:hover{border-color:rgba(46,139,255,.45);transform:translateX(4px)}
.svc .svc-no{font-family:var(--font-display);font-size:2.6rem;color:var(--blue-soft);opacity:.5;min-width:64px}
.svc h3{font-size:1.45rem;margin-bottom:8px}
.svc p{color:var(--muted);font-size:.97rem;margin-bottom:14px}
.svc .tags{display:flex;flex-wrap:wrap;gap:8px}
.svc .tags span{font-size:.78rem;padding:6px 12px;border-radius:30px;background:rgba(46,139,255,.08);
  border:1px solid var(--line);color:var(--blue-soft)}
@media(max-width:760px){.svc{grid-template-columns:1fr;gap:16px}.svc .btn{width:100%}}

/* ---------- Strip / CTA band ---------- */
.band{
  background:linear-gradient(110deg,rgba(10,92,255,.18),rgba(54,230,255,.08));
  border:1px solid var(--line);border-radius:24px;padding:54px;text-align:center;position:relative;overflow:hidden;
}
.band h2{font-size:clamp(1.8rem,4.5vw,2.9rem);margin-bottom:14px}
.band p{color:var(--muted);max-width:560px;margin:0 auto 28px;font-size:1.06rem}
.band .waveform{margin-top:0;margin-bottom:26px}

/* ---------- Steps ---------- */
.steps{counter-reset:s}
.step{display:flex;gap:20px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:0}
.step .n{counter-increment:s;flex:0 0 auto;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-display);font-size:1.3rem;color:#fff;
  background:linear-gradient(140deg,var(--blue),var(--blue-2));box-shadow:var(--glow)}
.step .n::before{content:counter(s)}
.step h4{font-size:1.15rem;margin-bottom:5px}
.step p{color:var(--muted);font-size:.96rem}

/* ---------- Embeds (Trabajos) ---------- */
.embed-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .3s,transform .3s}
.embed-card:hover{border-color:rgba(46,139,255,.45);transform:translateY(-4px)}
.embed-card .embed-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700;font-size:.9rem}
.embed-card .embed-head .dot{width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.ratio-yt{position:relative;width:100%;aspect-ratio:16/9;background:#000}
.ratio-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.embed-sp iframe{width:100%;border:0;border-radius:0}
.embed-empty{padding:34px 20px;text-align:center;color:var(--muted-2);font-size:.92rem;border:1px dashed var(--line);border-radius:12px;margin:14px}
.embed-empty strong{color:var(--blue-soft);display:block;margin-bottom:6px;font-size:.95rem}

/* ---------- Form ---------- */
.form-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
@media(max-width:860px){.form-wrap{grid-template-columns:1fr;gap:30px}}
.form{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:20px;padding:30px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:8px;font-weight:600}
.field input,.field select,.field textarea{
  width:100%;background:#070a12;border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;color:#fff;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,139,255,.18)}
.field textarea{resize:vertical;min-height:108px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236db4ff' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form .btn{width:100%;margin-top:6px}
.form-note{font-size:.82rem;color:var(--muted-2);margin-top:14px;text-align:center}

.contact-side{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:20px;padding:30px}
.contact-side h3{font-size:1.3rem;margin-bottom:18px}
.contact-link{display:flex;align-items:center;gap:14px;padding:14px;border-radius:12px;border:1px solid var(--line);margin-bottom:12px;transition:border-color .25s,transform .25s}
.contact-link:hover{border-color:var(--blue);transform:translateX(4px)}
.contact-link .ci{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(46,139,255,.12);color:var(--blue-soft);flex:0 0 auto}
.contact-link .ci svg{width:21px;height:21px}
.contact-link b{display:block;font-size:.96rem}
.contact-link small{color:var(--muted-2)}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:80;display:flex;align-items:center;gap:0;
  background:linear-gradient(100deg,#25d366,#128c4b);color:#fff;border-radius:50px;
  padding:14px;box-shadow:0 12px 30px rgba(18,140,75,.5);font-weight:700;overflow:hidden;
  transition:gap .3s,padding .3s,transform .25s}
.wa-float svg{width:28px;height:28px;flex:0 0 auto}
.wa-float .wa-txt{max-width:0;opacity:0;white-space:nowrap;transition:max-width .35s,opacity .25s,margin .3s;font-size:.95rem}
.wa-float:hover{transform:translateY(-3px)}
.wa-float:hover .wa-txt{max-width:180px;opacity:1;margin-left:10px;margin-right:6px}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50px;border:2px solid rgba(37,211,102,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}
@media(prefers-reduced-motion:reduce){.wa-float::after{animation:none}}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);padding:60px 0 34px;margin-top:40px;background:rgba(6,8,14,.6)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:40px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:26px}}
.footer .brand-mark{height:44px;width:auto;margin-bottom:14px;filter:drop-shadow(0 0 10px rgba(46,139,255,.4))}
.footer .brand-word{font-size:1.35rem;margin-bottom:16px}
.footer p{color:var(--muted);font-size:.94rem;max-width:320px}
.footer h5{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-soft);margin-bottom:16px}
.footer a.fl{display:block;color:var(--muted);font-size:.95rem;padding:6px 0;transition:color .2s}
.footer a.fl:hover{color:#fff}
.footer-social{display:flex;gap:12px;margin-top:6px}
.footer-social a{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.25s}
.footer-social a:hover{color:#fff;border-color:var(--blue);box-shadow:var(--glow);transform:translateY(-3px)}
.footer-social svg{width:20px;height:20px}
.footer-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted-2);font-size:.86rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* scrollbar */
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--blue-2),var(--blue));border-radius:10px;border:2px solid var(--bg)}

::selection{background:rgba(46,139,255,.4);color:#fff}
