/* ============================================================
   HEMMER — house / minimal
   palette: #0a0a0a · #efefef · #2e2eff
   ============================================================ */

:root{
  --bg:#0a0a0a;
  --bg-2:#111113;
  --fg:#efefef;
  --fg-dim:#9a9a9a;
  --line:#1d1d20;
  --accent:#2e2eff;
  --accent-glow: 0 0 24px rgba(46,46,255,.55), 0 0 2px rgba(46,46,255,.9);
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --disp:"Unbounded", "Archivo Black", system-ui, sans-serif;
  --maxw:1360px;
  --gutter: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{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(--mono);
  font-size:15px;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ------- fixed atmosphere ------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:90;mix-blend-mode:overlay;opacity:.25;
  background-image:
    radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,.12) 1px, transparent 1px);
  background-size:3px 3px, 5px 5px;
  background-position:0 0, 1px 2px;
}
.scanlines{
  position:fixed;inset:0;pointer-events:none;z-index:91;opacity:.08;
  background:repeating-linear-gradient(
    to bottom, rgba(255,255,255,.45) 0 1px, transparent 1px 3px
  );
  mix-blend-mode:overlay;
}

/* ------- nav ------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  padding-right: calc(var(--gutter) + 88px);
  font-family:var(--mono);font-size:12px;letter-spacing:.05em;
  backdrop-filter: blur(8px);
  background: linear-gradient(to bottom, rgba(10,10,10,.85), rgba(10,10,10,0));
  transform: translateY(-100%);
  transition: transform .5s cubic-bezier(.6,.1,.2,1);
}
.nav.is-visible{transform:translateY(0)}
.nav__brand{
  font-family:var(--disp);font-weight:900;font-size:16px;letter-spacing:.02em;
  color:var(--accent); text-shadow: var(--accent-glow);
}
.nav__brand span{animation: blink 1.2s infinite steps(1)}
@keyframes blink{50%{opacity:0}}
.nav__links{
  list-style:none;margin:0;padding:0;display:flex;gap:22px;align-items:center;
}
.nav__links a{color:var(--fg-dim);transition:color .2s}
.nav__links a:hover{color:var(--accent)}
.nav__cta{
  color:var(--accent) !important; border:1px solid var(--accent); padding:6px 12px;
  transition: background .2s, color .2s, box-shadow .2s;
}
.nav__cta:hover{background:var(--accent); color:var(--bg) !important; box-shadow: var(--accent-glow)}
@media (max-width: 760px){
  .nav{ padding-right: calc(var(--gutter) + 74px) }
  .nav__links li:not(:last-child){display:none}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  overflow:hidden;
  display:block;
  isolation:isolate;
}
.hero__photo{
  position:absolute;inset:0;z-index:1;
}
.hero__photo img{
  width:100%;height:100%;object-fit:cover;object-position:center 28%;
  filter: grayscale(1) contrast(1.08) brightness(.78);
  animation: heroIn 1.6s cubic-bezier(.2,.7,.2,1) both;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(120% 70% at 50% 40%, transparent 40%, rgba(0,0,0,.55) 85%),
    linear-gradient(to bottom, rgba(10,10,10,.35), rgba(10,10,10,.15) 50%, rgba(10,10,10,.9) 100%);
}
@keyframes heroIn{
  from{ transform:scale(1.08); filter:grayscale(1) contrast(1.08) brightness(.4) blur(6px); }
  to  { transform:scale(1);    filter:grayscale(1) contrast(1.08) brightness(.78) blur(0); }
}

.hero__wordmark{
  position:absolute; z-index:3; left:0; right:0; top: 38%;
  display:flex;justify-content:center;pointer-events:none;
}
.hero__wordmark .glitch{
  font-family:var(--disp);
  font-weight:900;
  font-size: clamp(80px, 19vw, 280px);
  letter-spacing:-.02em;
  line-height:.85;
  color: var(--accent);
  mix-blend-mode: screen;
  text-shadow: 0 0 28px rgba(46,46,255,.45);
  animation: wordIn 1.3s cubic-bezier(.2,.8,.2,1) .2s both;
}
.hero__wordmark .glitch::before {
  opacity: 0.35;
  clip-path: polygon(0 0, 100% 0, 100% 30%, 0 30%);
}
.hero__wordmark .glitch::after {
  opacity: 0.35;
  clip-path: polygon(0 70%, 100% 70%, 100% 100%, 0 100%);
}
@keyframes wordIn{
  0%{opacity:0; transform: translateY(20px) scale(.98); letter-spacing:.05em; filter: blur(18px)}
  60%{opacity:1; letter-spacing:-.04em}
  100%{opacity:1; transform:none; letter-spacing:-.02em; filter: blur(0)}
}

.hero__meta{position:absolute;inset:0;z-index:4;pointer-events:none}
.hero__meta .meta{position:absolute;padding:var(--gutter);font-size:11px;color:var(--accent);pointer-events:auto;animation: fadeUp .8s ease-out 1s both}
.meta--tl{top:64px;left:0}
.meta--tr{top:64px;right:0;text-align:right}
.frame{display:block;width:56px;height:56px;position:relative}
.frame::before,.frame::after{content:"";position:absolute;background:var(--accent);box-shadow: var(--accent-glow)}
.frame--tl::before{top:0;left:0;width:100%;height:2px}
.frame--tl::after{top:0;left:0;width:2px;height:100%}
.frame--tr{margin-left:auto}
.frame--tr::before{top:0;right:0;width:100%;height:2px}
.frame--tr::after{top:0;right:0;width:2px;height:100%}
.meta--bl{bottom:0;left:0}
.meta--br{bottom:0;right:0;text-align:right}
.meta__tag{display:block;font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--accent)}
.meta__mail{display:inline-block;margin-top:6px;color:var(--fg);border-bottom:1px dashed var(--accent);padding-bottom:2px}
.meta__mail:hover{color:var(--accent)}
.scrollcue{display:inline-flex;align-items:center;gap:8px;color:var(--fg-dim);font-size:11px}
.scrollcue svg{width:8px;height:18px;color:var(--accent);animation: nudge 1.6s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (max-width: 760px){
  .hero__meta .meta{padding:22px}
  .meta--tl, .meta--tr{top:56px;font-size:10px}
  .meta--br .scrollcue span{display:none}
}

/* ============================================================
   GLITCH (applied to any .glitch with data-text)
   ============================================================ */
