*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#000000;--accent:#D1EE3C;--white:#EBEBEB;
  --dim:#3a3a3a;--mid:#a8a8a8;
  --ease:cubic-bezier(0.16,1,0.3,1);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--white);font-family:'Space Mono',monospace;font-size:14px;line-height:1.6;cursor:none;overflow-x:hidden}

/* CURSOR Z */
#cur-z{position:fixed;pointer-events:none;z-index:9999;font-family:'VT323',monospace;font-size:22px;color:var(--accent);transform:translate(-50%,-50%);user-select:none;line-height:1;transition:color .15s,opacity .3s}
body.hovering #cur-z{color:var(--white)}

/* SCANLINE */
#scanline{position:fixed;left:0;right:0;height:1px;background:rgba(209,238,60,.02);pointer-events:none;z-index:200;animation:scan 10s linear infinite}
@keyframes scan{0%{top:0}100%{top:100vh}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:2rem 4rem}
.nav-brand{font-size:1.1rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(235,235,235,.45);text-decoration:none;cursor:none}
.nav-brand .gt{display:inline-block}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);text-decoration:none;cursor:none;transition:color .3s var(--ease);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;right:100%;height:1px;background:var(--accent);transition:right .45s var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{right:0}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:8rem 4rem 5rem;position:relative;overflow:hidden}
#hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(209,238,60,.04) 0%,transparent 70%);pointer-events:none;top:50%;left:50%;transform:translate(-50%,-50%);transition:transform 1.2s cubic-bezier(.25,.46,.45,.94)}
.hero-inner{position:relative;z-index:2;text-align:center;width:100%}

/* LOGO */
#logo-canvas{display:block;margin:0 auto;cursor:none;line-height:0}
.hero-sub{font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;color:var(--mid);margin-top:1.4rem;display:block;text-align:center;transition:color .4s}

/* COUNTDOWN */
#countdown{margin-top:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.cd-label{font-size:.38rem;letter-spacing:.35em;text-transform:uppercase;color:var(--mid)}
.cd-event{font-size:.45rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(209,238,60,.7)}
.cd-numbers{display:flex;gap:2.5rem;align-items:flex-end;margin-top:.3rem}
.cd-unit{display:flex;flex-direction:column;align-items:center;gap:.35rem}
.cd-val{font-size:clamp(.5rem,1.1vw,.8rem);font-weight:900;color:var(--white);line-height:1;letter-spacing:.05em;font-family:'Orbitron',monospace;font-variant-numeric:tabular-nums}
.cd-lbl{font-size:.32rem;letter-spacing:.28em;text-transform:uppercase;color:var(--mid)}
.cd-sep{font-size:clamp(.4rem,.75vw,.6rem);color:var(--dim);padding-bottom:.1rem;line-height:1;font-weight:700;font-family:'Orbitron',monospace}

/* SECTIONS */
section{position:relative;z-index:2;padding:6rem 4rem;max-width:1200px;margin:0 auto}
.sec-lbl{font-size:.57rem;letter-spacing:.38em;text-transform:uppercase;color:var(--mid);margin-bottom:3rem;display:flex;align-items:center;gap:1rem}
.sec-lbl::before{content:'//';color:var(--accent)}

