/* ============================================================
   KARMA UNTIL TOMORROW — shared design system
   Strictly black & white. Rock / Metal / Electro.
   ============================================================ */

:root{
  --ink:        #000000;
  --ink-1:      #060606;
  --ink-2:      #0c0c0c;
  --ink-3:      #161616;
  --paper:      #f3f1ec;
  --paper-2:    #ffffff;
  --dim:   rgba(243,241,236,.62);
  --faint: rgba(243,241,236,.34);
  --ghost: rgba(243,241,236,.14);
  --hair:  rgba(243,241,236,.10);

  --f-display: 'Oswald', 'Saira Condensed', sans-serif;
  --f-body:    'Barlow', system-ui, sans-serif;
  --f-mono:    'Space Mono', ui-monospace, monospace;

  --drips: 1;
  --glitch: 1;
  --shroud: .68;

  --edge: 1px solid var(--ghost);
  --pad: clamp(20px, 5vw, 92px);
  --maxw: 1360px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--ink); color:var(--paper);
  font-family:var(--f-body); font-weight:300; line-height:1.55;
  letter-spacing:.01em; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
::selection{ background:var(--paper); color:#000; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }

/* ---------- global grain + vignette ---------- */
.fx-grain{
  position:fixed; inset:0; z-index:60; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:170px 170px;
  mix-blend-mode:overlay; opacity:.38;
}
.fx-vignette{
  position:fixed; inset:0; z-index:59; pointer-events:none;
  background:radial-gradient(130% 120% at 50% 42%, transparent 52%, rgba(0,0,0,.55) 100%);
}

/* ---------- loader (logo animation — only surfaces on a slow load) ---------- */
.loader{
  position:fixed; inset:0; z-index:1000; background:var(--ink);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.loader__vid{
  width:100%; height:100%;
  object-fit:cover;          /* remplit tout l'écran, sans déformation */
  opacity:0; transition:opacity .45s ease;
}
.loader.is-visible .loader__vid{ opacity:1; }
.loader.is-done{ opacity:0; pointer-events:none; transition:opacity .6s ease; }

.matter{ position:relative; }
.matter::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.011' numOctaves='3' seed='7'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23c)'/%3E%3C/svg%3E");
  background-size:cover; opacity:.06; mix-blend-mode:screen;
}
.matter > *{ position:relative; z-index:1; }

/* ---------- shared bits ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.eyebrow{
  font-family:var(--f-mono); font-weight:400; font-size:12px;
  letter-spacing:.42em; text-transform:uppercase; color:var(--faint);
  display:inline-flex; align-items:center; gap:14px;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--ghost); }
.display{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  line-height:.9; letter-spacing:.005em; margin:0;
}
.btn{
  --bg:var(--paper); --fg:#000;
  display:inline-flex; align-items:center; gap:.8em;
  font-family:var(--f-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.14em; font-size:14px; line-height:1;
  padding:17px 26px; background:var(--bg); color:var(--fg); white-space:nowrap;
  border:1px solid var(--bg); position:relative; overflow:hidden;
  transition:color .35s, background .35s, transform .25s;
}
.btn .arw{ transition:transform .35s; }
.btn:hover .arw{ transform:translateX(5px); }
.btn:active{ transform:translateY(1px); }
.btn--ghost{ --bg:transparent; --fg:var(--paper); border-color:var(--ghost); }
.btn--ghost::after{
  content:""; position:absolute; inset:0; background:var(--paper);
  transform:translateY(101%); transition:transform .4s cubic-bezier(.2,.7,.2,1); z-index:-1;
}
.btn--ghost:hover{ color:#000; border-color:var(--paper); }
.btn--ghost:hover::after{ transform:translateY(0); }

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(0,0,0,.55); backdrop-filter:blur(10px) saturate(0);
  border-bottom:1px solid var(--ghost);
  transition:background .4s, border-color .4s;
}
.hdr.is-top{ background:rgba(0,0,0,0); border-color:transparent; }
.hdr__in{
  max-width:var(--maxw); margin-inline:auto; padding:0 var(--pad);
  height:74px; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{ display:flex; align-items:center; gap:13px; }
.brand__k{ width:38px; height:38px; display:block; }
.brand__txt{
  font-family:var(--f-display); font-weight:600; text-transform:uppercase;
  font-size:13px; letter-spacing:.26em; line-height:1.05; color:var(--paper);
}
.brand__txt small{ display:block; font-size:9px; letter-spacing:.4em; color:var(--faint); font-weight:400; }

.nav{ display:flex; align-items:center; gap:clamp(16px,2vw,34px); }
.nav__link{
  position:relative; font-family:var(--f-display); font-weight:500;
  text-transform:uppercase; font-size:14px; letter-spacing:.16em;
  color:var(--dim); padding:6px 0; transition:color .3s; white-space:nowrap;
}
.nav__link::after{
  content:""; position:absolute; left:0; bottom:0; height:1.5px; width:100%;
  background:var(--paper); transform:scaleX(0); transform-origin:left; transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.nav__link:hover{ color:var(--paper); }
.nav__link:hover::after{ transform:scaleX(1); }
.nav__link.is-active{ color:var(--paper); }
.nav__link.is-active::after{ transform:scaleX(1); }

.burger{
  display:none; width:42px; height:42px; align-items:center; justify-content:center; flex-direction:column; gap:6px;
}
.burger span{ width:24px; height:2px; background:var(--paper); transition:transform .3s, opacity .3s; }
.burger.is-open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

.sheet{
  position:fixed; inset:0; z-index:49; background:#000;
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:6px;
  opacity:0; pointer-events:none; transform:translateY(-2%);
  transition:opacity .4s, transform .4s;
}
.sheet.is-open{ opacity:1; pointer-events:auto; transform:none; }
.sheet a{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(34px,9vw,64px); letter-spacing:.02em; color:var(--paper); line-height:1.15;
  opacity:.85; transition:opacity .25s, letter-spacing .25s;
}
.sheet a:hover{ opacity:1; letter-spacing:.06em; }
.sheet__cd{ margin-top:30px; }
.sheet__meta{ position:absolute; bottom:34px; font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); }

/* ============================================================
   COUNTDOWN (replaces "Billetterie")
   ============================================================ */
.cd{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--ghost); padding:8px 12px;
  font-family:var(--f-mono); color:var(--paper); position:relative;
  transition:border-color .3s, background .3s;
}
.cd:hover{ border-color:var(--paper); }
.cd__pulse{ width:7px; height:7px; background:var(--paper); border-radius:50%; animation:pulse 1.4s ease-in-out infinite; flex:none; }
.cd__label{ font-size:10px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; white-space:nowrap; }
.cd__grid{ display:inline-flex; gap:6px; }
.cd__cell{ display:inline-flex; flex-direction:column; align-items:center; min-width:30px; }
.cd__num{ font-family:var(--f-display); font-weight:700; font-size:18px; line-height:1; letter-spacing:.02em; color:var(--paper); font-variant-numeric:tabular-nums; }
.cd__unit{ font-size:8px; letter-spacing:.24em; color:var(--faint); text-transform:uppercase; margin-top:3px; }
.cd--past .cd__pulse{ animation:none; background:var(--faint); }
.cd--past .cd__num{ color:var(--dim); }