.glitch{position:relative;display:inline-block}
.glitch::before,.glitch::after{
  content: attr(data-text);
  position:absolute;inset:0;
  overflow:hidden;
  pointer-events:none;
}
.glitch::before{
  color:#00e9ff; mix-blend-mode:screen;
  transform: translate(-2px,0);
  clip-path: polygon(0 0, 100% 0, 100% 42%, 0 42%);
  animation: glitchA 3.4s infinite steps(1);
}
.glitch::after{
  color:#ff2bd6; mix-blend-mode:screen;
  transform: translate(2px,0);
  clip-path: polygon(0 58%, 100% 58%, 100% 100%, 0 100%);
  animation: glitchB 3.8s infinite steps(1);
}
@keyframes glitchA{
  0%,92%,100%{transform:translate(0,0)}
  93%{transform:translate(-3px,-1px)}
  95%{transform:translate(2px,1px)}
  97%{transform:translate(-2px,2px)}
}
@keyframes glitchB{
  0%,90%,100%{transform:translate(0,0)}
  91%{transform:translate(3px,1px)}
  94%{transform:translate(-2px,-1px)}
  96%{transform:translate(2px,-2px)}
}

/* ============================================================
   SECTION LABELS
   ============================================================ */
section{position:relative; padding: clamp(80px, 10vw, 140px) var(--gutter); scroll-margin-top:70px}
.section__label{
  font-family:var(--mono);font-size:11px;letter-spacing:.25em;
  color:var(--accent);
  display:flex;align-items:center;gap:14px;
  margin-bottom: clamp(32px, 5vw, 64px);
  text-transform:uppercase;
}
.section__label::after{content:"";flex:1;height:1px;background: linear-gradient(to right, var(--accent), transparent)}
.section__label span{
  font-family:var(--disp);font-weight:900;font-size:14px;
  padding: 3px 8px; border:1px solid var(--accent); color:var(--accent);
}

/* ============================================================
   BIO
   ============================================================ */