/* SHOWS */
#shows-wrap{border-top:1px solid var(--dim)}
.show-list{list-style:none;max-width:1200px;margin:0 auto;padding:0 4rem}
.show-item{display:grid;grid-template-columns:175px 1fr auto;gap:1.5rem;padding:1.5rem 0 1.8rem;border-bottom:1px solid var(--dim);cursor:none;position:relative;align-items:center;opacity:0;transform:translateY(10px)}
.show-item::before{content:'////  ////  ////  ////  ////  ////  ////';position:absolute;left:0;top:50%;font-size:.44rem;color:var(--accent);opacity:0;transform:translateY(-50%);transition:opacity .4s var(--ease);white-space:nowrap;pointer-events:none;z-index:0}
.show-item:hover::before{opacity:.1}
.show-item:hover{background:rgba(209,238,60,.025)}
.show-date{font-size:.62rem;color:var(--mid);letter-spacing:.05em;z-index:1}
.show-venue{font-size:.82rem;color:var(--white);font-weight:400;font-family:'Share Tech Mono',monospace;letter-spacing:.06em;z-index:1;transition:color .3s}
.show-item:hover .show-venue{color:var(--accent)}
.show-festival{font-size:.59rem;color:var(--mid);text-align:right;z-index:1;transition:color .3s}
.show-item:hover .show-festival{color:rgba(209,238,60,.5)}
.show-egg{position:absolute;bottom:-.1rem;left:0;font-size:.42rem;letter-spacing:.18em;color:transparent;transition:color .7s var(--ease);pointer-events:none;font-family:'Space Mono',monospace}
.tix-link{color:inherit;text-decoration:none;border-bottom:1px solid rgba(209,238,60,.3);padding-bottom:1px;transition:border-color .3s;cursor:none}
.tix-link:hover{border-color:rgba(209,238,60,.9)}
.show-item[data-egg]:hover .show-egg{color:rgba(209,238,60,.5)}

/* MANIFESTO */
#manifesto{border-top:1px solid var(--dim)}
.manifesto-grid{display:grid;grid-template-columns:1fr 2fr;gap:6rem;align-items:start}
.manifesto-num{font-size:4.5rem;font-weight:900;color:var(--dim);line-height:1;user-select:none;font-family:'Orbitron',monospace;letter-spacing:.05em}
.manifesto-body{font-size:.8rem;line-height:2.15;color:rgba(235,235,235,.58);max-width:600px}
.manifesto-body strong{color:var(--white);font-weight:700}
.manifesto-quote{display:block;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--dim);font-size:.6rem;color:var(--mid);letter-spacing:.08em;line-height:2;font-style:italic}
.manifesto-quote cite{display:block;margin-top:.8rem;color:rgba(209,238,60,.5);font-style:normal;letter-spacing:.22em;text-transform:uppercase;font-size:.55rem}

/* ── MANIFESTO REVEAL ── */
.m-chunk{display:block;margin-bottom:.6em;position:relative;min-height:1.4em}
.m-slash{
  display:block;color:var(--mid);letter-spacing:.12em;font-size:.78rem;
  font-family:'Space Mono',monospace;line-height:2.15;
  transition:opacity .25s var(--ease);
  user-select:none;
}
.m-text{
  display:block;color:var(--accent);font-size:.8rem;line-height:2.15;
  opacity:0;transition:opacity .35s var(--ease);
  position:absolute;top:0;left:0;width:100%;
  user-select:none;
}
.m-text strong{color:var(--accent);font-weight:700}
.m-text em{font-style:italic;color:rgba(209,238,60,.75)}
.m-chunk.revealed .m-slash{opacity:0}
.m-chunk.revealed .m-text{opacity:1;user-select:text}
/* quote separator */
.m-sep{display:block;width:100%;height:1px;background:var(--dim);margin:2rem 0}

