/* ═══════════════════════════════════════════════════════════════════════════
   style.css — Whisky Kérosène · 7th Records · 2026
   Univers : memorabilia imprimée — affiches, polaroids, billets, tampons.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Reset ──────────────────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto;scroll-padding-top:64px}
body{
  width:100%;min-height:100vh;background:var(--bg);color:var(--bone);
  cursor:default;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  text-align:justify;
  text-justify:inter-word;
  hyphens:auto;
}

/* Éléments qui doivent rester centrés (titres, banners, marquees, etc.) */
.hero,
.hero-meta,
.hero-stars,
.section-banner,
.section-title,
.section-sub,
.marquee-track,
.stamp-frame,
.empty-stamp-frame,
.empty-stamp,
.disco-empty,
.live-empty,
.seal-header,
.seal-group-title,
.seal-press,
.site-footer,
.polaroid-caption{
  text-align:center;
}

/* Éléments qui doivent rester alignés à gauche (UI, listes, meta, navigation) */
.top-nav,
.nav-menu,
.nav-wordmark,
.hero-scroll,
.meta-key,
.meta-val,
.single-title,
.listen-on,
.stream-card,
.stream-card--feature,
.members-label,
.member-num,
.member-name,
.member-role,
.sounds-label,
.ref-pill,
.year-marker,
.year-digits,
.year-count,
.disco-type,
.disco-title-row,
.disco-date,
.disco-listen,
.ticket,
.ticket-stub,
.ticket-stub-num,
.ticket-stub-stamp,
.ticket-stub-date,
.ticket-day,
.ticket-venue,
.ticket-tour,
.ticket-loc,
.ticket-cta,
.seal-link{
  text-align:left;
}
img{display:block;max-width:100%}
a{color:inherit}
ol,ul{list-style:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}

/* ── Variables ──────────────────────────────────────────────────────────── */
:root{
  --bg:#0a0806;
  --bg-warm:#120a05;
  --bg-elev:#1a100a;
  --whisky:#9c5826;
  --copper:#c87a3d;
  --copper-soft:rgba(200,122,61,0.30);
  --ember:#d97706;
  --rust:#a83a1d;
  --bone:#ebe1cd;
  --bone-dim:rgba(235,225,205,0.55);
  --bone-faint:rgba(235,225,205,0.30);
  --smoke:#2a1a10;
  --ash:#6a4830;
  --ease:cubic-bezier(0.76,0,0.24,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);

  --font-display:'Big Shoulders Display',Impact,sans-serif;
  --font-serif:'Crimson Pro',Georgia,serif;
  --font-mono:'Special Elite','Courier New',monospace;
}

/* ── Grain overlay ─────────────────────────────────────────────────────── */
.grain{
  position:fixed;inset:0;z-index:999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.07;mix-blend-mode:overlay;
}

/* ── Reveal de base ────────────────────────────────────────────────────── */
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
[data-animate].in-view{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════════════════════════════
   TOP NAV
   ═══════════════════════════════════════════════════════════════════════════ */
.top-nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;
  transition:padding .3s var(--ease),background-color .3s ease,border-color .3s ease;
  border-bottom:1px solid transparent;
}
.top-nav.scrolled{
  padding:12px 5vw;
  background:rgba(10,8,6,0.85);backdrop-filter:blur(10px) saturate(120%);
  -webkit-backdrop-filter:blur(10px) saturate(120%);
  border-bottom-color:rgba(200,122,61,0.18);
}

.nav-wordmark{
  display:inline-flex;align-items:center;
  height:40px;
  text-decoration:none;color:var(--bone);
  transition:height .3s var(--ease),opacity .25s ease;
}
.nav-wordmark img{
  height:100%;width:auto;display:block;
  /* Logo noir à l'origine — inversé en blanc/ivoire via filter */
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
}
.nav-wordmark:hover{opacity:0.85}

.top-nav.scrolled .nav-wordmark{height:32px}

.nav-menu{display:flex;gap:28px;align-items:center}
.nav-menu a{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--bone-dim);text-decoration:none;
  position:relative;padding:6px 0;transition:color .25s;
}
.nav-menu a:hover{color:var(--bone)}
.nav-menu a.active{color:var(--copper)}
.nav-menu a.active::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--copper);
}

