:root{
  --bg:#030605;
  --bg-2:#07100e;
  --ink:#f4f5f0;
  --muted:#a8afa7;
  --soft:#6d766f;
  --line:rgba(244,245,240,.15);
  --accent:#7fffe8;
  --accent-2:#a8ffcf;
  --danger:#ff3d22;
  --glass:rgba(255,255,255,.055);
  --shadow:0 30px 90px rgba(0,0,0,.55);
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  font-family:var(--font-display);
  color:var(--ink);
  background:
    radial-gradient(circle at 20% 5%, rgba(127,255,232,.08), transparent 28%),
    radial-gradient(circle at 80% 10%, rgba(255,61,34,.055), transparent 26%),
    linear-gradient(180deg,#020302 0%,#050807 42%,#020302 100%);
  overflow-x:hidden;
  cursor:none;
}
body.is-locked{overflow:hidden}
a,button{font:inherit;color:inherit}
a{text-decoration:none}
button{border:0;background:none;cursor:none}
img{max-width:100%;display:block}
::selection{background:rgba(127,255,232,.25);color:var(--ink)}

.noise-layer,.scanline-layer{
  pointer-events:none;position:fixed;inset:0;z-index:60;
}
.noise-layer{
  opacity:.12;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  mix-blend-mode:screen;
}
.scanline-layer{
  opacity:.08;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.08) 0 1px,transparent 1px 5px);
  mix-blend-mode:overlay;
}

.cursor{
  width:16px;height:16px;border:1px solid rgba(127,255,232,.72);border-radius:50%;
  position:fixed;left:0;top:0;z-index:999;pointer-events:none;
  transform:translate(-50%,-50%);
  transition:width .22s ease,height .22s ease,border-color .22s ease,background .22s ease;
  box-shadow:0 0 24px rgba(127,255,232,.16);
}
.cursor.is-hover{width:42px;height:42px;background:rgba(127,255,232,.055);border-color:rgba(255,255,255,.45)}

.container{width:min(var(--max),calc(100% - 40px));margin-inline:auto}
.section{position:relative;min-height:100vh;padding:130px 0;overflow:hidden}
.section-bg{position:absolute;inset:0;z-index:-1;pointer-events:none}
.section-bg--radial{background:radial-gradient(circle at 50% 50%,rgba(127,255,232,.08),transparent 32%),linear-gradient(180deg,rgba(0,0,0,.0),rgba(0,0,0,.5))}
.section-bg--mesh{background:radial-gradient(circle at 12% 80%,rgba(127,255,232,.06),transparent 35%),radial-gradient(circle at 82% 18%,rgba(255,61,34,.04),transparent 30%)}
.section-bg--frequency{background:linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),radial-gradient(circle at 72% 35%,rgba(127,255,232,.075),transparent 32%);background-size:72px 72px,auto}
.section-bg--darkgrid{background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:88px 88px}
.section-bg--live{background:radial-gradient(circle at 18% 18%,rgba(255,61,34,.1),transparent 30%),radial-gradient(circle at 85% 70%,rgba(127,255,232,.07),transparent 33%)}
.section-bg--kit{background:radial-gradient(circle at 20% 50%,rgba(127,255,232,.06),transparent 35%),linear-gradient(135deg,transparent 0 48%,rgba(255,255,255,.035) 48% 49%,transparent 49%)}
.section-kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  margin:0 0 18px;
}
.section-kicker:before{content:"";width:42px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
h1,h2,h3,p{margin:0}
h2{font-size:clamp(2.2rem,6vw,6.8rem);line-height:.9;letter-spacing:-.055em;text-transform:uppercase}
h2 span,.accent{color:var(--accent)}
p{color:var(--muted);line-height:1.65;font-size:1.02rem}
strong{color:var(--ink);font-weight:700}
mark{background:rgba(127,255,232,.095);color:var(--ink);padding:.06em .26em;border:1px solid rgba(127,255,232,.18);border-radius:999px}

.preloader{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:#010202;transition:opacity .8s ease,visibility .8s ease}
.preloader.is-hidden{opacity:0;visibility:hidden}
.preloader__grid{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(circle at 50% 50%,black,transparent 66%);animation:gridPulse 2s infinite alternate}
.preloader__content{text-align:center;position:relative;width:min(520px,86vw)}
.preloader__logo{width:220px;margin:0 auto 34px;filter:drop-shadow(0 0 28px rgba(127,255,232,.16));animation:microGlitch 1.6s steps(1) infinite}
.preloader__words{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.preloader__words span{font-family:var(--font-mono);font-size:.82rem;color:var(--muted);animation:wordBlink 1.8s steps(1) infinite}
.preloader__words span:nth-child(2){animation-delay:.18s}.preloader__words span:nth-child(3){animation-delay:.36s}
.preloader__signal{height:1px;background:rgba(255,255,255,.11);overflow:hidden;margin:0 auto 18px;width:76%}
.preloader__signal span{display:block;height:100%;width:35%;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:signalLoad 1.2s ease-in-out infinite}
.preloader p{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}

.site-header{position:fixed;top:0;left:0;width:100%;height:82px;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,4vw,58px);transition:background .28s ease,backdrop-filter .28s ease,border-color .28s ease;border-bottom:1px solid transparent}
.site-header.is-scrolled{background:rgba(3,6,5,.68);backdrop-filter:blur(18px);border-color:rgba(255,255,255,.08)}
.brand img{width:118px;height:auto;filter:drop-shadow(0 0 12px rgba(255,255,255,.08))}
.desktop-nav{display:flex;gap:28px;font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.72)}
.desktop-nav a{position:relative;padding:8px 0;transition:color .25s ease}
.desktop-nav a:after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--accent);transition:width .25s ease}
.desktop-nav a:hover,.desktop-nav a.is-active{color:var(--ink)}
.desktop-nav a:hover:after,.desktop-nav a.is-active:after{width:100%}
.menu-toggle{display:none;width:44px;height:44px;position:relative;z-index:95}
.menu-toggle span{position:absolute;left:8px;right:8px;height:1px;background:var(--ink);transition:transform .25s ease,top .25s ease}
.menu-toggle span:first-child{top:17px}.menu-toggle span:last-child{top:27px}
.menu-toggle.is-open span:first-child{top:22px;transform:rotate(45deg)}.menu-toggle.is-open span:last-child{top:22px;transform:rotate(-45deg)}

.menu-panel{position:fixed;inset:0;z-index:75;background:rgba(2,4,4,.96);transform:translateY(-108%);opacity:0;visibility:hidden;pointer-events:none;transition:transform .65s cubic-bezier(.22,1,.36,1),opacity .28s ease,visibility 0s linear .65s;padding:100px 28px 36px;display:flex;flex-direction:column;justify-content:space-between}
.menu-panel.is-open{transform:translateY(0);opacity:1;visibility:visible;pointer-events:auto;transition:transform .65s cubic-bezier(.22,1,.36,1),opacity .28s ease,visibility 0s}
.menu-panel__bg{position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(127,255,232,.11),transparent 33%),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:auto,76px 76px;opacity:.8;pointer-events:none}
.menu-panel__top,.menu-panel__foot{position:relative;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;color:var(--soft);letter-spacing:.12em}
.menu-panel__top img{width:125px}
.menu-panel__links{position:relative;display:grid;gap:13px}
.menu-panel__links a{font-size:clamp(2.1rem,11vw,6rem);font-weight:700;line-height:.9;text-transform:uppercase;letter-spacing:-.06em;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:12px}
.menu-panel__links span{font-family:var(--font-mono);font-size:.78rem;letter-spacing:0;color:var(--accent);margin-right:16px;vertical-align:middle}
.menu-panel__foot{justify-content:flex-start;flex-wrap:wrap;gap:10px;padding-top:22px;border-top:1px solid rgba(255,255,255,.08)}
.menu-panel__foot a{position:relative;display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.72);padding:11px 14px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.018));backdrop-filter:blur(12px);overflow:hidden;transition:color .28s ease,border-color .28s ease,transform .28s ease,background .28s ease}
.menu-panel__foot a:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px rgba(127,255,232,.42)}
.menu-panel__foot a:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(127,255,232,.13),transparent);transform:translateX(-120%);transition:transform .45s ease;pointer-events:none}
.menu-panel__foot a:hover{color:var(--ink);border-color:rgba(127,255,232,.36);background:linear-gradient(135deg,rgba(127,255,232,.085),rgba(255,255,255,.025));transform:translateY(-3px)}
.menu-panel__foot a:hover:after{transform:translateX(120%)}

.hero{height:100vh;min-height:720px;padding:0;display:grid;align-items:center}
.hero__media{position:absolute;inset:0;overflow:hidden;background:#030303}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);filter:saturate(.95) contrast(1.02) brightness(.82)}
.hero__img--main{animation:heroDrift 18s ease-in-out infinite alternate;transform-origin:62% 55%}
.hero__img--flash{opacity:0;filter:saturate(1.3) contrast(1.18) brightness(.8);mix-blend-mode:screen;transform:scale(1.08);clip-path:polygon(0 9%,100% 0,100% 92%,0 100%)}
.flash-a{animation:imageInterference 7.4s steps(1) infinite}
.flash-b{animation:imageInterferenceB 10.8s steps(1) infinite}
.hero__vignette{position:absolute;inset:0;background:linear-gradient(90deg,#030605 0%,rgba(3,6,5,.92) 19%,rgba(3,6,5,.46) 52%,rgba(3,6,5,.7) 100%),radial-gradient(circle at 70% 48%,transparent 0 24%,rgba(0,0,0,.58) 67%)}
.hero__colorwash{position:absolute;inset:-20%;background:radial-gradient(circle at 66% 45%,rgba(127,255,232,.18),transparent 25%),radial-gradient(circle at 22% 30%,rgba(255,61,34,.12),transparent 20%);mix-blend-mode:screen;opacity:.75;animation:colorMove 9s ease-in-out infinite alternate}
.hero__wave{position:absolute;left:0;bottom:11%;width:100%;height:150px;opacity:.38;mix-blend-mode:screen;z-index:3}
.hero__ui{position:absolute;left:clamp(20px,4vw,58px);right:clamp(20px,4vw,58px);bottom:34px;display:flex;justify-content:space-between;z-index:4;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.48)}
.hero__content{position:relative;z-index:5;width:min(760px,calc(100% - 40px));margin-left:clamp(20px,8vw,120px);padding-top:80px}
.eyebrow{font-family:var(--font-mono);font-size:.78rem;color:var(--accent);text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.hero__logo{position:relative;display:block;width:min(520px,80vw);margin:0 0 18px}
.hero__logo img{width:100%;filter:drop-shadow(0 10px 36px rgba(0,0,0,.7)) drop-shadow(0 0 22px rgba(127,255,232,.13))}
.glitch-text{animation:microGlitch 3s steps(1) infinite}
.hero__genres{font-family:var(--font-mono);font-size:clamp(.72rem,1vw,.88rem);letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);margin:0 0 28px}
.hero__statement{font-size:clamp(1.32rem,2.7vw,2.65rem);line-height:1.05;color:rgba(255,255,255,.8);max-width:760px;letter-spacing:-.035em;margin-bottom:36px}
.hero__statement strong{display:inline-block;color:var(--ink);font-size:1.06em}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 24px;border-radius:999px;font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;overflow:hidden;isolation:isolate;transition:transform .25s ease,border-color .25s ease,color .25s ease}
.btn:before{content:"";position:absolute;inset:0;z-index:-1;transform:translateX(-110%) skewX(-18deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transition:transform .55s ease}
.btn:hover{transform:translateY(-3px)}.btn:hover:before{transform:translateX(110%) skewX(-18deg)}
.btn--primary{background:var(--ink);color:#020403;box-shadow:0 0 30px rgba(127,255,232,.13)}
.btn--ghost{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.2);color:var(--ink);backdrop-filter:blur(12px)}
.hero__scroll{position:absolute;right:clamp(20px,4vw,58px);bottom:94px;z-index:5;display:grid;gap:12px;justify-items:center;font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;color:rgba(255,255,255,.45);letter-spacing:.12em}
.hero__scroll i{display:block;width:1px;height:54px;background:rgba(255,255,255,.14);position:relative;overflow:hidden}
.hero__scroll i:after{content:"";position:absolute;left:0;top:-25%;width:1px;height:35%;background:var(--accent);animation:scrollLine 1.6s ease-in-out infinite}

.manifesto{min-height:70vh;display:grid;place-items:center;text-align:center}
.manifesto h2{font-size:clamp(3rem,9vw,10rem)}
.manifesto h2 span{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.65)}

.artist__grid{display:grid;grid-template-columns:minmax(340px,.95fr) minmax(300px,1fr);gap:clamp(35px,7vw,90px);align-items:center}
.artist__visual{position:relative;min-height:720px;display:flex;align-items:flex-end;justify-content:center}
.giant-label{position:absolute;left:-8%;top:8%;font-size:clamp(5rem,12vw,13rem);font-weight:700;letter-spacing:-.08em;color:rgba(255,255,255,.035);text-transform:uppercase;white-space:nowrap}
.artist__halo{position:absolute;width:72%;height:62%;border-radius:999px;background:radial-gradient(circle,rgba(127,255,232,.12),transparent 62%);filter:blur(20px);bottom:12%;animation:pulseHalo 5s ease-in-out infinite alternate}
.artist__cutout{position:relative;z-index:2;max-height:760px;width:auto;filter:drop-shadow(0 35px 45px rgba(0,0,0,.65)) drop-shadow(0 0 24px rgba(127,255,232,.08));transform:translateX(-4%)}
.artist__copy h2{font-size:clamp(2.2rem,5vw,5.2rem);margin-bottom:28px}
.rich-text{display:grid;gap:18px;max-width:690px}
.rich-text p{font-size:clamp(1rem,1.25vw,1.12rem)}
.quick-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08);margin-top:34px;border:1px solid rgba(255,255,255,.08)}
.quick-facts div{background:rgba(3,6,5,.72);padding:18px;min-height:104px}
.quick-facts span{display:block;font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:12px}
.quick-facts strong{font-size:.95rem;line-height:1.3}

