/* ============================================================
   yani.ar — cool / Apple-style · paleta ixi.ar
   Space Grotesk + Hanken Grotesk · menta #16e08a
   ============================================================ */

:root{
  --bg:        #ffffff;
  --soft:      #f4f7f7;
  --ink:       #0f1a22;
  --ink-soft:  #4a5760;
  --muted:     #8a949b;
  --line:      #e6ecec;

  --mint:      #16e08a;
  --green:     #0a8f57;
  --cyan:      #22d3ee;
  --violet:    #8b7cf0;

  --dark:      #0c151b;
  --dark-2:    #14222b;
  --on-dark:   #eef5f3;
  --on-dark-m: #8ba0a3;

  --grad: linear-gradient(100deg, #16e08a 0%, #22d3ee 50%, #8b7cf0 100%);

  --disp: 'Space Grotesk', system-ui, sans-serif;
  --body: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;

  --maxw: 1140px;
  --pad: clamp(1.25rem, 5vw, 4rem);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:5rem; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body); background:var(--bg); color:var(--ink);
  line-height:1.5; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
[data-lang]{ display:none; }
html[lang="es"] [data-lang="es"]{ display:revert; }
html[lang="en"] [data-lang="en"]{ display:revert; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--mint); color:var(--dark); }

.grad{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.grad-d{ color:var(--green); }

/* ============================================================ NAV */
.nav{
  position:sticky; top:0; z-index:60;
  display:flex; align-items:center; gap:1.5rem;
  padding:.7rem var(--pad);
  background:color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);
}
.nav__brand{
  font-family:var(--disp); font-weight:700; font-size:1.15rem; letter-spacing:-.02em;
  display:flex; align-items:center; gap:.45rem;
}
.dot{ width:10px; height:10px; border-radius:50%; background:var(--grad); box-shadow:0 0 12px rgba(22,224,138,.7); }
.nav__links{ display:flex; gap:1.6rem; margin-left:auto; font-size:.9rem; font-weight:500; }
.nav__links a{ color:var(--ink-soft); transition:color .2s; }
.nav__links a:hover{ color:var(--ink); }
.nav__tools{ display:flex; align-items:center; gap:.6rem; }
.langbtn{
  font-family:var(--disp); font-size:.78rem; font-weight:600;
  border:1px solid var(--line); background:transparent; color:var(--ink);
  padding:.4rem .6rem; border-radius:8px; cursor:pointer; transition:all .2s;
}
.langbtn:hover{ border-color:var(--ink); }
.iconbtn{
  display:grid; place-items:center; width:36px; height:36px; border-radius:9px;
  border:1px solid var(--line); background:transparent; cursor:pointer; transition:all .2s;
}
.iconbtn:hover{ border-color:var(--ink); }
.iconbtn__eq{ display:flex; align-items:flex-end; gap:2px; height:13px; }
.iconbtn__eq i{ width:3px; height:5px; background:var(--muted); border-radius:1px; }
.iconbtn.is-playing .iconbtn__eq i{ background:var(--green); animation:eq .9s ease-in-out infinite; }
.iconbtn.is-playing .iconbtn__eq i:nth-child(2){ animation-delay:.25s; }
.iconbtn.is-playing .iconbtn__eq i:nth-child(3){ animation-delay:.5s; }
@keyframes eq{ 0%,100%{ height:4px; } 50%{ height:13px; } }
.navcta{
  font-size:.88rem; font-weight:600; padding:.5rem .9rem; border-radius:999px;
  background:var(--ink); color:#fff; transition:all .2s;
}
.navcta:hover{ background:var(--green); }
@media (max-width:780px){ .nav__links, .navcta{ display:none; } }

/* ============================================================ HERO */
.hero{
  position:relative; min-height:92vh; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center;
  padding:5rem var(--pad) 0;
}
.hero__glow{ display:none; }   /* glow de fondo removido — hero limpio */
.hero__inner{ position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; width:100%; flex:1; display:flex; flex-direction:column; justify-content:center; }
.eyebrow{
  font-family:var(--disp); font-weight:600; font-size:.85rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--green); margin-bottom:1.6rem;
}
.hero__h1{
  font-family:var(--disp); font-weight:700;
  font-size:clamp(3rem, 11vw, 8rem); line-height:.95; letter-spacing:-.04em;
  margin-bottom:1.8rem;
}
.hero__sub{ font-size:clamp(1.1rem, 2.4vw, 1.5rem); color:var(--ink-soft); margin-bottom:2.4rem; max-width:40ch; }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; }