.nav-burger{display:none;width:32px;height:24px;position:relative}
.nav-burger span{
  position:absolute;left:0;right:0;height:1.5px;background:var(--bone);
  transition:transform .25s ease,opacity .15s ease,top .25s ease;
}
.nav-burger span:nth-child(1){top:4px}
.nav-burger span:nth-child(2){top:11px}
.nav-burger span:nth-child(3){top:18px}
.nav-burger.open span:nth-child(1){top:11px;transform:rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){top:11px;transform:rotate(-45deg)}

/* ═══════════════════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════════════════ */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:120px 5vw 80px;text-align:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  filter:brightness(0.42) saturate(0.85) sepia(0.20);
  transform:scale(1.05);
}
.hero-vignette{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at center,transparent 25%,rgba(10,8,6,0.92) 90%),
    linear-gradient(180deg,rgba(10,8,6,0.35) 0%,transparent 22%,transparent 70%,rgba(10,8,6,0.65) 100%);
}

.hero-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}

.hero-meta{
  display:flex;align-items:center;justify-content:center;gap:18px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--copper);margin-bottom:28px;
}
.hero-meta .meta-line{flex:0 0 60px;height:1px;background:var(--copper-soft)}

.hero-mark{
  display:flex;align-items:center;justify-content:center;
}
.hero-mark .hero-logo{
  width:auto;
  height:clamp(140px,22vw,320px);
  max-width:90vw;
  display:block;
  /* Logo noir d'origine — inversé en blanc/ivoire */
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
  opacity:0;transform:translateY(20px) scale(0.96);
  transition:opacity 1.1s var(--ease-out) 0.15s, transform 1.1s var(--ease-out) 0.15s;
}
.hero-inner.in-view .hero-logo{opacity:1;transform:translateY(0) scale(1)}

.hero-tagline{
  margin-top:32px;
  font-family:var(--font-mono);font-size:13px;letter-spacing:0.35em;
  text-transform:uppercase;color:var(--bone-dim);
}

.hero-stars{margin-top:24px;display:flex;justify-content:center;gap:14px;color:var(--copper);font-size:14px;letter-spacing:0.3em}