.section-head{max-width:880px;margin-bottom:55px}
.section-head h2{margin-bottom:22px}
.section-head p{font-size:clamp(1.05rem,1.7vw,1.35rem);max-width:760px}.section-head p strong{color:var(--ink)}
.sound__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:stretch}
.sound__player{position:relative;min-height:560px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035);overflow:hidden;box-shadow:var(--shadow)}
.sound__art{position:absolute;inset:0}.sound__art img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) brightness(.68)}
.sound__art-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(3,6,5,.95) 75%),radial-gradient(circle at 70% 25%,rgba(127,255,232,.14),transparent 35%)}
.player-card{position:absolute;left:26px;right:26px;bottom:26px;padding:26px;border:1px solid rgba(255,255,255,.13);background:rgba(3,6,5,.62);backdrop-filter:blur(18px)}
.player-card__tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.player-card h3{font-size:clamp(1.9rem,4vw,4.2rem);letter-spacing:-.06em;text-transform:uppercase;margin:10px 0 8px}
.player-card p{margin-bottom:18px}
.equalizer{height:54px;display:flex;gap:6px;align-items:center;margin:18px 0}
.equalizer span{display:block;width:5px;height:20px;background:linear-gradient(180deg,var(--accent),rgba(255,255,255,.2));animation:eq 1.1s ease-in-out infinite alternate}.equalizer span:nth-child(2){animation-delay:.1s}.equalizer span:nth-child(3){animation-delay:.22s}.equalizer span:nth-child(4){animation-delay:.31s}.equalizer span:nth-child(5){animation-delay:.16s}.equalizer span:nth-child(6){animation-delay:.28s}.equalizer span:nth-child(7){animation-delay:.05s}.equalizer span:nth-child(8){animation-delay:.38s}
.sound__cards{display:grid;gap:18px}
.sound-card{padding:30px;border:1px solid rgba(255,255,255,.09);background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.018));min-height:168px;position:relative;overflow:hidden;transition:transform .35s ease,border-color .35s ease,background .35s ease}
.sound-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(127,255,232,.12),transparent 30%);opacity:0;transition:opacity .35s ease}
.sound-card:hover{transform:translateY(-6px);border-color:rgba(127,255,232,.35)}.sound-card:hover:before{opacity:1}
.sound-card span{font-family:var(--font-mono);font-size:.75rem;color:var(--accent)}
.sound-card h3{font-size:clamp(1.8rem,3.2vw,3.8rem);text-transform:uppercase;letter-spacing:-.06em;margin:16px 0 8px}

.trajectory__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center;margin-bottom:56px}
.trajectory__copy h2{font-size:clamp(2rem,5.2vw,5.5rem);margin-bottom:26px}
.trajectory__copy p{font-size:1.08rem;max-width:650px}
.trajectory__visual{height:620px;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow);position:relative}
.trajectory__visual:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.35)),radial-gradient(circle at 50% 50%,transparent,rgba(0,0,0,.55));}
.trajectory__visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.74) saturate(.9);transition:transform 8s ease}.trajectory__visual:hover img{transform:scale(1.08)}
.lineup{display:grid;gap:18px}
.lineup__block{border-top:1px solid rgba(255,255,255,.14);padding-top:22px}
.lineup__block>span{display:block;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:18px}
.lineup__names{display:flex;flex-wrap:wrap;gap:10px}
.lineup__names b{font-size:clamp(1.45rem,3vw,3.1rem);line-height:.9;text-transform:uppercase;letter-spacing:-.06em;padding:12px 14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.035);transition:color .25s ease,border-color .25s ease,transform .25s ease}
.lineup__names--small b{font-size:clamp(1.1rem,2.2vw,2rem)}
.lineup__names b:hover{color:var(--accent);border-color:rgba(127,255,232,.35);transform:translateY(-3px)}

.live__grid{display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:18px;align-items:stretch}
.live-card{position:relative;min-height:490px;border:1px solid rgba(255,255,255,.1);overflow:hidden;background:rgba(255,255,255,.03);text-align:left;isolation:isolate}
.live-card--wide{min-height:560px}.live-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.62) saturate(.95);transition:transform .8s cubic-bezier(.22,1,.36,1),filter .35s ease}.live-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.06),rgba(0,0,0,.7)),radial-gradient(circle at 50% 42%,transparent 0 38%,rgba(0,0,0,.62) 100%);z-index:-1}.live-card span{position:absolute;left:22px;bottom:24px;font-size:clamp(1.8rem,3vw,3.4rem);text-transform:uppercase;font-weight:700;letter-spacing:-.065em}.live-card i{position:absolute;right:20px;top:20px;font-family:var(--font-mono);font-style:normal;color:var(--accent)}
.live-card:before{content:"▶";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);width:68px;height:68px;border:1px solid rgba(255,255,255,.32);border-radius:50%;display:grid;place-items:center;background:rgba(0,0,0,.24);backdrop-filter:blur(10px);opacity:0;transition:opacity .35s ease,transform .35s ease}.live-card:hover img{transform:scale(1.06);filter:brightness(.82) saturate(1.1)}.live-card:hover:before{opacity:1;transform:translate(-50%,-50%) scale(1)}

.kit__grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:50px;align-items:start}.kit__intro h2{font-size:clamp(2.1rem,5.2vw,5.2rem);margin-bottom:24px}.kit__intro p{margin-bottom:30px;max-width:570px}.kit__accordion{border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.035);backdrop-filter:blur(10px)}
.accordion{width:100%;display:grid;grid-template-columns:52px 1fr 28px;gap:18px;align-items:center;text-align:left;padding:24px;border-bottom:1px solid rgba(255,255,255,.08);color:var(--ink)}
.accordion span{font-family:var(--font-mono);color:var(--accent);font-size:.76rem}.accordion strong{text-transform:uppercase;font-size:clamp(1.2rem,2vw,2rem);letter-spacing:-.04em}.accordion i{width:18px;height:18px;position:relative}.accordion i:before,.accordion i:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:1px;background:var(--ink);transform:translate(-50%,-50%);transition:transform .25s ease}.accordion i:after{transform:translate(-50%,-50%) rotate(90deg)}.accordion.is-open i:after{transform:translate(-50%,-50%) rotate(0deg)}
.accordion-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease;border-bottom:1px solid rgba(255,255,255,.08)}.accordion-panel.is-open{grid-template-rows:1fr}.accordion-panel p{overflow:hidden;padding:0 24px;color:var(--muted)}.accordion-panel.is-open p{padding:0 24px 24px}

.contact{min-height:100vh;display:grid;align-items:center}.contact__media{position:absolute;inset:0;z-index:-2}.contact__media img{width:100%;height:100%;object-fit:cover;filter:brightness(.38) saturate(.75);transform:scale(1.05)}.contact__overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(3,6,5,.94) 0%,rgba(3,6,5,.78) 48%,rgba(3,6,5,.48)),radial-gradient(circle at 20% 70%,rgba(127,255,232,.09),transparent 35%)}
.contact__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}.contact__copy h2{font-size:clamp(2.4rem,6vw,6.4rem);margin-bottom:26px}.contact__copy p{font-size:1.1rem;max-width:640px}.social-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}.social-row a{font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;border:1px solid rgba(255,255,255,.12);padding:12px 14px;background:rgba(255,255,255,.035);transition:border-color .25s ease,transform .25s ease}.social-row a:hover{border-color:rgba(127,255,232,.36);transform:translateY(-3px)}
.booking-form{padding:30px;border:1px solid rgba(255,255,255,.13);background:rgba(3,6,5,.62);backdrop-filter:blur(18px);box-shadow:var(--shadow);display:grid;gap:16px}.booking-form label{display:grid;gap:8px}.booking-form span{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}.booking-form input,.booking-form textarea{width:100%;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);border-radius:0;color:var(--ink);padding:15px 14px;outline:none;font:inherit;transition:border-color .25s ease,background .25s ease}.booking-form input:focus,.booking-form textarea:focus{border-color:rgba(127,255,232,.45);background:rgba(127,255,232,.035)}.booking-form small{font-family:var(--font-mono);font-size:.68rem;color:var(--soft);line-height:1.5}

.site-footer{min-height:230px;padding:50px 20px;display:grid;place-items:center;text-align:center;gap:12px;background:#010202;border-top:1px solid rgba(255,255,255,.08)}.site-footer img{width:145px}.site-footer p{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.site-footer span{font-size:.85rem;color:var(--soft)}

.modal{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:110;display:grid;place-items:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.modal.is-open{opacity:1;visibility:visible}.modal__close{position:absolute;top:24px;right:24px;width:48px;height:48px;border:1px solid rgba(255,255,255,.2);border-radius:50%;color:var(--ink);font-size:2rem;background:rgba(255,255,255,.04)}.modal__content{width:min(920px,100%);border:1px solid rgba(255,255,255,.13);background:#050807;box-shadow:var(--shadow)}.modal__content img{width:100%;height:min(65vh,680px);object-fit:cover;filter:brightness(.82)}.modal__content div{padding:20px 24px}.modal__content span{font-size:2rem;text-transform:uppercase;font-weight:700}.modal__content p{margin-top:4px}

.reveal-up,.reveal-left,.reveal-right{opacity:0;transition:opacity .85s ease,transform .85s cubic-bezier(.22,1,.36,1)}.reveal-up{transform:translateY(34px)}.reveal-left{transform:translateX(-42px)}.reveal-right{transform:translateX(42px)}.is-visible{opacity:1;transform:none}

@keyframes heroDrift{from{transform:scale(1.06) translate3d(0,0,0)}to{transform:scale(1.12) translate3d(-1.2%,.7%,0)}}
@keyframes imageInterference{0%,92%,100%{opacity:0;transform:scale(1.08) translate(0,0)}93%{opacity:.34;transform:scale(1.1) translate(10px,-4px);clip-path:polygon(0 9%,100% 4%,100% 25%,0 20%)}94%{opacity:0}96%{opacity:.22;transform:scale(1.1) translate(-8px,6px);clip-path:polygon(0 62%,100% 55%,100% 78%,0 84%)}97%{opacity:0}}
@keyframes imageInterferenceB{0%,86%,100%{opacity:0}87%{opacity:.23;transform:scale(1.11) translate(-12px,0);clip-path:polygon(0 30%,100% 25%,100% 38%,0 43%)}88%{opacity:0}89%{opacity:.16;transform:scale(1.12) translate(8px,-5px);clip-path:polygon(0 72%,100% 68%,100% 91%,0 96%)}90%{opacity:0}}
@keyframes colorMove{from{transform:translate(-1%,1%) scale(1)}to{transform:translate(2%,-2%) scale(1.05)}}
@keyframes microGlitch{0%,92%,100%{transform:none;filter:none}93%{transform:translate(2px,-1px);filter:drop-shadow(-2px 0 var(--accent)) drop-shadow(2px 0 var(--danger))}94%{transform:translate(-2px,1px)}95%{transform:none;filter:none}}
@keyframes gridPulse{from{opacity:.35}to{opacity:.65}}
@keyframes wordBlink{0%,100%{color:var(--soft)}45%{color:var(--ink)}46%{color:var(--accent)}}
@keyframes signalLoad{from{transform:translateX(-120%)}to{transform:translateX(320%)}}
@keyframes scrollLine{0%{top:-35%}100%{top:100%}}
@keyframes pulseHalo{from{opacity:.4;transform:scale(.94)}to{opacity:.8;transform:scale(1.04)}}
@keyframes eq{from{height:12px;opacity:.45}to{height:52px;opacity:1}}

@media (max-width:980px){
  body{cursor:auto}.cursor{display:none}button,a{cursor:pointer}
  .desktop-nav{display:none}.menu-toggle{display:block}
  .hero{min-height:760px}.hero__content{margin-inline:20px;width:calc(100% - 40px);padding-top:120px}.hero__vignette{background:linear-gradient(180deg,rgba(3,6,5,.64),rgba(3,6,5,.78) 52%,rgba(3,6,5,.94)),radial-gradient(circle at 50% 38%,transparent,rgba(0,0,0,.7) 70%)}.hero__img{object-position:58% center}.hero__ui{display:none}.hero__scroll{right:20px;bottom:54px}
  .artist__grid,.sound__grid,.trajectory__grid,.kit__grid,.contact__grid{grid-template-columns:1fr}
  .artist__visual{min-height:600px;order:2}.artist__copy{order:1}.artist__cutout{max-height:640px;transform:translateX(0)}.quick-facts{grid-template-columns:1fr}.sound__player{min-height:620px}.trajectory__visual{height:520px}.live__grid{grid-template-columns:1fr}.live-card,.live-card--wide{min-height:450px}.contact__grid{gap:32px}.section{padding:100px 0}.menu-panel{display:flex}
}
@media (max-width:640px){
  .container{width:min(100% - 28px,var(--max))}.site-header{height:72px;padding:0 16px}.brand img{width:98px}.hero__statement{font-size:1.42rem}.hero__actions{display:grid;grid-template-columns:1fr;width:100%;max-width:330px}.btn{min-height:50px}.hero__logo{width:min(360px,88vw)}.manifesto h2{font-size:clamp(3rem,15vw,5.2rem)}h2{letter-spacing:-.065em}.artist__visual{min-height:520px}.artist__cutout{max-height:540px}.giant-label{top:12%;left:-18%;font-size:6rem}.player-card{left:14px;right:14px;bottom:14px;padding:18px}.sound__player{min-height:560px}.lineup__names b{font-size:1.35rem}.booking-form{padding:20px}.contact__copy h2{font-size:3rem}.menu-panel__links a{font-size:3rem}
}

/* === AJUSTES V6: sección El Artista más compacta, amplia y premium === */
.manifesto.section{
  min-height:58vh;
  padding-top:96px;
  padding-bottom:58px;
}
.artist.section{
  padding-top:74px;
}
.artist .container{
  width:min(1400px,calc(100% - 56px));
}
.artist__grid{
  grid-template-columns:minmax(360px,.78fr) minmax(620px,1.22fr);
  gap:clamp(34px,5vw,72px);
  align-items:center;
}
.artist__visual{
  min-height:740px;
  align-items:flex-end;
}
.artist__cutout{
  max-height:820px;
  width:auto;
  max-width:min(520px,100%);
  object-fit:contain;
  object-position:center bottom;
  transform:translateX(-2%);
}
.artist__copy{
  max-width:790px;
}
.artist__copy h2{
  max-width:790px;
  font-size:clamp(2.45rem,4.15vw,4.85rem);
  line-height:.93;
  letter-spacing:-.062em;
  margin-bottom:30px;
}
.artist__copy .rich-text{
  max-width:760px;
}
.quick-facts{
  gap:12px;
  background:transparent;
  border:0;
  margin-top:40px;
  perspective:900px;
}
.quick-facts div{
  position:relative;
  overflow:hidden;
  min-height:126px;
  padding:22px 20px 20px;
  background:
    linear-gradient(145deg,rgba(255,255,255,.072),rgba(255,255,255,.018) 56%,rgba(127,255,232,.035)),
    rgba(3,6,5,.72);
  border:1px solid rgba(255,255,255,.105);
  box-shadow:0 18px 45px rgba(0,0,0,.26), inset 0 1px 0 rgba(255,255,255,.055);
  backdrop-filter:blur(14px);
  transition:transform .42s cubic-bezier(.22,1,.36,1),border-color .42s ease,background .42s ease,box-shadow .42s ease;
}
.quick-facts div:before{
  content:"";
  position:absolute;
  left:0;top:0;width:100%;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:.52;
  transform:translateX(-35%);
  transition:transform .55s ease,opacity .35s ease;
}
.quick-facts div:after{
  content:"";
  position:absolute;
  inset:-1px;
  background:radial-gradient(circle at 78% 18%,rgba(127,255,232,.16),transparent 34%);
  opacity:0;
  transition:opacity .42s ease;
  pointer-events:none;
}
.quick-facts div:hover{
  transform:translateY(-8px) rotateX(1deg);
  border-color:rgba(127,255,232,.32);
  background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.024) 56%,rgba(127,255,232,.06));
  box-shadow:0 26px 60px rgba(0,0,0,.38),0 0 34px rgba(127,255,232,.055),inset 0 1px 0 rgba(255,255,255,.07);
}
.quick-facts div:hover:before{transform:translateX(0);opacity:.9}
.quick-facts div:hover:after{opacity:1}
.quick-facts span{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--accent);
  margin-bottom:15px;
}
.quick-facts span:before{
  content:"";
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 14px rgba(127,255,232,.45);
}
.quick-facts strong{
  position:relative;
  z-index:1;
  display:block;
  font-size:1rem;
  line-height:1.34;
  letter-spacing:-.012em;
}