.btn{ display:inline-block; font-family:var(--disp); font-weight:600; font-size:.95rem; padding:.85rem 1.5rem; border-radius:999px; transition:all .2s; cursor:pointer; }
.btn--mint{ background:var(--mint); color:var(--dark); }
.btn--mint:hover{ transform:translateY(-2px); box-shadow:0 10px 30px -10px rgba(22,224,138,.7); }
.btn--line{ border:1px solid currentColor; color:var(--ink); }
.btn--line:hover{ background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }

.hero__strip{
  position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; width:100%;
  display:flex; flex-wrap:wrap; gap:1.4rem 2.4rem; align-items:center;
  padding:1.6rem 0 2.4rem; border-top:1px solid var(--line);
  font-size:.95rem; color:var(--ink-soft);
}
.hero__strip b{ font-family:var(--disp); color:var(--ink); font-weight:700; }

/* ============================================================ SECTIONS */
.section{ padding:clamp(4.5rem, 10vw, 9rem) var(--pad); }
.section--soft{ background:var(--soft); }
.wrap{ max-width:var(--maxw); margin:0 auto; }
.wrap--narrow{ max-width:780px; }

.band{ padding:clamp(4.5rem, 10vw, 9rem) var(--pad); background:var(--dark); color:var(--on-dark); }
.band--music{ background:radial-gradient(120% 80% at 80% 0%, #16241f, var(--dark) 60%); }

/* featured project — variante clara */
.feature--light{ background:var(--bg); color:var(--ink); }
.feature--light .display{ color:var(--ink); }
.feature--light .kicker{ color:var(--green); }
.feature--light .band__lead{ color:var(--ink-soft); }
.band--contact{ background:radial-gradient(120% 90% at 50% 120%, #142a2c, var(--dark) 60%); text-align:center; }

.kicker{
  font-family:var(--disp); font-weight:600; font-size:.82rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--mint); margin-bottom:1.6rem;
}
.display{
  font-family:var(--disp); font-weight:700;
  font-size:clamp(2.2rem, 6.5vw, 4.6rem); line-height:.98; letter-spacing:-.035em;
  margin-bottom:2rem; color:var(--on-dark);
}
.display--dark{ color:var(--ink); }

.band__lead{ font-size:clamp(1.15rem, 2.2vw, 1.5rem); color:var(--on-dark-m); max-width:54ch; line-height:1.55; }
.band__lead--sm{ font-size:clamp(1.05rem,2vw,1.25rem); margin-bottom:2.4rem; }

/* ============================================================ CHIPS */
.chips{ display:flex; flex-wrap:wrap; gap:.55rem; margin-top:2.4rem; }
.chips span{
  font-family:var(--disp); font-weight:500; font-size:.8rem; letter-spacing:.01em;
  padding:.45rem .85rem; border-radius:999px;
}
.chips--dark span{ color:var(--on-dark); border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.03); }
.chips--light span{ color:var(--ink); border:1px solid var(--line); background:var(--soft); }
.band__cta{ margin-top:2.4rem; }

/* ============================================================ WORK CARDS */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:1rem; }
.card{
  position:relative; display:flex; flex-direction:column; gap:.6rem;
  background:var(--bg); border:1px solid var(--line); border-radius:22px;
  padding:1.8rem; min-height:200px; transition:transform .25s, box-shadow .25s, border-color .25s;
  overflow:hidden;
}
.card::after{ content:""; position:absolute; inset:auto -40% -60% auto; width:60%; height:60%;
  background:var(--grad); filter:blur(50px); opacity:0; transition:opacity .3s; }
.card:hover{ transform:translateY(-6px); box-shadow:0 24px 50px -28px rgba(15,26,34,.5); border-color:transparent; }
.card:hover::after{ opacity:.16; }
.card__k{ font-family:var(--disp); font-weight:600; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--green); }
.card h3{ font-family:var(--disp); font-weight:700; font-size:1.7rem; letter-spacing:-.02em; }
.card p{ font-size:.98rem; color:var(--ink-soft); flex:1; }
.card__go{ font-family:var(--disp); font-weight:700; color:var(--ink); font-size:1.05rem; }
.card--play{ background:linear-gradient(165deg, #ffffff, #eafdf4); border-color:#cdeede; }
.card--ghost{ background:var(--soft); border-style:dashed; }
@media (max-width:900px){ .cards{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:580px){ .cards{ grid-template-columns:1fr; } }

/* ============================================================ PATH */
.path{ list-style:none; border-top:1px solid var(--line); margin-top:1rem; }
.path li{
  display:grid; grid-template-columns:7rem 13rem 1fr; gap:1.5rem; align-items:baseline;
  padding:1.3rem 0; border-bottom:1px solid var(--line); transition:padding-left .2s;
}
.path li:hover{ padding-left:.6rem; }
.path__yr{ font-family:var(--disp); font-weight:600; color:var(--green); font-size:.95rem; }
.path__co{ font-family:var(--disp); font-weight:700; font-size:1.3rem; letter-spacing:-.01em; }
.path__ro{ color:var(--ink-soft); font-size:1rem; }
.path__foot{ margin-top:1.6rem; font-family:var(--disp); color:var(--muted); font-size:.95rem; }
@media (max-width:700px){
  .path li{ grid-template-columns:1fr; gap:.2rem; padding:1.1rem 0; }
  .path__co{ font-size:1.15rem; }
}

/* ============================================================ MUSIC */
.music-grid{ display:grid; grid-template-columns:1fr minmax(280px,360px); gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.music-grid__text{ min-width:0; }
.video video{
  width:100%; max-height:78vh;
  border-radius:20px; background:#000; border:1px solid rgba(255,255,255,.12);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8); display:block;
}
@media (max-width:820px){
  .music-grid{ grid-template-columns:1fr; }
  .video{ max-width:340px; margin-top:1rem; }
}
.player{
  display:flex; align-items:center; gap:1rem;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1);
  border-radius:16px; padding:1rem 1.2rem;
}
.player__play, .player__next{ display:grid; place-items:center; width:46px; height:46px; border-radius:50%; cursor:pointer; border:none; font-size:1rem; transition:transform .15s; }
.player__play{ background:var(--mint); color:var(--dark); }
.player__play:hover{ transform:scale(1.07); }
.player__next{ background:transparent; color:var(--on-dark-m); border:1px solid rgba(255,255,255,.18); }
.player__next:hover{ color:#fff; }
.player__meta{ flex:1; display:flex; flex-direction:column; gap:.15rem; min-width:0; }
.player__title{ font-family:var(--disp); font-weight:600; color:var(--on-dark); font-size:.95rem; }
.player__hint{ font-size:.8rem; color:var(--on-dark-m); }

/* ============================================================ MANIFESTO */
.manifesto-sec{ background:var(--bg); }
.manifesto{
  font-family:var(--disp); font-weight:700;
  font-size:clamp(1.7rem, 4.5vw, 3.2rem); line-height:1.08; letter-spacing:-.03em;
  color:var(--ink); margin-bottom:1.6rem;
}
.manifesto__sub{ font-size:clamp(1.05rem,2vw,1.3rem); color:var(--ink-soft); max-width:50ch; }

/* ============================================================ CONTACT + FOOT */
.contact__links{ display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; margin-top:.5rem; }
.band--contact .btn--line{ color:var(--on-dark); }
.band--contact .btn--line:hover{ background:#fff; color:var(--dark); border-color:#fff; }
.foot{
  display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap;
  padding:1.8rem var(--pad); background:var(--dark); color:var(--on-dark-m);
  font-family:var(--disp); font-size:.8rem; border-top:1px solid rgba(255,255,255,.07);
}

/* ============================================================ reveal */
.js .reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.js .reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .js .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .iconbtn.is-playing .iconbtn__eq i{ animation:none; }
}