.hero-scroll{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--bone-faint);text-decoration:none;
  transition:color .3s ease;
}
.hero-scroll svg{width:18px;height:30px;color:var(--copper);animation:scrollBob 2s ease-in-out infinite}
.hero-scroll:hover{color:var(--bone)}
@keyframes scrollBob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ═══════════════════════════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════════════════════════ */
.marquee{
  position:relative;overflow:hidden;
  border-top:1px solid var(--copper-soft);
  border-bottom:1px solid var(--copper-soft);
  background:linear-gradient(180deg,#0d0907,#1a100a);
  padding:14px 0;
}
.marquee-track{
  display:flex;align-items:center;gap:32px;white-space:nowrap;
  width:max-content;animation:marqueeScroll 38s linear infinite;
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(20px,2.4vw,30px);letter-spacing:0.06em;color:var(--bone);
}
.marquee-track > span{display:inline-block}
.marquee-logo{
  display:inline-block;height:0.85em;width:auto;
  vertical-align:middle;margin:-0.15em 4px 0;
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
}
.marquee-star{color:var(--copper);font-size:0.7em}
.marquee--reverse .marquee-track{animation-direction:reverse;animation-duration:42s}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTION CHROME PARTAGÉ (banner + title + sub)
   ═══════════════════════════════════════════════════════════════════════════ */
.section-banner{
  display:flex;align-items:center;justify-content:center;gap:18px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.45em;
  text-transform:uppercase;color:var(--copper);margin-bottom:18px;
}
.section-banner .banner-rule{flex:0 0 50px;height:1px;background:var(--copper-soft)}

.section-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(56px,9vw,150px);line-height:0.9;letter-spacing:0.01em;
  text-transform:uppercase;color:var(--bone);text-align:center;
  margin-bottom:16px;
}
.section-sub{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:clamp(15px,1.4vw,19px);color:var(--bone-dim);
  text-align:center;margin-bottom:60px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE — vinyle
   ═══════════════════════════════════════════════════════════════════════════ */
.single-section{
  padding:100px 5vw 110px;background:var(--bg);
  background-image:
    radial-gradient(ellipse at 20% 50%,rgba(156,88,38,0.10),transparent 60%),
    radial-gradient(ellipse at 80% 50%,rgba(168,58,29,0.06),transparent 65%);
}
.single-grid{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}

.vinyl-stage{position:relative;display:flex;flex-direction:column;align-items:center;gap:18px}
.vinyl{
  position:relative;width:min(100%,460px);aspect-ratio:1/1;border-radius:50%;
  background:
    repeating-radial-gradient(circle,rgba(255,255,255,0.025) 0 1px,transparent 1px 4px),
    radial-gradient(circle at 30% 30%,#1f1308 0%,#0a0806 70%);
  box-shadow:
    0 30px 80px rgba(0,0,0,0.7),
    inset 0 0 0 1px rgba(200,122,61,0.18),
    inset 0 0 60px rgba(0,0,0,0.6);
  animation:vinylSpin 18s linear infinite;
}
.vinyl-grooves{
  position:absolute;inset:8%;border-radius:50%;
  background:repeating-radial-gradient(circle,rgba(200,122,61,0.04) 0 1px,transparent 1px 6px);
  pointer-events:none;
}
.vinyl-label{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:36%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;
  box-shadow:0 0 0 2px rgba(10,8,6,0.6),0 0 0 3px rgba(200,122,61,0.2);
}
.vinyl-label img{width:100%;height:100%;object-fit:cover}
.vinyl-hole{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:4%;aspect-ratio:1/1;border-radius:50%;
  background:#0a0806;
  box-shadow:inset 0 0 0 1px rgba(200,122,61,0.4),0 0 8px rgba(0,0,0,0.8);
  z-index:5;
}
.vinyl-shine{
  position:absolute;inset:0;border-radius:50%;pointer-events:none;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,0.04) 50%,transparent 60%);
}
.vinyl-shadow{
  position:absolute;bottom:-20px;left:10%;right:10%;height:30px;border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(0,0,0,0.6),transparent 70%);
  filter:blur(8px);z-index:-1;
}
.vinyl-tag{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--copper);
}
@keyframes vinylSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.single-info{display:flex;flex-direction:column;gap:18px}

.stamp-now-playing{display:inline-flex}
.stamp-frame{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 16px;
  border:2px solid var(--copper);border-radius:4px;
  font-family:var(--font-display);font-weight:700;
  font-size:14px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--copper);transform:rotate(-2deg);
  box-shadow:inset 0 0 0 1px rgba(200,122,61,0.4);
  position:relative;
}
.stamp-frame::after{
  content:'';position:absolute;inset:-3px;border:1px dashed rgba(200,122,61,0.3);border-radius:6px;
}

.single-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(44px,5.5vw,84px);line-height:0.95;letter-spacing:0.005em;
  text-transform:uppercase;color:var(--bone);
}

.single-meta{display:flex;flex-direction:column;gap:6px;margin-top:8px;border-top:1px solid var(--copper-soft);padding-top:18px}
.meta-row{display:flex;align-items:baseline;gap:14px}
.meta-key{
  flex:0 0 90px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.28em;
  text-transform:uppercase;color:var(--bone-faint);
}
.meta-val{
  font-family:var(--font-serif);font-size:17px;color:var(--bone);font-style:italic;
}

.listen-on{
  margin-top:12px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.35em;
  text-transform:uppercase;color:var(--copper);
}
.stream-grid{display:flex;flex-wrap:wrap;gap:10px}
.stream-card{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 18px;
  background:rgba(200,122,61,0.05);border:1px solid var(--copper-soft);
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--bone-dim);text-decoration:none;
  transition:all .25s;
}
.stream-card:hover{background:rgba(200,122,61,0.12);border-color:var(--copper);color:var(--bone)}
.stream-card svg{width:14px;height:14px;fill:currentColor;opacity:0.85}
.stream-card--feature{
  background:linear-gradient(135deg,rgba(217,119,6,0.18),rgba(168,58,29,0.18));
  border-color:var(--copper);color:var(--bone);
  flex-direction:column;gap:2px;padding:14px 22px;align-items:flex-start;
}
.stream-card--feature .stream-card-label{
  font-size:9px;letter-spacing:0.3em;color:var(--copper);
}
.stream-card--feature .stream-card-name{font-size:13px}

