/*
Theme Name: SANDER
Theme URI: https://sander.fr
Author: PULS
Description: Thème custom one-page pour le DJ SANDER. Made by PULS.
Version: 1.1.4
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: sander
*/

:root{
  --bg:#0A0A12;
  --bg-2:#0E0E18;
  --bg-3:#14141F;
  --line:rgba(255,255,255,0.10);
  --line-2:rgba(255,255,255,0.06);
  --txt:#F2F2F2;
  --txt-2:#B5B5B5;
  --txt-3:#6E6E6E;
  --accent:#4A6CFF;
  --accent-deep:#2D4ADE;
  --accent-violet:#7B5AFF;
  --accent-cyan:#3FB8FF;
  --accent-soft:rgba(74,108,255,0.12);
  --accent-glow:rgba(74,108,255,0.4);
  /* Contenu pleine largeur — limité seulement par le padding latéral (léger, = nav) */
  --maxw:100%;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--txt);font-family:'Inter',-apple-system,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Accessibilité — focus visible */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible{outline-offset:4px}

/* Scroll-margin — pour pas que la nav fixe cache le titre quand on clique sur un lien d'ancre */
section[id]{scroll-margin-top:80px}

/* Skip link accessibilité */
.skip-link{position:absolute;top:-40px;left:0;background:var(--accent);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;font:600 13px 'Inter';z-index:200;transition:top .2s}
.skip-link:focus{top:0}

/* Reveal-on-scroll — apparition douce des sections */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* Préférence accessibilité : pas d'animation pour ceux qui veulent pas */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* HALOS COLORÉS FIXES — bleu + violet + cyan, plus présents */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 10% 15%, rgba(74,108,255,0.18) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 90% 30%, rgba(123,90,255,0.14) 0%, transparent 55%),
    radial-gradient(ellipse 90% 60% at 50% 85%, rgba(63,184,255,0.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 85% 70%, rgba(74,108,255,0.12) 0%, transparent 55%);
}

/* TEXTURE GRAIN — overlay subtile, ajoute du caractère sans criard */
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:0.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.18'/></svg>");
}

/* === NAV === */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px 40px;background:rgba(10,10,14,0.72);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--line-2)}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo img{height:32px;width:auto;filter:drop-shadow(0 1px 4px rgba(0,0,0,.4))}
.nav-links{display:flex;gap:40px;justify-content:center}
.nav-links a{font:500 13px/1 'Inter';color:var(--txt-2);letter-spacing:0.04em;transition:color .25s;position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:50%;bottom:-2px;width:0;height:1px;background:var(--accent);transition:all .3s}
.nav-links a:hover{color:var(--txt)}
.nav-links a:hover::after{left:0;width:100%}
.nav-right{display:flex;justify-content:flex-end;align-items:center;gap:14px;height:100%}
.nav-socials{display:flex;gap:10px;align-items:center;height:32px}
.nav-socials a{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--txt-2);transition:all .25s}
.nav-socials a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-socials svg{width:16px;height:16px;fill:currentColor}

/* === HERO === */
.hero{position:relative;height:100vh;min-height:760px;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 25%;filter:contrast(1.05) saturate(0.92) brightness(0.78);transform:scale(1.04);animation:slowzoom 22s ease-in-out infinite alternate}
@keyframes slowzoom{from{transform:scale(1.04)}to{transform:scale(1.08)}}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 80% 60% at 20% 60%, rgba(74,108,255,0.32) 0%, transparent 55%),
  radial-gradient(ellipse 60% 50% at 85% 30%, rgba(123,90,255,0.24) 0%, transparent 60%),
  radial-gradient(circle at 100% 100%, rgba(63,184,255,0.18) 0%, transparent 50%),
  linear-gradient(180deg, rgba(10,10,18,.45) 0%, transparent 30%, rgba(10,10,18,.5) 70%, rgba(10,10,18,.98) 100%);
  mix-blend-mode:normal;pointer-events:none}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:0 40px 80px;z-index:3}