/* TIENDA */
#tienda{border-top:1px solid var(--dim);text-align:center;padding:7rem 4rem}
.section-h{font-size:clamp(1.2rem,3.5vw,2.5rem);font-weight:700;letter-spacing:.12em;color:var(--white);display:block;margin-bottom:1.5rem}
.section-sub{font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--mid);margin-bottom:3rem;display:block}
.cta-btn{display:inline-block;font-size:.67rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);text-decoration:none;border:1px solid rgba(209,238,60,.3);padding:1rem 2.5rem;cursor:none;position:relative;overflow:hidden;transition:color .45s var(--ease);background:transparent;-webkit-appearance:none;appearance:none;border-radius:0;font-family:'Space Mono',monospace;line-height:1}
.cta-btn::before{content:'';position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);transition:transform .5s var(--ease);z-index:0}
.cta-btn:hover::before{transform:translateX(0)}
.cta-btn:hover{color:#000}
.cta-btn span{position:relative;z-index:1}

/* FOOTER */
/* ── PRODUCT CARD ── */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:0}
.product-card{position:relative;cursor:none}
.product-card a{display:block;text-decoration:none;cursor:none}
.product-img-wrap{
  position:relative;overflow:hidden;background:#0a0a0a;
  aspect-ratio:1/1;
  max-width:220px;
  margin:0 auto;
}
.product-img-wrap img{
  display:block;width:100%;height:100%;
  object-fit:cover;object-position:center top;
  transition:transform .7s var(--ease);
  filter:grayscale(20%);
}
.product-card a:hover .product-img-wrap img{transform:scale(1.04);filter:grayscale(0%)}
.product-img-wrap::after{
  content:'VER PRODUCTO';
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:.55rem;letter-spacing:.35em;color:var(--accent);
  background:rgba(0,0,0,.55);
  opacity:0;transition:opacity .4s var(--ease);
  font-family:'Space Mono',monospace;
}
.product-card a:hover .product-img-wrap::after{opacity:1}
.product-info{padding:1.2rem 0 .5rem}
.product-name{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--white);display:block;margin-bottom:.4rem;font-family:'Share Tech Mono',monospace}
.product-price{font-size:.85rem;font-weight:700;color:var(--accent);font-family:'Orbitron',monospace;letter-spacing:.05em}

.nl-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}
@media(max-width:768px){.nl-grid{grid-template-columns:1fr;gap:2.5rem}}
.nl-input{
  width:100%;background:transparent;
  border:1px solid var(--dim);
  color:var(--white);font-family:'Space Mono',monospace;
  font-size:.65rem;letter-spacing:.08em;
  padding:.85rem 1.1rem;outline:none;
  transition:border-color .3s var(--ease);
  -webkit-appearance:none;border-radius:0;
}
.nl-input:focus{border-color:var(--accent)}
.nl-input::placeholder{color:var(--mid)}

/* ── DRAMA ── */
#drama{border-top:1px solid var(--dim)}
.drama-list{list-style:none;max-width:1200px;margin:0 auto;padding:0 4rem}
.drama-item{display:grid;grid-template-columns:175px 1fr auto;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--dim);cursor:none;position:relative;align-items:center;opacity:0;transform:translateY(10px)}
.drama-item::before{content:'////  ////  ////  ////  ////  ////  ////';position:absolute;left:0;top:50%;font-size:.44rem;color:var(--accent);opacity:0;transform:translateY(-50%);transition:opacity .4s var(--ease);white-space:nowrap;pointer-events:none;z-index:0}
.drama-item:hover::before{opacity:.1}
.drama-item:hover{background:rgba(209,238,60,.025)}
.drama-date{font-size:.62rem;color:var(--mid);letter-spacing:.05em;z-index:1}
.drama-venue{font-size:.82rem;color:var(--white);font-weight:400;font-family:'Share Tech Mono',monospace;letter-spacing:.06em;z-index:1;transition:color .3s}
.drama-item:hover .drama-venue{color:var(--accent)}
.drama-city{font-size:.59rem;color:var(--mid);text-align:right;z-index:1;transition:color .3s}
.drama-item:hover .drama-city{color:rgba(209,238,60,.5)}

.footer-legal-link{font-size:.5rem;letter-spacing:.15em;color:var(--mid);text-decoration:none;transition:color .3s;cursor:none}
.footer-legal-link:hover{color:var(--white)}
footer{border-top:1px solid var(--dim);padding:2.5rem 4rem;display:flex;justify-content:space-between;align-items:flex-end}
.footer-left{font-size:.5rem;letter-spacing:.18em;color:var(--mid);line-height:2}
.footer-coords{color:transparent;transition:color .9s var(--ease);display:block}
footer:hover .footer-coords{color:rgba(209,238,60,.36)}
.footer-right{font-size:.72rem;letter-spacing:.28em;color:var(--dim);text-align:right;line-height:1.8}

