/* —— Design system —— */
:root{
  --bg:#0b0b0f;
  --surface:#121219;
  --text:#e8e8ee;
  --muted:#b3b3c2;
  --accent:#b388ff;
  --accent-2:#6ee7ff;
  --border:rgba(255,255,255,.08);
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.35);

  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.55}
img{max-width:100%;display:block}
.container{width:min(1120px, 92vw);margin:auto}
.section{padding:72px 0}
.section--alt{background:var(--surface)}
.eyebrow{letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--accent);font-size:.9rem}
.sub{color:var(--muted);margin-top:-6px}
.muted{color:var(--muted)}

/* —— Header —— */
.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:20px;padding:calc(14px + env(safe-area-inset-top)) 4vw 14px;background:rgba(11,11,15,.6);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--text);text-decoration:none}
.brand span{font-family:"Playfair Display",serif;font-weight:700;font-size:1.15rem;letter-spacing:.02em}
.site-nav{margin-left:auto;display:flex;gap:16px;align-items:center}
.site-nav a{color:var(--text);text-decoration:none;padding:10px 12px;border-radius:12px;border:1px solid transparent;min-height:44px;display:inline-flex;align-items:center}
.site-nav a:hover{border-color:var(--border)}
.site-nav .cta{background:var(--accent);color:#120a1f;font-weight:700}

/* Burger */
#nav-toggle{display:none}
.burger{display:none;cursor:pointer;width:44px;height:44px;place-content:center;-webkit-tap-highlight-color:transparent}
.burger span{display:block;width:22px;height:2px;background:var(--text);margin:5px 0;transition:.2s}
@media (max-width: 900px){
  .burger{display:grid}
  .site-nav{position:fixed;inset:64px 12px auto 12px;background:var(--surface);padding:12px;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);display:none;flex-direction:column}
  #nav-toggle:checked ~ .site-nav{display:flex}
}

/* —— Hero —— */
.hero{
  position:relative;
  min-height:150vh;
  display:grid;
  place-items:center;
  isolation:isolate;
  background:#000; /* 👉 fond noir "derrière" la photo */
  overflow:hidden;
}

.hero__media{
  position:absolute;
  inset:0;
  z-index:-1;
}

.hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top;   /* garde le haut de l’image visible */
  transform:translateY(120px); /* 👉 décale la photo vers le bas */
  filter:contrast(1.05) saturate(1.05) brightness(.6);
}

.hero__content{
  padding-block:80px;
  text-align:center;
  transform:translateY(-40%); /* remonte légèrement */
}