.hero-title{font:900 clamp(80px,16vw,260px)/0.85 'Inter';letter-spacing:-0.07em;color:#fff;margin-bottom:36px}
.hero-footer{display:grid;grid-template-columns:1fr auto;gap:64px;align-items:end;border-top:1px solid rgba(255,255,255,.16);padding-top:32px;max-width:var(--maxw)}
.hero-tagline{font:400 18px/1.55 'Inter';color:#ddd;max-width:560px}
.hero-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:#fff;color:#000;border-radius:999px;font:600 14px 'Inter';letter-spacing:0.02em;transition:all .3s;white-space:nowrap}
.hero-btn::after{content:"→";transition:transform .3s}
.hero-btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 12px 32px rgba(74,108,255,0.32)}
.hero-btn:hover::after{transform:translateX(4px)}


/* === SECTIONS === */
.section{padding:140px 40px;position:relative}
.section-head{margin-bottom:64px;border-bottom:1px solid var(--line);padding-bottom:28px;max-width:var(--maxw);margin-left:auto;margin-right:auto}
.section-title{font:800 clamp(40px,5vw,72px)/0.95 'Inter';letter-spacing:-0.04em;color:var(--txt)}

/* === STATS STRIP === */
.stats-strip{padding:32px 40px;background:linear-gradient(135deg, rgba(74,108,255,0.10) 0%, rgba(123,90,255,0.06) 100%), var(--bg-2);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);position:relative;overflow:hidden}
.stats-strip::before{content:"";position:absolute;top:-50%;right:-10%;width:600px;height:300px;border-radius:50%;background:radial-gradient(ellipse,rgba(74,108,255,0.2) 0%,transparent 70%);pointer-events:none;filter:blur(30px)}
.stats-wrap{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px 48px;position:relative;z-index:1}
.stats-l{font:500 11px 'Inter';letter-spacing:0.22em;text-transform:uppercase;color:var(--txt-3);white-space:nowrap}
.stat-card{display:flex;align-items:center;gap:20px;padding:14px 0;transition:all .3s ease}
.stat-card:hover{transform:translateX(4px)}
.stat-card:hover .icon{transform:scale(1.08)}
.stat-card .icon{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:transform .3s ease}
.stat-card .icon svg{width:22px;height:22px;fill:currentColor}
.stat-card.insta .icon{background:linear-gradient(45deg,#FEDA75 0%, #FA7E1E 25%, #D62976 50%, #962FBF 75%, #4F5BD5 100%);box-shadow:0 4px 16px rgba(214,41,118,0.35)}
.stat-card.tiktok .icon{background:#0A0A0E;border:1px solid rgba(255,255,255,0.15);position:relative}
.stat-card.tiktok .icon::before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,rgba(37,244,238,0.2) 0%, rgba(254,44,85,0.2) 100%);pointer-events:none}
.stat-card.sc .icon{background:#FF5500;box-shadow:0 4px 16px rgba(255,85,0,0.32)}
.stat-card.yt .icon{background:#FF0000;box-shadow:0 4px 16px rgba(255,0,0,0.30)}
.stat-card .info{display:flex;flex-direction:column;gap:2px}
.stat-card .n{font:800 28px 'Inter';color:#fff;letter-spacing:-0.02em;line-height:1.1}
.stat-card .l{font:500 11px 'Inter';letter-spacing:0.18em;text-transform:uppercase;color:var(--txt-3)}

/* === MUSIC === */
.music{background:var(--bg-2);border-top:1px solid var(--line-2);position:relative;overflow:hidden}
.music::before{content:"";position:absolute;top:-300px;left:-200px;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(74,108,255,0.18) 0%,transparent 65%);pointer-events:none;z-index:0}
.music::after{content:"";position:absolute;bottom:-200px;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(123,90,255,0.14) 0%,transparent 65%);pointer-events:none;z-index:0}
.music-wrap{max-width:var(--maxw);margin:0 auto;position:relative;z-index:1}

/* === HIT EN PROÉMINENCE === */
.hit{
  background:linear-gradient(135deg, rgba(74,108,255,0.08) 0%, rgba(120,80,200,0.04) 100%);
  border:1px solid rgba(74,108,255,0.2);
  border-radius:24px;
  padding:48px;
  margin-bottom:80px;
  position:relative;
  overflow:hidden;
}
.hit::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(74,108,255,0.15) 0%, transparent 70%);pointer-events:none}
.hit-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:center;position:relative;z-index:1}
.hit-cover{aspect-ratio:1;border-radius:14px;overflow:hidden;position:relative;box-shadow:0 32px 80px rgba(0,0,0,0.5), 0 0 60px rgba(74,108,255,0.15);border:1px solid rgba(255,255,255,0.08)}
.hit-cover img{width:100%;height:100%;object-fit:cover}
.hit-info h2{font:900 clamp(40px,5vw,72px)/0.95 'Inter';letter-spacing:-0.035em;color:#fff;margin-bottom:14px}
.hit-info .sub{font:500 13px 'Inter';color:var(--txt-2);margin-bottom:32px;letter-spacing:0.04em}
.hit-info .desc{font:400 17px/1.65 'Inter';color:var(--txt-2);margin-bottom:36px;max-width:500px}
.hit-info .desc strong{color:#fff;font-weight:600}

/* Player SoundCloud direct */
.hit-player{margin-bottom:32px;border-radius:10px;overflow:hidden;background:#15151B}
.hit-player iframe{display:block;border:0}

.hit-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-bottom:32px;border-top:1px solid var(--line);padding-top:24px}
.hit-stat{text-align:center;border-right:1px solid var(--line);padding:0 14px}
.hit-stat:last-child{border-right:none}
.hit-stat .n{font:800 24px 'Inter';color:#fff;letter-spacing:-0.02em}
.hit-stat .l{font:500 10px 'Inter';letter-spacing:0.2em;text-transform:uppercase;color:var(--txt-3);margin-top:4px}
.hit-actions{display:flex;flex-wrap:wrap;gap:8px}
.btn-sc{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:#FF5500;color:#fff;border-radius:999px;font:600 13px 'Inter';letter-spacing:0.02em;transition:all .25s}
.btn-sc:hover{background:#e54d00;transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:transparent;border:1px solid var(--line);border-radius:999px;font:500 13px 'Inter';color:var(--txt);letter-spacing:0.02em;transition:all .25s}
.btn-ghost:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.3)}

/* === RECENT === */
.recent-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.recent-head h3{font:700 22px 'Inter';color:#fff;letter-spacing:-0.015em}
.recent-head a{font:500 13px 'Inter';color:var(--txt-2);letter-spacing:0.04em;border-bottom:1px solid var(--line);padding-bottom:2px;transition:all .25s}
.recent-head a:hover{color:var(--accent);border-color:var(--accent)}
.recent{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.track{cursor:pointer;transition:transform .3s}
.track:hover{transform:translateY(-4px)}
.track:hover .track-cover{border-color:var(--accent)}
.track-cover{aspect-ratio:1;border-radius:10px;background:linear-gradient(135deg,#1a1a1f,#0a0a0e);margin-bottom:16px;overflow:hidden;position:relative;border:1px solid var(--line);transition:all .3s}
.track-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.track-cover .play-mini{position:absolute;bottom:14px;right:14px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.95);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:all .3s;z-index:2}
.track:hover .play-mini{opacity:1;transform:translateY(0)}
.track-cover .play-mini svg{width:16px;height:16px;color:#000;margin-left:2px}
.track h4{font:600 16px 'Inter';color:#fff;margin-bottom:4px;letter-spacing:-0.01em}
.track .meta{font:500 12px 'Inter';color:var(--txt-3);letter-spacing:0.02em}

/* === DATES === */
.dates-section{background:var(--bg);border-top:1px solid var(--line-2);position:relative;overflow:hidden}
.dates-section::before{content:"";position:absolute;top:10%;right:-300px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(63,184,255,0.12) 0%,transparent 65%);pointer-events:none;z-index:0}
.dates-section .section-head,.dates-wrap{position:relative;z-index:1}
.dates-wrap{max-width:var(--maxw);margin:0 auto}
.date{display:grid;grid-template-columns:140px 1fr 200px;gap:48px;align-items:center;padding:32px 0;border-top:1px solid var(--line);position:relative;transition:all .35s ease;text-decoration:none;color:inherit;cursor:pointer}
.date:last-of-type{border-bottom:1px solid var(--line)}
.date:hover{background:rgba(74,108,255,0.04);padding-left:24px;padding-right:24px}
/* Dates au-delà des 5 premières : masquées jusqu'au clic « Voir plus » */
.date.is-extra{display:none}
.dates-wrap.is-expanded .date.is-extra{display:grid}
.dates-wrap:not(.is-expanded) .date:nth-of-type(5){border-bottom:1px solid var(--line)}
.dates-more{display:flex;justify-content:center;margin-top:40px}
.dates-toggle{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:transparent;border:1px solid var(--line);border-radius:999px;font:600 13px 'Inter';color:var(--txt);letter-spacing:0.04em;cursor:pointer;transition:all .25s}
.dates-toggle:hover{border-color:var(--accent);color:var(--accent);background:rgba(74,108,255,0.06)}
.dates-toggle::after{content:"↓";font-size:14px;transition:transform .3s}
.dates-wrap.is-expanded .dates-toggle::after{transform:rotate(180deg)}
.date.is-past{opacity:0.35;transition:opacity .3s}
.date.is-past:hover{opacity:0.7}
.date.is-next{position:relative}
.date.is-next::before{content:"";position:absolute;left:-22px;top:14%;bottom:14%;width:3px;background:var(--accent);border-radius:2px;box-shadow:0 0 10px rgba(74,108,255,0.45)}
.date.is-next .date-when::before{content:"Prochain set";display:block;font:600 10px/1.2 'Inter',sans-serif;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.date.is-next .date-when strong{color:#fff;font-size:32px}
.date.is-next:hover{background:rgba(74,108,255,0.08)}
.date-when{font:500 11px 'Inter';letter-spacing:0.16em;text-transform:uppercase;color:var(--txt-3)}
.date-when strong{display:block;font:800 28px 'Inter';color:var(--txt);letter-spacing:-0.02em;margin-bottom:4px;text-transform:none}
.date-where h3{font:600 22px 'Inter';color:#fff;letter-spacing:-0.01em;margin-bottom:6px}
.date-where p{font:400 14px 'Inter';color:var(--txt-3);letter-spacing:0.02em}
.date-city{font:500 13px 'Inter';letter-spacing:0.16em;text-transform:uppercase;color:var(--txt-2);text-align:right}
.date-city span{display:block;color:var(--txt-3);font-size:11px;margin-top:6px;letter-spacing:0.22em}

/* === GALLERY (refaite, propre) === */
.gallery-section{background:var(--bg-2);border-top:1px solid var(--line-2);position:relative;overflow:hidden}
.gallery-section::before{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:500px;border-radius:50%;background:radial-gradient(ellipse,rgba(74,108,255,0.14) 0%,transparent 70%);pointer-events:none;z-index:0;filter:blur(20px)}
.gallery-section .section-head,.gallery-wrap{position:relative;z-index:1}
.gallery-wrap{max-width:var(--maxw);margin:0 auto}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:160px;gap:8px}
.gi{position:relative;overflow:hidden;background:#1a1a1a;border-radius:6px}
.gi img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform 1s cubic-bezier(.2,.8,.2,1), filter .4s;filter:saturate(.95) brightness(0.92);cursor:zoom-in}
.gi:hover img{transform:scale(1.05);filter:saturate(1.08) brightness(1)}

/* Lightbox galerie */
.lightbox{position:fixed;inset:0;background:rgba(8,8,12,0.96);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:32px;cursor:zoom-out;opacity:0;transition:opacity .25s ease}
.lightbox.open{opacity:1}
.lightbox img{max-width:92vw;max-height:92vh;object-fit:contain;border-radius:8px;box-shadow:0 24px 80px rgba(0,0,0,0.7);animation:lbZoom .3s cubic-bezier(.2,.8,.2,1)}
.lightbox-close{position:absolute;top:24px;right:24px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font:300 24px 'Inter';transition:background .2s}
.lightbox-close:hover{background:rgba(255,255,255,0.18)}
@keyframes lbZoom{from{transform:scale(0.94);opacity:0}to{transform:scale(1);opacity:1}}
.gi.a{grid-column:span 6;grid-row:span 4}
.gi.b{grid-column:span 3;grid-row:span 2}
.gi.c{grid-column:span 3;grid-row:span 2}
.gi.d{grid-column:span 3;grid-row:span 2}
.gi.e{grid-column:span 3;grid-row:span 2}
.gi.f{grid-column:span 4;grid-row:span 2}
.gi.g{grid-column:span 4;grid-row:span 2}
.gi.h{grid-column:span 4;grid-row:span 2}

/* === ABOUT === */
.about{background:var(--bg);border-top:1px solid var(--line-2);position:relative;overflow:hidden}
.about::before{content:"";position:absolute;top:5%;right:-250px;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(123,90,255,0.16) 0%,transparent 65%);pointer-events:none;z-index:0}
.about::after{content:"";position:absolute;bottom:-200px;left:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(74,108,255,0.12) 0%,transparent 65%);pointer-events:none;z-index:0}
.about .section-head,.about-wrap{position:relative;z-index:1}
.about-wrap{display:grid;grid-template-columns:0.85fr 1.15fr;gap:96px;align-items:start;max-width:var(--maxw);margin:0 auto;position:relative;z-index:1}
.about-portrait{aspect-ratio:4/5;border-radius:12px;overflow:hidden;position:sticky;top:120px;box-shadow:0 24px 80px rgba(0,0,0,.6);border:1px solid var(--line)}
.about-portrait img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04)}
.about-body{padding-top:8px}
.about-body .lead{font:500 26px/1.45 'Inter';color:#fff;margin-bottom:48px;letter-spacing:-0.015em;max-width:640px;position:relative;padding-left:28px}
.about-body .lead::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:2px}
.about-body p{font:400 17px/1.8 'Inter';color:var(--txt-2);margin-bottom:24px;max-width:640px}
.about-body p strong{color:#fff;font-weight:600}

/* === CONTACT (discret, pour pros) === */
.contact{padding:96px 40px;background:var(--bg-2);border-top:1px solid var(--line-2);text-align:center;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:500px;border-radius:50%;background:radial-gradient(ellipse,rgba(74,108,255,0.10) 0%,transparent 70%);pointer-events:none;z-index:0;filter:blur(40px)}
.contact-wrap{max-width:640px;margin:0 auto;position:relative;z-index:1}
.contact .eyebrow{font:500 11px 'Inter';letter-spacing:0.22em;text-transform:uppercase;color:var(--txt-3);margin-bottom:18px;display:inline-block}
.contact h2{font:700 36px/1.1 'Inter';letter-spacing:-0.025em;color:#fff;margin-bottom:18px}
.contact p{font:400 15px/1.6 'Inter';color:var(--txt-2);margin-bottom:32px}
.contact-mail{display:inline-block;font:500 16px 'Inter';color:#fff;padding:14px 26px;border:1px solid var(--line);border-radius:999px;transition:all .25s;letter-spacing:0.02em}
.contact-mail:hover{border-color:var(--accent);color:var(--accent)}

/* === FOOTER === */
.footer{padding:40px;background:var(--bg);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;border-top:1px solid var(--line-2)}
.footer-l{display:flex;align-items:center;gap:12px}
.footer-l img{height:28px;opacity:.7}
.footer-c{font:500 11px 'Inter';color:var(--txt-3);letter-spacing:0.16em;text-transform:uppercase}
.footer-r{display:flex;gap:10px;align-items:center}
.footer-r a{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--txt-2);border:1px solid var(--line);transition:all .25s}
.footer-r a:hover{color:#fff;border-color:#fff}
.footer-r svg{width:16px;height:16px;fill:currentColor}

@media (max-width:1100px){
  .hit-grid{grid-template-columns:1fr;gap:40px}
  .recent{grid-template-columns:repeat(2,1fr)}
}
/* Tablette */
@media (max-width:1024px){
  .section{padding:100px 32px}
  .hit-grid{gap:40px}
  .recent{grid-template-columns:repeat(2,1fr)}
  .about-wrap{gap:64px}
  .gallery-wrap{padding:0}
}

/* Tablette portrait */
@media (max-width:900px){
  .nav{padding:14px 20px}
  .nav-links{display:none}
  .stats-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;align-items:center}
  .hit-grid{grid-template-columns:1fr;gap:32px}
  .hit-cover{max-width:480px;margin:0 auto}
  .recent{grid-template-columns:repeat(2,1fr)}
  .about-wrap{grid-template-columns:1fr;gap:48px}
  .about-portrait{position:relative;top:auto;max-width:480px;margin:0 auto}
}

/* Mobile */
@media (max-width:640px){
  .nav{padding:14px 16px;grid-template-columns:auto 1fr auto}
  .nav-socials{gap:4px}
  .nav-socials a{width:30px;height:30px}
  .hero{min-height:640px}
  /* Crop portrait : recentrer sur le sujet (Sander, à droite de la photo) */
  .hero-bg img{object-position:76% 28%}
  .hero-content{padding:0 20px 32px}
  .hero-meta{margin-bottom:20px;font-size:10px;letter-spacing:0.2em}
  .hero-title{margin-bottom:24px}
  .hero-footer{grid-template-columns:1fr;gap:20px;padding-top:24px}
  .hero-info{flex-wrap:wrap;gap:20px}
  .hero-btn{padding:14px 26px;font-size:13px;width:100%;justify-content:center}
  .scroll-cue{display:none}
  .section{padding:72px 20px}
  .section-head{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:36px;padding-bottom:20px}
  .section-head .right{text-align:left;max-width:none}
  .stats-strip{padding:28px 20px}
  .stats-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px 12px;align-items:center}
  .stat-card{flex-direction:row;gap:10px;padding:0}
  .stat-card .icon{width:38px;height:38px}
  .stat-card .icon svg{width:17px;height:17px}
  .stat-card .n{font-size:17px}
  .stat-card .l{font-size:9px;letter-spacing:0.12em}
  .hit{padding:24px;border-radius:18px}
  .hit-tag{padding:6px 14px;font-size:10px}
  .hit-info h2{font-size:28px;line-height:1.05;margin-bottom:10px}
  .hit-info .sub{margin-bottom:24px;font-size:11px}
  .hit-info .desc{font-size:14px;margin-bottom:24px}
  .hit-stats{grid-template-columns:repeat(3,1fr);margin-bottom:24px;padding-top:18px;gap:4px}
  .hit-stat{padding:0 4px}
  .hit-stat .n{font-size:16px}
  .hit-stat .l{font-size:8px;letter-spacing:0.14em}
  .hit-actions{flex-direction:column}
  .hit-actions .btn-sc,.hit-actions .btn-ghost{width:100%;justify-content:center}
  /* FIX 1 — recent en 2 colonnes sur mobile */
  .recent{grid-template-columns:repeat(2,1fr);gap:16px}
  .track h4{font-size:13px}
  .track .meta{font-size:10px;letter-spacing:0.01em}
  .track-cover{border-radius:8px}
  .recent-head{flex-direction:column;align-items:flex-start;gap:12px}
  .recent-head a{font-size:12px}
  /* FIX 5 — galerie 9 photos sur mobile, sans vide */
  .gallery{grid-template-columns:repeat(6,1fr);grid-auto-rows:120px;gap:6px}
  .gi.a{grid-column:span 6;grid-row:span 3}
  .gi.b,.gi.c,.gi.d,.gi.e{grid-column:span 3;grid-row:span 2}
  .gi.f,.gi.g,.gi.h{grid-column:span 6;grid-row:span 2}
  /* Dates compactes — date à gauche, lieu + ville à droite (2 lignes) */
  .date{grid-template-columns:auto 1fr;grid-template-areas:"when where" "when city";column-gap:16px;row-gap:1px;padding:16px 0;align-items:center}
  .date-when{grid-area:when;align-self:center}
  .date-where{grid-area:where;align-self:end}
  .date-city{grid-area:city;align-self:start;text-align:left;font-size:11px}
  .date-city span{margin-top:2px;letter-spacing:0.14em}
  .date-when strong{font-size:21px;margin-bottom:1px}
  .date-where h3{font-size:16px;margin-bottom:0}
  .date:hover{padding-left:12px;padding-right:12px}
  /* Prochaine date — barre accent (border-left), pas de label texte ni de barre ::before sur mobile */
  .date.is-next .date-when::before{display:none}
  .date.is-next::before{display:none}
  .date.is-next{border-left:3px solid var(--accent);padding-left:12px}
  .about-body .lead{font-size:19px;padding-left:18px;margin-bottom:28px}
  .about-body p{font-size:14px;line-height:1.7}
  .contact{padding:64px 20px}
  .contact h2{font-size:26px}
  .contact-mail{font-size:13px;padding:11px 20px;display:block;text-align:center;word-break:break-all}
  .footer{flex-direction:column;align-items:center;text-align:center;padding:32px 20px;gap:20px}
  .footer-l{justify-content:center}
  .footer-l img{height:26px;width:auto}
}