@media (max-width:1180px){
  .artist .container{width:min(100% - 40px,var(--max))}
  .artist__grid{grid-template-columns:minmax(320px,.9fr) minmax(420px,1.1fr)}
  .artist__copy h2{font-size:clamp(2.35rem,4.75vw,4.45rem)}
}
@media (max-width:980px){
  .manifesto.section{min-height:48vh;padding-top:86px;padding-bottom:42px}
  .artist.section{padding-top:76px}
  .artist__grid{grid-template-columns:1fr;gap:42px}
  .artist__copy{max-width:100%}
  .artist__copy h2{max-width:860px;font-size:clamp(2.45rem,8vw,5rem)}
  .artist__visual{min-height:620px;align-items:flex-end}
  .artist__cutout{max-height:660px;max-width:min(520px,92vw);transform:none}
  .quick-facts{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:720px){
  .manifesto.section{min-height:auto;padding-top:76px;padding-bottom:38px}
  .artist.section{padding-top:70px}
  .artist .container{width:min(100% - 28px,var(--max))}
  .artist__copy h2{font-size:clamp(2.35rem,13vw,4.25rem);line-height:.9}
  .artist__visual{min-height:560px}
  .artist__cutout{max-height:570px;max-width:96vw}
  .quick-facts{grid-template-columns:1fr;gap:12px;margin-top:32px}
  .quick-facts div{min-height:auto;padding:20px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}
  .preloader{display:none}
}


/* === AJUSTE V7: los accesos Instagram / SoundCloud / Contacto quedan dentro del menú, no flotando en el hero === */
@media (max-width:640px){
  .menu-panel__foot{gap:8px;align-items:flex-start}
  .menu-panel__foot a{width:100%;justify-content:space-between;padding:13px 14px}
}

/* === AJUSTE V8: Mobile El Artista === */
.artist__mobile-visual,
.rich-text--mobile{display:none}

@media (max-width:980px){
  .manifesto.section{
    padding-bottom:18px;
  }
  .artist.section{
    padding-top:42px;
  }
}

@media (max-width:720px){
  .manifesto.section{
    padding-top:62px;
    padding-bottom:14px;
  }
  .artist.section{
    padding-top:34px;
  }
  .artist__grid{
    gap:0;
  }
  .artist__grid > .artist__visual{
    display:none;
  }
  .artist__copy{
    display:flex;
    flex-direction:column;
  }
  .artist__copy h2{
    font-size:clamp(2.05rem,10.2vw,3.05rem);
    line-height:.94;
    letter-spacing:-.064em;
    max-width:100%;
    margin-bottom:22px;
  }
  .artist__mobile-visual{
    position:relative;
    display:flex;
    justify-content:center;
    align-items:flex-end;
    min-height:430px;
    margin:6px 0 24px;
    overflow:hidden;
  }
  .artist__mobile-visual .giant-label{
    top:44%;
    left:-18%;
    font-size:clamp(4.8rem,24vw,7.2rem);
    opacity:.16;
    white-space:nowrap;
  }
  .artist__mobile-visual .artist__halo{
    width:78%;
    height:64%;
    bottom:9%;
    opacity:.65;
    filter:blur(26px);
  }
  .artist__mobile-visual .artist__cutout{
    max-height:430px;
    width:auto;
    max-width:92vw;
    transform:none;
    object-fit:contain;
    filter:drop-shadow(0 28px 38px rgba(0,0,0,.72)) drop-shadow(0 0 20px rgba(127,255,232,.06));
  }
  .rich-text--desktop{
    display:none;
  }
  .rich-text--mobile{
    display:grid;
    gap:15px;
  }
  .rich-text--mobile p{
    font-size:.98rem;
    line-height:1.64;
  }
  .quick-facts{
    gap:8px;
    margin-top:24px;
  }
  .quick-facts div{
    padding:13px 14px;
    min-height:auto;
    border-radius:0;
  }
  .quick-facts span{
    margin-bottom:7px;
    font-size:.58rem;
    letter-spacing:.13em;
    gap:7px;
  }
  .quick-facts span:before{
    width:5px;
    height:5px;
  }
  .quick-facts strong{
    font-size:.86rem;
    line-height:1.28;
  }
}

@media (max-width:390px){
  .artist__copy h2{
    font-size:clamp(1.9rem,9.6vw,2.55rem);
  }
  .artist__mobile-visual{
    min-height:400px;
  }
  .artist__mobile-visual .artist__cutout{
    max-height:400px;
  }
}

/* === AJUSTE V9: reproductor profesional de sets === */
.section-head--sound{max-width:840px}
.section-head--sound h2{max-width:760px}
.section-head--sound p{max-width:680px;font-size:1.08rem}
.set-player{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.52fr);
  gap:22px;
  align-items:stretch;
  margin-top:46px;
  isolation:isolate;
}
.set-player:before{
  content:"";
  position:absolute;
  inset:-1px;
  z-index:-1;
  background:
    radial-gradient(circle at 18% 8%,rgba(127,255,232,.12),transparent 28%),
    radial-gradient(circle at 82% 86%,rgba(255,61,34,.08),transparent 30%);
  opacity:.82;
  filter:blur(12px);
  pointer-events:none;
}
.set-player__main{
  display:grid;
  grid-template-columns:minmax(300px,.9fr) minmax(360px,1.1fr);
  min-height:560px;
  border:1px solid rgba(127,255,232,.17);
  background:
    linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.018) 42%,rgba(127,255,232,.035)),
    rgba(3,6,5,.72);
  box-shadow:0 34px 90px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(16px);
  overflow:hidden;
}
.set-player__visual{
  position:relative;
  overflow:hidden;
  min-height:560px;
  background:#010302;
}
.set-player__cover{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:brightness(.74) saturate(.96) contrast(1.05);
  transform:scale(1.02);
  transition:transform .75s cubic-bezier(.22,1,.36,1),filter .45s ease,opacity .35s ease;
}
.set-player.is-playing .set-player__cover{transform:scale(1.065);filter:brightness(.86) saturate(1.08) contrast(1.06)}
.set-player__visual:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,rgba(3,6,5,.04),rgba(3,6,5,.76) 82%),
    radial-gradient(circle at 18% 18%,rgba(127,255,232,.18),transparent 30%);
  pointer-events:none;
}
.set-player__light{
  position:absolute;
  pointer-events:none;
  mix-blend-mode:screen;
  opacity:.46;
  filter:blur(1px);
}
.set-player__light--a{
  width:48%;height:2px;top:18%;right:-5%;
  background:linear-gradient(90deg,transparent,rgba(127,255,232,.88),transparent);
  transform:rotate(-16deg);
  animation:setLightSweep 5.8s ease-in-out infinite;
}
.set-player__light--b{
  width:40%;height:2px;bottom:28%;left:-7%;
  background:linear-gradient(90deg,transparent,rgba(168,255,207,.56),transparent);
  transform:rotate(12deg);
  animation:setLightSweep 7.2s ease-in-out infinite reverse;
}
.set-player__noise{
  position:absolute;inset:0;opacity:.22;mix-blend-mode:screen;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}