.bio{max-width:var(--maxw);margin:0 auto}
.bio__grid{display:grid;grid-template-columns: 1fr 1.2fr; gap: clamp(28px, 5vw, 72px); align-items:center}
.bio__img{margin:0;position:relative; aspect-ratio: 4/5; overflow:hidden; border: 1px solid var(--line)}
.bio__img img{
  width:100%;height:100%;object-fit:cover;
  filter: grayscale(1) contrast(1.05) brightness(.88);
  transition: filter .6s, transform .8s;
}
.bio__img:hover img{filter: grayscale(0) contrast(1.05); transform: scale(1.03)}
.bio__img figcaption{
  position:absolute;bottom:12px;left:12px;right:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--accent);
  text-transform:lowercase; opacity:.85;
}
.bio__copy p{
  font-family:var(--mono); font-weight:400;
  font-size: clamp(18px, 1.7vw, 23px);
  line-height:1.55; color:var(--fg);
  max-width: 56ch;
}
.bio__copy p em{color:var(--accent); font-style:normal; font-weight:500}
.bio__name{font-family:var(--disp);font-weight:900;color:var(--fg);letter-spacing:.01em}
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin: 40px 0 0;padding:0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stats > div{padding:18px 16px;border-right:1px solid var(--line)}
.stats > div:last-child{border-right:0}
.stats dt{font-size:10px;letter-spacing:.15em;color:var(--fg-dim);text-transform:uppercase;margin-bottom:6px}
.stats dd{margin:0;font-family:var(--disp);font-weight:700;font-size:14px;color:var(--accent);letter-spacing:.02em}
@media (max-width: 820px){
  .bio__grid{grid-template-columns:1fr}
  .bio__img{aspect-ratio: 5/6; max-width:520px}
}

/* ============================================================
   VENUES
   ============================================================ */
.venues{max-width:var(--maxw);margin:0 auto; position:relative}
.venues__stack{position:relative; line-height:.95; margin-bottom: 40px}
.venues__ghost{
  font-family:var(--disp);font-weight:900;
  font-size: clamp(60px, 13vw, 190px);
  letter-spacing:-.03em;
  color: var(--fg);
  margin:0;
  opacity:.85;
}
.venues__region{position:relative;border:1px solid var(--line); padding: 26px var(--gutter); background: linear-gradient(to bottom, rgba(46,46,255,.04), transparent 80%)}
.venues__region-label{font-size:11px;letter-spacing:.2em;color:var(--accent);margin-bottom:18px}
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);list-style:none;padding:0;margin: 0 calc(-1 * var(--gutter)) 24px}
.marquee__track{
  display:inline-flex;white-space:nowrap;gap:32px;padding:18px 0;align-items:center;
  font-family:var(--disp);font-weight:700;font-size: clamp(20px, 3.2vw, 40px);letter-spacing:.02em;
  animation: scroll 28s linear infinite;
  color: var(--fg);
}
.marquee__track .dot{color:var(--accent);font-size: .6em; transform: translateY(-2px)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.venues__list{list-style:none;padding:0;margin:0;display:grid;gap:0;border-top:1px solid var(--line)}
.venues__list li{
  display:grid;grid-template-columns: 64px 1fr auto; align-items:baseline; gap:20px;
  padding:22px 0; border-bottom:1px solid var(--line);
  transition: padding-left .3s, background .3s;
}
.venues__list li:hover{padding-left:12px; background: linear-gradient(to right, rgba(46,46,255,.07), transparent 60%)}
.venues__n{font-family:var(--mono);font-size:11px;color:var(--fg-dim)}
.venues__name{font-family:var(--disp);font-weight:900;font-size:clamp(20px,2.6vw,32px);letter-spacing:.01em}
.venues__city{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.1em;text-transform:lowercase}

/* ============================================================
   GIGS
   ============================================================ */
.gigs{max-width:var(--maxw);margin:0 auto}
.gigs__grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.gig{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  transition: transform .5s cubic-bezier(.2,.8,.2,1), border-color .3s;
  aspect-ratio: 1/1;
}
.gig img{width:100%;height:100%;object-fit:cover;transition: transform .8s, filter .5s;filter:grayscale(.15) contrast(1.03)}
.gig:hover{border-color: var(--accent)}
.gig:hover img{transform:scale(1.08);filter:grayscale(0) contrast(1.03)}
.gig__caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:14px 16px;
  background: linear-gradient(to top, rgba(10,10,10,.96) 30%, rgba(10,10,10,.75) 70%, transparent);
  transform: translateY(30%); opacity:0; transition: transform .4s, opacity .3s;
}
.gig:hover .gig__caption{transform:translateY(0);opacity:1}
.gig__caption span{font-family:var(--disp);font-weight:900;font-size:14px;color:var(--fg);display:block;letter-spacing:.02em;text-shadow: 0 1px 2px rgba(0,0,0,.9)}
.gig__caption em{font-style:normal;font-family:var(--mono);font-size:11px;color:var(--fg-dim);text-shadow: 0 1px 2px rgba(0,0,0,.9)}
/* asymmetric sizing — 8 items */
.gig:nth-child(1){grid-column:span 7; aspect-ratio: 7/5}
.gig:nth-child(2){grid-column:span 5; aspect-ratio: 5/6}
.gig:nth-child(3){grid-column:span 4; aspect-ratio: 3/4}
.gig:nth-child(4){grid-column:span 4; aspect-ratio: 3/4}
.gig:nth-child(5){grid-column:span 4; aspect-ratio: 4/5}
.gig:nth-child(5) img{object-position: center top}
.gig:nth-child(6){grid-column:span 6; aspect-ratio: 6/5}
.gig:nth-child(7){grid-column:span 3; aspect-ratio: 3/4}
.gig:nth-child(8){grid-column:span 3; aspect-ratio: 3/4}
@media (max-width: 820px){
  .gigs__grid{grid-template-columns: repeat(4, 1fr); gap:10px}
  .gig, .gig:nth-child(n){grid-column: span 2; aspect-ratio: 1/1}
  .gig:nth-child(1){grid-column: span 4; aspect-ratio: 4/3}
  .gig__caption{transform:none;opacity:1;background: linear-gradient(to top, rgba(10,10,10,.9) 0%, transparent 60%);padding: 10px 12px}
  .gig__caption span{font-size:12px}
}