.hero-ghost{position:absolute;bottom:4rem;right:4rem;font-size:.53rem;letter-spacing:.22em;color:transparent;transition:color 1.2s var(--ease);text-align:right;line-height:2.1;pointer-events:none;max-width:280px}
#hero:hover .hero-ghost{color:rgba(209,238,60,.18)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .manifesto-grid{grid-template-columns:1fr 1.5fr;gap:3rem}
  .show-item{grid-template-columns:140px 1fr auto}
}
@media(max-width:768px){
  nav{padding:1.2rem 1.5rem}
  .nav-brand{font-size:.6rem}
  .nav-links{gap:1.2rem}
  .nav-links a{font-size:.6rem}

  #hero{padding:6rem 1.5rem 3rem}
  .hero-ghost{display:none}

  #logo-canvas{max-width:90vw!important}

  #countdown{margin-top:2.5rem;gap:.8rem}
  .cd-numbers{gap:1rem}
  .cd-val{font-size:clamp(.9rem,3.5vw,1.3rem)!important}
  .cd-sep{font-size:clamp(.8rem,2.5vw,1rem)!important}
  .cd-event{font-size:.52rem;text-align:center}

  section{padding:3.5rem 1.5rem}
  #tienda{padding:3.5rem 1.5rem}
  .show-list{padding:0 1.5rem}

  .show-item{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    gap:.8rem;padding:1.2rem 0;
  }
  .show-date{font-size:.55rem}
  .show-venue{font-size:.72rem}
  .show-festival{text-align:left;grid-column:1/-1;font-size:.52rem}
  .show-egg{display:none}

  .manifesto-grid{grid-template-columns:1fr;gap:1.5rem}
  .manifesto-num{font-size:2.5rem}
  .manifesto-body{font-size:.75rem}
  .m-slash{font-size:.7rem}
  .m-text{font-size:.75rem}

  .product-grid{grid-template-columns:1fr;max-width:340px;margin-left:auto;margin-right:auto}

  .tienda-header{flex-direction:column;align-items:flex-start!important}

  footer{padding:2rem 1.5rem;flex-direction:column;gap:1.5rem;align-items:flex-start}
  .footer-right{font-size:.6rem}

  .sec-lbl{font-size:.52rem;margin-bottom:2rem}
}
@media(max-width:480px){
  nav{padding:1rem 1.2rem}
  .nav-links{gap:.8rem}
  #hero{padding:5rem 1.2rem 2.5rem}
  section{padding:3rem 1.2rem}
  #tienda{padding:3rem 1.2rem}
  .show-list{padding:0 1.2rem}
  footer{padding:1.5rem 1.2rem}
  .product-grid{max-width:100%}
  .cd-numbers{gap:.7rem}
}
@media(max-width:768px){
  .drama-list{padding:0 1.5rem}
  .drama-item{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.8rem;padding:1.2rem 0}
  .drama-city{text-align:left;grid-column:1/-1;font-size:.52rem}
}
@media(max-width:480px){
  .drama-list{padding:0 1.2rem}
}
@media(max-width:768px){
  #newsletter{padding:3.5rem 1.5rem 1rem 1.5rem}
}
@media(max-width:480px){
  #newsletter{padding:3rem 1.2rem}
  #newsletter form > div:first-child,
  #newsletter form > div:nth-child(2){grid-template-columns:1fr!important}
}
@media(max-width:768px){
  footer ~ div{padding:1.2rem 1.5rem;gap:1rem}
}
@media(max-width:480px){
  footer ~ div{padding:1rem 1.2rem}
}
@media(hover:none),(pointer:coarse){
  #cur-z{display:none!important}
  body{cursor:auto}
  a,button,.show-item,.cta-btn,.logo-wrap,.product-card a{cursor:pointer}
}
@media(min-width:769px) and (max-width:1023px){
  .product-grid{grid-template-columns:repeat(2,1fr)}
  nav{padding:1.5rem 2.5rem}
  section{padding:5rem 2.5rem}
  .show-list{padding:0 2.5rem}
}