.set-player__status{
  position:absolute;left:18px;right:18px;bottom:18px;z-index:2;
  display:flex;justify-content:space-between;gap:14px;
  font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.84);
}
.set-player__status span{
  padding:8px 10px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.28);backdrop-filter:blur(10px)
}
.set-player__console{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:24px;
  padding:clamp(24px,3.4vw,42px);
  overflow:hidden;
}
.set-player__console:before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;
  background:
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(180deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(circle at 40% 50%,black,transparent 72%);
}
.set-player__meta,.set-player__timeline,.set-player__controls,.set-player__bottom,.set-player__spectrum{position:relative;z-index:1}
.player-label{
  display:inline-flex;align-items:center;gap:9px;margin-bottom:14px;
  font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);
}
.player-label:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px rgba(127,255,232,.5)}
.set-player__meta h3{
  max-width:640px;
  font-size:clamp(2rem,3.5vw,4.35rem);
  line-height:.94;
  letter-spacing:-.065em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.set-player__meta p{max-width:560px;color:rgba(244,245,240,.72);font-size:.98rem}
.set-player__spectrum{
  display:flex;
  align-items:end;
  gap:5px;
  height:92px;
  padding:18px 0 8px;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.set-player__spectrum span{
  flex:1;
  min-width:3px;
  max-width:13px;
  height:24px;
  background:linear-gradient(180deg,var(--accent),rgba(127,255,232,.18));
  opacity:.42;
  transform-origin:bottom;
  animation:setSpectrum 1.15s ease-in-out infinite alternate;
  animation-play-state:paused;
}
.set-player.is-playing .set-player__spectrum span{animation-play-state:running}
.set-player__spectrum span:nth-child(2n){animation-duration:.82s}.set-player__spectrum span:nth-child(3n){animation-duration:1.35s}.set-player__spectrum span:nth-child(5n){animation-duration:1.65s}.set-player__spectrum span:nth-child(7n){animation-duration:.98s}
.set-player__time{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-family:var(--font-mono);font-size:.72rem;color:rgba(244,245,240,.74);letter-spacing:.06em}
.progress-bar,.volume-control input{width:100%;accent-color:var(--accent);cursor:pointer}
.progress-bar{height:5px;appearance:none;background:linear-gradient(90deg,var(--accent) var(--progress,0%),rgba(255,255,255,.13) var(--progress,0%));border-radius:999px;outline:none}
.progress-bar::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--ink);border:3px solid var(--accent);box-shadow:0 0 22px rgba(127,255,232,.32)}
.progress-bar::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--ink);border:3px solid var(--accent);box-shadow:0 0 22px rgba(127,255,232,.32)}
.set-player__controls{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:2px}
.control-btn{
  width:48px;height:48px;border:1px solid rgba(255,255,255,.12);border-radius:50%;
  display:grid;place-items:center;background:rgba(255,255,255,.035);color:var(--ink);
  transition:transform .25s ease,border-color .25s ease,background .25s ease,box-shadow .25s ease,opacity .25s ease;
}
.control-btn span{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.02em}
.control-btn--play{width:66px;height:66px;background:var(--ink);color:#030605;border-color:var(--ink);box-shadow:0 0 34px rgba(255,255,255,.12)}
.control-btn--play span{font-size:1rem;transform:translateX(1px)}
.control-btn:hover{transform:translateY(-3px);border-color:rgba(127,255,232,.44);box-shadow:0 12px 28px rgba(0,0,0,.22),0 0 22px rgba(127,255,232,.08)}
.control-btn:disabled{opacity:.42;pointer-events:none}
.set-player__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;border-top:1px solid rgba(255,255,255,.08);padding-top:18px}
.volume-control{display:flex;align-items:center;gap:12px;min-width:210px;font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;color:rgba(244,245,240,.72)}
.volume-control input{max-width:120px;height:4px}
.set-player__external{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);border:1px solid rgba(127,255,232,.2);padding:10px 12px;background:rgba(127,255,232,.035);transition:transform .25s ease,border-color .25s ease,background .25s ease}
.set-player__external:hover{transform:translateY(-2px);border-color:rgba(127,255,232,.48);background:rgba(127,255,232,.075)}
.set-list{
  border:1px solid rgba(255,255,255,.105);
  background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.018)),rgba(3,6,5,.72);
  backdrop-filter:blur(16px);
  box-shadow:0 24px 70px rgba(0,0,0,.26);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:560px;
}
.set-list__head{display:flex;justify-content:space-between;align-items:center;padding:2px 2px 12px;border-bottom:1px solid rgba(255,255,255,.08);font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}
.set-list__head strong{font-size:.68rem;color:rgba(255,255,255,.62);font-weight:500}
.set-track{
  position:relative;
  display:grid;
  grid-template-columns:72px 1fr auto;
  gap:14px;
  align-items:center;
  width:100%;
  min-height:96px;
  padding:12px;
  text-align:left;
  border:1px solid rgba(255,255,255,.09);
  background:rgba(255,255,255,.028);
  overflow:hidden;
  transition:transform .28s ease,border-color .28s ease,background .28s ease,box-shadow .28s ease;
}
.set-track:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(127,255,232,.12),transparent 48%);opacity:0;transition:opacity .28s ease;pointer-events:none}
.set-track:hover,.set-track.is-active{border-color:rgba(127,255,232,.35);background:rgba(127,255,232,.045);box-shadow:0 18px 38px rgba(0,0,0,.24)}
.set-track:hover{transform:translateY(-2px)}.set-track:hover:before,.set-track.is-active:before{opacity:1}
.set-track img{width:72px;height:72px;object-fit:cover;filter:brightness(.82) saturate(.96)}
.set-track__info{position:relative;z-index:1;display:grid;gap:6px;min-width:0}.set-track__info b{font-size:.85rem;line-height:1.18;letter-spacing:-.02em;color:var(--ink);text-transform:uppercase}.set-track__info small{font-family:var(--font-mono);font-size:.64rem;line-height:1.25;color:rgba(244,245,240,.6);text-transform:uppercase;letter-spacing:.06em}.set-track i{position:relative;z-index:1;font-family:var(--font-mono);font-style:normal;font-size:.65rem;color:var(--accent)}
.set-list__placeholder{margin-top:auto;padding:16px;border:1px dashed rgba(255,255,255,.12);background:rgba(255,255,255,.02)}.set-list__placeholder span{font-family:var(--font-mono);font-size:.66rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}.set-list__placeholder p{margin-top:7px;font-size:.82rem;color:rgba(244,245,240,.55);line-height:1.45}
.soundcloud-widget{position:absolute;width:1px;height:1px;opacity:.01;pointer-events:none;overflow:hidden;left:-9999px;bottom:0}
@keyframes setSpectrum{0%{height:14px;opacity:.36}100%{height:84px;opacity:1}}
@keyframes setLightSweep{0%,100%{opacity:.18;transform:translateX(-10%) rotate(-16deg)}45%{opacity:.62}70%{opacity:.38;transform:translateX(18%) rotate(-16deg)}}
@media (max-width:1120px){
  .set-player{grid-template-columns:1fr;gap:18px}.set-list{min-height:auto}.set-list__placeholder{display:none}
}
@media (max-width:860px){
  .set-player__main{grid-template-columns:1fr;min-height:auto}.set-player__visual{min-height:430px}.set-player__console{padding:24px}.set-player__meta h3{font-size:clamp(2rem,8vw,3.5rem)}.set-player__bottom{align-items:flex-start;flex-direction:column}.volume-control{width:100%;justify-content:space-between}.volume-control input{max-width:170px}.set-list{padding:12px}.set-track{grid-template-columns:60px 1fr auto;min-height:82px;padding:10px}.set-track img{width:60px;height:60px}.set-player__spectrum{height:78px}
}
@media (max-width:520px){
  .section-head--sound p{font-size:.98rem}.set-player{margin-top:30px}.set-player__visual{min-height:330px}.set-player__status{font-size:.58rem;left:12px;right:12px;bottom:12px}.set-player__status span{padding:7px 8px}.set-player__console{padding:18px}.player-label{font-size:.62rem}.set-player__meta h3{font-size:2.05rem}.set-player__meta p{font-size:.9rem}.set-player__controls{gap:7px}.control-btn{width:40px;height:40px}.control-btn--play{width:58px;height:58px}.set-player__bottom{gap:12px}.set-player__external{width:100%;justify-content:center;display:flex}.set-list__head{font-size:.62rem}.set-track__info b{font-size:.78rem}.set-track__info small{font-size:.58rem}
}

/* === AJUSTE V11: reproductor fijo y estable para portadas de distintos tamaños === */
.set-player__main{
  height:560px;
  min-height:560px;
}
.set-player__visual{
  height:560px;
  min-height:0;
  aspect-ratio:auto;
}
.set-player__cover{
  position:absolute;
  inset:0;
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.set-player__console{
  min-width:0;
  min-height:0;
}
.set-player__meta h3{
  max-width:100%;
  font-size:clamp(1.9rem,3.05vw,3.75rem);
  line-height:.96;
  text-wrap:balance;
}
.set-player.is-loading .control-btn--play{
  border-color:rgba(127,255,232,.48);
  box-shadow:0 0 0 1px rgba(127,255,232,.2),0 0 32px rgba(127,255,232,.12);
}
.set-player.is-loading .control-btn--play span{
  animation:playerPulse .72s ease-in-out infinite alternate;
}
@keyframes playerPulse{from{opacity:.45;transform:scale(.94)}to{opacity:1;transform:scale(1.03)}}
.set-list{
  height:560px;
  min-height:560px;
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(127,255,232,.45) rgba(255,255,255,.06);
}
.set-list::-webkit-scrollbar{width:6px}
.set-list::-webkit-scrollbar-track{background:rgba(255,255,255,.04)}
.set-list::-webkit-scrollbar-thumb{background:rgba(127,255,232,.36);border-radius:99px}
.set-track img{
  flex:none;
  width:72px;
  height:72px;
  object-fit:cover;
  object-position:center;
}
.set-track__info b{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
@media (max-width:1120px){
  .set-player__main{height:auto;min-height:auto;}
  .set-list{height:auto;min-height:auto;max-height:520px;}
}
@media (max-width:860px){
  .set-player__visual{height:430px;min-height:0;}
}
@media (max-width:520px){
  .set-player__visual{height:330px;min-height:0;}
  .set-player__meta h3{font-size:1.85rem;line-height:1;}
  .set-list{max-height:none;}
}

/* === AJUSTE V12: interfaz estable y completa del reproductor === */
.set-player{
  grid-template-columns:minmax(0, 1.88fr) minmax(320px, .92fr);
  align-items:stretch;
  gap:clamp(18px,2vw,28px);
}
.set-player__main{
  height:auto;
  min-height:620px;
  display:grid;
  grid-template-columns:minmax(280px, .92fr) minmax(0, 1.08fr);
  overflow:visible;
}
.set-player__visual{
  height:auto;
  min-height:620px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.set-player__cover{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:opacity .28s ease, transform .72s cubic-bezier(.22,1,.36,1), filter .42s ease;
}
.set-player__cover.is-switching{opacity:.28;transform:scale(1.045)}
.set-player__console{
  min-width:0;
  min-height:620px;
  display:grid;
  grid-template-rows:auto minmax(64px, 82px) auto auto auto;
  align-content:stretch;
  gap:clamp(15px,1.5vw,20px);
  padding:clamp(28px,3vw,42px);
  overflow:visible;
}
.set-player__meta h3{
  max-width:100%;
  font-size:clamp(1.75rem,2.65vw,3.28rem);
  line-height:1;
  letter-spacing:-.058em;
  margin-bottom:12px;
  text-wrap:balance;
}
.set-player__meta p{
  max-width:520px;
  font-size:clamp(.88rem,.95vw,.98rem);
  line-height:1.55;
}
.set-player__spectrum{
  height:auto;
  min-height:64px;
  max-height:82px;
  padding:13px 0 8px;
  align-self:center;
}
.set-player__timeline{align-self:center;}
.set-player__controls{
  align-self:center;
  display:flex;
  flex-wrap:nowrap;
  gap:clamp(8px,1vw,12px);
  padding:2px 0;
  min-height:72px;
}
.control-btn{
  flex:0 0 auto;
  width:46px;
  height:46px;
}
.control-btn--play{
  width:64px;
  height:64px;
}
.control-btn.is-disabled{opacity:.55;cursor:wait;}
.set-player__bottom{
  align-self:end;
  min-height:48px;
  padding-top:14px;
}
.set-list{
  min-height:620px;
  height:620px;
  overflow-y:auto;
}
.set-track{
  min-height:104px;
}
.set-list__placeholder{
  display:none;
}
.soundcloud-widget{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
  overflow:hidden;
  left:-9999px;
  top:auto;
}
@media (max-width:1240px){
  .set-player__main{grid-template-columns:minmax(250px,.84fr) minmax(0,1.16fr)}
  .set-player__meta h3{font-size:clamp(1.68rem,2.45vw,2.85rem)}
}
@media (max-width:1120px){
  .set-player{grid-template-columns:1fr;}
  .set-player__main{min-height:0;height:auto;}
  .set-player__visual{min-height:520px;height:520px;}
  .set-player__console{min-height:520px;}
  .set-list{height:auto;min-height:0;max-height:560px;}
}
@media (max-width:860px){
  .set-player__main{grid-template-columns:1fr;}
  .set-player__visual{height:430px;min-height:430px;}
  .set-player__console{min-height:0;grid-template-rows:auto auto auto auto auto;padding:24px;}
  .set-player__meta h3{font-size:clamp(2rem,8vw,3.35rem);}
  .set-player__controls{min-height:64px;}
  .set-player__bottom{align-self:stretch;}
}
@media (max-width:520px){
  .set-player__visual{height:330px;min-height:330px;}
  .set-player__console{padding:18px;gap:14px;}
  .set-player__meta h3{font-size:1.82rem;letter-spacing:-.045em;}
  .set-player__spectrum{min-height:56px;}
  .set-player__controls{gap:7px;min-height:58px;}
  .control-btn{width:39px;height:39px;}
  .control-btn--play{width:56px;height:56px;}
  .set-list{max-height:none;}
  .set-track{min-height:82px;}
}

/* === AJUSTE V13: reproductor estable con tamaño fijo real === */
.sound .section-head--sound{
  margin-bottom:clamp(34px,5vw,68px);
}
.set-player{
  --player-height: 640px;
  align-items:stretch;
}
.set-player__main{
  height:var(--player-height) !important;
  min-height:var(--player-height) !important;
  max-height:var(--player-height) !important;
  display:grid;
  grid-template-columns:minmax(285px,.9fr) minmax(0,1.1fr);
  overflow:hidden;
}
.set-player__visual{
  height:var(--player-height) !important;
  min-height:var(--player-height) !important;
  max-height:var(--player-height) !important;
}
.set-player__cover{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.set-player__console{
  height:var(--player-height) !important;
  min-height:var(--player-height) !important;
  max-height:var(--player-height) !important;
  display:grid;
  grid-template-rows:minmax(0,1fr) 72px 74px 74px 58px;
  gap:14px;
  overflow:hidden;
}
.set-player__meta{
  min-height:0;
  align-self:end;
}
.set-player__meta h3{
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
  max-height:4.05em;
  font-size:clamp(1.72rem,2.32vw,3.04rem);
  line-height:1.01;
  letter-spacing:-.055em;
  text-wrap:balance;
}
.set-player__meta p{
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  max-width:500px;
}
.set-player__spectrum{
  height:72px !important;
  min-height:72px !important;
  max-height:72px !important;
  overflow:hidden;
}
.set-player__timeline,
.set-player__controls,
.set-player__bottom{
  min-height:0;
}
.set-player__controls{
  height:74px;
  min-height:74px;
  align-items:center;
  overflow:visible;
}
.set-player__bottom{
  height:58px;
  min-height:58px;
}
.set-list{
  height:var(--player-height) !important;
  min-height:var(--player-height) !important;
  max-height:var(--player-height) !important;
  overflow-y:auto;
}
.set-track{
  min-height:104px;
  max-height:104px;
}
.set-track img{
  width:72px;
  height:72px;
  object-fit:cover;
  object-position:center;
}
.set-track__info b{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.soundcloud-widget{
  position:fixed !important;
  left:-9999px !important;
  top:-9999px !important;
  width:320px !important;
  height:166px !important;
  opacity:.001 !important;
  pointer-events:none !important;
  overflow:hidden !important;
}
@media (max-width:1240px){
  .set-player{--player-height:620px;}
  .set-player__main{grid-template-columns:minmax(260px,.82fr) minmax(0,1.18fr);}
  .set-player__meta h3{font-size:clamp(1.58rem,2.2vw,2.72rem);}
}
@media (max-width:1120px){
  .set-player{--player-height:auto;}
  .set-player__main{
    height:auto !important;
    min-height:0 !important;
    max-height:none !important;
  }
  .set-player__visual{
    height:520px !important;
    min-height:520px !important;
    max-height:520px !important;
  }
  .set-player__console{
    height:auto !important;
    min-height:520px !important;
    max-height:none !important;
  }
  .set-list{
    height:auto !important;
    min-height:0 !important;
    max-height:560px !important;
  }
}
@media (max-width:860px){
  .set-player__main{grid-template-columns:1fr;}
  .set-player__visual{
    height:430px !important;
    min-height:430px !important;
    max-height:430px !important;
  }
  .set-player__console{
    min-height:0 !important;
    grid-template-rows:auto 66px auto 66px auto;
  }
  .set-player__meta h3{
    -webkit-line-clamp:3;
    font-size:clamp(2rem,8vw,3.1rem);
  }
  .set-player__bottom{height:auto;min-height:0;}
}
@media (max-width:520px){
  .set-player__visual{
    height:330px !important;
    min-height:330px !important;
    max-height:330px !important;
  }
  .set-player__console{grid-template-rows:auto 58px auto 58px auto;}
  .set-player__meta h3{font-size:1.78rem;line-height:1.02;}
  .set-player__spectrum{height:58px !important;min-height:58px !important;max-height:58px !important;}
  .set-player__controls{height:58px;min-height:58px;}
  .set-track{min-height:82px;max-height:82px;}
}


/* === AJUSTE V15: lista scrollable y alturas fijas del reproductor === */
.set-player{
  --player-height: 690px;
  align-items: stretch;
}
.set-player__main,
.set-list{
  height: var(--player-height) !important;
  min-height: var(--player-height) !important;
  max-height: var(--player-height) !important;
}
.set-list{
  display: grid;
  grid-template-rows: auto minmax(0,1fr);
  overflow: hidden !important;
}
.set-list__head{
  position: relative;
  z-index: 2;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.set-list__scroll{
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  display: grid;
  align-content: start;
  gap: 14px;
  padding-right: 6px;
}
.set-list__scroll::-webkit-scrollbar{width:8px;}
.set-list__scroll::-webkit-scrollbar-track{background:rgba(255,255,255,.04);border-radius:999px;}
.set-list__scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg, rgba(127,255,232,.42), rgba(127,255,232,.16));border-radius:999px;border:1px solid rgba(255,255,255,.06);}
.set-list__scroll{scrollbar-width:thin;scrollbar-color:rgba(127,255,232,.42) rgba(255,255,255,.04);}
.set-track{margin:0;}

@media (max-width: 1240px){
  .set-player{--player-height: 650px;}
}
@media (max-width: 1120px){
  .set-player{--player-height: auto;}
  .set-player__main,
  .set-list{
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }
  .set-list{
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    max-height: 560px !important;
  }
  .set-list__scroll{
    max-height: 470px;
  }
}
@media (max-width: 860px){
  .set-list{
    max-height: 520px !important;
  }
  .set-list__scroll{
    max-height: 430px;
  }
}
@media (max-width: 520px){
  .set-list{
    max-height: 470px !important;
  }
  .set-list__scroll{
    max-height: 390px;
    gap: 10px;
    padding-right: 4px;
  }
}


/* === AJUSTE V16: playlist final con 6 sets, largo fijo y scroll estable === */
.set-list__scroll{
  padding-bottom: 4px;
}
.set-list__scroll .set-track:last-child{
  margin-bottom: 0;
}
.set-player__cover,
.set-track img{
  background: rgba(255,255,255,.03);
}
@media (min-width:1121px){
  .set-player__main,
  .set-list{
    height: var(--player-height) !important;
    min-height: var(--player-height) !important;
    max-height: var(--player-height) !important;
  }
}


/* === AJUSTE V17: Trayectoria limpia y espacios compactos === */
.lineup--compact{
  margin-top: clamp(34px, 5vw, 72px);
}
.lineup--compact .lineup__block{
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.18);
}
.lineup__names--single{
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  align-items: center;
  width: 100%;
}
.lineup__names--single b{
  font-size: clamp(1.42rem, 2.1vw, 2.45rem);
  line-height: .95;
  padding: 12px 16px 11px;
  letter-spacing: -.055em;
  white-space: nowrap;
}
@media (max-width: 980px){
  .lineup__names--single{
    flex-wrap: wrap;
    gap: 9px;
  }
  .lineup__names--single b{
    font-size: clamp(1.15rem, 5vw, 1.9rem);
    padding: 10px 12px;
  }
}
@media (max-width: 520px){
  .lineup--compact{margin-top: 34px;}
  .lineup--compact .lineup__block{padding-top: 18px;}
  .lineup__names--single{gap: 8px;}
  .lineup__names--single b{
    font-size: 1.02rem;
    padding: 9px 10px;
    letter-spacing: -.04em;
  }
}


/* === AJUSTE V18: En Vivo con video real, orden visual y modal profesional === */
.live__grid--video{
  grid-template-columns:1.25fr .88fr .88fr;
  gap:18px;
  align-items:stretch;
}
.live-card{
  cursor:pointer;
}
.live-card video,
.live-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.58) saturate(.98) contrast(1.04);
  transition:transform .85s cubic-bezier(.22,1,.36,1), filter .35s ease;
  z-index:-2;
}
.live-card--featured{
  min-height:610px;
}
.live-card--placeholder{
  min-height:610px;
}
.live-card:after{
  z-index:-1;
  background:
    linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.82)),
    radial-gradient(circle at 50% 46%,transparent 0 34%,rgba(0,0,0,.58) 100%),
    linear-gradient(90deg,rgba(127,255,232,.08),transparent 45%);
}
.live-card:before{
  z-index:4;
  color:var(--ink);
}
.live-card:hover video,
.live-card:hover img{
  transform:scale(1.055);
  filter:brightness(.78) saturate(1.08) contrast(1.08);
}
.live-card__tag{
  position:absolute !important;
  left:22px !important;
  top:22px !important;
  bottom:auto !important;
  font-family:var(--font-mono) !important;
  font-size:.66rem !important;
  letter-spacing:.12em !important;
  line-height:1 !important;
  color:var(--accent) !important;
  text-transform:uppercase !important;
  font-weight:700 !important;
  background:rgba(0,0,0,.34);
  border:1px solid rgba(127,255,232,.18);
  padding:9px 10px;
  backdrop-filter:blur(10px);
  z-index:3;
}
.live-card strong{
  position:absolute;
  left:22px;
  right:22px;
  bottom:52px;
  z-index:3;
  font-size:clamp(2rem,3.2vw,4.2rem);
  line-height:.92;
  text-transform:uppercase;
  letter-spacing:-.075em;
  color:var(--ink);
}
.live-card small{
  position:absolute;
  left:22px;
  right:22px;
  bottom:24px;
  z-index:3;
  font-family:var(--font-mono);
  font-size:.68rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(244,245,240,.68);
}
.live-card i{z-index:3;}
.modal__content--media video,
.modal__content--media img{
  width:100%;
  height:min(72vh,760px);
  object-fit:contain;
  background:#020403;
  filter:none;
  display:block;
}
.modal__content--media img{
  object-fit:cover;
  filter:brightness(.82);
}
@media (max-width:1080px){
  .live__grid--video{grid-template-columns:1fr;}
  .live-card--featured,
  .live-card--placeholder{min-height:520px;}
}
@media (max-width:520px){
  .live-card--featured,
  .live-card--placeholder{min-height:430px;}
  .live-card strong{font-size:2.25rem;bottom:50px;}
  .live-card__tag{left:16px !important;top:16px !important;font-size:.58rem !important;}
  .live-card i{right:16px;top:16px;}
  .live-card small{font-size:.58rem;}
  .modal__content--media video,
  .modal__content--media img{height:min(68vh,620px);}
}