/* ============================================================
   RIDER
   ============================================================ */
.rider{max-width:1000px;margin:0 auto}
.rider__card{
  border:1px solid var(--accent);
  padding: clamp(28px, 4vw, 56px);
  background: linear-gradient(135deg, rgba(46,46,255,.05), rgba(46,46,255,0) 60%), var(--bg-2);
  position:relative;
}
.rider__card::before{
  content:"";position:absolute;top:-1px;left:-1px;width:18px;height:18px;
  border-top:2px solid var(--accent);border-left:2px solid var(--accent);
}
.rider__card::after{
  content:"";position:absolute;bottom:-1px;right:-1px;width:18px;height:18px;
  border-bottom:2px solid var(--accent);border-right:2px solid var(--accent);
}
.rider__head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.rider__title{
  font-family:var(--disp);font-weight:900;
  font-size: clamp(44px, 7vw, 88px); line-height:.85; margin:0;
  color:var(--fg); letter-spacing:-.02em;
}
.rider__hint{font-family:var(--mono);font-size:12px;color:var(--fg-dim);max-width:260px;text-align:right}
.spec{list-style:none;padding:0;margin:0}
.spec li{
  display:grid;grid-template-columns:170px 1fr; gap:24px;
  padding:18px 0; border-top:1px dashed var(--line); align-items:baseline;
}
.spec li:last-child{border-bottom:1px dashed var(--line)}
.spec__k{font-family:var(--mono);font-size:11px;color:var(--fg-dim);letter-spacing:.1em;text-transform:uppercase}
.spec__v{font-family:var(--disp);font-weight:700;font-size: clamp(14px, 1.4vw, 18px);letter-spacing:.02em}
.spec__v em{color:var(--accent);font-style:normal;padding:0 6px}
.rider__dl{
  display:inline-flex;align-items:center;gap:14px;margin-top:34px;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--accent);
  border-bottom:1px solid var(--accent);padding-bottom:6px;
  transition: gap .3s;
}
.rider__dl:hover{gap:22px}
.rider__dl svg{width:28px;height:14px}
@media (max-width:680px){
  .spec li{grid-template-columns:1fr; gap:6px}
  .rider__hint{text-align:left;max-width:100%}
}