/* large variant for hero / section embed */
.cd--lg{ padding:18px 22px; gap:18px; border-width:1px; }
.cd--lg .cd__label{ font-size:11px; }
.cd--lg .cd__cell{ min-width:60px; }
.cd--lg .cd__num{ font-size:clamp(40px,5vw,68px); }
.cd--lg .cd__unit{ font-size:10px; letter-spacing:.32em; margin-top:8px; }
.cd--lg .cd__sep{ font-family:var(--f-display); font-weight:300; font-size:clamp(36px,4.5vw,60px); color:var(--faint); align-self:flex-start; line-height:1; }

@keyframes pulse{ 50%{ opacity:.35; transform:scale(.9) } }

/* ============================================================
   HERO (shared base)
   ============================================================ */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; align-items:center; text-align:center; overflow:hidden;
  padding:120px var(--pad) 90px;
  /* own compositing context → fixes repaint glitches when scrolling back up */
  isolation:isolate; transform:translateZ(0);
}
.hero--short{ min-height:78svh; }
.hero__media{
  position:absolute; inset:0; z-index:0; background:#040404; overflow:hidden;
  transform:translateZ(0); backface-visibility:hidden;
}
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='h'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.006 0.018' numOctaves='3' seed='3'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23h)'/%3E%3C/svg%3E");
  background-size:cover; opacity:.5; mix-blend-mode:screen;
  animation:heroZoom 26s ease-in-out infinite alternate; pointer-events:none;
}
/* real video hero — kills the SVG flicker, shows the actual reel */
.hero__media.has-video::after{ opacity:.15; mix-blend-mode:overlay; }
.hero__video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.1) brightness(.78);
}
/* real photo hero — keeps real colors, just a subtle dark for legibility */
.hero__media.has-photo::after{ opacity:.18; mix-blend-mode:overlay; }
.hero__photo{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  /* NO grayscale — show real photo */
}
/* photo-style hero media (B&W placeholder, used only when no real photo) */
.hero__media--photo{
  background:
    radial-gradient(120% 90% at 30% 30%, rgba(243,241,236,.10), transparent 55%),
    radial-gradient(80% 60% at 80% 70%, rgba(243,241,236,.07), transparent 60%),
    linear-gradient(180deg, #0a0a0a 0%, #050505 60%, #000 100%);
}
.hero__media--photo::before{
  content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='800'%3E%3Cfilter id='ph'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ph)' opacity='.4'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:.7;
}
@keyframes heroZoom{ from{ transform:scale(1.04) translate(0,0) } to{ transform:scale(1.2) translate(-1%,-2%) } }
.hero__shroud{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.55) 0%, rgba(0,0,0,.20) 32%, rgba(0,0,0,.40) 64%, #000 100%),
    radial-gradient(120% 90% at 50% 45%, transparent 30%, rgba(0,0,0,calc(var(--shroud))) 100%);
}
.hero__playwrap{ position:absolute; inset:0; z-index:2; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.playbtn{
  width:96px; height:96px; border:1.5px solid rgba(243,241,236,.5); border-radius:50%;
  display:flex; align-items:center; justify-content:center; backdrop-filter:blur(2px);
  opacity:.0; transition:opacity .5s, transform .4s, border-color .3s; transform:scale(.9);
  pointer-events:auto;
}
.hero:hover .playbtn{ opacity:.85; transform:scale(1); }
.playbtn:hover{ border-color:var(--paper); }
.playbtn::before{ content:""; width:0; height:0; margin-left:6px;
  border-left:20px solid var(--paper); border-top:13px solid transparent; border-bottom:13px solid transparent; }

.hero__content{ position:relative; z-index:3; display:flex; flex-direction:column; align-items:center; gap:30px; }
.hero__logo{ width:min(560px,82vw); filter:drop-shadow(0 18px 60px rgba(0,0,0,.8)); }
.hero__tag{
  font-family:var(--f-mono); font-size:clamp(11px,1.5vw,14px); letter-spacing:.5em;
  text-transform:uppercase; color:var(--dim); display:flex; align-items:center; gap:16px;
}
.hero__tag i{ width:6px; height:6px; background:var(--paper); display:block; transform:rotate(45deg); }
.hero__actions{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; align-items:center; }

.hero__title{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(64px,14vw,220px); line-height:.85; letter-spacing:-.01em; margin:0;
  text-shadow:0 18px 60px rgba(0,0,0,.8);
}
.hero__subtitle{
  font-family:var(--f-mono); font-size:clamp(11px,1.4vw,13px); letter-spacing:.45em;
  text-transform:uppercase; color:var(--dim); max-width:54ch;
}

.hero__corner{
  position:absolute; z-index:3; font-family:var(--f-mono); font-size:11px;
  letter-spacing:.28em; color:var(--faint); text-transform:uppercase;
}
.hero__corner.tl{ top:96px; left:var(--pad); }
.hero__corner.tr{ top:96px; right:var(--pad); text-align:right; }
.hero__scroll{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.34em; color:var(--faint);
  display:flex; flex-direction:column; align-items:center; gap:10px; text-transform:uppercase;
}
.hero__scroll .ln{ width:1px; height:46px; background:linear-gradient(var(--ghost),transparent); position:relative; overflow:hidden; }
.hero__scroll .ln::after{ content:""; position:absolute; top:-40%; left:0; width:100%; height:40%; background:var(--paper); animation:scrolln 2.2s cubic-bezier(.7,0,.3,1) infinite; }
@keyframes scrolln{ to{ top:120% } }

/* ---------- ink drips ---------- */
.drip-edge{ position:relative; height:0; z-index:5; }
.drip{
  position:absolute; top:-1px; width:2px; background:var(--paper);
  opacity:calc(.5 * var(--drips)); transform-origin:top;
}
.drip::after{
  content:""; position:absolute; left:50%; bottom:-4px; width:6px; height:6px;
  background:var(--paper); border-radius:50%; transform:translateX(-50%);
}

/* ============================================================
   NEXT DATE (home)
   ============================================================ */
.next{ position:relative; background:var(--ink); border-top:1px solid var(--ghost); padding:clamp(70px,9vw,140px) 0; overflow:hidden; }
.next__ghost{
  position:absolute; right:-4%; top:50%; transform:translateY(-50%);
  font-family:var(--f-display); font-weight:700; font-size:min(40vw,560px);
  line-height:.7; color:var(--paper-2); opacity:.035; pointer-events:none; user-select:none; letter-spacing:-.02em;
}
.next__grid{ display:grid; grid-template-columns:minmax(0,1fr) auto; gap:48px; align-items:end; }
.next__head{ margin-bottom:clamp(44px,5vw,64px); display:flex; align-items:baseline; gap:22px; flex-wrap:wrap; }
.next__head h2{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(26px,3.4vw,46px); margin:0; letter-spacing:.01em; white-space:nowrap; }
.next__index{ font-family:var(--f-mono); font-size:12px; letter-spacing:.3em; color:var(--faint); }
.next__date{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(58px,12vw,168px); line-height:.82; letter-spacing:-.01em; margin:0;
  display:flex; align-items:flex-start; gap:.12em; flex-wrap:wrap;
}
.next__date .sep{ color:var(--faint); font-weight:300; }
.next__meta{ margin-top:30px; display:flex; flex-wrap:wrap; gap:34px 56px; align-items:flex-end; }
.next__meta .field .k{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; display:block; margin-bottom:8px; }
.next__meta .field .v{ font-family:var(--f-display); font-weight:600; text-transform:uppercase; font-size:clamp(18px,2vw,26px); letter-spacing:.05em; }
.next__cta{ display:flex; flex-direction:column; gap:18px; align-items:flex-start; }
.next__note{ font-family:var(--f-mono); font-size:11px; letter-spacing:.22em; color:var(--faint); text-transform:uppercase; }
.next__all{ font-family:var(--f-display); font-weight:500; text-transform:uppercase; letter-spacing:.16em; font-size:14px; color:var(--dim); display:inline-flex; gap:.6em; align-items:center; transition:color .3s, gap .3s; }
.next__all:hover{ color:var(--paper); gap:1em; }

.marquee{ border-block:1px solid var(--ghost); overflow:hidden; white-space:nowrap; padding:18px 0; margin-top:clamp(50px,7vw,96px); }
.marquee__track{ display:inline-flex; gap:46px; animation:marq 24s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee span{ font-family:var(--f-display); font-weight:600; text-transform:uppercase; font-size:clamp(16px,2.2vw,30px); letter-spacing:.08em; color:var(--dim); display:inline-flex; align-items:center; gap:46px; }
.marquee span::after{ content:""; width:9px; height:9px; background:var(--paper); transform:rotate(45deg); display:inline-block; }
@keyframes marq{ to{ transform:translateX(-50%) } }

/* ============================================================
   PLATFORMS (home) — real platform marks as watermark
   ============================================================ */
.plat{ position:relative; padding:clamp(70px,9vw,130px) 0 clamp(80px,9vw,140px); border-top:1px solid var(--ghost); }
.plat__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:clamp(34px,4vw,60px); }
.plat__head h2{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(40px,8vw,118px); line-height:.86; margin:0; letter-spacing:-.005em; }
.plat__head p{ max-width:34ch; color:var(--dim); font-size:15px; margin:0; }

.plat__grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:1fr; gap:14px; }
.pcard{
  position:relative; overflow:hidden; background:var(--ink-2);
  border:1px solid var(--ghost); padding:26px; min-height:210px;
  display:flex; flex-direction:column; justify-content:space-between;
  color:var(--paper); transition:color .4s, border-color .4s; isolation:isolate;
}
.pcard--feature{ grid-column:span 2; grid-row:span 2; min-height:436px; }
.pcard__fill{ position:absolute; inset:0; background:var(--paper); transform:translateY(101%); transition:transform .55s cubic-bezier(.16,.84,.3,1); z-index:-1; }
.pcard:hover{ color:#000; border-color:var(--paper); }
.pcard:hover .pcard__fill{ transform:translateY(0); }
.pcard__top{ display:flex; justify-content:space-between; align-items:flex-start; z-index:1; position:relative; }
.pcard__idx{ font-family:var(--f-mono); font-size:12px; letter-spacing:.24em; opacity:.5; }
.pcard__name{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; line-height:.92; letter-spacing:.005em; font-size:clamp(26px,2.6vw,40px); margin-top:auto; position:relative; z-index:1; }
.pcard--feature .pcard__name{ font-size:clamp(44px,5.6vw,86px); }
.pcard__go{ display:flex; align-items:center; justify-content:space-between; margin-top:18px; font-family:var(--f-mono); font-size:12px; letter-spacing:.24em; text-transform:uppercase; opacity:.7; position:relative; z-index:1; }
.pcard__go .arw{ transition:transform .35s; }
.pcard:hover .pcard__go{ opacity:1; }
.pcard:hover .pcard__go .arw{ transform:translateX(6px); }
/* real platform watermark — inline SVG behind content */
.pcard__brand{
  position:absolute; right:-18px; bottom:-22px; width:240px; height:240px;
  opacity:.06; pointer-events:none; transition:opacity .5s, transform .6s; z-index:0;
  color:var(--paper);
}
.pcard:hover .pcard__brand{ opacity:.14; transform:translate(-6px,-6px); color:#000; }
.pcard--feature .pcard__brand{ width:380px; height:380px; right:-30px; bottom:-40px; opacity:.07; }
.pcard:hover.pcard--feature .pcard__brand{ opacity:.16; }
.pcard__brand svg{ width:100%; height:100%; fill:currentColor; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ position:relative; border-top:1px solid var(--ghost); padding:clamp(64px,8vw,110px) 0 40px; overflow:hidden; }
.foot__band{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(34px,9.5vw,150px); line-height:.82; letter-spacing:-.015em; color:transparent; -webkit-text-stroke:1px var(--ghost); margin:0 0 clamp(40px,6vw,80px); text-align:center; }
.foot__band span{ display:block; }
.foot__cols{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; align-items:start; }
.foot__brand{ display:flex; flex-direction:column; gap:20px; }
.foot__brand img{ width:64px; }
.foot__brand p{ max-width:36ch; color:var(--dim); font-size:14px; margin:0; }
.foot__col h4{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--faint); margin:0 0 18px; font-weight:400; }
.foot__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.foot__col a{ font-family:var(--f-display); font-weight:500; text-transform:uppercase; letter-spacing:.12em; font-size:14px; color:var(--dim); width:fit-content; position:relative; transition:color .3s; }
.foot__col a::after{ content:""; position:absolute; left:0; bottom:-3px; width:100%; height:1px; background:var(--paper); transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.foot__col a:hover{ color:var(--paper); }
.foot__col a:hover::after{ transform:scaleX(1); }
.foot__bottom{ margin-top:clamp(50px,7vw,86px); padding-top:26px; border-top:1px solid var(--ghost); display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-family:var(--f-mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--faint); }

/* ============================================================
   GLITCH
   ============================================================ */
.glitch{ position:relative; display:inline-block; }
.glitch::before, .glitch::after{
  content:attr(data-text); position:absolute; inset:0; pointer-events:none;
  opacity:calc(.9 * var(--glitch)); clip-path:inset(0 0 100% 0);
}
.glitch::before{ left:2px; text-shadow:-1px 0 rgba(255,255,255,.6); animation:gl1 3.4s steps(2) infinite; }
.glitch::after{ left:-2px; text-shadow:1px 0 rgba(0,0,0,.9); animation:gl2 2.7s steps(2) infinite; }
@keyframes gl1{
  0%,82%,100%{ clip-path:inset(0 0 100% 0); transform:translate(0) }
  84%{ clip-path:inset(12% 0 60% 0); transform:translate(-3px,0) }
  88%{ clip-path:inset(48% 0 28% 0); transform:translate(3px,0) }
  92%{ clip-path:inset(70% 0 8% 0); transform:translate(-2px,0) }
}
@keyframes gl2{
  0%,80%,100%{ clip-path:inset(100% 0 0 0); transform:translate(0) }
  85%{ clip-path:inset(30% 0 44% 0); transform:translate(3px,0) }
  90%{ clip-path:inset(62% 0 18% 0); transform:translate(-3px,0) }
}

/* ============================================================
   SECTION HEAD (shared eyebrow + title)
   ============================================================ */
.shead{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:clamp(38px,5vw,68px); }
.shead h2{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(40px,7vw,108px); line-height:.88; letter-spacing:-.005em; margin:0; }
.shead p{ color:var(--dim); max-width:38ch; font-size:15px; margin:0; }
.shead__idx{ font-family:var(--f-mono); font-size:12px; letter-spacing:.3em; color:var(--faint); display:block; margin-bottom:14px; text-transform:uppercase; }

/* ============================================================
   CLIPS / SONS — player + track list
   Covers = WHITE bg + K logo (placeholder until real artwork)
   ============================================================ */
.player{ position:relative; padding:clamp(64px,8vw,120px) 0 clamp(40px,6vw,80px); border-top:1px solid var(--ghost); }
.player__dock{
  display:grid; grid-template-columns:auto 1fr auto; gap:28px; align-items:center;
  padding:22px 26px; background:var(--ink-1); border:1px solid var(--ghost);
  margin-bottom:clamp(34px,4vw,60px);
}
.cover{
  width:74px; height:74px; flex:none; position:relative; background:var(--paper-2);
  border:1px solid var(--ghost); overflow:hidden; display:flex; align-items:center; justify-content:center;
}
.cover img{ width:78%; height:auto; }
.cover::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='cv'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23cv)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply; opacity:.12;
}
.player__info{ min-width:0; display:flex; flex-direction:column; gap:6px; }
.player__eyebrow{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; display:flex; align-items:center; gap:10px; }
.player__eyebrow .dot{ width:7px; height:7px; background:var(--paper); border-radius:50%; animation:pulse 1.4s ease-in-out infinite; }
.player__title{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(18px,2vw,26px); letter-spacing:.04em; line-height:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.player__bar{ position:relative; height:2px; background:var(--ink-3); margin-top:10px; overflow:hidden; }
.player__bar::after{ content:""; position:absolute; left:0; top:0; bottom:0; width:38%; background:var(--paper); }
.player__bar .ghost{ position:absolute; left:38%; top:0; bottom:0; width:6%; background:linear-gradient(90deg, var(--paper), transparent); opacity:.6; }
.player__time{ display:flex; justify-content:space-between; font-family:var(--f-mono); font-size:10px; letter-spacing:.22em; color:var(--faint); margin-top:8px; }
.player__ctrl{ display:flex; align-items:center; gap:14px; }
.player__ctrl button{ width:46px; height:46px; border:1px solid var(--ghost); display:inline-flex; align-items:center; justify-content:center; color:var(--paper); transition:border-color .3s, background .3s, color .3s; }
.player__ctrl button:hover{ border-color:var(--paper); background:var(--paper); color:#000; }
.player__ctrl .ic{ font-family:var(--f-display); font-weight:700; font-size:16px; line-height:1; }
.player__ctrl .ic--play{ width:0; height:0; border-left:11px solid currentColor; border-top:7px solid transparent; border-bottom:7px solid transparent; margin-left:3px; }

.tracks{ display:flex; flex-direction:column; }
.tracks__head{
  display:grid; grid-template-columns:48px 80px 1fr 1.3fr 80px 48px;
  gap:18px; padding:0 18px 14px; border-bottom:1px solid var(--ghost);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.28em; color:var(--faint); text-transform:uppercase;
}
.track{
  display:grid; grid-template-columns:48px 80px 1fr 1.3fr 80px 48px;
  gap:18px; align-items:center; padding:14px 18px; border-bottom:1px solid var(--hair);
  transition:background .25s, color .25s;
}
.track:hover{ background:var(--ink-1); }
.track.is-playing{ background:linear-gradient(90deg, rgba(243,241,236,.06), transparent 60%); }
.track__num{ font-family:var(--f-mono); font-size:13px; color:var(--faint); }
.track.is-playing .track__num{ color:var(--paper); }
.track__cover{ width:64px; height:64px; flex:none; }
.track__title{ font-family:var(--f-display); font-weight:600; text-transform:uppercase; font-size:clamp(15px,1.4vw,18px); letter-spacing:.06em; color:var(--paper); line-height:1.1; }
.track__sub{ font-family:var(--f-mono); font-size:11px; letter-spacing:.22em; color:var(--faint); text-transform:uppercase; margin-top:4px; }
.track__album{ font-family:var(--f-mono); font-size:12px; letter-spacing:.18em; color:var(--dim); text-transform:uppercase; }
.track__time{ font-family:var(--f-mono); font-size:12px; letter-spacing:.18em; color:var(--dim); text-align:right; }
.track__play{ width:36px; height:36px; border:1px solid var(--ghost); display:inline-flex; align-items:center; justify-content:center; margin-left:auto; transition:border-color .3s, background .3s, color .3s; color:var(--paper); }
.track__play::before{ content:""; width:0; height:0; border-left:8px solid currentColor; border-top:5px solid transparent; border-bottom:5px solid transparent; margin-left:2px; }
.track:hover .track__play{ border-color:var(--paper); background:var(--paper); color:#000; }
.track.is-playing .track__play{ border-color:var(--paper); background:var(--paper); color:#000; }
.track.is-playing .track__play::before{ border:none; width:8px; height:10px; margin:0; background:linear-gradient(90deg, currentColor 0 30%, transparent 30% 70%, currentColor 70% 100%); }

/* ============================================================
   DATES — agenda with poster placeholder
   ============================================================ */
.agenda{ position:relative; padding:clamp(64px,8vw,120px) 0 clamp(80px,9vw,140px); border-top:1px solid var(--ghost); }
.agenda__list{ display:flex; flex-direction:column; gap:clamp(28px,4vw,60px); }
.show{
  display:grid; grid-template-columns:minmax(280px, 380px) 1fr; gap:clamp(24px,4vw,56px);
  align-items:center; padding:clamp(20px,2vw,30px); background:var(--ink-1);
  border:1px solid var(--ghost); position:relative; transition:border-color .35s, transform .35s;
}
.show:hover{ border-color:var(--paper); }
.show__poster{
  position:relative; aspect-ratio:3/4; background:#000; overflow:hidden;
  border:1px solid var(--ghost);
}
.show__poster::before{ content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, #000 100%);
}
.show__poster::after{ content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='sp'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23sp)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:.25;
}
.show__poster img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:2; }
.show__poster-label{
  position:absolute; left:0; right:0; top:50%; transform:translateY(-50%); z-index:1; text-align:center;
  font-family:var(--f-display); font-weight:700; text-transform:uppercase; line-height:.9;
  color:var(--paper); text-shadow:0 12px 30px rgba(0,0,0,.7); padding:0 18px;
}
.show__poster-label .top{ display:block; font-family:var(--f-mono); font-weight:400; font-size:10px; letter-spacing:.32em; color:var(--faint); margin-bottom:14px; }
.show__poster-label .main{ display:block; font-size:clamp(28px,3vw,40px); letter-spacing:.02em; }
.show__poster-label .sub{ display:block; font-family:var(--f-mono); font-weight:400; font-size:11px; letter-spacing:.28em; color:var(--dim); margin-top:14px; }
.show__poster-tag{
  position:absolute; top:12px; left:12px; z-index:3;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:var(--paper);
  border:1px solid var(--ghost); padding:5px 9px; text-transform:uppercase; background:rgba(0,0,0,.55);
}

.show__body{ display:flex; flex-direction:column; gap:18px; min-width:0; }
.show__date-row{ display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; }
.show__day{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(54px,7vw,96px); line-height:.85; letter-spacing:-.01em; }
.show__month{ font-family:var(--f-mono); font-size:13px; letter-spacing:.32em; color:var(--faint); text-transform:uppercase; }
.show__city{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(22px,3vw,40px); letter-spacing:.01em; line-height:1; margin:0;
}
.show__city small{ display:block; font-family:var(--f-mono); font-weight:400; font-size:11px; letter-spacing:.28em; color:var(--faint); margin-top:8px; }
.show__venue{ font-family:var(--f-mono); font-size:12px; letter-spacing:.2em; color:var(--dim); text-transform:uppercase; }
.show__venue b{ display:block; color:var(--paper); font-family:var(--f-display); font-weight:600; font-size:clamp(14px,1.4vw,18px); letter-spacing:.08em; margin-bottom:6px; }
.show__bottom{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-top:6px; }
.show__status{
  font-family:var(--f-mono); font-weight:700; font-size:11px; letter-spacing:.3em;
  text-transform:uppercase; padding:9px 14px; border:1px solid var(--paper);
  background:var(--paper); color:#000; white-space:nowrap;
}
.show__status.is-out{ background:transparent; color:var(--paper); border-color:var(--ghost); }
.show__status.is-soon{ background:transparent; color:var(--dim); border-style:dashed; border-color:var(--ghost); }
.show__cta{ font-family:var(--f-display); font-weight:600; text-transform:uppercase; letter-spacing:.16em; font-size:13px; color:var(--paper); display:inline-flex; align-items:center; gap:.5em; }
.show__cta .arw{ transition:transform .3s; }
.show:hover .show__cta .arw{ transform:translateX(5px); }

.agenda__strip{
  border-top:1px solid var(--ghost); border-bottom:1px solid var(--ghost);
  overflow:hidden; white-space:nowrap; padding:22px 0; margin-top:clamp(50px,6vw,80px);
}
.agenda__strip-track{ display:inline-flex; gap:46px; animation:marq 32s linear infinite; }
.agenda__strip span{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(20px,2.6vw,36px); letter-spacing:.06em; color:var(--paper); display:inline-flex; align-items:center; gap:46px; }
.agenda__strip span::after{ content:""; width:9px; height:9px; background:var(--paper); transform:rotate(45deg); display:inline-block; }

/* large countdown wrap (dates page) */
.cd-wrap{ display:flex; flex-direction:column; gap:14px; padding:clamp(28px,4vw,52px) clamp(20px,3vw,40px);
  background:var(--ink-1); border:1px solid var(--ghost); margin-bottom:clamp(40px,5vw,72px); }
.cd-wrap__head{ display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; align-items:baseline; }
.cd-wrap__head span{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; }
.cd-wrap__head b{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(18px,2vw,26px); letter-spacing:.06em; color:var(--paper); }

/* ============================================================
   À PROPOS — editorial + map
   ============================================================ */
.bio{ position:relative; padding:clamp(64px,8vw,120px) 0; border-top:1px solid var(--ghost); }
.bio__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,90px); align-items:start; }
.bio__photo{
  aspect-ratio:4/5; background:#050505; border:1px solid var(--ghost); position:relative; overflow:hidden;
}
.bio__photo::before{ content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 50% at 50% 35%, rgba(243,241,236,.28), transparent 60%),
    radial-gradient(100% 80% at 50% 100%, rgba(243,241,236,.06), transparent 60%),
    linear-gradient(180deg, #0a0a0a, #000);
}
.bio__photo::after{ content:""; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='bp'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23bp)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:.55;
}
.bio__caption{ font-family:var(--f-mono); font-size:11px; letter-spacing:.28em; color:var(--faint); text-transform:uppercase; margin-top:14px; display:flex; justify-content:space-between; }