/* === AJUSTE V19: segunda card de En Vivo con video real === */
.live-card--video .live-card__video{
  transform-origin:center center;
}
.live-card--video:nth-child(2) .live-card__video{
  object-position:center center;
}
.live-card--video:nth-child(2):hover .live-card__video{
  transform:scale(1.055);
}


/* === AJUSTE V20: En Vivo con 3 videos y encabezado más horizontal === */
.live .section-head{
  max-width:min(1180px, calc(100% - 48px));
}
.live .section-head h2{
  max-width:1120px;
  font-size:clamp(3.6rem, 6.7vw, 7.9rem);
  line-height:.9;
  letter-spacing:-.075em;
  text-wrap:balance;
}
.live .section-head p{
  max-width:760px;
}
.live__grid--video{
  grid-template-columns:repeat(3, minmax(0,1fr));
}
.live-card--video,
.live-card--featured,
.live-card--placeholder{
  min-height:560px;
}
.live-card--video:nth-child(3) .live-card__video{
  object-position:center center;
}
@media (max-width:1080px){
  .live .section-head{
    max-width:var(--container);
  }
  .live .section-head h2{
    font-size:clamp(3.4rem, 10vw, 6.5rem);
    max-width:900px;
  }
  .live__grid--video{grid-template-columns:1fr;}
  .live-card--video,
  .live-card--featured,
  .live-card--placeholder{min-height:520px;}
}
@media (max-width:520px){
  .live .section-head h2{
    font-size:clamp(2.65rem, 13vw, 4.1rem);
    line-height:.92;
  }
  .live-card--video,
  .live-card--featured,
  .live-card--placeholder{min-height:430px;}
}


/* === AJUSTE V21: sección Booking / Rider & Contacto rediseñada === */
.booking-kit{
  position:relative;
  overflow:hidden;
}
.booking-kit:before{
  content:"BOOKING";
  position:absolute;
  right:-4vw;
  top:8%;
  font-size:clamp(5rem,17vw,18rem);
  line-height:.8;
  font-weight:700;
  letter-spacing:-.08em;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.055);
  opacity:.75;
  pointer-events:none;
}
.booking-kit__grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(320px,.78fr) minmax(520px,1.22fr);
  gap:clamp(34px,5vw,78px);
  align-items:center;
}
.booking-kit__intro h2{
  max-width:760px;
  font-size:clamp(2.8rem,6vw,6.8rem);
  line-height:.88;
  letter-spacing:-.075em;
  margin-bottom:24px;
}
.booking-kit__intro p{
  max-width:590px;
  color:rgba(244,245,240,.72);
  margin-bottom:30px;
}
.booking-kit__intro p strong{color:var(--ink)}
.booking-kit__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
.booking-kit__cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.booking-info-card{
  position:relative;
  min-height:520px;
  display:flex;
  flex-direction:column;
  padding:clamp(22px,2.4vw,34px);
  border:1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(135deg,rgba(127,255,232,.055),transparent 42%),
    rgba(255,255,255,.032);
  box-shadow:0 28px 90px rgba(0,0,0,.28);
  overflow:hidden;
  isolation:isolate;
  transition:transform .35s ease,border-color .35s ease,background .35s ease,box-shadow .35s ease;
}
.booking-info-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 16%,rgba(127,255,232,.12),transparent 24%),
    linear-gradient(180deg,rgba(255,255,255,.05),transparent 30%);
  opacity:.85;
  z-index:-1;
  pointer-events:none;
}
.booking-info-card:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(127,255,232,.7),transparent);
  transform:translateX(-45%);
  opacity:.42;
  transition:transform .55s ease,opacity .35s ease;
}
.booking-info-card:hover{
  transform:translateY(-6px);
  border-color:rgba(127,255,232,.34);
  background:linear-gradient(135deg,rgba(127,255,232,.075),transparent 44%),rgba(255,255,255,.045);
  box-shadow:0 34px 110px rgba(0,0,0,.36);
}
.booking-info-card:hover:after{transform:translateX(45%);opacity:.8}
.booking-info-card__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding-bottom:20px;
  border-bottom:1px solid rgba(255,255,255,.095);
  margin-bottom:22px;
}
.booking-info-card__head span{
  font-family:var(--font-mono);
  color:var(--accent);
  font-size:.72rem;
  letter-spacing:.11em;
  padding-top:8px;
}
.booking-info-card__head h3{
  font-size:clamp(1.75rem,2.65vw,3.15rem);
  line-height:.92;
  letter-spacing:-.065em;
  text-transform:uppercase;
  text-align:right;
}
.booking-info-card p{
  color:rgba(244,245,240,.68);
  max-width:520px;
  margin-bottom:26px;
}
.rider-list{
  display:grid;
  gap:12px;
  margin-top:auto;
}
.rider-list div{
  display:grid;
  grid-template-columns:94px 1fr;
  gap:14px;
  align-items:center;
  padding:15px 0;
  border-top:1px solid rgba(255,255,255,.08);
}
.rider-list span{
  font-family:var(--font-mono);
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:.11em;
  font-size:.68rem;
}
.rider-list strong{
  color:var(--ink);
  font-size:1rem;
  line-height:1.25;
}
.booking-links{
  display:grid;
  gap:10px;
  margin-top:auto;
}
.booking-links a{
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  min-height:66px;
  padding:14px 16px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(3,6,5,.35);
  overflow:hidden;
  transition:transform .25s ease,border-color .25s ease,background .25s ease;
}
.booking-links a:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(127,255,232,.1),transparent 55%);
  opacity:0;
  transition:opacity .25s ease;
  pointer-events:none;
}
.booking-links a:hover{
  transform:translateX(4px);
  border-color:rgba(127,255,232,.38);
  background:rgba(127,255,232,.045);
}
.booking-links a:hover:before{opacity:1}
.booking-links span{
  position:relative;
  z-index:1;
  color:var(--ink);
  text-transform:uppercase;
  font-weight:700;
  letter-spacing:-.025em;
}
.booking-links i{
  position:relative;
  z-index:1;
  font-family:var(--font-mono);
  font-style:normal;
  font-size:.66rem;
  color:rgba(244,245,240,.56);
  text-transform:uppercase;
  letter-spacing:.08em;
  text-align:right;
}
.booking-info-card--contact{transform:translateY(34px)}
.booking-info-card--contact:hover{transform:translateY(28px)}
@media (max-width:1120px){
  .booking-kit__grid{grid-template-columns:1fr;align-items:start}
  .booking-kit__intro h2{max-width:940px}
  .booking-kit__cards{grid-template-columns:1fr 1fr}
  .booking-info-card--contact,.booking-info-card--contact:hover{transform:none}
  .booking-info-card{min-height:430px}
}
@media (max-width:760px){
  .booking-kit:before{top:3%;right:-20%;font-size:32vw}
  .booking-kit__grid{gap:28px}
  .booking-kit__intro h2{font-size:clamp(2.35rem,14vw,4.2rem);line-height:.9}
  .booking-kit__intro p{font-size:.98rem;margin-bottom:22px}
  .booking-kit__actions{display:grid;grid-template-columns:1fr;max-width:340px}
  .booking-kit__cards{grid-template-columns:1fr;gap:14px}
  .booking-info-card{min-height:0;padding:22px}
  .booking-info-card__head h3{text-align:left;font-size:2rem}
  .booking-info-card__head{align-items:center}
  .rider-list div{grid-template-columns:1fr;gap:6px;padding:12px 0}
  .booking-links a{min-height:58px;padding:12px 14px}
}
@media (max-width:460px){
  .booking-links a{display:grid;gap:3px;justify-content:stretch}
  .booking-links i{text-align:left}
}