/* ═══════════════════════════════════════════════════════════════════════════
   ABOUT — polaroid + bio + members + sounds-like
   ═══════════════════════════════════════════════════════════════════════════ */
.about-section{
  padding:120px 5vw 120px;background:var(--bg);
  border-top:1px solid rgba(200,122,61,0.08);
}

.about-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:80px;align-items:start;
}

/* Polaroid */
.polaroid{
  position:relative;
  background:#ebe1cd;padding:18px 18px 70px;
  box-shadow:
    0 30px 70px rgba(0,0,0,0.65),
    0 2px 0 rgba(0,0,0,0.4);
  transform:rotate(-2.5deg);
  transition:transform .5s var(--ease);
  margin-top:30px;
}
.polaroid:hover{transform:rotate(-1.2deg) translateY(-4px)}
.polaroid-photo{
  aspect-ratio:4/5;overflow:hidden;
  background:#2a1a10;
}
.polaroid-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:contrast(1.05) saturate(0.9) sepia(0.12);
}
.polaroid-photo-empty{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#3a2818,#1d100a);padding:20%;
}
.polaroid-photo-empty img{
  width:100%;height:auto;max-height:100%;object-fit:contain;
  opacity:0.55;
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
}
.polaroid-caption{
  position:absolute;bottom:20px;left:18px;right:18px;
  font-family:var(--font-mono);font-size:13px;letter-spacing:0.05em;
  color:#3a2818;text-align:center;
}

/* Tape */
.tape{
  position:absolute;width:90px;height:24px;z-index:2;
  background:rgba(220,200,160,0.45);
  box-shadow:0 2px 4px rgba(0,0,0,0.3);
  border:1px solid rgba(150,130,90,0.2);
}
.tape--tl{top:-10px;left:-18px;transform:rotate(-30deg)}
.tape--br{bottom:60px;right:-18px;transform:rotate(-25deg)}

/* Text side */
.about-text{display:flex;flex-direction:column;gap:42px}

.bio-columns{
  column-count:2;column-gap:36px;column-rule:1px solid rgba(200,122,61,0.12);
}
.bio-columns p{
  font-family:var(--font-serif);font-size:clamp(15px,1.1vw,18px);font-weight:400;
  line-height:1.75;color:rgba(235,225,205,0.78);margin-bottom:16px;
  break-inside:avoid;
}
.bio-columns p:first-child::first-letter{
  font-family:var(--font-display);font-weight:800;
  font-size:3.4em;line-height:0.85;float:left;
  margin:6px 10px 0 0;color:var(--copper);
}

.members-block{}
.members-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.members-label{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.35em;
  text-transform:uppercase;color:var(--copper);
}
.members-rule{flex:1;height:1px;background:var(--copper-soft)}

.members-list{display:flex;flex-direction:column;gap:8px}
.members-list li{
  display:grid;grid-template-columns:36px 1fr;align-items:baseline;gap:14px;
  padding:8px 0;border-bottom:1px dashed rgba(200,122,61,0.18);
}
.member-num{
  font-family:var(--font-mono);font-size:13px;color:var(--copper);
}
.member-name{
  font-family:var(--font-serif);font-style:italic;font-size:clamp(18px,1.6vw,22px);
  color:var(--bone);font-weight:500;
}
.member-role{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.25em;
  text-transform:uppercase;color:var(--bone-faint);
}

.sounds-block{display:flex;align-items:center;flex-wrap:wrap;gap:10px}
.sounds-label{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--copper);margin-right:4px;
}
.ref-pill{
  padding:6px 14px;
  border:1px solid rgba(200,122,61,0.25);border-radius:999px;
  font-family:var(--font-serif);font-style:italic;font-size:14px;
  color:var(--bone-dim);
}

