/* =====================================================
   GERRY VILLARREAL — NARRADOR DE LO IMPOSIBLE
   ===================================================== */
:root {
  --bg:#0A0A0F; --bg2:#0F0F18; --bg3:#13131F;
  --purple:#7C3AED; --purple-l:#9B7FE8; --purple-dim:rgba(124,58,237,.15);
  --cyan:#00C8B4; --lavender:#C4B5FD;
  --text:#F0EEF8; --muted:#7A7A9A; --dim:#3A3A5C;
  --border:rgba(196,181,253,.08); --border-h:rgba(124,58,237,.30);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Syne',sans-serif;
  --bserif:'DM Serif Text',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.7;overflow-x:hidden;cursor:none}
a,button{cursor:none}

/* CURSOR */
#cur{width:8px;height:8px;background:var(--cyan);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,background .2s;mix-blend-mode:screen}
#cur-t{width:32px;height:32px;border:1px solid rgba(124,58,237,.5);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .15s ease}

/* LAYOUT */
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.sec-label{font-size:.7rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--cyan);margin-bottom:1rem}
.sec-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:900;line-height:1.1;color:var(--text);margin-bottom:1rem}
.sec-title em{font-style:italic;color:var(--purple-l)}

/* NAV — centrado, sin logo */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem 2.5rem;transition:background .3s}
.nav.on{background:rgba(10,10,15,.93);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav-links{display:flex;gap:3rem;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.75rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--cyan);transform:scaleX(0);transition:transform .25s;transform-origin:left}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;position:absolute;right:1.5rem}
.nav-btn span{display:block;width:24px;height:1.5px;background:var(--text)}

/* HERO — centrado */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:0 2rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");opacity:.4}
.grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(124,58,237,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.04) 1px,transparent 1px);background-size:60px 60px}
.orb{position:absolute;border-radius:50%;filter:blur(80px)}
.orb1{width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,.18) 0%,transparent 70%);top:-150px;right:-150px;animation:oFloat 12s ease-in-out infinite}
.orb2{width:500px;height:500px;background:radial-gradient(circle,rgba(0,200,180,.1) 0%,transparent 70%);bottom:-100px;left:-100px;animation:oFloat 15s ease-in-out infinite reverse}
.orb3{width:400px;height:400px;background:radial-gradient(circle,rgba(196,181,253,.08) 0%,transparent 70%);top:50%;left:50%;animation:oFloat3 9s ease-in-out infinite 3s}
@keyframes oFloat{0%,100%{transform:translate(0,0)}33%{transform:translate(20px,-30px)}66%{transform:translate(-15px,15px)}}
@keyframes oFloat3{0%,100%{transform:translate(-50%,-50%)}33%{transform:translate(calc(-50% + 20px),calc(-50% - 30px))}66%{transform:translate(calc(-50% - 15px),calc(-50% + 15px))}}

