/* ============================================================
   AIKI ENTERTAIMENT — institutional / editorial / cold
   Type: Archivo (grotesk) + Spectral (serif italic accents)
   ============================================================ */

:root{
  --bg:#0A0A0A;
  --panel:#0E0F11;
  --fg:#F5F2EC;
  --fg-dim:rgba(245,242,236,0.55);
  --muted:#8A8A8A;
  --accent:#8A8A8A;                       /* gris metálico (tweakable -> azul #3A4A5A) */
  --hairline:rgba(245,242,236,0.13);
  --hairline-soft:rgba(245,242,236,0.06);
  --ghost:rgba(245,242,236,0.035);
  --font-sans:"Archivo","Helvetica Neue",Arial,sans-serif;
  --font-display:"Spectral",Georgia,serif;
  --maxw:1320px;
  --pad-x:clamp(22px,5.5vw,90px);
  --section-y:clamp(110px,15vh,210px);
  --ease:cubic-bezier(.16,.7,.3,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--bg);color:var(--fg);
  font-family:var(--font-sans);font-weight:300;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--fg);color:var(--bg);}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x);}

/* ---------- film grain + vignette ---------- */
.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 0%,transparent 55%,rgba(0,0,0,.55) 100%);}

/* ---------- scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0%;background:var(--accent);z-index:9500;transition:width .12s linear;}

/* ---------- header / nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:8000;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad-x);
  transition:background .5s var(--ease),border-color .5s var(--ease),padding .5s var(--ease);
  border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(10,10,10,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hairline-soft);padding-top:14px;padding-bottom:14px;}
.nav__brand{font-family:var(--font-sans);font-weight:700;font-size:15px;letter-spacing:.42em;}
.nav__links{display:flex;gap:clamp(20px,2.6vw,42px);align-items:center;}
.nav__links a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);
  font-weight:500;position:relative;padding:4px 0;transition:color .35s ease;}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--fg);transition:width .4s var(--ease);}
.nav__links a:hover{color:var(--fg);}
.nav__links a:hover::after{width:100%;}
@media(max-width:780px){.nav__links a:not(.nav__cta){display:none;}
  .nav__cta{color:var(--fg);} }
.nav__cta{border:1px solid var(--hairline);padding:9px 16px;border-radius:100px;color:var(--fg)!important;}
.nav__cta::after{display:none;}
.nav__cta:hover{background:var(--fg);color:var(--bg)!important;}

/* ---------- intro overlay ---------- */
.intro{position:fixed;inset:0;z-index:9700;background:var(--bg);
  display:grid;place-items:center;transition:opacity .9s var(--ease);}
.intro__inner{display:flex;flex-direction:column;align-items:center;gap:22px;}
.intro__mark{width:46px;color:var(--accent);}
.intro__mark .chev{fill:none;stroke:currentColor;stroke-width:1.5;
  stroke-dasharray:120;stroke-dashoffset:120;animation:draw 1s var(--ease) forwards;}
.intro__bar{width:140px;height:1px;background:var(--hairline);position:relative;overflow:hidden;}
.intro__bar::after{content:"";position:absolute;inset:0;background:var(--fg);transform:translateX(-100%);animation:load 1.15s var(--ease) forwards .15s;}
.intro__word{font-size:10px;letter-spacing:.5em;color:var(--muted);text-transform:uppercase;}
.intro.is-done{opacity:0;pointer-events:none;}
@keyframes draw{to{stroke-dashoffset:0;}}
@keyframes load{to{transform:translateX(0);}}

/* ============================================================
   REVEALS  (class-gated => degrades to visible without JS)
   ============================================================ */
.reveal-ready [data-reveal]{opacity:0;transform:translateY(30px);
  transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);}