/* === AJUSTE V22: Booking sin superposiciones y cards proporcionadas === */
@media (min-width:1121px){
  .booking-kit__grid{
    grid-template-columns:minmax(390px,.82fr) minmax(620px,1.18fr) !important;
    gap:clamp(72px,6.5vw,118px) !important;
    align-items:center;
  }
  .booking-kit__intro{
    max-width:560px;
    min-width:0;
  }
  .booking-kit__intro h2{
    max-width:540px !important;
    font-size:clamp(3.2rem,4.7vw,5.75rem) !important;
    line-height:.9 !important;
    letter-spacing:-.07em !important;
    overflow-wrap:normal;
  }
  .booking-kit__intro p{
    max-width:520px !important;
  }
  .booking-kit__cards{
    min-width:0;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
    gap:20px !important;
  }
}

.booking-info-card{
  min-width:0;
  overflow:hidden;
}
.booking-info-card__head{
  gap:14px !important;
}
.booking-info-card__head h3{
  max-width:100%;
  min-width:0;
  font-size:clamp(1.45rem,1.72vw,2.2rem) !important;
  line-height:.98 !important;
  letter-spacing:-.055em !important;
  text-wrap:balance;
  word-break:normal;
  overflow-wrap:normal;
}
.booking-info-card p{
  font-size:.98rem;
  line-height:1.62;
}
.rider-list div{
  grid-template-columns:82px minmax(0,1fr) !important;
}
.rider-list strong{
  min-width:0;
  font-size:.96rem !important;
}
.booking-links a{
  min-width:0;
  gap:10px !important;
}
.booking-links span,
.booking-links i{
  min-width:0;
}
.booking-links span{
  font-size:.92rem;
}
.booking-links i{
  font-size:.61rem !important;
}

@media (max-width:1360px) and (min-width:1121px){
  .booking-kit__grid{
    grid-template-columns:minmax(350px,.78fr) minmax(560px,1.22fr) !important;
    gap:72px !important;
  }
  .booking-kit__intro h2{
    font-size:clamp(3rem,4.25vw,5rem) !important;
    max-width:500px !important;
  }
  .booking-info-card{
    padding:26px !important;
  }
  .booking-info-card__head h3{
    font-size:clamp(1.35rem,1.55vw,1.92rem) !important;
  }
}

@media (max-width:1120px){
  .booking-kit__intro h2{
    max-width:820px !important;
    font-size:clamp(2.8rem,8vw,5.5rem) !important;
  }
  .booking-info-card__head h3{
    font-size:clamp(1.45rem,3.3vw,2.15rem) !important;
  }
}

@media (max-width:760px){
  .booking-kit__intro h2{
    font-size:clamp(2.15rem,12vw,3.7rem) !important;
    line-height:.92 !important;
  }
  .booking-info-card__head{
    align-items:flex-start !important;
  }
  .booking-info-card__head h3{
    font-size:1.75rem !important;
    text-align:left !important;
  }
}