.hero-content{position:relative;z-index:2;max-width:860px;display:flex;flex-direction:column;align-items:center}
.eyebrow{display:flex;align-items:center;gap:1rem;margin-bottom:2.5rem;font-size:.68rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:0;animation:fUp .8s ease forwards .2s}
.eyebrow-line{display:block;width:30px;height:1px;background:var(--cyan);flex-shrink:0}
.hero-title{font-family:var(--serif);font-size:clamp(4rem,11vw,9.5rem);font-weight:900;line-height:.9;letter-spacing:-.02em;margin-bottom:1.8rem}
.tl{display:block;opacity:0;animation:fUp .9s ease forwards}
.tl:nth-child(1){animation-delay:.35s}
.tl.outline{color:transparent;-webkit-text-stroke:2px var(--purple-l);animation-delay:.5s}
.tagline{font-family:var(--bserif);font-size:clamp(1.1rem,2vw,1.4rem);font-style:italic;color:var(--cyan);margin-bottom:1rem;letter-spacing:.06em;opacity:0;animation:fUp .8s ease forwards .7s}
.hero-sub{font-size:.98rem;color:var(--muted);max-width:460px;margin-bottom:3rem;opacity:0;animation:fUp .8s ease forwards .85s}
.cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;opacity:0;animation:fUp .8s ease forwards 1s}
.btn{display:inline-flex;align-items:center;padding:.85rem 2.2rem;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:all .25s}
.btn-p{background:var(--purple);color:#fff;border:1px solid var(--purple)}
.btn-p:hover{background:var(--purple-l);border-color:var(--purple-l);transform:translateY(-2px);box-shadow:0 8px 30px rgba(124,58,237,.35)}
.btn-g{background:transparent;color:var(--lavender);border:1px solid rgba(196,181,253,.3)}
.btn-g:hover{border-color:var(--lavender);background:rgba(196,181,253,.05);transform:translateY(-2px)}
.scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:1rem;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);opacity:0;animation:fUp .8s ease forwards 1.3s}
.scroll-line{width:40px;height:1px;background:var(--dim);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;background:var(--cyan);animation:sLine 2.5s ease-in-out infinite 2s}
@keyframes sLine{0%{left:-100%}50%{left:0}100%{left:100%}}
@keyframes fUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* LAUNCH */
.launch-band{
  position:relative;
  padding:2.75rem 0;
  background:
    linear-gradient(180deg, rgba(8,8,14,.98), rgba(12,12,20,.98)),
    radial-gradient(circle at 82% 18%, rgba(0,200,180,.14), transparent 24%),
    radial-gradient(circle at 18% 82%, rgba(124,58,237,.16), transparent 28%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.launch-band::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(0,200,180,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.05) 1px, transparent 1px);
  background-size:70px 70px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.5), transparent 100%);
  pointer-events:none;
}
.launch-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.4fr .95fr;
  gap:2rem;
  align-items:center;
}
.launch-title{
  font-family:var(--serif);
  font-size:clamp(2rem,4vw,3.15rem);
  font-weight:900;
  line-height:1.04;
  margin-bottom:.9rem;
}
.launch-title em{
  color:var(--cyan);
  font-style:italic;
}
.launch-text{
  max-width:58ch;
  color:var(--muted);
  font-size:.98rem;
}
.launch-panel{
  justify-self:end;
  width:min(100%, 420px);
  padding:1.35rem 1.45rem;
  background:rgba(11,11,19,.88);
  border:1px solid rgba(0,200,180,.18);
  box-shadow:
    0 0 0 1px rgba(124,58,237,.06),
    0 0 28px rgba(0,200,180,.08),
    0 18px 50px rgba(0,0,0,.24);
}
.launch-date{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1.2rem;
}
.launch-day{
  font-family:var(--serif);
  font-size:3.8rem;
  font-weight:900;
  line-height:.9;
  color:#fff;
}
.launch-meta{
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#c8fff6;
  line-height:1.55;
}
.launch-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
}

/* ABOUT */
.about{padding:8rem 0;background:var(--bg2);position:relative}
.about::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--purple-dim),transparent)}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:center}
.about-visual{position:relative}
.about-frame{position:relative;width:320px;height:420px;overflow:hidden;border:1px solid var(--border)}
.about-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.fa1{position:absolute;width:60px;height:2px;background:var(--purple);bottom:-20px;right:-20px}
.fa2{position:absolute;width:2px;height:60px;background:var(--purple);bottom:-20px;right:-20px}
.badge{position:absolute;bottom:-30px;right:-30px;background:var(--bg3);border:1px solid var(--border-h);padding:1.2rem 1.5rem;display:flex;align-items:center;gap:1rem}
.badge-n{font-family:var(--serif);font-size:2.5rem;font-weight:900;color:var(--purple-l);line-height:1}
.badge-t{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;line-height:1.4}
.about-text p{color:var(--muted);margin-bottom:1.2rem;font-size:.97rem}
.stats{display:flex;gap:3rem;margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--border)}
.stat-n{display:block;font-family:var(--serif);font-size:2.2rem;font-weight:900;color:var(--lavender);line-height:1;margin-bottom:.3rem}
.stat-l{font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--dim)}

/* ── BOOKSHELF 3D ── */
.books{padding:8rem 0}
.sec-head{margin-bottom:4rem}
.sec-desc{color:var(--muted);max-width:500px;font-size:.97rem}

