/* ============================================================
   VICTOR RENY — victor-reny.fr — Refonte 2026
   Direction artistique : « nuit de tablao »
   Noir chaud, braise ambrée, carmin flamenco.
   Typo : Fraunces (titres) + Figtree (texte).
   Aucune dépendance JS/CSS externe hormis Google Fonts.
   ============================================================ */

/* ---------- Variables ---------- */
:root{
	--noir:        #151009;   /* fond principal, noir chaud (bois brûlé) */
	--noir-2:      #1d1610;   /* fond des sections alternées */
	--noir-3:      #251c13;   /* cartes / surfaces */
	--sable:       #f4eadb;   /* texte principal */
	--fumee:       #a6988a;   /* texte secondaire */
	--braise:      #df9a47;   /* accent ambré (lueur de scène) */
	--carmin:      #a8322d;   /* accent rouge flamenco */
	--ligne:       #2c231a;   /* filets discrets */
  
	--police-titre: "Fraunces", Georgia, serif;
	--police-texte: "Figtree", system-ui, -apple-system, sans-serif;
  
	--largeur-max: 1120px;
	--transition:  .35s cubic-bezier(.25,.7,.3,1);
  }
  
  /* ---------- Base ---------- */
  *,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
  html{ scroll-behavior:smooth; }
  @media (prefers-reduced-motion: reduce){
	html{ scroll-behavior:auto; }
	*,*::before,*::after{ animation:none !important; transition:none !important; }
  }
  body{
	background:var(--noir);
	color:var(--sable);
	font-family:var(--police-texte);
	font-size:17px;
	line-height:1.7;
	-webkit-font-smoothing:antialiased;
	overflow-x:hidden;
  }
  img{ max-width:100%; display:block; }
  a{ color:var(--braise); text-decoration:none; transition:color var(--transition); }
  a:hover{ color:var(--sable); }
  :focus-visible{ outline:2px solid var(--braise); outline-offset:3px; border-radius:2px; }
  
  /* ---------- Conteneur ---------- */
  .conteneur{ max-width:var(--largeur-max); margin:0 auto; padding:0 24px; }
  
  /* ---------- Navigation fixe ---------- */
  .nav{
	position:fixed; top:0; left:0; right:0; z-index:100;
	display:flex; align-items:center; justify-content:space-between;
	padding:14px 28px;
	background:linear-gradient(to bottom, rgba(21,16,9,.92), rgba(21,16,9,0));
	transition:background var(--transition), box-shadow var(--transition);
  }
  .nav.est-collee{
	background:rgba(21,16,9,.95);
	backdrop-filter:blur(10px);
	box-shadow:0 1px 0 var(--ligne);
  }
  .nav__marque{
	font-family:var(--police-titre);
	font-weight:600; font-size:1.15rem; letter-spacing:.02em;
	color:var(--sable);
  }
  .nav__marque em{ color:var(--braise); font-style:italic; }
  .nav__liens{ display:flex; gap:26px; list-style:none; }
  .nav__liens a{
	color:var(--fumee); font-size:.82rem; font-weight:600;
	letter-spacing:.14em; text-transform:uppercase;
  }
  .nav__liens a:hover{ color:var(--braise); }
  .nav__cta{
	border:1px solid var(--braise); border-radius:999px;
	padding:7px 18px; color:var(--braise) !important;
  }
  .nav__cta:hover{ background:var(--braise); color:var(--noir) !important; }
  
  /* Bouton burger (mobile) */
  .nav__burger{
	display:none; background:none; border:0; cursor:pointer;
	width:42px; height:42px; position:relative;
  }
  .nav__burger span, .nav__burger span::before, .nav__burger span::after{
	content:""; position:absolute; left:9px; width:24px; height:2px;
	background:var(--sable); transition:transform var(--transition), opacity var(--transition);
  }
  .nav__burger span{ top:20px; }
  .nav__burger span::before{ top:-7px; left:0; }
  .nav__burger span::after{ top:7px; left:0; }
  .nav.est-ouverte .nav__burger span{ background:transparent; }
  .nav.est-ouverte .nav__burger span::before{ transform:translateY(7px) rotate(45deg); }
  .nav.est-ouverte .nav__burger span::after{ transform:translateY(-7px) rotate(-45deg); }
  
  @media (max-width: 880px){
	.nav__burger{ display:block; }
	.nav__liens{
	  position:fixed; inset:0; top:0;
	  flex-direction:column; align-items:center; justify-content:center; gap:30px;
	  background:rgba(21,16,9,.98);
	  opacity:0; pointer-events:none; transition:opacity var(--transition);
	}
	.nav.est-ouverte .nav__liens{ opacity:1; pointer-events:auto; }
	.nav__liens a{ font-size:1.05rem; }
	.nav__burger{ z-index:110; }
  }
  
  /* ---------- Héros ---------- */
  .heros{
	position:relative; min-height:100svh;
	display:grid; grid-template-columns: 1.05fr .95fr;
	align-items:center; overflow:hidden;
  }
  .heros__texte{
	padding:120px 24px 80px calc(max(24px, (100vw - var(--largeur-max)) / 2));
	position:relative; z-index:2;
  }
  .heros__sur-titre{
	font-size:.85rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
	color:var(--braise); margin-bottom:18px;
  }
  .heros__nom{
	font-family:var(--police-titre);
	font-weight:300; font-style:italic;
	font-size:clamp(3.4rem, 8.5vw, 6.8rem);
	line-height:.95; letter-spacing:-.01em;
	margin-bottom:26px;
  }
  .heros__nom b{ font-weight:600; font-style:normal; display:block; }
  .heros__accroche{
	max-width:46ch; color:var(--fumee); font-size:1.08rem; margin-bottom:38px;
  }
  .heros__actions{ display:flex; flex-wrap:wrap; gap:16px; }
  
  /* Photo héros : traitement chaud + fondu vers le fond */
  .heros__photo{
	position:relative; height:100svh; min-height:540px;
  }
  .heros__photo img{
	width:100%; height:100%; object-fit:cover; object-position:center top;
	filter:sepia(.25) saturate(.95) contrast(1.05) brightness(.92);
  }
  .heros__photo::before{
	content:""; position:absolute; inset:0; z-index:1;
	background:
	  linear-gradient(to right, var(--noir) 0%, rgba(21,16,9,.35) 38%, rgba(21,16,9,0) 70%),
	  linear-gradient(to top, var(--noir) 0%, rgba(21,16,9,0) 32%),
	  radial-gradient(ellipse at 75% 30%, rgba(223,154,71,.16), transparent 55%);
  }
  .heros__defile{
	position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
	color:var(--fumee); font-size:.75rem; letter-spacing:.25em; text-transform:uppercase;
	z-index:3; opacity:.8;
  }
  @media (max-width: 880px){
	.heros{ grid-template-columns:1fr; min-height:auto; }
	.heros__photo{ order:-1; height:62svh; min-height:380px; }
	.heros__photo::before{
	  background:
		linear-gradient(to top, var(--noir) 4%, rgba(21,16,9,0) 45%),
		radial-gradient(ellipse at 50% 25%, rgba(223,154,71,.14), transparent 60%);
	}
	.heros__texte{ padding:8px 24px 64px; }
	.heros__defile{ display:none; }
  }
  
  /* ---------- Boutons ---------- */
  .bouton{
	display:inline-flex; align-items:center; gap:10px;
	padding:14px 30px; border-radius:999px;
	font-weight:700; font-size:.92rem; letter-spacing:.06em; text-transform:uppercase;
	border:1px solid transparent; cursor:pointer;
	transition:transform var(--transition), background var(--transition), color var(--transition), border-color var(--transition);
  }
  .bouton:hover{ transform:translateY(-2px); }
  .bouton--plein{ background:var(--braise); color:var(--noir); }
  .bouton--plein:hover{ background:var(--sable); color:var(--noir); }
  .bouton--contour{ border-color:var(--ligne); color:var(--sable); background:transparent; }
  .bouton--contour:hover{ border-color:var(--braise); color:var(--braise); }
  
  /* ---------- Signature : le compás (12 temps de bulería) ----------
	 Accents sur les temps 3, 6, 8, 10 et 12 — séparateur de sections. */
  .compas{
	display:flex; justify-content:center; align-items:center; gap:clamp(8px,2vw,18px);
	padding:54px 0 10px; user-select:none;
  }
  .compas span{
	width:7px; height:7px; border-radius:50%;
	background:var(--ligne);
	transition:background .4s, transform .4s, box-shadow .4s;
  }
  .compas span.accent{ width:10px; height:10px; background:#4a382a; }
  .compas.est-visible span.accent{
	background:var(--braise);
	box-shadow:0 0 14px rgba(223,154,71,.55);
  }
  .compas.est-visible span:nth-child(12).accent{ background:var(--carmin); box-shadow:0 0 14px rgba(168,50,45,.6); }
  .compas__legende{
	text-align:center; color:var(--fumee); opacity:.55;
	font-size:.72rem; letter-spacing:.3em; text-transform:uppercase;
	padding-bottom:44px;
  }
  
  /* ---------- Sections ---------- */
  .section{ padding:50px 0 90px; }
  .section--alt{ background:var(--noir-2); }
  .section__entete{ margin-bottom:48px; max-width:640px; }
  .section__sur-titre{
	color:var(--carmin); font-weight:700; font-size:.8rem;
	letter-spacing:.24em; text-transform:uppercase; margin-bottom:12px;
  }
  .section__titre{
	font-family:var(--police-titre); font-weight:500;
	font-size:clamp(2rem, 4.5vw, 3.1rem); line-height:1.1;
  }
  .section__titre em{ font-style:italic; color:var(--braise); }
  .section__intro{ color:var(--fumee); margin-top:16px; }
  
  /* Apparition au défilement */
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
  .reveal.est-visible{ opacity:1; transform:none; }
  @media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; } }
  
  /* ---------- Formations (3 cartes) ---------- */
  .formations{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
  .formation{
	background:var(--noir-3); border:1px solid var(--ligne); border-radius:14px;
	overflow:hidden; display:flex; flex-direction:column;
	transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  }
  .formation:hover{
	transform:translateY(-6px); border-color:rgba(223,154,71,.45);
	box-shadow:0 22px 50px -22px rgba(0,0,0,.75);
  }
  .formation__photo{ aspect-ratio:16/10; overflow:hidden; }
  .formation__photo img{
	width:100%; height:100%; object-fit:cover;
	filter:sepia(.2) saturate(.95); transition:transform .8s ease, filter .8s ease;
  }
  .formation:hover .formation__photo img{ transform:scale(1.05); filter:sepia(0) saturate(1.05); }
  .formation__corps{ padding:26px 26px 30px; display:flex; flex-direction:column; gap:12px; flex:1; }
  .formation__etiquette{
	color:var(--braise); font-size:.75rem; font-weight:700;
	letter-spacing:.2em; text-transform:uppercase;
  }
  .formation__nom{ font-family:var(--police-titre); font-size:1.55rem; font-weight:600; }
  .formation__desc{ color:var(--fumee); font-size:.97rem; flex:1; }
  .formation__musiciens{ color:var(--sable); font-size:.88rem; opacity:.85; }
  .formation__musiciens strong{ color:var(--braise); font-weight:600; }
  .formation__lien{ font-size:.85rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
  @media (max-width: 980px){ .formations{ grid-template-columns:1fr; max-width:560px; margin:0 auto; } }
  
  /* ---------- Lecteur audio ---------- */
  .audio{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:start; }
  @media (max-width: 880px){ .audio{ grid-template-columns:1fr; } }
  .lecteur{
	background:var(--noir-3); border:1px solid var(--ligne); border-radius:14px; padding:26px;
  }
  .lecteur__titre{ font-family:var(--police-titre); font-size:1.3rem; margin-bottom:4px; min-height:1.6em; }
  .lecteur__compositeur{ color:var(--fumee); font-size:.88rem; margin-bottom:18px; }
  .lecteur__controles{ display:flex; align-items:center; gap:16px; }
  .lecteur__lire{
	width:54px; height:54px; border-radius:50%; flex:none;
	background:var(--braise); color:var(--noir); border:0; cursor:pointer;
	font-size:1.1rem; display:grid; place-items:center;
	transition:transform var(--transition), background var(--transition);
  }
  .lecteur__lire:hover{ transform:scale(1.07); background:var(--sable); }
  .lecteur__barre{ flex:1; display:flex; align-items:center; gap:10px; }
  .lecteur__temps{ color:var(--fumee); font-size:.8rem; font-variant-numeric:tabular-nums; min-width:42px; }
  .lecteur__piste{
	-webkit-appearance:none; appearance:none; width:100%; height:4px; border-radius:2px;
	background:linear-gradient(to right, var(--braise) var(--progression,0%), var(--ligne) var(--progression,0%));
	cursor:pointer;
  }
  .lecteur__piste::-webkit-slider-thumb{
	-webkit-appearance:none; width:13px; height:13px; border-radius:50%;
	background:var(--sable); box-shadow:0 0 0 3px rgba(223,154,71,.35);
  }
  .lecteur__piste::-moz-range-thumb{
	width:13px; height:13px; border:0; border-radius:50%;
	background:var(--sable); box-shadow:0 0 0 3px rgba(223,154,71,.35);
  }
  .liste-pistes{ list-style:none; display:flex; flex-direction:column; }
  .piste{
	display:flex; align-items:center; gap:18px; width:100%; text-align:left;
	background:none; border:0; border-bottom:1px solid var(--ligne);
	padding:18px 10px; cursor:pointer; color:var(--sable); font-family:var(--police-texte);
	transition:background var(--transition), padding var(--transition);
  }
  .piste:hover{ background:rgba(223,154,71,.06); padding-left:18px; }
  .piste.est-active{ background:rgba(223,154,71,.09); }
  .piste__num{ color:var(--fumee); font-size:.8rem; font-variant-numeric:tabular-nums; width:22px; }
  .piste.est-active .piste__num{ color:var(--braise); }
  .piste__titre{ font-size:1.02rem; font-weight:600; flex:1; }
  .piste__info{ color:var(--fumee); font-size:.85rem; }
  /* Petites barres animées sur la piste en cours de lecture */
  .piste__onde{ display:none; gap:3px; align-items:flex-end; height:16px; }
  .piste.est-active.est-en-lecture .piste__onde{ display:flex; }
  .piste__onde i{
	width:3px; background:var(--braise); border-radius:1px;
	animation:onde 1s ease-in-out infinite;
  }
  .piste__onde i:nth-child(2){ animation-delay:.2s; }
  .piste__onde i:nth-child(3){ animation-delay:.4s; }
  @keyframes onde{ 0%,100%{ height:5px; } 50%{ height:16px; } }
  
  /* ---------- Albums ---------- */
  .albums{ display:grid; grid-template-columns:1fr 1fr; gap:26px; margin-top:54px; }
  @media (max-width: 880px){ .albums{ grid-template-columns:1fr; } }
  .album{
	background:var(--noir-3); border:1px solid var(--ligne); border-radius:14px;
	padding:28px; display:flex; flex-direction:column; gap:14px;
  }
  .album__annee{ color:var(--carmin); font-weight:700; font-size:.8rem; letter-spacing:.2em; }
  .album__titre{ font-family:var(--police-titre); font-size:1.6rem; font-weight:600; }
  .album__credits{ color:var(--fumee); font-size:.86rem; }
  .album__plateformes{ display:flex; flex-wrap:wrap; gap:10px; margin-top:6px; }
  .album__plateformes a{
	border:1px solid var(--ligne); border-radius:999px; padding:8px 16px;
	font-size:.82rem; font-weight:600; color:var(--sable);
	transition:border-color var(--transition), color var(--transition), background var(--transition);
  }
  .album__plateformes a:hover{ border-color:var(--braise); color:var(--braise); }
  
  /* ---------- Vidéos ---------- */
  .videos-grille{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  @media (max-width: 980px){ .videos-grille{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width: 640px){ .videos-grille{ grid-template-columns:1fr; } }
  .video{
	position:relative; aspect-ratio:16/9; border-radius:12px; overflow:hidden;
	cursor:pointer; border:1px solid var(--ligne); background:#000;
  }
  .video img{
	width:100%; height:100%; object-fit:cover;
	filter:saturate(.85) brightness(.85); transition:transform .7s ease, filter .7s ease;
  }
  .video:hover img{ transform:scale(1.05); filter:saturate(1) brightness(.95); }
  .video iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
  .video__lire{
	position:absolute; inset:0; display:grid; place-items:center; z-index:2;
	transition:opacity var(--transition);
  }
  .video__lire::before{
	content:""; width:62px; height:62px; border-radius:50%;
	background:rgba(21,16,9,.7); border:1px solid rgba(223,154,71,.6);
	backdrop-filter:blur(4px);
	transition:transform var(--transition), background var(--transition);
  }
  .video__lire::after{
	content:""; position:absolute;
	border-left:16px solid var(--braise);
	border-top:10px solid transparent; border-bottom:10px solid transparent;
	margin-left:5px;
  }
  .video:hover .video__lire::before{ transform:scale(1.1); background:rgba(168,50,45,.55); }
  .videos-sous-titre{
	font-family:var(--police-titre); font-size:1.4rem; font-weight:600;
	margin:48px 0 22px;
  }
  .lien-chaine{ margin-top:26px; font-size:.9rem; }
  
  /* ---------- Partitions ---------- */
  .partitions{ display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:22px; }
  .partition{
	background:var(--noir-3); border:1px solid var(--ligne); border-radius:12px;
	padding:18px; text-align:center; color:var(--sable);
	display:flex; flex-direction:column; gap:12px; align-items:center;
	transition:transform var(--transition), border-color var(--transition);
  }
  .partition:hover{ transform:translateY(-5px); border-color:rgba(223,154,71,.5); color:var(--sable); }
  .partition img{
	width:97px; height:139px; object-fit:cover; border-radius:4px;
	box-shadow:0 10px 26px -10px rgba(0,0,0,.8); background:#fff;
  }
  .partition__titre{ font-family:var(--police-titre); font-size:1.08rem; font-weight:600; }
  .partition__style{ color:var(--fumee); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; }
  .partition__formats{ color:var(--braise); font-size:.75rem; font-weight:700; }
  
  /* ---------- Photos ---------- */
  .galerie{ display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:14px; }
  .galerie button{
	border:0; padding:0; cursor:pointer; border-radius:10px; overflow:hidden;
	aspect-ratio:4/3; background:var(--noir-3);
  }
  .galerie img{
	width:100%; height:100%; object-fit:cover;
	filter:sepia(.18) saturate(.95);
	transition:transform .6s ease, filter .6s ease;
  }
  .galerie button:hover img{ transform:scale(1.06); filter:sepia(0) saturate(1.05); }
  /* Visionneuse plein écran (élément <dialog> natif) */
  .visionneuse{
	border:0; padding:0; background:rgba(12,9,5,.95); max-width:100vw; max-height:100vh;
	width:100vw; height:100vh; display:none; align-items:center; justify-content:center;
  }
  .visionneuse[open]{ display:flex; }
  .visionneuse img{ max-width:92vw; max-height:82vh; object-fit:contain; border-radius:6px; }
  .visionneuse figcaption{
	position:absolute; bottom:28px; left:0; right:0; text-align:center;
	color:var(--fumee); font-size:.85rem; padding:0 24px;
  }
  .visionneuse__fermer{
	position:absolute; top:20px; right:24px;
	background:none; border:1px solid var(--ligne); border-radius:50%;
	width:46px; height:46px; color:var(--sable); font-size:1.2rem; cursor:pointer;
  }
  .visionneuse__fleche{
	position:absolute; top:50%; transform:translateY(-50%);
	background:rgba(21,16,9,.6); border:1px solid var(--ligne); border-radius:50%;
	width:50px; height:50px; color:var(--sable); font-size:1.3rem; cursor:pointer;
  }
  .visionneuse__fleche:hover{ border-color:var(--braise); color:var(--braise); }
  .visionneuse__fleche--prec{ left:22px; }
  .visionneuse__fleche--suiv{ right:22px; }
  
  /* ---------- Biographie ---------- */
  .bio{ display:grid; grid-template-columns:.8fr 1.2fr; gap:54px; align-items:start; }
  @media (max-width: 880px){ .bio{ grid-template-columns:1fr; } }
  .bio__photo{ position:relative; }
  .bio__photo img{
	border-radius:14px; filter:sepia(.2) saturate(.95);
	box-shadow:0 30px 60px -30px rgba(0,0,0,.85);
  }
  .bio__photo::after{
	content:""; position:absolute; inset:18px -18px -18px 18px;
	border:1px solid rgba(223,154,71,.3); border-radius:14px; z-index:-1;
  }
  .bio__texte p{ margin-bottom:18px; color:var(--fumee); text-align:justify; }
  .bio__texte p strong, .bio__texte p b{ color:var(--sable); }
  .bio__citation{
	font-family:var(--police-titre); font-style:italic; font-size:1.5rem;
	color:var(--sable); line-height:1.45; border-left:3px solid var(--carmin);
	padding-left:22px; margin:28px 0;
  }
  .bio__freescores{
	display:flex; gap:20px; align-items:center; margin-top:26px;
	background:var(--noir-3); border:1px solid var(--ligne); border-radius:12px; padding:20px;
  }
  .bio__freescores img{ width:110px; flex:none; }
  .bio__freescores p{ margin:0; font-size:.92rem; }
  
  /* ---------- Contact ---------- */
  .contact{
	text-align:center; max-width:640px; margin:0 auto;
  }
  .contact__titre{
	font-family:var(--police-titre); font-weight:400; font-style:italic;
	font-size:clamp(2.1rem, 5vw, 3.4rem); line-height:1.15; margin-bottom:18px;
  }
  .contact__titre b{ font-weight:600; font-style:normal; color:var(--braise); }
  .contact__texte{ color:var(--fumee); margin-bottom:34px; }
  .contact__actions{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; margin-bottom:40px; }
  .contact__tel{ font-variant-numeric:tabular-nums; }
  
  /* ---------- Réseaux sociaux ---------- */
  .sociaux{ display:flex; gap:14px; justify-content:center; list-style:none; }
  .sociaux a{
	width:46px; height:46px; border-radius:50%;
	border:1px solid var(--ligne); display:grid; place-items:center;
	color:var(--fumee); transition:border-color var(--transition), color var(--transition), transform var(--transition);
  }
  .sociaux a:hover{ border-color:var(--braise); color:var(--braise); transform:translateY(-3px); }
  .sociaux svg{ width:18px; height:18px; fill:currentColor; }
  
  /* ---------- Pied de page ---------- */
  .pied{
	border-top:1px solid var(--ligne); padding:42px 0; text-align:center;
	color:var(--fumee); font-size:.85rem;
  }
  .pied a{ color:var(--fumee); }
  .pied a:hover{ color:var(--braise); }
  .pied__mentions{ margin-top:10px; opacity:.7; }