.reveal-ready [data-reveal].in{opacity:1;transform:none;}
/* stagger children */
.reveal-ready [data-stagger]>*{opacity:0;transform:translateY(26px);
  transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal-ready [data-stagger].in>*{opacity:1;transform:none;}
.reveal-ready [data-stagger].in>*:nth-child(1){transition-delay:.05s;}
.reveal-ready [data-stagger].in>*:nth-child(2){transition-delay:.13s;}
.reveal-ready [data-stagger].in>*:nth-child(3){transition-delay:.21s;}
.reveal-ready [data-stagger].in>*:nth-child(4){transition-delay:.29s;}
.reveal-ready [data-stagger].in>*:nth-child(5){transition-delay:.37s;}
.reveal-ready [data-stagger].in>*:nth-child(6){transition-delay:.45s;}
/* line mask */
.reveal-ready .lines .ln{display:block;overflow:hidden;}
.reveal-ready .lines .ln>span{display:block;transform:translateY(115%);transition:transform 1s var(--ease);}
.reveal-ready .lines.in .ln>span{transform:translateY(0);}
.reveal-ready .lines.in .ln:nth-child(2)>span{transition-delay:.08s;}
.reveal-ready .lines.in .ln:nth-child(3)>span{transition-delay:.16s;}
.reveal-ready .lines.in .ln:nth-child(4)>span{transition-delay:.24s;}

body[data-motion="reduced"] *{animation:none!important;transition:none!important;}
body[data-motion="reduced"] [data-reveal],
body[data-motion="reduced"] [data-stagger]>*,
body[data-motion="reduced"] .lines .ln>span{opacity:1!important;transform:none!important;}

/* shared section bits */
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);font-weight:500;
  display:inline-flex;align-items:center;gap:12px;}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block;}
.serif{font-family:var(--font-display);}
.it{font-family:var(--font-display);font-style:italic;font-weight:400;}
.section{padding-block:var(--section-y);position:relative;}
.ghost{position:absolute;font-family:var(--font-sans);font-weight:900;color:var(--ghost);
  letter-spacing:-.04em;white-space:nowrap;pointer-events:none;z-index:0;line-height:.8;text-transform:uppercase;}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:140px var(--pad-x) 90px;position:relative;overflow:hidden;}
.hero__ghost{top:50%;left:50%;transform:translate(-50%,calc(-50% + var(--py,0px)));
  font-size:clamp(180px,40vw,640px);color:rgba(245,242,236,0.022);}
.hero__top{position:absolute;top:96px;left:0;right:0;display:flex;justify-content:space-between;
  padding-inline:var(--pad-x);font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);}
.brand-mark{height:clamp(54px,8vh,92px);display:flex;align-items:flex-end;justify-content:center;margin-bottom:clamp(30px,4.5vh,52px);position:relative;z-index:2;}
.brand-mark svg{width:38px;color:var(--accent);overflow:visible;}
.brand-mark .chev{fill:none;stroke:currentColor;stroke-width:1.5;transform-origin:center bottom;animation:breathe 3.6s ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.28;transform:translateY(2px) scaleY(.96);}50%{opacity:.95;transform:translateY(0) scaleY(1.04);}}
.hero__logo{width:clamp(230px,40vw,470px);margin:0 auto;position:relative;z-index:2;}
.hero__tagline{font-family:var(--font-display);font-weight:400;font-size:clamp(19px,2.4vw,32px);
  line-height:1.32;letter-spacing:.005em;margin:clamp(28px,4vh,46px) auto 0;max-width:min(92vw,38ch);
  text-wrap:balance;position:relative;z-index:2;}
.hero__loc{margin-top:clamp(20px,2.6vh,32px);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);position:relative;z-index:2;}
.hero__scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2;}
.hero__scroll span{font-size:9.5px;letter-spacing:.4em;color:var(--muted);text-transform:uppercase;}
.hero__scroll i{width:1px;height:46px;background:linear-gradient(var(--muted),transparent);position:relative;overflow:hidden;}
.hero__scroll i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--fg);animation:scrolldot 2.2s var(--ease) infinite;}
@keyframes scrolldot{0%{transform:translateY(-100%);}60%,100%{transform:translateY(260%);}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  padding:22px 0;overflow:hidden;white-space:nowrap;position:relative;}
.marquee__track{display:inline-flex;gap:48px;animation:scrollx 34s linear infinite;will-change:transform;}
.marquee__track span{font-family:var(--font-display);font-style:italic;font-size:clamp(18px,2.1vw,28px);color:var(--fg-dim);}
.marquee__track span::before{content:"—";margin-right:48px;color:var(--accent);font-style:normal;}
@keyframes scrollx{to{transform:translateX(-50%);}}