.bio__text{ display:flex; flex-direction:column; gap:26px; }
.bio__lead{ font-family:var(--f-display); font-weight:500; text-transform:uppercase; font-size:clamp(22px,2.4vw,34px); line-height:1.15; letter-spacing:.01em; color:var(--paper); }
.bio__body p{ font-size:16px; line-height:1.7; color:var(--dim); margin:0 0 18px; max-width:60ch; }
.bio__body p strong{ color:var(--paper); font-weight:600; }
.bio__infl{ display:flex; flex-direction:column; gap:14px; margin-top:14px; border-top:1px solid var(--ghost); padding-top:24px; }
.bio__infl h4{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; margin:0; font-weight:400; }
.bio__infl ul{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:10px 18px; }
.bio__infl li{ font-family:var(--f-display); font-weight:600; text-transform:uppercase; letter-spacing:.08em; font-size:15px; color:var(--paper); display:inline-flex; align-items:center; gap:10px; }
.bio__infl li + li::before{ content:"×"; color:var(--faint); margin-right:6px; }

.bio__stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:18px; border-top:1px solid var(--ghost); padding-top:30px; }
.bio__stat .k{ font-family:var(--f-mono); font-size:10px; letter-spacing:.32em; color:var(--faint); text-transform:uppercase; display:block; margin-bottom:8px; }
.bio__stat .v{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(22px,2.4vw,32px); letter-spacing:.02em; line-height:1; }