/* ============================================================
   SOUND
   ============================================================ */
.sound{max-width:1100px;margin:0 auto;text-align:center}
.sound__head{margin-bottom: 40px}
.sound__title{
  font-family:var(--disp);font-weight:900;
  font-size: clamp(40px, 7.5vw, 100px);
  letter-spacing:-.02em;color: var(--fg);margin:0 0 12px;
  display:flex;flex-direction:column;align-items:center;gap:.05em;
}
.sound__sub{font-family:var(--mono);font-size:13px;color:var(--fg-dim);margin:0;letter-spacing:.05em}
.sound__player{
  border:1px solid var(--line);
  padding:0;
  background: var(--bg-2);
  overflow:hidden;
}
.sound__player iframe{display:block;width:100%;border:0}
.sound__links{display:flex;justify-content:center;gap: 40px;flex-wrap:wrap;margin-top:32px;font-family:var(--mono);font-size:13px;letter-spacing:.05em}
.sound__links a{color:var(--accent);border-bottom:1px dashed var(--accent);padding-bottom:3px;transition: color .2s, text-shadow .3s}
.sound__links a:hover{text-shadow: var(--accent-glow)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:var(--maxw);margin:0 auto;padding: clamp(60px, 8vw, 120px) var(--gutter) clamp(40px, 5vw, 80px)}
.faq__head{margin-bottom: clamp(28px, 4vw, 52px)}
.faq__title{
  font-family:var(--disp);font-weight:900;
  font-size: clamp(36px, 6.5vw, 84px);
  letter-spacing:-.02em;color:var(--fg);
  margin:0 0 10px;
  display:flex;align-items:baseline;gap:.25em;flex-wrap:wrap;line-height:.98;
}
.faq__title-slash{color:var(--accent);font-weight:900;font-size:.72em;letter-spacing:-.04em;text-shadow: var(--accent-glow)}
.faq__sub{
  font-family:var(--mono);font-size:13px;color:var(--fg-dim);
  margin:0;letter-spacing:.05em;
}
.faq__list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item details{padding:0}
.faq__item summary{
  list-style:none;
  cursor:pointer;
  display:grid;grid-template-columns: 1fr auto;align-items:center;gap:20px;
  padding: clamp(18px, 2.5vw, 28px) 0;
  transition: padding-left .3s, background .3s, color .2s;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{padding-left:12px;background: linear-gradient(to right, rgba(46,46,255,.07), transparent 60%)}
.faq__item summary:focus-visible{outline:2px solid var(--accent);outline-offset:4px}
.faq__qtext{
  font-family:var(--disp);font-weight:700;
  font-size: clamp(18px, 2vw, 26px);
  letter-spacing:-.01em;color:var(--fg);
}
.faq__item details[open] .faq__qtext{color:var(--accent);text-shadow: 0 0 18px rgba(46,46,255,.4)}
.faq__chev{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;
  color:var(--accent);
  transition: transform .35s cubic-bezier(.6,0,.2,1);
}
.faq__chev svg{width:14px;height:auto}
.faq__item details[open] .faq__chev{transform:rotate(180deg)}
.faq__a{
  font-family:var(--mono);font-size: clamp(14px, 1.2vw, 16px);
  color:var(--fg-dim);line-height:1.7;
  padding: 0 0 clamp(22px, 3vw, 36px);
  max-width: 720px;
  animation: faq-fade .35s cubic-bezier(.6,0,.2,1);
}
.faq__a a{color:var(--accent);border-bottom:1px dashed var(--accent);transition: color .2s, text-shadow .3s}
.faq__a a:hover{text-shadow: var(--accent-glow)}
@keyframes faq-fade{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:none}
}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto{max-width:var(--maxw);margin:0 auto; padding-bottom: 40px}
.contacto__inner{
  border:1px solid var(--line);
  padding: clamp(40px, 6vw, 90px) clamp(24px, 5vw, 72px);
  background:
    radial-gradient(120% 80% at 80% 10%, rgba(46,46,255,.14), transparent 55%),
    var(--bg-2);
}
.contacto__title{
  font-family:var(--disp);font-weight:900;
  font-size: clamp(40px, 7vw, 100px);
  letter-spacing:-.02em; line-height:.9; margin:0 0 50px;
  display:flex;gap:.3em;flex-wrap:wrap;align-items:baseline;
}
.contacto__slash{color:var(--accent);opacity:.6;font-size:.7em}
.contacto__list{list-style:none;padding:0;margin:0 0 40px; display:grid;gap:0;border-top:1px solid var(--line)}
.contacto__list li{
  display:grid;grid-template-columns: 160px 1fr;gap:24px;
  padding:22px 0;border-bottom:1px solid var(--line);align-items:baseline;
  transition: padding-left .3s, background .3s;
}
.contacto__list li:hover{padding-left:14px; background: linear-gradient(to right, rgba(46,46,255,.06), transparent 60%)}
.contacto__list .k{font-family:var(--mono);font-size:11px;color:var(--fg-dim);letter-spacing:.2em;text-transform:uppercase}
.contacto__list .v{
  font-family:var(--disp);font-weight:700;font-size: clamp(16px, 2vw, 26px);color:var(--fg);
  text-align:left;letter-spacing:.01em; padding:0;
  transition: color .2s, text-shadow .3s;
}
.contacto__list .v:hover, .contacto__list .v:focus-visible{color:var(--accent);text-shadow: var(--accent-glow); outline:0}
.contacto__list .v em{font-style:normal;font-family:var(--mono);font-size:11px;color:var(--fg-dim);margin-left:8px}
button.copyable{cursor:copy}
button.copyable::after{content:" ⎘";color:var(--accent);opacity:.6;font-size:.7em;margin-left:4px}