/* ============================================================
   MANIFIESTO
   ============================================================ */
.manifesto{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(36px,6vw,90px);align-items:end;}
.manifesto__head{font-weight:700;font-size:clamp(34px,6vw,82px);line-height:.98;letter-spacing:-.03em;margin:18px 0 0;}
.manifesto__head .it{font-weight:400;letter-spacing:-.01em;}
.manifesto__aside p{color:var(--fg-dim);font-size:clamp(15px,1.15vw,18px);line-height:1.6;font-weight:300;max-width:34ch;}
@media(max-width:820px){.manifesto{grid-template-columns:1fr;align-items:start;gap:34px;}}

/* ============================================================
   ARTISTA (featured)
   ============================================================ */
.artist__ghost{top:-2.4vw;left:50%;transform:translateX(-50%) translateY(var(--py,0px));font-size:clamp(90px,18vw,300px);}
.artist__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3.5vw,60px);align-items:center;position:relative;z-index:1;margin-top:clamp(40px,5vw,72px);}
.artist__media{position:relative;aspect-ratio:4/3;border:1px solid var(--hairline);overflow:hidden;}
.artist__media image-slot,.artist__media img{display:block;width:100%;height:100%;object-fit:cover;object-position:50% 50%;}
.artist__play{position:absolute;right:20px;bottom:20px;width:64px;height:64px;border-radius:50%;
  border:1px solid rgba(245,242,236,.55);background:rgba(10,10,10,.35);backdrop-filter:blur(6px);
  display:grid;place-items:center;color:var(--fg);transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease);}
.artist__play svg{width:20px;height:20px;margin-left:2px;}
.artist__play:hover{background:var(--fg);color:var(--bg);transform:scale(1.06);}
.artist__meta-top{display:flex;gap:28px;flex-wrap:wrap;padding-bottom:22px;border-bottom:1px solid var(--hairline);margin-bottom:30px;}
.artist__meta-top div{display:flex;flex-direction:column;gap:5px;}
.artist__meta-top dt{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);}
.artist__meta-top dd{margin:0;font-size:14px;color:var(--fg);letter-spacing:.02em;}
.artist__name{font-weight:700;font-size:clamp(34px,5vw,76px);line-height:.96;letter-spacing:-.025em;margin:0 0 6px;}
.artist__name .it{font-weight:400;letter-spacing:-.01em;}
.artist__sub{color:var(--fg-dim);font-size:15px;letter-spacing:.04em;margin:0 0 30px;}
.eq{display:inline-flex;align-items:flex-end;gap:3px;height:18px;margin-bottom:30px;}
.eq i{width:3px;background:var(--accent);animation:eq 1.1s ease-in-out infinite;}
.eq i:nth-child(1){height:40%;animation-delay:0s;}.eq i:nth-child(2){height:90%;animation-delay:.2s;}
.eq i:nth-child(3){height:60%;animation-delay:.4s;}.eq i:nth-child(4){height:100%;animation-delay:.1s;}
.eq i:nth-child(5){height:50%;animation-delay:.3s;}
@keyframes eq{0%,100%{transform:scaleY(.4);}50%{transform:scaleY(1);}}
.btn-link{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;width:fit-content;padding-bottom:6px;border-bottom:1px solid var(--hairline);
  transition:gap .4s var(--ease),border-color .4s var(--ease);}
.btn-link:hover{gap:18px;border-color:var(--fg);}
.btn-link .arrow{transition:transform .4s var(--ease);}
.btn-link:hover .arrow{transform:translateX(5px);}
@media(max-width:820px){.artist__grid{grid-template-columns:1fr;gap:30px;}}

/* ============================================================
   SERVICIOS (sticky title + list)
   ============================================================ */
.services{display:grid;grid-template-columns:0.85fr 1.3fr;gap:clamp(30px,5vw,80px);align-items:start;}
.services__title{position:sticky;top:120px;}
.services__title h2{font-family:var(--font-display);font-weight:400;font-size:clamp(34px,4.6vw,62px);line-height:1;margin:18px 0 20px;letter-spacing:-.01em;}
.services__title p{color:var(--fg-dim);font-size:15px;line-height:1.6;max-width:30ch;}
.svc{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(18px,2.4vw,40px);align-items:center;
  padding:clamp(26px,3vw,40px) 0;border-top:1px solid var(--hairline);transition:padding-left .5s var(--ease);}