.locale{ position:relative; padding:clamp(64px,8vw,120px) 0; border-top:1px solid var(--ghost); }
.locale__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:clamp(30px,4vw,54px); }
.locale__head h2{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(36px,5vw,72px); margin:0; line-height:.95; letter-spacing:-.005em; }
.locale__head p{ font-family:var(--f-mono); font-size:12px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; }
.locale__map{
  position:relative; aspect-ratio:21/9; border:1px solid var(--ghost); overflow:hidden; background:#050505;
}
.locale__map iframe{
  position:absolute; inset:0; width:100%; height:100%; border:0;
  filter:grayscale(1) contrast(1.15) brightness(.7) invert(.92);
}
.locale__map::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(80% 60% at 50% 50%, transparent 40%, rgba(0,0,0,.65) 100%),
    linear-gradient(180deg, rgba(0,0,0,.25), transparent 30%, rgba(0,0,0,.45));
  mix-blend-mode:multiply;
}
.locale__pin{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-100%); z-index:2; pointer-events:none;
  display:flex; flex-direction:column; align-items:center; gap:6px;
}
.locale__pin span{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--paper); text-transform:uppercase; background:#000; padding:6px 10px; border:1px solid var(--paper); }
.locale__pin::after{ content:""; width:1px; height:60px; background:linear-gradient(var(--paper), transparent); }