/* === AJUSTE V23: Hospitality + contacto real sin romper estructura === */
@media (min-width:1121px){
  .booking-kit__grid{
    grid-template-columns:minmax(360px,.72fr) minmax(680px,1.28fr) !important;
    gap:clamp(64px,5.8vw,104px) !important;
    align-items:center;
  }
  .booking-kit__intro{
    max-width:540px;
  }
  .booking-kit__intro h2{
    max-width:520px !important;
  }
  .booking-kit__cards{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:18px !important;
    align-items:stretch;
  }
}
.booking-info-card{
  min-height:0 !important;
  padding:clamp(22px,2vw,30px) !important;
}
.booking-info-card--rider,
.booking-info-card--hospitality{
  min-height:430px !important;
}
.booking-info-card--contact{
  grid-column:1 / -1;
  transform:none !important;
  min-height:0 !important;
}
.booking-info-card--contact:hover{
  transform:translateY(-6px) !important;
}
.booking-info-card__head h3{
  font-size:clamp(1.32rem,1.55vw,2.05rem) !important;
  line-height:1 !important;
  max-width:260px;
}
.booking-info-card--contact .booking-info-card__head h3{
  max-width:360px;
}
.hospitality-list{
  display:grid;
  gap:10px;
  margin-top:auto;
}
.hospitality-list div{
  display:grid;
  grid-template-columns:38px minmax(0,1fr);
  gap:12px;
  align-items:center;
  padding:13px 0;
  border-top:1px solid rgba(255,255,255,.08);
}
.hospitality-list span{
  font-family:var(--font-mono);
  color:var(--accent);
  font-size:.64rem;
  letter-spacing:.11em;
}
.hospitality-list strong{
  color:var(--ink);
  font-size:.96rem;
  line-height:1.25;
  min-width:0;
}
.booking-info-card--contact .booking-links{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.booking-links a.is-disabled{
  opacity:.55;
  cursor:not-allowed;
  pointer-events:none;
}
.booking-links a.is-disabled:before{
  display:none;
}
@media (max-width:1360px) and (min-width:1121px){
  .booking-kit__grid{
    grid-template-columns:minmax(330px,.72fr) minmax(620px,1.28fr) !important;
    gap:60px !important;
  }
  .booking-info-card--rider,
  .booking-info-card--hospitality{
    min-height:410px !important;
  }
  .booking-info-card__head h3{
    font-size:clamp(1.25rem,1.45vw,1.82rem) !important;
  }
  .booking-info-card p{
    font-size:.94rem;
  }
}
@media (max-width:1120px){
  .booking-kit__cards{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .booking-info-card--contact{
    grid-column:1 / -1;
  }
  .booking-info-card--rider,
  .booking-info-card--hospitality{
    min-height:360px !important;
  }
}
@media (max-width:760px){
  .booking-kit__cards{
    grid-template-columns:1fr !important;
  }
  .booking-info-card--contact{
    grid-column:auto;
  }
  .booking-info-card--rider,
  .booking-info-card--hospitality{
    min-height:0 !important;
  }
  .booking-info-card--contact .booking-links{
    grid-template-columns:1fr;
  }
  .hospitality-list div{
    grid-template-columns:32px minmax(0,1fr);
    padding:11px 0;
  }
}

/* === AJUSTE V24: Booking rediseñado sin superposiciones === */
.booking-kit{
  min-height: auto !important;
  padding-top: clamp(96px, 10vw, 150px) !important;
  padding-bottom: clamp(96px, 10vw, 150px) !important;
}
.booking-kit__grid{
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(36px, 4.5vw, 64px) !important;
  align-items: start !important;
}
.booking-kit__intro{
  width: min(100%, 930px) !important;
  max-width: 930px !important;
  position: relative;
  z-index: 2;
}
.booking-kit__intro h2{
  max-width: 860px !important;
  font-size: clamp(3.2rem, 6.25vw, 7.35rem) !important;
  line-height: .86 !important;
  letter-spacing: -.078em !important;
  margin-bottom: 24px !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}
.booking-kit__intro p{
  max-width: 620px !important;
  font-size: 1rem !important;
  line-height: 1.68 !important;
  margin-bottom: 28px !important;
}
.booking-kit__cards{
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
  margin-top: 4px !important;
  position: relative !important;
  z-index: 3 !important;
}
.booking-info-card,
.booking-info-card--rider,
.booking-info-card--hospitality,
.booking-info-card--contact{
  grid-column: auto !important;
  min-height: 455px !important;
  height: auto !important;
  transform: none !important;
  padding: clamp(22px, 2vw, 30px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
.booking-info-card:hover,
.booking-info-card--contact:hover{
  transform: translateY(-6px) !important;
}
.booking-info-card__head{
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: start !important;
  justify-content: start !important;
  padding-bottom: 18px !important;
  margin-bottom: 20px !important;
}
.booking-info-card__head span{
  padding-top: .38em !important;
  white-space: nowrap !important;
}
.booking-info-card__head h3,
.booking-info-card--contact .booking-info-card__head h3{
  max-width: 100% !important;
  min-width: 0 !important;
  text-align: left !important;
  font-size: clamp(1.75rem, 2.05vw, 2.65rem) !important;
  line-height: .94 !important;
  letter-spacing: -.065em !important;
  text-wrap: balance !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}
.booking-info-card p{
  font-size: .96rem !important;
  line-height: 1.62 !important;
  max-width: 100% !important;
  margin-bottom: 22px !important;
}
.rider-list,
.hospitality-list,
.booking-links{
  margin-top: auto !important;
}
.rider-list div{
  grid-template-columns: 78px minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 13px 0 !important;
}
.rider-list span,
.hospitality-list span{
  font-size: .62rem !important;
}
.rider-list strong,
.hospitality-list strong{
  font-size: .92rem !important;
  line-height: 1.25 !important;
}
.hospitality-list div{
  grid-template-columns: 32px minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 13px 0 !important;
}
.booking-info-card--contact .booking-links,
.booking-links{
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}
.booking-links a{
  min-height: 58px !important;
  padding: 12px 14px !important;
  gap: 10px !important;
}
.booking-links span{
  font-size: .9rem !important;
}
.booking-links i{
  font-size: .58rem !important;
  line-height: 1.35 !important;
}
.booking-links a.is-disabled{
  pointer-events: auto !important;
  opacity: 1 !important;
  cursor: pointer !important;
}
@media (max-width: 1240px){
  .booking-kit__intro h2{
    font-size: clamp(3rem, 7vw, 6.2rem) !important;
    max-width: 760px !important;
  }
  .booking-kit__cards{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .booking-info-card--contact{
    grid-column: 1 / -1 !important;
    min-height: 0 !important;
  }
  .booking-info-card--contact .booking-links{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 760px){
  .booking-kit{
    padding-top: 86px !important;
    padding-bottom: 86px !important;
  }
  .booking-kit__grid{
    gap: 28px !important;
  }
  .booking-kit__intro h2{
    font-size: clamp(2.25rem, 12.4vw, 4rem) !important;
    line-height: .9 !important;
    max-width: 100% !important;
  }
  .booking-kit__intro p{
    font-size: .96rem !important;
  }
  .booking-kit__cards{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .booking-info-card,
  .booking-info-card--rider,
  .booking-info-card--hospitality,
  .booking-info-card--contact{
    grid-column: auto !important;
    min-height: 0 !important;
    padding: 22px !important;
  }
  .booking-info-card__head h3,
  .booking-info-card--contact .booking-info-card__head h3{
    font-size: 1.72rem !important;
    line-height: .98 !important;
  }
  .rider-list div,
  .hospitality-list div{
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }
  .booking-info-card--contact .booking-links{
    grid-template-columns: 1fr !important;
  }
}


/* === AJUSTE V25: cierre de contrataciones premium con iconos y jerarquía limpia === */
.contact--final{
  min-height: 100vh;
  padding: clamp(120px, 12vh, 170px) 0 clamp(90px, 10vh, 140px);
  overflow: hidden;
}
.contact--final .contact__overlay{
  background:
    linear-gradient(90deg, rgba(3,6,5,.96) 0%, rgba(3,6,5,.84) 43%, rgba(3,6,5,.58) 100%),
    radial-gradient(circle at 22% 62%, rgba(127,255,232,.12), transparent 32%),
    linear-gradient(180deg, rgba(3,6,5,.2), rgba(3,6,5,.78));
}
.contact__grid--final{
  display: grid;
  grid-template-columns: minmax(0, .98fr) minmax(420px, .82fr);
  gap: clamp(42px, 6vw, 92px);
  align-items: center;
}
.contact__copy--final{
  max-width: 780px;
}
.contact__copy--final h2{
  max-width: 820px;
  margin: 0 0 26px;
  font-size: clamp(3.3rem, 5.7vw, 6.55rem);
  line-height: .86;
  letter-spacing: -.075em;
  text-wrap: balance;
}
.contact__copy--final h2 span{
  color: var(--accent);
  display: inline-block;
}
.contact__copy--final p{
  max-width: 650px;
  font-size: clamp(1rem, 1vw, 1.12rem);
  line-height: 1.75;
}
.contact-direct{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 34px;
  max-width: 690px;
}
.contact-direct__item{
  min-height: 68px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 13px;
  align-items: center;
  padding: 13px 16px;
  border: 1px solid rgba(255,255,255,.13);
  background: linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  color: var(--ink);
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
  position: relative;
  overflow: hidden;
}
.contact-direct__item:before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, transparent, rgba(127,255,232,.09), transparent);
  transform: translateX(-100%);
  transition: transform .55s ease;
}
.contact-direct__item:hover{
  transform: translateY(-4px);
  border-color: rgba(127,255,232,.42);
  background: rgba(127,255,232,.045);
  box-shadow: 0 18px 45px rgba(0,0,0,.24);
}
.contact-direct__item:hover:before{transform: translateX(100%)}
.contact-direct__item--primary{
  background: linear-gradient(135deg, rgba(127,255,232,.17), rgba(255,255,255,.035));
  border-color: rgba(127,255,232,.34);
}
.contact-direct__icon{
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(127,255,232,.22);
  background: rgba(127,255,232,.055);
  position: relative;
  z-index: 1;
}
.contact-direct__icon svg{
  width: 22px;
  height: 22px;
  fill: var(--accent);
}
.contact-direct__item span:last-child{
  min-width: 0;
  position: relative;
  z-index: 1;
}
.contact-direct__item b,
.contact-direct__item i{
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.contact-direct__item b{
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: .95rem;
  letter-spacing: -.025em;
}
.contact-direct__item i{
  margin-top: 3px;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: .66rem;
  color: var(--soft);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.booking-form--premium{
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(255,255,255,.14);
  background:
    linear-gradient(180deg, rgba(127,255,232,.045), transparent 36%),
    rgba(3,6,5,.68);
  backdrop-filter: blur(18px);
  box-shadow: 0 28px 90px rgba(0,0,0,.34);
  display: grid;
  gap: 20px;
  position: relative;
}
.booking-form--premium:before{
  content:"";
  position:absolute;
  inset: 14px;
  border: 1px solid rgba(127,255,232,.065);
  pointer-events:none;
}
.booking-form__head{
  position: relative;
  z-index: 1;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.booking-form__head span{
  display: block;
  font-family: var(--font-display);
  color: var(--ink);
  font-size: clamp(1.55rem, 2vw, 2.25rem);
  line-height: .94;
  letter-spacing: -.055em;
  text-transform: uppercase;
}
.booking-form__head p{
  margin: 12px 0 0;
  color: var(--muted);
  line-height: 1.65;
  max-width: 470px;
}
.booking-form__fields{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
}
.booking-form--premium button,
.booking-form--premium small{
  position: relative;
  z-index: 1;
}
.booking-form--premium small a{
  color: var(--accent);
}
.booking-form--premium .btn{
  width: 100%;
}

@media (max-width: 1120px){
  .contact__grid--final{
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .contact__copy--final,
  .contact__copy--final h2,
  .contact__copy--final p,
  .contact-direct{
    max-width: 860px;
  }
  .booking-form--premium{
    max-width: 760px;
  }
}
@media (max-width: 720px){
  .contact--final{
    padding: 108px 0 84px;
  }
  .contact__copy--final h2{
    font-size: clamp(3.05rem, 15vw, 4.9rem);
    line-height: .9;
  }
  .contact-direct{
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .contact-direct__item{
    min-height: 62px;
  }
}
@media (max-width: 420px){
  .contact__copy--final h2{
    font-size: 2.76rem;
  }
  .contact-direct__item{
    grid-template-columns: 38px minmax(0, 1fr);
    padding: 12px;
  }
  .contact-direct__icon{
    width: 38px;
    height: 38px;
  }
  .booking-form--premium{
    padding: 20px;
  }
}


/* === AJUSTE V26: hero mobile con recorte vertical específico === */
@media (max-width: 720px){
  .hero{
    min-height: 100svh;
    height: 100svh;
    overflow: hidden;
  }
  .hero__img--main{
    content: url('../assets/hero-main-mobile.jpg');
    object-position: center center !important;
    transform: scale(1.01) !important;
    filter: saturate(1.02) contrast(1.04) brightness(.96) !important;
    animation: heroMobileDrift 14s ease-in-out infinite alternate;
  }
  .hero__img--flash{
    object-position: 50% 50%;
    opacity: 0;
  }
  .hero__vignette{
    background:
      linear-gradient(180deg, rgba(3,6,5,.46) 0%, rgba(3,6,5,.42) 28%, rgba(3,6,5,.72) 61%, rgba(3,6,5,.95) 100%),
      linear-gradient(90deg, rgba(3,6,5,.72) 0%, rgba(3,6,5,.24) 46%, rgba(3,6,5,.5) 100%),
      radial-gradient(circle at 54% 42%, rgba(127,255,232,.08), transparent 38%);
  }
  .hero__colorwash{
    opacity:.58;
    background:
      radial-gradient(circle at 64% 36%, rgba(127,255,232,.18), transparent 30%),
      radial-gradient(circle at 20% 26%, rgba(255,61,34,.12), transparent 22%);
  }
  .hero__content{
    width: calc(100% - 36px);
    margin-inline: 18px;
    padding-top: 118px;
  }
  .hero__logo{
    width: min(315px, 86vw);
    margin-bottom: 20px;
  }
  .hero__genres{
    font-size: .68rem;
    line-height: 1.55;
    margin-bottom: 24px;
  }
  .hero__statement{
    max-width: 340px;
    font-size: clamp(1.12rem, 5.6vw, 1.38rem);
    line-height: 1.06;
    margin-bottom: 32px;
  }
  .hero__actions{
    max-width: 100%;
    gap: 12px;
  }
  .hero__wave{
    bottom: 15%;
    height: 110px;
    opacity:.32;
  }
  .hero__scroll{
    bottom: 34px;
    right: 20px;
    opacity:.7;
  }
}
@keyframes heroMobileDrift{
  from{transform:scale(1.01) translate3d(0,0,0)}
  to{transform:scale(1.055) translate3d(-1.4%,.8%,0)}
}

/* === AJUSTE V27: hero mobile optimizado para que el DJ respire === */
@media (max-width: 720px){
  .hero{
    min-height: 100svh;
    height: 100svh;
    align-items: initial;
  }
  .hero__img--main{
    object-position: 52% 50% !important;
    transform: scale(1.015) !important;
    filter: saturate(1.02) contrast(1.04) brightness(1.02) !important;
  }
  .hero__vignette{
    background:
      linear-gradient(180deg, rgba(3,6,5,.38) 0%, rgba(3,6,5,.28) 26%, rgba(3,6,5,.54) 58%, rgba(3,6,5,.92) 100%),
      linear-gradient(90deg, rgba(3,6,5,.60) 0%, rgba(3,6,5,.18) 48%, rgba(3,6,5,.46) 100%),
      radial-gradient(circle at 52% 43%, rgba(127,255,232,.07), transparent 40%);
  }
  .hero__content{
    position:absolute;
    inset:0 18px;
    width:auto;
    margin:0;
    padding:0;
    z-index:5;
  }
  .hero__content .eyebrow{
    margin-top: clamp(172px, 23svh, 212px);
    margin-bottom: 13px;
    font-size:.68rem;
    letter-spacing:.15em;
  }
  .hero__logo{
    width:min(292px,78vw);
    margin:0 0 17px;
  }
  .hero__genres{
    max-width: 96%;
    font-size:.64rem;
    line-height:1.45;
    letter-spacing:.145em;
    margin:0;
  }
  .hero__statement{
    max-width: 338px;
    margin-top: clamp(58px, 8.4svh, 86px);
    margin-bottom: 22px;
    font-size: clamp(1.04rem, 5.05vw, 1.22rem);
    line-height:1.08;
    letter-spacing:-.035em;
  }
  .hero__actions{
    width:100%;
    max-width:100%;
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    margin-top: clamp(16px, 3svh, 30px);
  }
  .hero__actions .btn{
    min-height:52px;
    width:100%;
    justify-content:center;
  }
  .hero__wave{
    bottom: clamp(184px, 26svh, 228px);
    height:88px;
    opacity:.34;
    pointer-events:none;
  }
  .hero__scroll{
    display:none !important;
  }
}

@media (max-width: 390px){
  .hero__content .eyebrow{
    margin-top: 166px;
  }
  .hero__logo{
    width:min(270px,76vw);
    margin-bottom:15px;
  }
  .hero__statement{
    margin-top: 50px;
    font-size:1.02rem;
    max-width: 330px;
  }
  .hero__actions{
    gap:11px;
  }
  .hero__actions .btn{
    min-height:50px;
  }
}

/* === AJUSTE V28: hero mobile con lectura superior y CTA inferior === */
@media (max-width: 720px){
  .hero{
    min-height: 100svh !important;
    height: 100svh !important;
    overflow: hidden !important;
  }

  .hero__content{
    position: absolute !important;
    inset: 0 18px !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Bloque superior: identidad, sin bajar sobre el rostro */
  .hero__content .eyebrow{
    margin-top: clamp(118px, 15.5svh, 138px) !important;
    margin-bottom: 12px !important;
    font-size: .66rem !important;
    letter-spacing: .145em !important;
  }

  .hero__logo{
    width: min(272px, 73vw) !important;
    margin: 0 0 16px !important;
  }

  .hero__genres{
    max-width: 100% !important;
    margin: 0 !important;
    font-size: .60rem !important;
    line-height: 1.45 !important;
    letter-spacing: .13em !important;
    white-space: nowrap !important;
  }

  /* Bloque inferior: frase y botones cerca del borde sin tapar la figura */
  .hero__statement{
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: clamp(148px, 18svh, 168px) !important;
    max-width: 342px !important;
    margin: 0 !important;
    font-size: clamp(.98rem, 4.55vw, 1.13rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -.03em !important;
  }

  .hero__actions{
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: clamp(22px, 4.2svh, 38px) !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .hero__actions .btn{
    width: 100% !important;
    min-height: 52px !important;
    justify-content: center !important;
  }

  .hero__wave{
    bottom: clamp(228px, 31svh, 270px) !important;
    height: 88px !important;
    opacity: .32 !important;
    pointer-events: none !important;
  }

  .hero__scroll{
    display: none !important;
  }
}

@media (max-width: 390px){
  .hero__content .eyebrow{
    margin-top: 112px !important;
  }

  .hero__logo{
    width: min(248px, 70vw) !important;
    margin-bottom: 14px !important;
  }

  .hero__genres{
    font-size: .56rem !important;
    letter-spacing: .115em !important;
  }

  .hero__statement{
    bottom: 142px !important;
    font-size: .96rem !important;
    max-width: 330px !important;
  }

  .hero__actions{
    bottom: 20px !important;
    gap: 10px !important;
  }

  .hero__actions .btn{
    min-height: 50px !important;
  }

  .hero__wave{
    bottom: 214px !important;
  }
}

/* === AJUSTE V29: Hero mobile final — CTA más arriba, texto más legible y visual line más limpia === */
@media (max-width: 720px){
  .hero__logo{
    width: min(294px, 78vw) !important;
    margin-bottom: 16px !important;
  }

  .hero__statement{
    bottom: clamp(190px, 23.5svh, 214px) !important;
    max-width: 352px !important;
    font-size: clamp(1.06rem, 4.95vw, 1.22rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -.032em !important;
  }

  .hero__actions{
    bottom: clamp(50px, 7.2svh, 68px) !important;
    gap: 12px !important;
  }

  .hero__actions .btn{
    min-height: 52px !important;
  }

  .hero__wave{
    bottom: clamp(286px, 37svh, 326px) !important;
    height: 86px !important;
    opacity: .34 !important;
  }
}

@media (max-width: 390px){
  .hero__logo{
    width: min(266px, 76vw) !important;
    margin-bottom: 14px !important;
  }

  .hero__statement{
    bottom: 184px !important;
    max-width: 342px !important;
    font-size: 1.04rem !important;
    line-height: 1.075 !important;
  }

  .hero__actions{
    bottom: 46px !important;
    gap: 10px !important;
  }

  .hero__wave{
    bottom: 268px !important;
    height: 84px !important;
  }
}


/* === AJUSTE V30: menú mobile limpio, compacto y profesional === */
.menu-panel__brandmark{display:none}

@media (max-width: 760px){
  body.menu-open{overflow:hidden;}

  .menu-panel{
    z-index:85;
    padding:88px 20px 24px;
    justify-content:flex-start;
    gap:18px;
    overflow-y:auto;
    background:
      radial-gradient(circle at 80% 8%, rgba(127,255,232,.10), transparent 30%),
      radial-gradient(circle at 20% 82%, rgba(127,255,232,.055), transparent 34%),
      rgba(2,5,5,.972);
  }

  .menu-panel__top{
    justify-content:flex-end;
    min-height:18px;
    padding-right:42px;
    font-size:.62rem;
    letter-spacing:.16em;
    color:rgba(255,255,255,.48);
  }

  .menu-panel__top img{display:none!important;}

  .menu-panel__links{
    gap:6px;
    margin-top:4px;
  }

  .menu-panel__links a{
    display:grid;
    grid-template-columns:30px minmax(0,1fr);
    align-items:center;
    gap:0;
    width:100%;
    min-width:0;
    font-size:clamp(2rem, 8.6vw, 2.85rem)!important;
    line-height:.9;
    letter-spacing:-.058em;
    padding:10px 0 12px;
    border-bottom:1px solid rgba(255,255,255,.075);
    overflow:hidden;
    text-wrap:balance;
  }

  .menu-panel__links a[href="#contacto"]{
    font-size:clamp(1.75rem, 7.55vw, 2.45rem)!important;
    letter-spacing:-.06em;
  }

  .menu-panel__links span{
    width:24px;
    margin-right:0;
    font-size:.62rem;
    letter-spacing:.04em;
    align-self:center;
  }

  .menu-panel__foot{
    margin-top:auto;
    border-top:1px solid rgba(255,255,255,.09);
    padding-top:18px;
    justify-content:space-between;
    align-items:center;
  }

  .menu-panel__foot > a:not(.menu-panel__brandmark){display:none!important;}

  .menu-panel__brandmark{
    position:relative;
    display:flex!important;
    width:100%;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    padding:0;
    border:0;
    background:none;
    color:rgba(255,255,255,.52);
    text-decoration:none;
    transform:none!important;
  }

  .menu-panel__brandmark::before,
  .menu-panel__brandmark::after{display:none!important;}

  .menu-panel__brandmark img{
    display:block;
    width:112px;
    height:auto;
    filter:drop-shadow(0 0 12px rgba(255,255,255,.08));
  }

  .menu-panel__brandmark span{
    font-family:var(--font-mono);
    font-size:.58rem;
    line-height:1.35;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:rgba(255,255,255,.45);
    text-align:right;
  }
}

@media (max-width: 390px){
  .menu-panel{
    padding:82px 18px 22px;
    gap:14px;
  }

  .menu-panel__links a{
    font-size:clamp(1.85rem, 8.15vw, 2.45rem)!important;
    padding:9px 0 11px;
  }

  .menu-panel__links a[href="#contacto"]{
    font-size:clamp(1.58rem, 7vw, 2.1rem)!important;
  }

  .menu-panel__brandmark img{width:100px;}
}


/* === AJUSTE V31: menú mobile + sección Rider final === */
.menu-panel__close{
  position:absolute;
  top:18px;
  right:18px;
  width:46px;
  height:46px;
  z-index:3;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.035);
  color:rgba(255,255,255,.82);
  font-size:2rem;
  line-height:1;
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform .25s ease,border-color .25s ease,color .25s ease,background .25s ease;
}
.menu-panel__close:hover{
  transform:rotate(90deg);
  border-color:rgba(127,255,232,.42);
  color:var(--accent);
  background:rgba(127,255,232,.06);
}
.site-footer__credit{
  display:block;
  margin-top:-4px;
  font-family:var(--font-mono);
  font-size:.75rem!important;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45)!important;
}
.site-footer__credit a{
  color:rgba(127,255,232,.9);
  text-decoration:none;
  border-bottom:1px solid rgba(127,255,232,.35);
  transition:color .25s ease,border-color .25s ease;
}
.site-footer__credit a:hover{color:#fff;border-color:#fff;}

@media (min-width: 981px){
  .booking-kit__grid{
    grid-template-columns:minmax(310px, .82fr) minmax(560px, 1.18fr)!important;
    gap:clamp(54px,7vw,112px)!important;
    align-items:center!important;
  }
  .booking-kit__intro{
    max-width:560px!important;
    transform:none!important;
  }
  .booking-kit__intro h2{
    max-width:520px!important;
    font-size:clamp(5rem,9.4vw,10.4rem)!important;
    line-height:.82!important;
    letter-spacing:-.075em!important;
    white-space:normal!important;
  }
  .booking-kit__intro p{max-width:470px!important;}
  .booking-kit__cards{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:clamp(18px,2vw,28px)!important;
    align-items:stretch!important;
    margin-top:clamp(34px,4vw,64px)!important;
  }
  .booking-info-card--rider,
  .booking-info-card--hospitality{
    min-height:520px!important;
  }
}
.booking-info-card--contact{display:none!important;}
.booking-info-card,
.booking-info-card--rider,
.booking-info-card--hospitality{
  overflow:hidden!important;
  isolation:isolate;
}
.booking-info-card__head{
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr)!important;
  gap:16px!important;
  align-items:start!important;
}
.booking-info-card__head h3{
  min-width:0!important;
  max-width:100%!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  hyphens:none!important;
  font-size:clamp(1.95rem,3.1vw,3.25rem)!important;
  line-height:.88!important;
  letter-spacing:-.06em!important;
}
.booking-info-card p{
  max-width:100%!important;
  font-size:clamp(.9rem,1.1vw,1rem)!important;
  line-height:1.62!important;
}
.rider-list div,
.hospitality-list div{
  grid-template-columns:minmax(72px,.48fr) minmax(0,1fr)!important;
  gap:18px!important;
  align-items:center!important;
}
.rider-list strong,
.hospitality-list strong{
  min-width:0!important;
  font-size:clamp(.86rem,1.05vw,.98rem)!important;
  line-height:1.24!important;
}

@media (max-width: 980px){
  .menu-panel__close{display:flex;}
  .menu-toggle.is-open{opacity:0;pointer-events:none;}
  .menu-panel{padding-top:88px!important;}
  .menu-panel__links a{font-size:clamp(1.85rem,9.2vw,3.05rem)!important;line-height:.94!important;letter-spacing:-.055em!important;}
  .booking-kit__grid{grid-template-columns:1fr!important;gap:34px!important;}
  .booking-kit__intro h2{font-size:clamp(4.8rem,22vw,8.6rem)!important;line-height:.78!important;}
  .booking-kit__cards{display:grid!important;grid-template-columns:1fr!important;gap:16px!important;margin-top:0!important;}
  .booking-info-card{min-height:0!important;}
  .booking-info-card__head h3{font-size:clamp(1.9rem,8.5vw,3rem)!important;}
}
@media (max-width: 520px){
  .menu-panel__close{top:14px;right:14px;width:42px;height:42px;font-size:1.8rem;}
  .menu-panel__links{gap:8px!important;}
  .menu-panel__links a{font-size:clamp(1.65rem,8.4vw,2.3rem)!important;padding-bottom:10px!important;}
  .menu-panel__links span{font-size:.66rem!important;margin-right:10px!important;}
  .menu-panel__foot{padding-top:16px!important;}
  .booking-info-card{padding:22px!important;}
  .rider-list div,.hospitality-list div{grid-template-columns:1fr!important;gap:6px!important;}
  .rider-list span,.hospitality-list span{font-size:.66rem!important;}
}


/* === AJUSTE V33 SAFE: Rider desktop estable, sin romper el resto === */
@media (min-width: 1181px){
  #kit.booking-kit{
    padding-top: clamp(118px, 9vw, 165px) !important;
    padding-bottom: clamp(118px, 9vw, 165px) !important;
    overflow: hidden !important;
  }

  #kit .booking-kit__grid{
    width: min(100% - 64px, 1180px) !important;
    margin-inline: auto !important;
    display: grid !important;
    grid-template-columns: minmax(320px, 430px) minmax(0, 720px) !important;
    gap: clamp(58px, 5.5vw, 92px) !important;
    align-items: center !important;
  }

  #kit .booking-kit__intro{
    width: 100% !important;
    max-width: 430px !important;
    min-width: 0 !important;
    position: relative !important;
    z-index: 2 !important;
  }

  #kit .booking-kit__intro h2{
    width: 100% !important;
    max-width: 430px !important;
    font-size: clamp(4.8rem, 6.1vw, 7.25rem) !important;
    line-height: .82 !important;
    letter-spacing: -.078em !important;
    margin: 0 0 24px !important;
    white-space: normal !important;
    overflow: visible !important;
    transform: none !important;
  }

  #kit .booking-kit__intro p{
    max-width: 390px !important;
    font-size: .98rem !important;
    line-height: 1.62 !important;
    margin-bottom: 28px !important;
  }

  #kit .booking-kit__actions{
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
  }

  #kit .booking-kit__cards{
    width: 100% !important;
    max-width: 720px !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin: 0 !important;
    position: relative !important;
    z-index: 3 !important;
  }

  #kit .booking-info-card,
  #kit .booking-info-card--rider,
  #kit .booking-info-card--hospitality{
    width: 100% !important;
    min-width: 0 !important;
    min-height: 470px !important;
    height: auto !important;
    padding: 30px 28px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    transform: none !important;
  }

  #kit .booking-info-card:hover{
    transform: translateY(-5px) !important;
  }

  #kit .booking-info-card__head{
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 16px !important;
    align-items: start !important;
    justify-content: start !important;
    padding-bottom: 18px !important;
    margin-bottom: 20px !important;
  }

  #kit .booking-info-card__head span{
    padding-top: .35em !important;
    white-space: nowrap !important;
  }

  #kit .booking-info-card__head h3{
    min-width: 0 !important;
    max-width: 100% !important;
    font-size: clamp(1.85rem, 2.05vw, 2.55rem) !important;
    line-height: .92 !important;
    letter-spacing: -.06em !important;
    text-align: left !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }

  #kit .booking-info-card p{
    max-width: 100% !important;
    font-size: .95rem !important;
    line-height: 1.58 !important;
    margin-bottom: 22px !important;
  }

  #kit .rider-list,
  #kit .hospitality-list{
    margin-top: auto !important;
    width: 100% !important;
  }

  #kit .rider-list div,
  #kit .hospitality-list div{
    display: grid !important;
    grid-template-columns: 78px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: center !important;
    padding: 13px 0 !important;
  }

  #kit .rider-list span,
  #kit .hospitality-list span{
    font-size: .61rem !important;
    letter-spacing: .1em !important;
    white-space: nowrap !important;
  }

  #kit .rider-list strong,
  #kit .hospitality-list strong{
    min-width: 0 !important;
    font-size: .92rem !important;
    line-height: 1.22 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  #kit .booking-info-card--contact{
    display: none !important;
  }
}