/* ═══════════════════════════════════════════════════════════════════════════
   DISCOGRAPHY — chronologie
   ═══════════════════════════════════════════════════════════════════════════ */
.disco-section{
  padding:120px 5vw 120px;background:var(--bg);
  border-top:1px solid rgba(200,122,61,0.08);
}

.disco-year-block{
  max-width:1100px;margin:0 auto 60px;
}

.year-marker{
  display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:end;
  margin-bottom:28px;
}
.year-digits{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(60px,9vw,140px);line-height:0.85;letter-spacing:-0.01em;
  color:var(--bone);
  text-shadow:6px 6px 0 var(--copper);
}
.year-line{height:1px;background:var(--copper-soft);align-self:center;margin-bottom:18px}
.year-count{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--copper);margin-bottom:18px;white-space:nowrap;
}

.disco-list{display:flex;flex-direction:column;gap:0}
.disco-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:24px;align-items:center;
  padding:18px 4px;
  border-bottom:1px solid rgba(200,122,61,0.12);
  transition:background-color .25s ease;
}
.disco-row:hover{background:rgba(200,122,61,0.04)}

.disco-cover{position:relative;width:80px;aspect-ratio:1/1;overflow:hidden;background:var(--bg-elev)}
.disco-cover img{width:100%;height:100%;object-fit:cover}
.disco-cover-fallback{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:rgba(200,122,61,0.4);
}
.disco-new{
  position:absolute;top:4px;left:4px;
  font-family:var(--font-mono);font-size:8px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--bg);background:var(--copper);
  padding:2px 6px;
}
.disco-coming{
  position:absolute;top:4px;left:4px;
  font-family:var(--font-mono);font-size:8px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--bone);background:var(--rust);
  padding:2px 6px;
}
.disco-row--coming{
  background:linear-gradient(90deg,rgba(168,58,29,0.06),transparent 70%);
}
.disco-row--coming .disco-type{color:var(--rust)}

.disco-text{display:flex;flex-direction:column;gap:4px;min-width:0}
.disco-type{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.28em;
  text-transform:uppercase;color:var(--copper);
}
.disco-title-row{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(22px,2.4vw,30px);line-height:1.05;letter-spacing:0.01em;
  text-transform:uppercase;color:var(--bone);
}
.disco-date{
  font-family:var(--font-mono);font-size:11px;color:var(--bone-faint);
}

.disco-listen{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.25em;
  text-transform:uppercase;color:var(--copper);text-decoration:none;
  padding:8px 14px;border:1px solid var(--copper-soft);
  transition:all .25s;
}
.disco-listen:hover{background:rgba(200,122,61,0.10);border-color:var(--copper)}
.disco-listen svg{width:12px;height:12px}
.disco-listen--coming{
  color:var(--rust);border-color:rgba(168,58,29,0.4);
}
.disco-listen--coming:hover{background:rgba(168,58,29,0.10);border-color:var(--rust)}

.disco-empty{
  max-width:600px;margin:80px auto;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.empty-mark{font-family:var(--font-display);font-size:80px;color:var(--copper);opacity:0.6}
.empty-text{font-family:var(--font-serif);font-style:italic;font-size:18px;color:var(--bone-dim)}

/* ═══════════════════════════════════════════════════════════════════════════
   LIVE — ticket stubs
   ═══════════════════════════════════════════════════════════════════════════ */
.live-section{
  padding:120px 5vw 120px;
  background:
    linear-gradient(180deg,rgba(10,8,6,0.92),rgba(10,8,6,0.92)),
    repeating-linear-gradient(45deg,transparent 0 28px,rgba(200,122,61,0.04) 28px 29px);
  border-top:1px solid rgba(200,122,61,0.08);
}

.ticket-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:24px;
}

.ticket{
  display:grid;grid-template-columns:140px 1fr;
  background:var(--bone);color:#2a1a10;
  position:relative;
  box-shadow:0 18px 40px rgba(0,0,0,0.55),0 2px 0 rgba(0,0,0,0.4);
  transform:rotate(-0.4deg);
  transition:transform .35s var(--ease);
  overflow:hidden;
}
.ticket:nth-child(even){transform:rotate(0.3deg)}
.ticket:hover{transform:rotate(0) translateY(-3px)}