.shelf{
  display:flex;
  justify-content:center;
  gap:4rem;
  align-items:flex-end;
  padding:4rem 2rem 5rem;
  position:relative;
}
/* shelf plank */
.shelf::after{
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:20px;
  background:linear-gradient(to bottom, #1e1030 0%, #0f0820 100%);
  border-top:2px solid rgba(124,58,237,.5);
  box-shadow:0 10px 50px rgba(0,0,0,.8), 0 -4px 20px rgba(124,58,237,.1);
}

.book-slot{
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;
  position:relative;
  cursor:none;
}

/* Preventa ambient glow */
.preventa-slot::before{
  content:'';
  position:absolute;
  bottom:1.2rem; left:50%;
  transform:translateX(-50%);
  width:200px; height:300px;
  background:radial-gradient(ellipse at 50% 90%, rgba(0,200,180,.25) 0%, transparent 65%);
  pointer-events:none;
  z-index:0;
  animation:prevGlow 3s ease-in-out infinite;
}
@keyframes prevGlow{0%,100%{opacity:.6}50%{opacity:1}}

/* ── THE BOOK ITSELF ── */
/*
  Real CSS 3D book technique:
  - container has perspective + preserve-3d
  - front face is the cover (z = 0)
  - spine face is rotated -90deg around Y, translated left by spine width
  - top face is rotated +90deg around X, translated up
*/
.book-wrap{
  position:relative;
  z-index:1;
  --spine-w: 28px;
  --cover-w: 160px;
  --cover-h: 240px;
}

.book-3d{
  width:var(--cover-w);
  height:var(--cover-h);
  position:relative;
  transform-style:preserve-3d;
  /* perspective lives here so it applies to children */
  transform:perspective(700px) rotateY(-30deg) rotateX(6deg);
  transition:transform .45s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}

.book-slot:hover .book-3d{
  transform:perspective(700px) rotateY(-12deg) rotateX(3deg) translateY(-20px);
}

/* Front face — push forward by half spine width */
.book-face.front{
  position:absolute;
  width:var(--cover-w);
  height:var(--cover-h);
  top:0; left:0;
  overflow:hidden;
  border-radius:0 2px 2px 0;
  transform:translateZ(calc(var(--spine-w) / 2));
  box-shadow:inset -4px 0 14px rgba(0,0,0,.5);
}
.book-face.front img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
/* right-edge shadow */
.book-face.front::after{
  content:'';
  position:absolute;
  top:0; right:0;
  width:8px; height:100%;
  background:linear-gradient(to right, transparent, rgba(0,0,0,.35));
  pointer-events:none;
}

/* Shine */
.book-shine{
  position:absolute;inset:0;
  background:linear-gradient(
    115deg,
    rgba(255,255,255,.18) 0%,
    rgba(255,255,255,.05) 30%,
    transparent 55%,
    rgba(0,0,0,.08) 100%
  );
  pointer-events:none;
  transition:opacity .35s;
  z-index:2;
}
.book-slot:hover .book-shine{opacity:.3}

/* Spine — rotate from left edge, then translate back so it aligns */
.book-face.spine{
  position:absolute;
  width:var(--spine-w);
  height:var(--cover-h);
  top:0; left:0;
  transform-origin:left center;
  transform:rotateY(-90deg) translateZ(calc(var(--spine-w) * -1)) translateX(calc(var(--spine-w) / -2));
  background:linear-gradient(to right, #030107 0%, #0e0820 50%, #1e1035 80%, #2a1548 100%);
  box-shadow:inset -4px 0 10px rgba(0,0,0,.6), inset 2px 0 4px rgba(255,255,255,.03);
}

/* Top edge — rotate from top, push back */
.book-face.top{
  position:absolute;
  width:var(--cover-w);
  height:var(--spine-w);
  top:0; left:0;
  transform-origin:top center;
  transform:rotateX(90deg) translateZ(calc(var(--spine-w) * -1)) translateY(calc(var(--spine-w) / -2));
  background:linear-gradient(to bottom,
    #f4f0fc 0%,
    #ddd0f8 20%,
    #c4b5fd 50%,
    #a090e0 75%,
    #7860b8 100%
  );
  /* subtle page-line texture */
  background-image:
    linear-gradient(to bottom, #f4f0fc 0%, #ddd0f8 20%, #c4b5fd 50%, #a090e0 75%, #7860b8 100%),
    repeating-linear-gradient(to right, transparent 0px, transparent 2px, rgba(0,0,0,.06) 2px, rgba(0,0,0,.06) 3px);
  opacity:.9;
}

/* Book label */
.book-label{
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  text-align:center;width:190px;
  position:relative;z-index:1;
}
.bl-title{
  font-family:var(--sans);font-size:.78rem;font-weight:600;
  color:var(--muted);letter-spacing:.04em;line-height:1.3;
  transition:color .25s;
}
.book-slot:hover .bl-title{color:var(--text)}
.bl-badge{
  font-size:.6rem;font-weight:800;
  letter-spacing:.15em;text-transform:uppercase;
  padding:.28rem .8rem;border-radius:2px;
}
.preventa-pill{background:var(--cyan);color:#0a0a0f}
.free-pill{background:rgba(196,181,253,.15);color:var(--lavender);border:1px solid rgba(196,181,253,.3)}

/* Hover tooltip */
.book-slot::after{
  content:'Ver sinopsis →';
  position:absolute;
  top:40%; left:50%;
  transform:translate(-50%,-50%) translateY(10px);
  background:rgba(8,6,16,.95);
  color:var(--cyan);
  font-family:var(--sans);
  font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  padding:.5rem 1.1rem;
  opacity:0;transition:all .3s ease;
  pointer-events:none;
  white-space:nowrap;
  border:1px solid var(--cyan);
  z-index:10;
}
.book-slot:hover::after{
  opacity:1;
  transform:translate(-50%,-50%) translateY(-120px);
}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(5,5,10,.85);
  backdrop-filter:blur(8px);
  z-index:1000;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all}

.modal{
  background:var(--bg2);
  border:1px solid var(--border-h);
  max-width:780px;width:100%;
  position:relative;
  transform:translateY(30px) scale(.97);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  max-height:90vh;
  overflow-y:auto;
}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}

.modal-close{
  position:absolute;top:1rem;right:1rem;
  background:var(--bg3);border:1px solid var(--border);
  color:var(--muted);width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:2;
}
.modal-close:hover{color:var(--text);border-color:var(--border-h)}

.modal-inner{display:grid;grid-template-columns:220px 1fr;gap:0}

.modal-cover{
  position:relative;overflow:hidden;
  background:var(--bg3);
  flex-shrink:0;
}
.modal-cover img{width:100%;height:100%;object-fit:cover;display:block;min-height:320px}

.modal-body{padding:2.5rem}
.modal-badge{
  display:inline-block;
  font-size:.62rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;
  padding:.28rem .8rem;margin-bottom:.8rem;border-radius:2px;
}
.modal-badge.is-preventa{background:var(--cyan);color:#0a0a0f}
.modal-badge.is-free{background:rgba(196,181,253,.15);color:var(--lavender);border:1px solid rgba(196,181,253,.3)}
.modal-badge:empty{display:none}
.modal-genre{font-size:.7rem;color:var(--cyan);letter-spacing:.1em;margin-bottom:.6rem}
.modal-title{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);font-weight:900;color:var(--text);margin-bottom:1.2rem;line-height:1.15}
.modal-desc{font-size:.92rem;color:var(--muted);line-height:1.75;margin-bottom:2rem}
.modal-links{display:flex;gap:.75rem;flex-wrap:wrap}
.mlink{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1.2rem;font-size:.75rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
  border:1px solid var(--border);color:var(--muted);
  transition:all .2s;border-radius:2px;
}
.mlink:hover{color:var(--lavender);border-color:rgba(196,181,253,.3);background:rgba(196,181,253,.04)}
.mlink.primary{background:var(--purple);color:#fff;border-color:var(--purple)}
.mlink.primary:hover{background:var(--purple-l);border-color:var(--purple-l);transform:translateY(-2px);box-shadow:0 6px 20px rgba(124,58,237,.35)}
.mlink.cta-cyan{background:var(--cyan);color:#0a0a0f;border-color:var(--cyan);font-weight:800}
.mlink.cta-cyan:hover{background:#00e8d0;border-color:#00e8d0;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,200,180,.35);color:#0a0a0f}
.mlink.cta-free{background:rgba(196,181,253,.1);color:var(--lavender);border-color:rgba(196,181,253,.4)}
.mlink.cta-free:hover{background:rgba(196,181,253,.2);border-color:var(--lavender);transform:translateY(-2px)}

/* NEWSLETTER */
.newsletter{padding:8rem 0;background:var(--bg2);position:relative;overflow:hidden}
.newsletter::before{content:'';position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,.08) 0%,transparent 70%);top:50%;left:60%;transform:translate(-50%,-50%);pointer-events:none}
.nl-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:6rem;align-items:center;position:relative;z-index:1}
.nl-perks{list-style:none;margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}
.nl-perks li{display:flex;align-items:center;gap:.75rem;font-size:.88rem;color:var(--muted)}
.pi{color:var(--cyan);font-size:.7rem;flex-shrink:0}
.nl-box{background:var(--bg3);border:1px solid var(--border);padding:2rem}
.el{font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--purple-l);margin-bottom:1rem}
.en{font-size:.75rem;color:var(--dim);margin-top:1rem}
.en a{color:var(--cyan);text-decoration:none}
.en a:hover{color:var(--lavender)}

/* CONTACT */
.contact{
  padding:8rem 0;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(0,200,180,.08), transparent 22%),
    radial-gradient(circle at 88% 14%, rgba(124,58,237,.16), transparent 26%),
    radial-gradient(circle at 70% 70%, rgba(255,0,153,.08), transparent 24%),
    linear-gradient(180deg, #07070d 0%, #090913 55%, #05050a 100%);
}
.contact::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(0,200,180,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.05) 1px, transparent 1px);
  background-size:120px 120px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.65), transparent 92%);
  pointer-events:none;
}
.contact-lead{
  max-width:760px;
  color:rgba(240,238,248,.72);
  font-size:1rem;
  letter-spacing:.02em;
}
.contact-layout{
  display:grid;
  grid-template-columns:1.25fr .95fr;
  gap:1.5rem;
  margin-bottom:3rem;
}
.feature-stack{
  display:grid;
  grid-template-rows:1fr auto;
  gap:1.5rem;
}
.feature-card,
.visit-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(196,181,253,.14);
  background:
    linear-gradient(135deg, rgba(8,8,14,.92), rgba(13,10,22,.97)),
    #0a0a0f;
  padding:2rem;
  text-decoration:none;
  clip-path:polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%);
  box-shadow:
    0 0 0 1px rgba(124,58,237,.05),
    0 0 18px rgba(255,45,85,.08),
    0 0 42px rgba(124,58,237,.10),
    0 0 64px rgba(0,200,180,.06),
    inset 0 0 0 1px rgba(255,255,255,.02);
}
.feature-card::before,
.visit-card::before,
.scard::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, transparent 0, rgba(255,255,255,.06) 48%, transparent 52%, transparent 100%),
    repeating-linear-gradient(180deg, rgba(255,255,255,.03) 0 1px, transparent 1px 4px);
  opacity:.22;
  pointer-events:none;
  mix-blend-mode:screen;
}
.feature-card::after,
.visit-card::after{
  content:'';
  position:absolute;
  inset:1px;
  border:1px solid rgba(0,200,180,.22);
  clip-path:polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 0 100%);
  pointer-events:none;
  opacity:.45;
}
.feature-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:280px;
  transition:transform .3s,border-color .3s,box-shadow .3s,filter .3s;
}
.feature-card:hover{
  transform:translateY(-8px) skewX(-1deg);
  border-color:rgba(0,200,180,.28);
  box-shadow:
    0 0 0 1px rgba(0,200,180,.15),
    0 0 34px rgba(0,200,180,.16),
    0 0 74px rgba(124,58,237,.18);
  filter:saturate(1.08);
}
.feature-card-main{
  min-height:100%;
  background:
    radial-gradient(circle at 100% 0%, rgba(124,58,237,.18), transparent 38%),
    radial-gradient(circle at 0% 100%, rgba(255,45,85,.10), transparent 34%),
    linear-gradient(135deg, rgba(8,8,14,.96), rgba(12,10,24,.98));
}
.feature-kicker,
.visit-label{
  position:relative;
  z-index:1;
  font-size:.68rem;
  font-weight:800;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--cyan);
  text-shadow:0 0 10px rgba(0,200,180,.42);
}
.feature-title{
  position:relative;
  z-index:1;
  font-family:var(--serif);
  font-size:clamp(1.9rem,3.6vw,4rem);
  line-height:.98;
  color:#fff7fb;
  max-width:10ch;
  text-shadow:
    0 0 12px rgba(255,255,255,.08),
    0 0 30px rgba(124,58,237,.12);
}
.feature-card-secondary .feature-title{
  font-size:clamp(1.55rem,2.2vw,2.35rem);
  max-width:15ch;
}
.feature-copy,
.visit-copy{
  position:relative;
  z-index:1;
  color:rgba(240,238,248,.65);
  font-size:.95rem;
  line-height:1.8;
  max-width:56ch;
}
.feature-meta{
  position:relative;
  z-index:1;
  display:flex;
  flex-wrap:wrap;
  gap:.85rem;
  align-items:center;
}
.feature-pill{
  display:inline-flex;
  align-items:center;
  padding:.45rem .85rem;
  border:1px solid rgba(196,181,253,.22);
  background:rgba(196,181,253,.08);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#cdbbff;
  box-shadow:0 0 18px rgba(124,58,237,.14) inset;
}
.feature-link{
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#f7f5ff;
  text-shadow:0 0 12px rgba(255,255,255,.12);
}
.visit-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:180px;
  background:
    radial-gradient(circle at 100% 0%, rgba(124,58,237,.18), transparent 42%),
    radial-gradient(circle at 0% 100%, rgba(255,45,85,.10), transparent 34%),
    linear-gradient(135deg, rgba(10,10,16,.95), rgba(14,10,24,.98));
}
.visit-count{
  position:relative;
  z-index:1;
  font-family:var(--serif);
  font-size:clamp(2.2rem,5vw,4.8rem);
  line-height:.9;
  color:#fff7fb;
  text-shadow:
    0 0 16px rgba(255,255,255,.08),
    0 0 30px rgba(124,58,237,.18);
}
.contact-cluster{margin-bottom:3rem}
.contact-shelves{display:grid;grid-template-columns:1fr 1.2fr;gap:2rem}
.contact-column{min-width:0}
.soc-label{
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(196,181,253,.58);
  margin-bottom:1.25rem;
  padding-bottom:.8rem;
  border-bottom:1px solid rgba(196,181,253,.12);
}
.social-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.social-grid.cols3{grid-template-columns:repeat(3,1fr)}
.social-grid.cols2{grid-template-columns:repeat(2,1fr)}
.social-grid.cols4{grid-template-columns:repeat(4,1fr)}
.social-grid-rich{gap:1rem}
.books-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}
.books-grid .scard:first-child{
  grid-column:1 / -1;
  min-height:170px;
}
.books-grid .scard:first-child{
  min-height:220px;
  padding:1.8rem;
  gap:.82rem;
}
.books-grid .scard:nth-child(n+2){
  min-height:190px;
}
.music-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.scard{
  position:relative;
  min-height:200px;
  text-decoration:none;
  display:block;
  overflow:visible;
  perspective:1400px;
  clip-path:polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 0 100%);
}
.metro-shell{
  position:relative;
  min-height:200px;
  transform-style:preserve-3d;
  transition:transform .9s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.metro-face{
  position:absolute;
  inset:0;
  padding:1.55rem;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:1rem;
  backface-visibility:hidden;
  border:1px solid rgba(196,181,253,.12);
  background:
    linear-gradient(180deg, rgba(14,14,24,.98), rgba(7,7,12,.98)),
    radial-gradient(circle at 100% 0%, rgba(124,58,237,.18), transparent 42%),
    radial-gradient(circle at 0% 100%, rgba(255,45,85,.08), transparent 34%);
  box-shadow:
    0 0 0 1px rgba(124,58,237,.03),
    0 0 14px rgba(255,45,85,.07),
    0 0 24px rgba(124,58,237,.08);
  overflow:hidden;
}
.metro-face::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, transparent 0 24%, rgba(255,255,255,.09) 32%, transparent 44%),
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 30%);
  opacity:.35;
  transform:translateX(-12%);
  transition:transform .7s cubic-bezier(.22,1,.36,1),opacity .35s;
  pointer-events:none;
}
.metro-front{
  background:
    linear-gradient(180deg, rgba(14,14,24,.98), rgba(7,7,12,.98)),
    radial-gradient(circle at 100% 0%, rgba(124,58,237,.14), transparent 38%),
    radial-gradient(circle at 0% 100%, rgba(255,45,85,.08), transparent 32%);
}
.metro-back{
  transform:rotateY(180deg);
  background:
    linear-gradient(145deg, rgba(2,44,52,.98), rgba(10,10,18,.98) 38%, rgba(54,15,68,.96)),
    radial-gradient(circle at 100% 0%, rgba(0,200,180,.34), transparent 44%),
    radial-gradient(circle at 0% 100%, rgba(255,45,85,.18), transparent 34%);
  border-color:rgba(0,200,180,.34);
  box-shadow:
    0 0 0 1px rgba(0,200,180,.1),
    0 14px 36px rgba(0,0,0,.28),
    0 0 38px rgba(0,200,180,.12);
}
.metro-back::after{
  content:'';
  position:absolute;
  inset:auto 0 0 0;
  height:42%;
  background:
    linear-gradient(180deg, transparent, rgba(0,200,180,.12) 24%, rgba(0,200,180,.24)),
    repeating-linear-gradient(180deg, rgba(255,255,255,.05) 0 1px, transparent 1px 6px);
  opacity:.8;
  pointer-events:none;
}
.social-grid-rich .scard:nth-child(2n) .metro-back{
  background:
    linear-gradient(145deg, rgba(34,7,58,.98), rgba(8,12,22,.98) 42%, rgba(2,56,54,.96)),
    radial-gradient(circle at 100% 0%, rgba(124,58,237,.34), transparent 44%),
    radial-gradient(circle at 0% 100%, rgba(0,200,180,.18), transparent 34%);
}
.social-grid-rich .scard:nth-child(3n) .metro-back{
  background:
    linear-gradient(145deg, rgba(53,8,28,.98), rgba(10,10,18,.98) 38%, rgba(2,54,58,.96)),
    radial-gradient(circle at 100% 0%, rgba(255,45,85,.3), transparent 44%),
    radial-gradient(circle at 0% 100%, rgba(0,200,180,.18), transparent 34%);
}
.metro-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}
.metro-copy{
  display:flex;
  flex-direction:column;
  gap:.8rem;
  margin-top:auto;
}
.metro-copy-back{
  margin-top:0;
  gap:.55rem;
}
.metro-badge{
  font-size:.66rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#d9fff7;
  text-shadow:0 0 16px rgba(0,200,180,.22);
}
.scard:hover .metro-shell{
  transform:rotateY(180deg);
}
.scard:hover .metro-face::before{
  transform:translateX(18%);
  opacity:.7;
}
.s-icon{
  color:#b48cff;
  transition:color .25s,filter .25s,transform .45s cubic-bezier(.22,1,.36,1);
  filter:drop-shadow(0 0 8px rgba(124,58,237,.28));
}
.metro-back .s-icon{
  color:#8effea;
  filter:drop-shadow(0 0 16px rgba(0,200,180,.4));
  transform:scale(1.08);
}
.s-name{
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(1.05rem,1.3vw,1.45rem);
  color: #fff7fb;
  letter-spacing: .05em;
  line-height: 1.02;
  text-transform:uppercase;
  max-width:12ch;
  overflow-wrap:anywhere;
}
.books-grid .scard:first-child .s-name{max-width:none}
.music-grid .s-name{font-size:clamp(1rem,1.15vw,1.28rem);max-width:10ch}
.s-handle{
  font-size:.74rem;
  color:#b8a8ff;
  letter-spacing:.03em;
}
.metro-back .s-name{
  color:#ffffff;
  font-size:clamp(.96rem,1.05vw,1.18rem);
  line-height:.95;
  text-shadow:0 0 18px rgba(0,200,180,.1);
  max-width:none;
}
.metro-back .s-handle{
  color:#c6fff3;
  font-size:.7rem;
}
.s-desc{
  font-size:.86rem;
  color:rgba(246,255,252,.92);
  line-height:1.58;
  max-width:28ch;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
  overflow:hidden;
  padding-top:.9rem;
  border-top:1px solid rgba(255,255,255,.15);
  text-shadow:0 0 14px rgba(0,0,0,.18);
}
.metro-back .s-desc{
  font-size:.76rem;
  line-height:1.42;
  -webkit-line-clamp:3;
  padding-top:.65rem;
}
.books-grid .scard:first-child .s-desc{
  -webkit-line-clamp:3;
  max-width:48ch;
}
.books-grid .scard:nth-child(n+2) .s-desc{max-width:24ch}
.music-grid .s-desc{
  -webkit-line-clamp:3;
  max-width:21ch;
}
.s-arrow{
  color:rgba(196,181,253,.42);
  font-size:1rem;
  transition:transform .35s,color .25s,text-shadow .25s;
  text-shadow:0 0 10px rgba(124,58,237,.18);
}
.metro-back .s-arrow{color:#9ffff0;text-shadow:0 0 16px rgba(0,200,180,.28)}
.scard:hover .metro-front .s-icon{
  color:#c8a0ff;
}
.scard:hover .metro-front .s-arrow{
  color:var(--cyan);
  text-shadow:0 0 12px rgba(0,200,180,.3);
}
.music-grid .scard,
.books-grid .scard:nth-child(n+2){min-height:236px}
.books-grid .scard:first-child,
.books-grid .scard:first-child .metro-shell{min-height:286px}
.music-grid .scard .metro-face,
.books-grid .scard:nth-child(n+2) .metro-face{padding:1.4rem}
.music-grid .scard .metro-back,
.books-grid .scard:nth-child(n+2) .metro-back{padding:1.1rem 1.15rem}

@media (prefers-reduced-motion: reduce){
  .metro-shell,.metro-face::before,.s-icon,.s-arrow{
    animation:none !important;
    transition:none !important;
    transform:none !important;
  }
}

/* FOOTER */
.footer{padding:3rem 0;border-top:1px solid var(--border)}
.footer-in{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center}
.f-name{font-family:var(--serif);font-size:1.4rem;font-weight:900;color:var(--purple-l)}
.f-tag{font-family:var(--bserif);font-style:italic;color:var(--muted);font-size:.9rem}
.f-copy{font-size:.72rem;color:var(--dim);letter-spacing:.08em;margin-top:.25rem}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.on{opacity:1;transform:none}

/* MOBILE NAV */
.mnav{position:fixed;inset:0;background:rgba(10,10,15,.98);z-index:99;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2rem;opacity:0;pointer-events:none;transition:opacity .3s}
.mnav.open{opacity:1;pointer-events:all}
.mnav a{font-family:var(--serif);font-size:2.5rem;font-weight:900;color:var(--text);text-decoration:none;transition:color .2s}
.mnav a:hover{color:var(--purple-l)}

/* RESPONSIVE */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:4rem}
  .about-frame{max-width:320px}
  .nl-grid{grid-template-columns:1fr;gap:3rem}
  .launch-grid{grid-template-columns:1fr}
  .launch-panel{justify-self:start}
  .contact-layout,.contact-shelves{grid-template-columns:1fr}
  .social-grid{grid-template-columns:repeat(2,1fr)}
  .social-grid.cols3{grid-template-columns:repeat(2,1fr)}
  .social-grid.cols4{grid-template-columns:repeat(2,1fr)}
  .shelf{gap:2rem;flex-wrap:wrap}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-btn{display:flex}
  .hero{min-height:auto;padding:7.5rem 1.5rem 5rem}
  .hero-sub{max-width:34ch}
  .cta{width:100%}
  .cta .btn{flex:1 1 100%;justify-content:center}
  .launch-band{padding:2rem 0}
  .launch-panel{width:100%}
  .launch-date{align-items:flex-start;flex-direction:column;gap:.45rem}
  .launch-day{font-size:3.1rem}
  .shelf{gap:1.5rem}
  .book-wrap{--spine-w:20px;--cover-w:120px;--cover-h:180px}
  .book-face.spine{width:20px;height:180px}
  .book-face.top{width:120px;height:20px}
  .modal-inner{grid-template-columns:1fr}
  .modal-cover img{min-height:200px;max-height:260px;object-position:top}
  .social-grid,.social-grid.cols3,.social-grid.cols2,.social-grid.cols4{grid-template-columns:1fr 1fr}
  .container{padding:0 1.5rem}
  .badge{bottom:-20px;right:-10px}
  .feature-card,.visit-card,.scard{min-height:auto}
  .feature-title{max-width:none;font-size:clamp(1.8rem,8vw,3rem)}
  .feature-card,.visit-card{clip-path:none}
  .feature-card::after,.visit-card::after{clip-path:none}
  .scard{clip-path:none}
  .metro-shell,.books-grid .scard:first-child .metro-shell{min-height:auto}
  .metro-face,.music-grid .scard .metro-face,.books-grid .scard:nth-child(n+2) .metro-face{position:relative;padding:1.35rem}
  .metro-back{display:none}
  .scard:hover .metro-shell{transform:translateY(-4px)}
  .s-name,.music-grid .s-name{max-width:none}
  .s-desc,.music-grid .s-desc{-webkit-line-clamp:unset;max-width:none}
  .books-grid .scard:first-child{grid-column:auto}
  .music-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .shelf{gap:1rem}
  .book-wrap{--spine-w:18px;--cover-w:100px;--cover-h:150px}
  .book-face.spine{width:18px;height:150px}
  .book-face.top{width:100px;height:18px}
  .launch-title{font-size:clamp(1.8rem,9vw,2.4rem)}
  .launch-text{font-size:.92rem}
  .social-grid,.social-grid.cols3,.social-grid.cols2,.social-grid.cols4{grid-template-columns:1fr}
  .stats{gap:1.5rem}
  .contact{padding:6rem 0}
  .feature-card,.visit-card{padding:1.5rem}
  .scard{padding:1.35rem}
  .feature-meta{align-items:flex-start;flex-direction:column}
  .music-grid{grid-template-columns:1fr}
}