/* ============================================================
   GOODIES — showcase grid
   ============================================================ */
.shop{ position:relative; padding:clamp(64px,8vw,120px) 0 clamp(80px,9vw,140px); border-top:1px solid var(--ghost); }
.shop__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,28px); }
.good{
  position:relative; display:flex; flex-direction:column; background:var(--ink-1);
  border:1px solid var(--ghost); overflow:hidden; transition:border-color .35s, transform .35s;
}
.good:hover{ border-color:var(--paper); }
.good__media{
  aspect-ratio:1/1; background:var(--paper-2); position:relative; overflow:hidden; border-bottom:1px solid var(--ghost);
  display:flex; align-items:center; justify-content:center;
}
.good__media img{ width:62%; height:auto; }
.good__media::after{ content:""; position:absolute; inset:0; pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='gm'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23gm)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply; opacity:.15;
}
.good__tag{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:#000;
  border:1px solid #000; padding:5px 9px; text-transform:uppercase; background:#fff;
}
.good__num{
  position:absolute; bottom:14px; right:14px; z-index:2;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:#444; text-transform:uppercase;
}
.good__body{ padding:22px 22px 24px; display:flex; flex-direction:column; gap:14px; }
.good__name{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(20px,2vw,26px); letter-spacing:.02em; line-height:1.05; margin:0; }
.good__desc{ color:var(--dim); font-size:14px; margin:0; line-height:1.55; }
.good__where{ margin-top:6px; padding-top:14px; border-top:1px solid var(--ghost); display:flex; flex-direction:column; gap:8px; }
.good__where h5{ font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; font-weight:400; margin:0; }
.good__where ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.good__where li{ font-family:var(--f-display); font-weight:500; text-transform:uppercase; letter-spacing:.1em; font-size:13px; color:var(--paper); display:flex; align-items:center; gap:10px; }
.good__where li::before{ content:""; width:8px; height:1px; background:var(--paper); flex:none; }