.contacto__mailbtn{
  display:inline-flex;align-items:center;gap:16px;
  padding:18px 28px; border:1px solid var(--accent); color:var(--accent);
  font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  transition: background .25s, color .25s, box-shadow .3s, gap .3s;
}
.contacto__mailbtn:hover{background:var(--accent);color:var(--bg);box-shadow:var(--accent-glow);gap:24px}
.contacto__mailbtn svg{width:28px;height:14px}

@media (max-width: 680px){
  .contacto__list li{grid-template-columns: 1fr; gap:4px; padding:18px 0}
}

.footer{
  margin-top: 60px; padding-top: 20px; border-top:1px solid var(--line);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;color:var(--fg-dim);letter-spacing:.1em;
}
.footer a{color:var(--accent)}

/* ============================================================
   LANG TOGGLE
   ============================================================ */
.lang-toggle{
  position:fixed;
  top: calc(14px + env(safe-area-inset-top));
  right: calc(14px + env(safe-area-inset-right));
  z-index: 110;
  display:inline-flex;align-items:center;gap:6px;
  padding: 8px 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing:.15em;
  color: var(--fg-dim);
  background: rgba(10,10,10,.72);
  border:1px solid var(--line);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color .25s, box-shadow .3s, color .25s;
}
.lang-toggle:hover{ border-color: var(--accent); box-shadow: var(--accent-glow) }
.lang-toggle__opt{
  transition: color .2s, text-shadow .3s;
  padding: 2px 2px;
}
.lang-toggle__opt.is-active{
  color: var(--accent);
  text-shadow: var(--accent-glow);
}
.lang-toggle__sep{ color: var(--line) }

@media (max-width: 760px){
  .lang-toggle{
    top: calc(10px + env(safe-area-inset-top));
    right: calc(10px + env(safe-area-inset-right));
    padding: 7px 10px;
    font-size: 10px;
    letter-spacing:.12em;
  }
}

/* ============================================================
   COPY TOAST
   ============================================================ */
.copy-toast{
  position:fixed;bottom:24px;left:50%;transform:translate(-50%, 20px);
  background:var(--accent);color:var(--bg);
  font-family:var(--mono);font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  padding:10px 18px;z-index:200;opacity:0;pointer-events:none;
  transition: transform .3s, opacity .3s;
  box-shadow: 0 0 40px rgba(46,46,255,.6);
}
.copy-toast.is-shown{opacity:1;transform:translate(-50%, 0)}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:none}

/* ============================================================
   reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .marquee__track{animation:none}
  .glitch::before,.glitch::after{display:none}
}