.hero h1{font-family:"Playfair Display",serif;font-size:clamp(2.2rem,4.5vw,4rem);line-height:1.1;margin:.2em 0 .4em}
.hero .accent{background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.lede{font-size:1.1rem;color:#e0e0f0;max-width:58ch;margin:0 auto 20px}
.actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:28px; /* ✅ espace au-dessus des boutons */
}

/* —— Buttons —— */
.btn{display:inline-block;padding:12px 18px;border-radius:14px;text-decoration:none;font-weight:700;border:1px solid var(--border);min-height:44px}
.btn--primary{background:var(--accent);color:#120a1f}
.btn--ghost{background:transparent;color:var(--text)}
.btn:hover{transform:translateY(-1px)}

/* —— Duo (new layout) —— */
.section--duo .container{width:min(1400px,96vw)}
.section--duo{background:#000}
.duo-grid{display:grid;grid-template-columns:minmax(480px,1fr) minmax(420px,520px) minmax(480px,1fr);gap:28px;align-items:center}
.portrait{display:flex;justify-content:center;align-items:center}
.portrait img{
  width:100%;
  height:auto;
  max-width:clamp(360px,34vw,720px);        /* largeur max confortable sur desktop */
  aspect-ratio:3/4;       /* ratio portrait constant */
  object-fit:cover;
  background:#000;
  border:none;
  border-radius:0;
  box-shadow:none;

  /* Fondu subtil vers le noir sur les bords */
  -webkit-mask-image: radial-gradient(circle, rgba(0,0,0,1) 85%, rgba(0,0,0,0) 100%);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: cover;
  mask-image: radial-gradient(circle, rgba(0,0,0,1) 85%, rgba(0,0,0,0) 100%);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: cover;
}
.duo-copy h2{font-family:"Playfair Display",serif;margin:.1em 0 .4em}
.duo-bios p{margin:.6em 0}
.duo-points{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:8px}
.duo-points li{position:relative;padding-left:26px}
.duo-points li::before{content:"•";position:absolute;left:6px;top:0;color:var(--accent)}

@media (max-width: 1100px){
  .duo-grid{display:grid;grid-template-columns:minmax(480px,1fr) minmax(420px,520px) minmax(480px,1fr);grid-template-areas:"left text" "right text"}
  .portrait--left{grid-area:left}
  .portrait--right{grid-area:right}
  .duo-copy{grid-area:text}
}
@media (max-width: 820px){
  .duo-grid{display:grid;grid-template-columns:minmax(480px,1fr) minmax(420px,520px) minmax(480px,1fr);gap:18px}
  .portrait--left,.portrait--right{order:0}
  .duo-copy{order:1}
}

/* —— Services —— */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.card__body{padding:16px}
.card img{aspect-ratio:4/3;object-fit:cover}
.service .card__body{display:flex;flex-direction:column;gap:12px}
/* Ajuste l'espacement des paragraphes dans les cartes services */
.service .card__body p {
  margin: 0 0 8px;  /* 0 en haut, 8px en bas */
  line-height: 1.5; /* garde une bonne lisibilité */
}

.card__points{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:.95rem;color:var(--muted)}
.card__points li::before{content:"✓ ";color:var(--accent)}
.btn--small{padding:8px 14px;font-size:.9rem;border-radius:10px;align-self:start}
.card:hover{transform:translateY(-4px);transition:.25s;box-shadow:0 14px 34px rgba(0,0,0,.45)}
@media (max-width: 980px){.cards{grid-template-columns:1fr}}
.card__meta {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  font-size: .95rem;
  color: var(--text);   /* ✅ même couleur que le texte normal */
  display: grid;
  gap: 4px;
}

.card__meta li strong {
  color: var(--accent); /* optionnel : labels mis en valeur en violet */
  font-weight: 600;
}
/* Même couleur que le paragraphe .muted (#444) */
#services.section--light .card__meta,
#services.section--light .card__meta li,
#services.section--light .card__meta li strong{
  color:#444 !important;
}

/* —— Shows —— */
.shows{display:grid;gap:18px}
.show{display:grid;grid-template-columns:320px 1fr;gap:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.show img{width:100%;height:100%;object-fit:cover}
.show__body{padding:16px}
.show__dates{list-style:none;padding:0;margin:.6em 0}
@media (max-width: 900px){.show{grid-template-columns:1fr}}

/* —— Logos clients —— */
.logo-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:18px;align-items:center;list-style:none;padding:0;margin:28px 0 0}
.logo-strip img{max-height:44px;width:auto;filter:grayscale(1) opacity(.9)}
@media (max-width:1100px){.logo-strip{grid-template-columns:repeat(4,1fr)}}
@media (max-width:600px){.logo-strip{grid-template-columns:repeat(2,1fr)}}

/* —— Contact —— */
.contact{display:grid;grid-template-columns:1fr 1.1fr;gap:28px}
.contact-list{list-style:none;padding:0;margin:18px 0 0}
.contact-list li{margin:10px 0}
.contact-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
label{display:block;font-weight:600;margin-top:8px}
input,textarea,select{width:100%;margin-top:6px;padding:12px;background:#0f0f15;color:var(--text);border:1px solid var(--border);border-radius:12px;font-size:16px}
input:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent}

/* —— Footer —— */
.site-footer{border-top:1px solid var(--border);background:#0a0a0e;color:var(--muted);padding:24px 0 calc(24px + env(safe-area-inset-bottom))}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.footer-nav a{color:var(--muted);text-decoration:none;margin-left:14px}
.footer-nav a[aria-disabled="true"]{opacity:.5;pointer-events:none}
@media (max-width:700px){.footer__inner{flex-direction:column;align-items:flex-start}}

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

@media (min-width: 1100px){
  .portrait img{ aspect-ratio:auto; }
}

@media (min-width: 1600px){
  .portrait img{ max-width: 760px; } /* avoid comically huge faces on ultra-wide */
}

/* —— Section light (services + clients) —— */
.section--light{
  background:#fff;
  color:#111;
}
.section--light h2,
.section--light h3{ color:#111; }
.section--light .sub{ color:#444; }
.section--light .card{ background:#f9f9f9; color:#111; }
.section--light .card__points,
.section--light .muted{ color:#444; }
.section--light .card__meta li strong{ color:#111; }

/* —— Clients — Marquee propre, sans chevauchement —— */
:root{
  --logo-size: 64px;    /* taille des logos */
  --logo-gap: 56px;     /* espace entre logos */
  --logo-speed: 28s;    /* durée d’un cycle (↑ = plus lent) */
}

.clients-carousel{ margin-top:56px; text-align:center; }
.clients-carousel h3{ margin-bottom:18px; font-size:1.3rem; }

.logo-scroller{
  overflow:hidden;
  width:100%;
  /* petit fondu aux bords pour l’élégance (optionnel) */
  -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

.logo-track{
  display:flex;
  gap:var(--logo-gap);
  align-items:center;
  /* très important : contenu non-retourné à la ligne */
  white-space:nowrap;
  /* largeur = contenu → permet la translation infinie */
  width:max-content;
  animation:logo-scroll var(--logo-speed) linear infinite;
}

.logo-track > li{ list-style:none; flex:0 0 auto; } /* aucune contraction → pas de chevauchement */
.logo-track img{
  height:var(--logo-size);
  width:auto;
  display:block;
  filter: none;           /* ✅ couleurs normales */
  opacity: 1;
}
.logo--light{
  /* garde juste un petit halo pour la lisibilité si besoin */
  filter: drop-shadow(0 0 0.75px rgba(0,0,0,.35)) drop-shadow(0 0 6px rgba(0,0,0,.15));
}

@keyframes logo-scroll{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); } /* comme on a doublé la séquence, -50% = un cycle parfait */
}

/* Accessibilité : réduction du mouvement */
@media (prefers-reduced-motion: reduce){
  .logo-track{ animation:none; }
}

/* Ajustements responsive */
@media (max-width:1100px){
  :root{ --logo-size: 56px; --logo-gap: 44px; }
}
@media (max-width:700px){
  :root{ --logo-size: 48px; --logo-gap: 36px; --logo-speed: 24s; }
}


/* —— Spectacles (refonte) —— */
.main-show {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
  margin-bottom: 64px;
}
.main-show__poster img {
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.main-show__content h3 {
  font-family: "Playfair Display", serif;
  font-size: 2rem;
  margin: 0 0 12px;
}
.main-show__content p { margin: 0 0 14px; line-height: 1.6; }
.show-highlights { list-style: none; padding: 0; margin: 18px 0; display: grid; gap: 6px; }
.show-highlights li::before { content: "✦ "; color: var(--accent); }

.subsection { margin: 12px 0 10px; color: var(--muted); }
.other-shows { display: grid; gap: 20px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.mini-show { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow); }
.mini-show h3 { margin: 0 0 6px; font-family: "Playfair Display", serif; }
.mini-show p { margin: 0 0 8px; color: var(--muted); }
.mini-show .show__dates { list-style: none; padding: 0; margin: 8px 0 0; display: grid; gap: 6px; }
.tag { background: var(--accent); color: #120a1f; padding: 2px 8px; border-radius: 8px; font-size: 0.85rem; font-weight: 700; }

@media (max-width: 900px) {
  .main-show { grid-template-columns: 1fr; gap: 20px; }
}
/* —— Séparation visuelle avant Spectacles —— */
#spectacles {
  border-top: 1px solid var(--border); /* fine ligne grise */
  padding-top: 64px;                   /* espace respirant */
}

/* —— Spectacles : titre personnalisé —— */
#spectacles .shows-title {
  text-align: center;
  font-size: 2.6rem;          /* plus grand */
  font-family: "Playfair Display", serif;
  margin-bottom: 40px;
  color: #111;                /* bien lisible sur fond blanc */
}

/* Réduit l’espace au-dessus de la section spectacles */
#spectacles.section {
  padding-top: 16px;  /* au lieu de 72px */
}

/* Mini-shows avec fond blanc (lisible) */
#spectacles .mini-show {
  background: #fff;
  color: #111; /* texte bien lisible */
}

#spectacles .mini-show h3 {
  color: #111;
}

#spectacles .mini-show p,
#spectacles .mini-show .show__dates li {
  color: #444; /* gris foncé pour contraste doux */
}

/* Forcer la couleur des liens du footer */
/* Liens dans la liste de contact */
.contact-list a {
  color: var(--text);       /* même couleur que le reste du texte */
  text-decoration: none;    /* enlève le soulignement */
}

.contact-list a:hover {
  color: var(--accent);     /* si tu veux un effet au survol */
}

/* --- MOBILE FIXES -------------------------------------------------------- */
@media (max-width: 700px){
  /* HERO : montrer l'image en entier, sans recadrage ni décalage */
  .hero{
    min-height:auto;           /* ne force plus 150vh */
    display:block;             /* on empile visuellement */
  }
  .hero__media{
    position:relative;         /* l'image reprend sa place dans le flux */
    inset:auto;
    z-index:auto;
  }
  .hero__media img{
    height:auto;
    width:100%;
    object-fit:contain;        /* 👈 affiche l’image complète */
    object-position:center;
    transform:none;            /* supprime le translateY */
    filter:contrast(1) saturate(1) brightness(1);
  }
  .hero__content{
    transform:none;            /* supprime le décalage vertical du texte */
    padding-block:32px 44px;   /* espace confortable sous l’image */
    text-align:center;
  }
}

/* DUO : passer en une seule colonne et empêcher tout débordement */
@media (max-width: 900px){
  .section--duo .container{ width: min(1000px, 92vw); }
  .duo-grid{
    display:grid;
    grid-template-columns: 1fr;                          /* 1 colonne */
    grid-template-areas:
      "left"
      "text"
      "right";                                           /* ordre : Corentin → texte → Flore */
    gap: 18px;
    align-items: start;
  }
  .portrait--left{ grid-area: left; }
  .duo-copy{ grid-area: text; }
  .portrait--right{ grid-area: right; }

  /* Les portraits ne doivent pas avoir de taille mini qui déborde */
  .portrait img{
    max-width: 92vw;           /* pas de clamp imposant 360px minimum */
    width: 100%;
    height: auto;
    aspect-ratio: auto;
    -webkit-mask-image: none;  /* optionnel : retire le fondu si ça coupe trop serré sur mobile */
    mask-image: none;
  }
}

/* Optionnel : resserrer un peu la section duo sur petits écrans */
@media (max-width: 700px){
  .section--duo{ padding: 48px 0; }
  .duo-copy .actions{ justify-content: start; flex-wrap: wrap; }
}

/* —— Étiquette verte pour les réservations —— */
.tag--open {
  background: #4ade80; /* vert doux (équiv. Tailwind emerald-400) */
  color: #0b0b0f;      /* texte sombre pour contraste lisible */
}

.tag--open:hover {
  background: #22c55e; /* vert un peu plus foncé au survol */
  text-decoration: none;
}