.svc:last-child{border-bottom:1px solid var(--hairline);}
.svc:hover{padding-left:14px;}
.svc__num{font-size:12px;letter-spacing:.2em;color:var(--muted);font-weight:500;transition:color .5s ease;min-width:2.2em;}
.svc:hover .svc__num{color:var(--accent);}
.svc__title{font-weight:400;font-size:clamp(20px,2.3vw,30px);letter-spacing:-.01em;line-height:1.08;}
.svc__dot{width:7px;height:7px;border:1px solid var(--muted);border-radius:50%;opacity:0;transform:translateX(-8px);transition:opacity .5s var(--ease),transform .5s var(--ease),background .5s ease,border-color .5s ease;}
.svc:hover .svc__dot{opacity:1;transform:none;background:var(--accent);border-color:var(--accent);}
@media(max-width:820px){.services{grid-template-columns:1fr;gap:24px;}.services__title{position:static;}}

/* ============================================================
   DIRECCIÓN (CEOs)
   ============================================================ */
.direction{text-align:center;}
.direction__head{font-family:var(--font-display);font-weight:400;font-size:clamp(30px,4vw,56px);line-height:1.04;margin:18px auto clamp(44px,5vw,70px);max-width:18ch;letter-spacing:-.01em;}
.direction__head .it{display:block;color:var(--fg-dim);}
.direction__photo{max-width:760px;margin:0 auto;position:relative;}
.direction__photo img{width:100%;border:1px solid var(--hairline-soft);}
.direction__links{display:flex;justify-content:center;gap:clamp(30px,6vw,90px);margin-top:clamp(34px,4vw,56px);flex-wrap:wrap;}
.direction__links a{display:flex;flex-direction:column;gap:6px;align-items:center;color:var(--muted);transition:color .35s ease;}
.direction__links a strong{font-weight:600;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg);}
.direction__links a:hover{color:var(--fg);}

/* ============================================================
   CONTACTO
   ============================================================ */
.contact__head{font-family:var(--font-display);font-weight:400;font-size:clamp(52px,11vw,150px);line-height:.92;letter-spacing:-.02em;margin:20px 0 clamp(50px,6vw,84px);}
.contact__head .it{font-style:italic;}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,1.8vw,26px);}
.cbtn{display:flex;align-items:center;gap:18px;padding:clamp(28px,3.2vw,44px) clamp(26px,3vw,44px);
  border:1px solid var(--fg);color:var(--fg);background:transparent;position:relative;overflow:hidden;
  transition:color .5s var(--ease);}
.cbtn::before{content:"";position:absolute;inset:0;background:var(--fg);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0;}
.cbtn:hover::before{transform:translateY(0);}
.cbtn:hover{color:var(--bg);}
.cbtn>*{position:relative;z-index:1;}
.cbtn .wa{width:26px;height:26px;flex:none;}
.cbtn .lbl{display:flex;flex-direction:column;gap:6px;}
.cbtn .lbl b{font-weight:600;font-size:clamp(18px,2vw,24px);letter-spacing:.03em;}
.cbtn .lbl span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .5s ease;}
.cbtn:hover .lbl span{color:rgba(10,10,10,.55);}
.cbtn .farrow{margin-left:auto;font-size:20px;transition:transform .5s var(--ease);}
.cbtn:hover .farrow{transform:translate(4px,-4px);}
@media(max-width:760px){.contact__grid{grid-template-columns:1fr;}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--hairline);padding:clamp(50px,6vh,80px) var(--pad-x) clamp(34px,4vh,48px);}
.footer__row{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap;margin-bottom:clamp(40px,6vw,70px);}
.footer__brand{font-weight:700;letter-spacing:.4em;font-size:18px;}
.footer__nav{display:flex;gap:26px;flex-wrap:wrap;}
.footer__nav a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);transition:color .35s ease;}
.footer__nav a:hover{color:var(--fg);}
.footer__legal{font-size:11.5px;letter-spacing:.1em;color:var(--muted);text-align:center;border-top:1px solid var(--hairline-soft);padding-top:26px;}