/* Souche perforée */
.ticket-stub{
  background:var(--smoke);color:var(--bone);
  padding:18px 14px;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  text-align:center;gap:8px;
  position:relative;
}
/* Perforation entre souche et corps */
.ticket-stub::after{
  content:'';position:absolute;top:0;bottom:0;right:-1px;width:2px;
  background-image:radial-gradient(circle,var(--bg) 1.5px,transparent 1.5px);
  background-size:2px 8px;background-repeat:repeat-y;
}
.ticket-stub-num{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.25em;
  color:var(--copper);
}
.ticket-stub-stamp{
  font-family:var(--font-display);font-weight:800;
  font-size:22px;line-height:0.95;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--bone);
  padding:8px 12px;border:2px solid var(--copper);
  transform:rotate(-4deg);
  position:relative;
}
.ticket-stub-stamp::before{
  content:'';position:absolute;inset:-3px;border:1px dashed rgba(200,122,61,0.5);
}
.ticket-stub-date{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  color:var(--bone-dim);
}

/* Corps du ticket */
.ticket-body{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  padding:22px 28px;
  background:
    linear-gradient(180deg,var(--bone),#dfd5be);
}
.ticket-day{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(60px,7vw,92px);line-height:0.85;letter-spacing:-0.01em;
  color:#2a1a10;
}
.ticket-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.ticket-venue{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(20px,2vw,26px);text-transform:uppercase;letter-spacing:0.02em;
  color:#2a1a10;line-height:1.1;
}
.ticket-tour{
  font-family:var(--font-serif);font-style:italic;font-size:14px;
  color:var(--whisky);margin-top:2px;
}
.ticket-loc{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:#6a4830;margin-top:4px;
}
.ticket-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;
  background:#2a1a10;color:var(--bone);text-decoration:none;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.22em;
  text-transform:uppercase;
  transition:background .25s;white-space:nowrap;
}
.ticket-cta:hover{background:var(--rust)}
.ticket-cta svg{width:12px;height:12px}
.ticket-cta--sold,.ticket-cta--tba{
  background:transparent;color:var(--rust);border:1.5px solid var(--rust);
  cursor:default;
}
.ticket-cta--tba{color:var(--ash);border-color:var(--ash)}
.ticket--sold-out .ticket-day,.ticket--sold-out .ticket-venue{opacity:0.4}

.live-empty{max-width:520px;margin:60px auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}
.empty-stamp .empty-stamp-frame{
  display:inline-block;padding:18px 28px;
  border:2.5px solid var(--copper);
  font-family:var(--font-display);font-weight:800;font-size:24px;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--copper);
  transform:rotate(-3deg);line-height:1;
  position:relative;
}
.empty-stamp .empty-stamp-frame::after{
  content:'';position:absolute;inset:-4px;border:1px dashed rgba(200,122,61,0.4);
}
.live-empty p{font-family:var(--font-serif);font-style:italic;color:var(--bone-dim);max-width:380px}

/* ═══════════════════════════════════════════════════════════════════════════
   CONNECT — sceau
   ═══════════════════════════════════════════════════════════════════════════ */
.connect-section{
  padding:120px 5vw 100px;background:var(--bg);
  background-image:radial-gradient(ellipse at center top,rgba(156,88,38,0.08),transparent 60%);
  border-top:1px solid rgba(200,122,61,0.08);
}

.seal-frame{
  max-width:780px;margin:50px auto 0;
  padding:42px 50px;
  background:rgba(26,16,10,0.4);
  border:double 4px var(--copper);
  position:relative;
}
.seal-corner{
  position:absolute;width:24px;height:24px;
  border:1.5px solid var(--copper);
}
.seal-corner--tl{top:-2px;left:-2px;border-right:none;border-bottom:none}
.seal-corner--tr{top:-2px;right:-2px;border-left:none;border-bottom:none}
.seal-corner--bl{bottom:-2px;left:-2px;border-right:none;border-top:none}
.seal-corner--br{bottom:-2px;right:-2px;border-left:none;border-top:none}