.shop__intro{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:clamp(34px,4vw,56px); }
.shop__intro p{ color:var(--dim); max-width:46ch; font-size:15px; margin:0; }
.shop__intro .meta{ font-family:var(--f-mono); font-size:11px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; display:flex; gap:24px; flex-wrap:wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .plat__grid{ grid-template-columns:repeat(2,1fr); }
  .pcard--feature{ grid-column:span 2; grid-row:span 1; min-height:240px; }
  .foot__cols{ grid-template-columns:1fr 1fr; }
  .bio__grid{ grid-template-columns:1fr; gap:46px; }
  .shop__grid{ grid-template-columns:repeat(2,1fr); }
  .tracks__head{ grid-template-columns:48px 70px 1fr 80px 48px; }
  .tracks__head .h-album{ display:none; }
  .track{ grid-template-columns:48px 70px 1fr 80px 48px; }
  .track__album{ display:none; }
  .show{ grid-template-columns:1fr; }
  .show__poster{ max-width:520px; aspect-ratio:16/10; }
}
@media (max-width:860px){
  .nav{ display:none; }
  .burger{ display:flex; }
  .next__grid{ grid-template-columns:1fr; gap:38px; align-items:start; }
  .next__ghost{ display:none; }
  .player__dock{ grid-template-columns:auto 1fr; row-gap:18px; }
  .player__ctrl{ grid-column:1 / -1; justify-content:center; }
  .cd--lg .cd__num{ font-size:42px; }
  .cd--lg .cd__cell{ min-width:46px; }
}
@media (max-width:620px){
  .plat__grid{ grid-template-columns:1fr; }
  .pcard--feature{ grid-column:span 1; }
  .foot__cols{ grid-template-columns:1fr; gap:34px; }
  .foot__bottom{ justify-content:center; text-align:center; gap:8px 18px; }
  .hero__corner{ display:none; }
  .next__meta{ gap:24px 36px; }
  .shop__grid{ grid-template-columns:1fr; }
  /* tracks: keep the play button reachable by thumb, drop the empty duration */
  .tracks__head{ grid-template-columns:32px 52px 1fr 44px; gap:12px; padding:0 4px 14px; }
  .tracks__head > span:nth-child(5){ display:none; }   /* "Durée" label */
  .tracks__head .h-play{ display:block; text-align:right; }
  .track{ grid-template-columns:32px 52px 1fr 44px; gap:12px; padding:14px 4px; }
  .track__time{ display:none; }
  .track__play{ display:inline-flex; margin-left:auto; }
  .track__cover{ width:52px; height:52px; }
  .bio__stats{ grid-template-columns:1fr 1fr; }
  .show__day{ font-size:46px; }
  .cd__num{ font-size:16px; }
  .cd__cell{ min-width:28px; }
  .cd__label{ display:none; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; }
}

/* ============================================================
   COVERS — support real artwork (overrides white-K placeholder)
   ============================================================ */
.cover.has-artwork{ background:#000; }
.cover.has-artwork img{ width:100%; height:100%; object-fit:cover; filter:none; }
.cover.has-artwork::after{ display:none; }

/* photo image inside bio (real colors) */
.bio__photo--real{ background:#000; }
.bio__photo--real::before, .bio__photo--real::after{ display:none; }
.bio__photo--real img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
}

/* good (merch) — real product image, no filter */
.good__media.has-photo{ background:#fff; }
.good__media.has-photo::after{ opacity:.06; }
.good__media.has-photo img{ width:100%; height:100%; object-fit:cover; filter:none; }

/* show poster — real image */
.show__poster.has-image::before,
.show__poster.has-image::after,
.show__poster.has-image .show__poster-label{ display:none; }
.show__poster.has-image img{ filter:none; }

/* ============================================================
   AUDIO PLAYER — real <audio> progress bar
   ============================================================ */
.track__play{ cursor:pointer; transition:border-color .25s, background .25s, color .25s, opacity .25s; }
.track__play.is-empty{ opacity:.35; cursor:not-allowed; }
.track__play.is-empty:hover{ background:transparent; color:var(--paper); border-color:var(--ghost); }

.track__play.is-loading::before,
.track__play.is-playing::before{ display:none; }
.track__play.is-playing::after{
  content:""; width:10px; height:12px;
  background:linear-gradient(90deg, currentColor 0 35%, transparent 35% 65%, currentColor 65% 100%);
}
.track__play.is-loading::after{
  content:""; width:14px; height:14px; border:1.5px solid currentColor; border-top-color:transparent; border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg) } }

/* Inline progress bar that appears under a playing track */
.track__progress{
  grid-column:1 / -1; height:2px; background:rgba(243,241,236,.10); position:relative;
  margin:8px 0 -6px; overflow:hidden;
}
.track__progress::after{
  content:""; position:absolute; left:0; top:0; bottom:0;
  width:var(--p, 0%); background:var(--paper); transition:width .08s linear;
}
.track__progress .ghost{
  position:absolute; top:0; bottom:0; width:8%; left:var(--p, 0%);
  background:linear-gradient(90deg, var(--paper), transparent); opacity:.6;
  transform:translateX(-50%);
}