@media (min-width: 1181px) and (max-width: 1440px){
  #kit .booking-kit__grid{
    width: min(100% - 54px, 1080px) !important;
    grid-template-columns: minmax(300px, 400px) minmax(0, 650px) !important;
    gap: 56px !important;
  }

  #kit .booking-kit__intro h2{
    font-size: clamp(4.25rem, 5.7vw, 6.4rem) !important;
    max-width: 400px !important;
  }

  #kit .booking-kit__intro p{
    max-width: 360px !important;
    font-size: .93rem !important;
  }

  #kit .booking-kit__cards{
    max-width: 650px !important;
    gap: 18px !important;
  }

  #kit .booking-info-card,
  #kit .booking-info-card--rider,
  #kit .booking-info-card--hospitality{
    min-height: 440px !important;
    padding: 26px 24px !important;
  }

  #kit .booking-info-card__head h3{
    font-size: clamp(1.62rem, 1.9vw, 2.25rem) !important;
  }

  #kit .booking-info-card p{
    font-size: .9rem !important;
  }

  #kit .rider-list div,
  #kit .hospitality-list div{
    grid-template-columns: 70px minmax(0, 1fr) !important;
    gap: 12px !important;
  }

  #kit .rider-list strong,
  #kit .hospitality-list strong{
    font-size: .86rem !important;
  }
}

/* Tablet/mobile: apilar sin deformar */
@media (max-width: 1180px){
  #kit .booking-kit__grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 34px !important;
    align-items: start !important;
  }

  #kit .booking-kit__intro{
    max-width: 760px !important;
  }

  #kit .booking-kit__intro h2{
    max-width: 720px !important;
    font-size: clamp(3.3rem, 11vw, 6rem) !important;
    line-height: .86 !important;
  }

  #kit .booking-kit__cards{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
    margin-top: 0 !important;
  }

  #kit .booking-info-card--contact{
    display: none !important;
  }

  #kit .booking-info-card__head h3{
    font-size: clamp(1.65rem, 4vw, 2.35rem) !important;
    text-align: left !important;
  }
}

@media (max-width: 760px){
  #kit .booking-kit__cards{
    grid-template-columns: 1fr !important;
  }

  #kit .booking-info-card,
  #kit .booking-info-card--rider,
  #kit .booking-info-card--hospitality{
    min-height: 0 !important;
    padding: 24px 22px !important;
  }

  #kit .rider-list div,
  #kit .hospitality-list div{
    grid-template-columns: 68px minmax(0, 1fr) !important;
  }

  #kit .rider-list strong,
  #kit .hospitality-list strong{
    font-size: .9rem !important;
  }
}


/* === AJUSTE V34: botón del formulario + email centrado === */
#contacto .booking-form .btn,
#contacto .booking-form button[type="submit"]{
  width:100% !important;
  justify-content:center !important;
}

#contacto .booking-form .btn--primary,
#contacto .booking-form button[type="submit"].btn--primary{
  background:
    linear-gradient(135deg, rgba(127,255,232,.96), rgba(46,212,203,.88) 45%, rgba(127,255,232,.72)) !important;
  color:#020403 !important;
  border:1px solid rgba(127,255,232,.7) !important;
  box-shadow:
    0 0 0 1px rgba(127,255,232,.12) inset,
    0 18px 55px rgba(127,255,232,.18),
    0 8px 24px rgba(0,0,0,.32) !important;
  position:relative !important;
  overflow:hidden !important;
}

#contacto .booking-form .btn--primary:before,
#contacto .booking-form button[type="submit"].btn--primary:before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent) !important;
  transform:translateX(-120%) !important;
  transition:transform .55s ease !important;
  pointer-events:none !important;
}

#contacto .booking-form .btn--primary:hover,
#contacto .booking-form button[type="submit"].btn--primary:hover{
  transform:translateY(-2px) !important;
  border-color:rgba(255,255,255,.72) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.16) inset,
    0 24px 70px rgba(127,255,232,.26),
    0 10px 28px rgba(0,0,0,.38) !important;
}

#contacto .booking-form .btn--primary:hover:before,
#contacto .booking-form button[type="submit"].btn--primary:hover:before{
  transform:translateX(120%) !important;
}

#contacto .booking-form .btn--primary span,
#contacto .booking-form button[type="submit"].btn--primary span{
  position:relative !important;
  z-index:1 !important;
  color:#020403 !important;
}

#contacto .booking-form small{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  text-align:center !important;
  margin:2px auto 0 !important;
  color:rgba(244,245,240,.56) !important;
}

#contacto .booking-form small a{
  color:rgba(127,255,232,.92) !important;
  text-decoration:none !important;
  border-bottom:1px solid rgba(127,255,232,.35) !important;
}

#contacto .booking-form small a:hover{
  color:#fff !important;
  border-color:#fff !important;
}

@media (max-width:760px){
  #contacto .booking-form small{
    font-size:.64rem !important;
    line-height:1.55 !important;
    padding-inline:8px !important;
  }
}


/* === AJUSTE V37: Trayectoria con artistas compartidos === */
.lineup--compact{
  display:grid;
  gap:clamp(26px,3vw,38px);
}
.lineup__block--artists{
  padding-top:clamp(24px,3vw,34px);
  border-top:1px solid rgba(255,255,255,.16);
}
.lineup__note{
  max-width:720px;
  margin:10px 0 18px;
  color:rgba(244,245,240,.58);
  font-size:.98rem;
  line-height:1.55;
}
.lineup__names--artists{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.lineup__names--artists b{
  font-size:clamp(1.05rem,1.35vw,1.58rem);
  line-height:1;
  padding:11px 14px 10px;
  letter-spacing:-.045em;
  white-space:nowrap;
  background:
    linear-gradient(135deg,rgba(127,255,232,.04),transparent 58%),
    rgba(255,255,255,.026);
  border-color:rgba(255,255,255,.12);
  transition:transform .28s ease,border-color .28s ease,background .28s ease,color .28s ease;
}
.lineup__names--artists b:hover{
  transform:translateY(-3px);
  border-color:rgba(127,255,232,.34);
  background:linear-gradient(135deg,rgba(127,255,232,.07),transparent 62%),rgba(255,255,255,.038);
  color:#fff;
}
@media (max-width:760px){
  .lineup__note{
    font-size:.9rem;
    margin-bottom:16px;
  }
  .lineup__names--artists{
    gap:8px;
  }
  .lineup__names--artists b{
    font-size:.98rem;
    padding:9px 10px;
    white-space:normal;
  }
}