.seal-header{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding-bottom:28px;border-bottom:1px solid var(--copper-soft);margin-bottom:32px}
.seal-est,.seal-loc{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--copper);
}
.seal-wordmark{
  display:flex;align-items:center;justify-content:center;
  width:100%;
}
.seal-wordmark img{
  height:clamp(56px,8vw,90px);width:auto;display:block;
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
}

.seal-body{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:start}
.seal-divider{width:1px;background:var(--copper-soft)}

.seal-group{display:flex;flex-direction:column;gap:14px}
.seal-group-title{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--copper);text-align:center;
}
.seal-group-links{display:flex;flex-direction:column;gap:6px}
.seal-link{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  font-family:var(--font-serif);font-size:15px;color:var(--bone-dim);
  text-decoration:none;border:1px solid transparent;
  transition:all .25s;
}
.seal-link:hover{color:var(--bone);border-color:var(--copper-soft);background:rgba(200,122,61,0.06)}
.seal-link svg{width:14px;height:14px;fill:currentColor;opacity:0.7;flex-shrink:0}

.seal-press{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--copper-soft);
  text-align:center;
}
.press-label{
  display:block;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.35em;
  text-transform:uppercase;color:var(--copper);margin-bottom:6px;
}
.seal-press a{
  font-family:var(--font-serif);font-style:italic;font-size:18px;
  color:var(--bone);text-decoration:none;border-bottom:1px solid var(--copper-soft);
  transition:border-color .25s;
}
.seal-press a:hover{border-bottom-color:var(--copper)}

/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════════ */
.site-footer{
  padding:60px 5vw 50px;background:var(--bg);text-align:center;
  border-top:1px solid var(--copper-soft);
}
.footer-wordmark{
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.footer-wordmark img{
  height:38px;width:auto;display:block;
  filter:brightness(0) invert(1) sepia(0.08) saturate(2) hue-rotate(350deg);
  opacity:0.7;
}
.footer-credit{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--bone-faint);
}
.footer-credit a{color:inherit;text-decoration:none;transition:color .25s}
.footer-credit a:hover{color:var(--copper)}

/* ═══════════════════════════════════════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════════════════════════════════════ */
@media(max-width:960px){
  .single-grid{grid-template-columns:1fr;gap:60px}
  .vinyl-stage{order:-1}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .polaroid{max-width:340px;margin:0 auto}
  .bio-columns{column-count:1}
  .seal-body{grid-template-columns:1fr;gap:24px}
  .seal-divider{display:none}
}

@media(max-width:720px){
  .top-nav{padding:14px 5vw}
  .nav-burger{display:block}
  .nav-menu{
    position:fixed;top:0;right:0;bottom:0;width:78%;max-width:320px;z-index:49;
    background:rgba(10,8,6,0.97);backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;align-items:flex-start;
    gap:24px;padding:80px 36px;
    transform:translateX(100%);transition:transform .35s var(--ease);
    border-left:1px solid var(--copper-soft);
  }
  .nav-menu.open{transform:translateX(0)}
  .nav-menu a{font-size:16px}

  .hero{padding:100px 5vw 60px}
  .hero-meta{gap:10px;margin-bottom:20px}
  .hero-meta .meta-line{flex:0 0 30px}

  .section-title{font-size:clamp(46px,12vw,80px)}
  .year-marker{grid-template-columns:1fr;gap:8px}
  .year-line{display:none}
  .year-count{margin-bottom:0}

  .disco-row{grid-template-columns:60px 1fr;gap:14px}
  .disco-cover{width:60px}
  .disco-listen{grid-column:1 / -1;justify-self:start;margin-top:4px}

  .ticket{grid-template-columns:100px 1fr}
  .ticket-body{grid-template-columns:auto 1fr;gap:14px;padding:16px 18px}
  .ticket-body .ticket-cta{grid-column:1/-1;justify-self:start;margin-top:6px}
  .ticket-stub-stamp{font-size:16px;padding:6px 10px}
  .ticket-day{font-size:54px}

  .seal-frame{padding:30px 24px}
}