/* Dock real progress bar */
.player__dock.is-playing .player__bar::after{ width:var(--p, 0%) !important; transition:width .08s linear; }
.player__dock.is-playing .player__bar .ghost{ left:var(--p, 0%) !important; }
.player__ctrl button.is-playing{ background:var(--paper); color:#000; border-color:var(--paper); }
.player__ctrl button.is-playing .ic--play{
  border:none; width:8px; height:10px; margin:0;
  background:linear-gradient(90deg, currentColor 0 30%, transparent 30% 70%, currentColor 70% 100%);
}

/* ============================================================
   NOW-PLAYING EQUALIZER — small bars that dance while a track plays
   (pure CSS, driven by the .is-playing state — no Web Audio needed)
   ============================================================ */
.player__eq{ display:inline-flex; align-items:flex-end; gap:2px; height:11px; margin-left:9px; vertical-align:-1px; }
.player__eq i{
  width:2px; height:18%; background:var(--paper); opacity:.45;
  transform-origin:bottom; transition:height .12s linear, opacity .2s;
}
.player__dock.is-playing .player__eq i{ opacity:.9; animation:eqBar 900ms ease-in-out infinite; }
.player__dock.is-playing .player__eq i:nth-child(2){ animation-delay:-200ms; }
.player__dock.is-playing .player__eq i:nth-child(3){ animation-delay:-480ms; }
.player__dock.is-playing .player__eq i:nth-child(4){ animation-delay:-120ms; }
.player__dock.is-playing .player__eq i:nth-child(5){ animation-delay:-360ms; }
/* when JS drives the bars from real frequency data, drop the canned animation */
.player__eq.is-live i{ animation:none !important; }
@keyframes eqBar{ 0%,100%{ height:18%; } 50%{ height:100%; } }

/* smoke breathes gently with the track while it plays (--amp 0..1 set in JS) */
.player.is-amp .smoke{ opacity:calc(.4 + var(--amp, 0) * .45); transition:opacity .22s ease-out; }

/* ============================================================
   MODAL — track info popup
   ============================================================ */
.modal{
  position:fixed; inset:0; z-index:80; background:rgba(0,0,0,.78);
  backdrop-filter:blur(12px) saturate(0);
  display:flex; align-items:center; justify-content:center; padding:clamp(16px,3vw,48px);
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.modal.is-open{ opacity:1; pointer-events:auto; }
.modal__shell{
  position:relative; background:var(--ink-1); border:1px solid var(--ghost);
  width:min(960px, 100%); max-height:90vh; overflow:auto;
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.1fr); gap:0;
  transform:translateY(20px) scale(.98); transition:transform .35s cubic-bezier(.16,.84,.3,1);
}
.modal.is-open .modal__shell{ transform:none; }
.modal__close{
  position:absolute; top:14px; right:14px; z-index:3;
  width:42px; height:42px; border:1px solid var(--ghost); color:var(--paper);
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-size:22px; line-height:1; transition:background .25s, color .25s, border-color .25s;
}
.modal__close:hover{ background:var(--paper); color:#000; border-color:var(--paper); }
.modal__art{
  aspect-ratio:1/1; background:#000; position:relative; overflow:hidden; border-right:1px solid var(--ghost);
}
.modal__art img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.modal__art.is-placeholder{ background:var(--paper-2); display:flex; align-items:center; justify-content:center; }
.modal__art.is-placeholder img{ position:static; width:62%; height:auto; filter:invert(1); object-fit:initial; }
.modal__art-tag{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:var(--paper);
  border:1px solid var(--ghost); padding:5px 9px; text-transform:uppercase; background:rgba(0,0,0,.55);
}
.modal__body{ padding:clamp(24px,3.5vw,48px); display:flex; flex-direction:column; gap:18px; }
.modal__eyebrow{ font-family:var(--f-mono); font-size:11px; letter-spacing:.32em; color:var(--faint); text-transform:uppercase; }
.modal__title{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:clamp(28px,3.6vw,52px); line-height:.95; letter-spacing:.005em; margin:0; }
.modal__desc{ color:var(--dim); font-size:15px; line-height:1.65; margin:0; max-width:42ch; }
.modal__meta{ display:flex; flex-wrap:wrap; gap:10px 24px; font-family:var(--f-mono); font-size:11px; letter-spacing:.24em; color:var(--faint); text-transform:uppercase; }
.modal__meta span b{ color:var(--paper); font-weight:400; font-family:var(--f-display); font-size:13px; letter-spacing:.1em; margin-left:8px; }
.modal__listen{ display:flex; flex-direction:column; gap:10px; margin-top:6px; padding-top:18px; border-top:1px solid var(--ghost); }
.modal__listen h4{ font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:var(--faint); text-transform:uppercase; font-weight:400; margin:0 0 4px; }
.modal__listen-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.modal__plat{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:14px 16px; border:1px solid var(--ghost); color:var(--paper);
  font-family:var(--f-display); font-weight:600; text-transform:uppercase; letter-spacing:.12em; font-size:13px;
  transition:background .25s, color .25s, border-color .25s;
}
.modal__plat:hover{ background:var(--paper); color:#000; border-color:var(--paper); }
.modal__plat .arw{ transition:transform .25s; }
.modal__plat:hover .arw{ transform:translateX(4px); }

@media (max-width:760px){
  /* drop the ambient fog on phones — lighter GPU load, cleaner reading */
  .smoke{ display:none; }
  .modal__shell{ grid-template-columns:1fr; max-height:94vh; }
  .modal__art{ aspect-ratio:16/10; border-right:0; border-bottom:1px solid var(--ghost); }
}

/* ============================================================
   SMOKE — real volumetric fog (baked fractal-noise texture)
   The white wisps come from an SVG feTurbulence rasterised ONCE
   (blur baked into the filter), so only transform/opacity animate
   at runtime → realistic *and* GPU-cheap (no live blur per frame).
   ============================================================ */
.smoke{ position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.matter > .smoke{ z-index:0; }
.smoke{ opacity:.5; }
.smoke i{
  position:absolute; display:block;
  width:200%; height:200%; left:-50%; bottom:-65%;
  /* ONE non-repeating texture (no tiling → no moving seams) */
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='900' height='900'%3E%3Cfilter id='sm' x='-20%25' y='-20%25' width='140%25' height='140%25'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.006 0.009' numOctaves='5' seed='11'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 1.4 0'/%3E%3CfeGaussianBlur stdDeviation='6'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23sm)'/%3E%3C/svg%3E") center / cover no-repeat;
  -webkit-mask-image:radial-gradient(80% 70% at 50% 78%, #000 14%, rgba(0,0,0,.38) 50%, transparent 82%);
          mask-image:radial-gradient(80% 70% at 50% 78%, #000 14%, rgba(0,0,0,.38) 50%, transparent 82%);
  will-change:transform; transform:translateZ(0);
}
/* steady fog — CONSTANT opacity, slow easing drift that reverses (alternate)
   so it never fades in/out or jumps → no flicker, no "buggy" pulsing */
.smoke i:nth-child(1){ opacity:.5; animation:smokeDrift1 56s ease-in-out infinite alternate; }
.smoke i:nth-child(2){ opacity:.4; background-position:28% 22%; animation:smokeDrift2 68s ease-in-out infinite alternate; }
.smoke i:nth-child(3){ opacity:.3; background-position:72% 64%; animation:smokeDrift3 62s ease-in-out infinite alternate; }
@keyframes smokeDrift1{ from{ transform:translate3d(-3%,3%,0)  scale(1.04); } to{ transform:translate3d(3%,-4%,0)  scale(1.16); } }
@keyframes smokeDrift2{ from{ transform:translate3d(2%,4%,0)   scale(1.1);  } to{ transform:translate3d(-4%,-3%,0) scale(1.24); } }
@keyframes smokeDrift3{ from{ transform:translate3d(0,5%,0)    scale(1);    } to{ transform:translate3d(4%,-5%,0)  scale(1.2);  } }

/* ============================================================
   DATES — filter bar + past shows
   ============================================================ */
.agenda__filters{
  display:inline-flex; gap:6px; flex-wrap:wrap; padding:6px;
  border:1px solid var(--ghost); margin-bottom:clamp(30px,4vw,52px);
}
.agenda__filter{
  font-family:var(--f-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.14em; font-size:13px; line-height:1; color:var(--dim);
  padding:11px 20px; border:1px solid transparent;
  transition:color .25s, background .25s, border-color .25s;
}
.agenda__filter:hover{ color:var(--paper); border-color:var(--ghost); }
.agenda__filter.is-active{ background:var(--paper); color:#000; border-color:var(--paper); }
.show[hidden]{ display:none; }
.show.is-past{ opacity:.6; transition:opacity .35s, border-color .35s; }
.show.is-past:hover{ opacity:1; }

/* ============================================================
   ON PARLE DE NOUS — press / video features
   ============================================================ */
.press{ position:relative; padding:clamp(64px,8vw,120px) 0; border-top:1px solid var(--ghost); }
.press__grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(340px,1fr));
  gap:clamp(16px,2vw,28px);
}
.press__item{
  position:relative; background:var(--ink-1); border:1px solid var(--ghost);
  overflow:hidden; transition:border-color .35s;
}
.press__item:hover{ border-color:var(--paper); }
.press__media{ position:relative; background:#000; line-height:0; }
.press__media video{ width:100%; height:auto; display:block; background:#000; }
.press__tag{
  position:absolute; top:14px; left:14px; z-index:3;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.3em; color:var(--paper);
  border:1px solid var(--ghost); padding:5px 9px; text-transform:uppercase; background:rgba(0,0,0,.6);
  pointer-events:none;
}
.press__body{ padding:20px 22px 24px; display:flex; flex-direction:column; gap:10px; }
.press__name{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(18px,1.8vw,24px); letter-spacing:.02em; line-height:1.1; margin:0;
}
.press__meta{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.24em; color:var(--faint);
  text-transform:uppercase; display:flex; gap:8px 18px; flex-wrap:wrap; align-items:center;
}
.press__meta b{ color:var(--dim); font-weight:400; }

@media (prefers-reduced-motion:reduce){
  .smoke{ display:none; }
  .loader{ display:none; }
}

/* ============================================================
   ACCESSIBILITÉ — focus visible, touch targets, lisibilité
   ============================================================ */

/* Focus visible : contour net sur tous les éléments interactifs */
:focus-visible{
  outline: 2px solid var(--paper);
  outline-offset: 3px;
}
/* Masquer le focus souris (uniquement visible au clavier) */
:focus:not(:focus-visible){ outline: none; }

/* Touch targets minimaux 44×44 px (WCAG 2.5.5) */
.track__play,
.modal__close,
.agenda__filter,
.player__ctrl button,
.show__cta,
.btn,
.burger{
  min-width: 44px;
  min-height: 44px;
}
.track__play{ display:inline-flex; align-items:center; justify-content:center; }

/* Taille de texte minimale — évite le zoom auto sur iOS */
input, textarea, select{ font-size: 16px; }

/* ============================================================
   MOBILE — améliorations 480px et moins
   ============================================================ */
@media (max-width:480px){

  /* Hero : titre plus compact */
  .hero__title{ font-size: clamp(48px, 18vw, 80px); line-height: 1; }

  /* Boutons hero : colonne unique sur très petit écran */
  .hero__actions{ flex-direction: column; align-items: flex-start; gap: 12px; }
  .hero__actions .btn{ width: 100%; justify-content: space-between; }

  /* Corners hero : cachés sur très petit écran (trop chargé) */
  .hero__corner.tr{ display: none; }

  /* Section prochaine date */
  .next__date{ font-size: clamp(52px, 18vw, 90px); }
  .next__grid{ gap: clamp(24px, 6vw, 48px); }

  /* Compte à rebours : chiffres plus compacts */
  .cd--lg .cd__grid{ gap: 8px; }
  .cd--lg .cd__cell{ min-width: 54px; padding: 10px 8px 8px; }
  .cd--lg .cd__num{ font-size: clamp(28px, 10vw, 52px); }

  /* Lecteur : dock en colonne sur mobile */
  .player__dock{
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 14px;
    padding: 18px 16px;
  }
  .player__dock .cover{ display: none; }
  .player__ctrl{ justify-content: center; }

  /* Liste des morceaux : grille simplifiée */
  .tracks__head > span:nth-child(4),
  .tracks__head > span:nth-child(5){ display: none; }
  .track__album,
  .track__time{ display: none; }

  /* Cards concerts : pleine largeur */
  .show{
    grid-template-columns: 1fr;
    border-bottom: 1px solid var(--ghost);
  }
  .show__poster{ aspect-ratio: 16/9; min-height: unset; }

  /* Section platforms : 1 colonne */
  .plat__grid{
    grid-template-columns: 1fr;
  }
  .pcard--feature{ grid-column: 1; }

  /* Merch : 1 colonne */
  .shop__grid{ grid-template-columns: 1fr; }

  /* Pied de page */
  .foot__cols{ grid-template-columns: 1fr; }
  .foot__brand{ padding-bottom: 24px; border-bottom: 1px solid var(--ghost); }

  /* Section bio */
  .bio__grid{ grid-template-columns: 1fr; }
  .bio__stats{ grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   MOBILE — améliorations 620px
   ============================================================ */
@media (max-width:620px){

  /* Espacement général */
  .wrap{ padding-inline: clamp(16px, 5vw, 32px); }

  /* Cards concerts : simplifiées */
  .show{ gap: 0; }
  .show__body{ padding: 18px 16px 20px; }

  /* Modal : plein écran */
  .modal{ padding: 0; align-items: flex-end; }
  .modal__shell{
    width: 100%; max-height: 92vh;
    border-bottom: none;
    border-radius: 0;
  }

  /* Filtres agenda */
  .agenda__filters{ width: 100%; justify-content: stretch; }
  .agenda__filter{ flex: 1; text-align: center; padding: 13px 10px; }

  /* Shead responsive */
  .shead{ flex-direction: column; gap: 16px; }
  .shead p{ max-width: 100%; }

  /* Good cards merch : toujours lisibles */
  .good__media{ aspect-ratio: 4/3; }
  .good__body{ padding: 18px 16px 20px; }
}

