/* ============================================================
   VICHY PRO SOCCER ACADEMY × NEXT PLAYER
   Design system (DA interprétée — recalibrable)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;600;700&family=Hanken+Grotesk:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500&display=swap');

:root{
  /* --- Couleurs (navy + or) --- */
  --bg:        oklch(0.16 0.024 250);
  --bg-2:      oklch(0.20 0.030 251);
  --surface:   oklch(0.235 0.034 252);
  --surface-2: oklch(0.285 0.040 252);
  --line:      oklch(0.34 0.030 252);
  --line-soft: oklch(0.30 0.026 252 / .6);

  --text:      oklch(0.972 0.006 250);
  --muted:     oklch(0.74 0.020 250);
  --faint:     oklch(0.58 0.018 250);

  /* accent = bleu du blason VPSA (rgb ~0,96,120) */
  --gold:      oklch(0.70 0.125 233);
  --gold-2:    oklch(0.59 0.130 238);
  --gold-soft: oklch(0.70 0.125 233 / .16);
  --blue:      oklch(0.78 0.110 230);
  --green:     oklch(0.80 0.150 152);
  --red:       oklch(0.66 0.180 25);

  /* --- Type --- */
  --display: 'Oswald', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;

  /* --- Geometry --- */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --maxw: 1240px;
  --pad:  clamp(20px, 5vw, 64px);

  --shadow: 0 24px 60px -24px oklch(0.05 0.02 250 / .8);
  --shadow-gold: 0 18px 44px -18px oklch(0.55 0.13 238 / .55);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;   /* clip (pas hidden) : évite que iOS bloque le scroll vertical */
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; border:none; background:none; }
::selection{ background:var(--gold); color:oklch(0.99 0.01 240); }

/* ---------- Typography ---------- */
.kicker{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-weight:500;
  font-size:.78rem;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.kicker::before{
  content:""; width:26px; height:2px; background:var(--gold); display:inline-block;
}
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:.98; text-transform:uppercase; letter-spacing:-.005em; }
h1{ font-size:clamp(2.6rem, 7vw, 6rem); font-weight:700; }
h2{ font-size:clamp(2rem, 4.6vw, 3.7rem); }
h3{ font-size:clamp(1.3rem, 2vw, 1.7rem); }
.lead{ font-size:clamp(1.05rem, 1.5vw, 1.3rem); color:var(--muted); line-height:1.5; max-width:60ch; }
.text-gold{ color:var(--gold); }
.text-blue{ color:var(--blue); }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
section{ position:relative; }
.section-pad{ padding-block:clamp(72px,9vw,140px); }
.bg-2{ background:var(--bg-2); }
.divider-top{ border-top:1px solid var(--line-soft); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.08em; font-weight:600;
  font-size:.95rem; padding:.95em 1.6em; border-radius:999px;
  transition:transform .18s ease, box-shadow .25s ease, background .25s ease, color .2s ease;
  white-space:nowrap;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn-gold{ background:linear-gradient(180deg, var(--gold), var(--gold-2)); color:oklch(0.99 0.01 240); box-shadow:var(--shadow-gold); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 24px 54px -16px oklch(0.55 0.13 238 / .7); }
.btn-ghost{ border:1.5px solid var(--line); color:var(--text); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.btn-dark{ background:var(--surface); color:var(--text); border:1px solid var(--line); }
.btn-dark:hover{ background:var(--surface-2); transform:translateY(-2px); }
.btn-lg{ font-size:1.05rem; padding:1.1em 2em; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:oklch(0.16 0.024 250 / .72);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; height:78px; }
.brand-lockup{ display:flex; align-items:center; gap:.85rem; }
.brand-lockup img.vpsa{ height:46px; width:auto; border-radius:9px; }
.brand-x{ color:var(--faint); font-family:var(--display); font-weight:300; font-size:1.2rem; }
.brand-np{ display:flex; flex-direction:column; line-height:1; }
.brand-np .np-mark{ font-family:var(--display); font-weight:700; letter-spacing:.02em; font-size:1.02rem; text-transform:uppercase; }
.brand-np .np-sub{ font-size:.6rem; letter-spacing:.32em; text-transform:uppercase; color:var(--faint); margin-top:3px; }
.np-dot{ color:var(--gold); }
.np-logo{ height:34px; width:auto; display:block; }
.site-footer .np-logo{ height:30px; }
.nav-links{ display:flex; align-items:center; gap:2rem; margin-left:auto; }
.nav-links a{ font-size:.92rem; color:var(--muted); transition:color .18s; font-weight:500; }
.nav-links a:hover{ color:var(--text); }
.nav-links .nav-cta{ display:none; }            /* CTA réservé au menu mobile */
.header-cta{ display:flex; align-items:center; gap:1rem; }
.menu-toggle{ display:none; }

/* ---------- Partner carousel ---------- */
.marquee{
  overflow:hidden; border-block:1px solid var(--line-soft);
  background:var(--bg-2); padding-block:22px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
}
.marquee-track{ display:flex; gap:clamp(32px,5vw,72px); width:max-content; animation:marquee 38s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.club-chip{
  display:flex; align-items:center; gap:.6rem; color:var(--faint);
  font-family:var(--display); text-transform:uppercase; letter-spacing:.1em; font-weight:500; font-size:.95rem;
  white-space:nowrap; transition:color .2s, opacity .2s; opacity:.92;
}
.club-chip:hover{ color:var(--text); opacity:1; }
.club-logo{ height:40px; width:auto; flex:none; display:block; }
.crest-chip{ flex:none; display:grid; place-items:center; height:58px; }
.crest-chip img{ max-height:58px; max-width:92px; object-fit:contain; display:block; filter:drop-shadow(0 3px 7px oklch(0.05 0.02 250 / .6)); }
.club-crest{
  width:30px; height:34px; border:1.5px solid var(--line); border-radius:5px 5px 9px 9px;
  display:grid; place-items:center; font-size:.66rem; color:var(--muted);
  background:linear-gradient(160deg, var(--surface), transparent);
}

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:clamp(560px, 88vh, 880px); display:flex; align-items:flex-end; overflow:hidden; }
.hero-media{ position:absolute; inset:0; z-index:0; }
/* YouTube background — full-bleed cover, ratio preserved */
.hero-yt{ position:absolute; inset:0; z-index:0; overflow:hidden; background:var(--bg); }
.hero-yt iframe{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:max(100vw,177.78vh); height:max(56.25vw,100vh); pointer-events:none; border:0; }
.hero-yt video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(90deg, oklch(0.11 0.02 250 / .82), oklch(0.11 0.02 250 / .42) 52%, oklch(0.11 0.02 250 / .15)); }
.hero-scene{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 50% -10%, oklch(0.34 0.05 248 / .9), transparent 60%),
    radial-gradient(60% 50% at 15% 8%, oklch(0.55 0.07 250 / .35), transparent 55%),
    radial-gradient(60% 50% at 85% 8%, oklch(0.55 0.07 250 / .35), transparent 55%),
    linear-gradient(180deg, oklch(0.22 0.03 250), oklch(0.12 0.02 250));
}
/* pitch lines */
.hero-pitch{ position:absolute; inset:42% -20% -25% -20%; z-index:0;
  background-image:
    linear-gradient(180deg, transparent, oklch(0.40 0.05 250 / .14)),
    repeating-linear-gradient(90deg, oklch(0.5 0.04 250 / .10) 0 2px, transparent 2px 96px);
  transform:perspective(520px) rotateX(62deg); transform-origin:bottom; opacity:.6;
}
.hero-sweep{ position:absolute; inset:0; z-index:0; mix-blend-mode:screen; opacity:.5;
  background:linear-gradient(100deg, transparent 30%, oklch(0.8 0.08 250 / .14) 48%, transparent 62%);
  background-size:240% 100%; animation:sweep 9s ease-in-out infinite; }
@keyframes sweep{ 0%,100%{ background-position:120% 0; } 50%{ background-position:-20% 0; } }
.hero-grain{ position:absolute; inset:0; z-index:1; opacity:.5;
  background:radial-gradient(circle at 50% 120%, transparent 40%, oklch(0.08 0.02 250 / .85) 100%); }
.hero-vignette{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, oklch(0.12 0.02 250 / .55) 0%, transparent 30%, transparent 45%, oklch(0.12 0.02 250 / .96) 100%); }

/* hero bottom marquees (clubs + players) */
.hero-foot{ position:absolute; left:0; right:0; bottom:0; z-index:3;
  background:linear-gradient(0deg, oklch(0.09 0.02 250 / .94) 18%, oklch(0.09 0.02 250 / 0)); padding-top:14px; }
.hero-strip-label{ font-family:var(--display); text-transform:uppercase; letter-spacing:.18em;
  font-size:.66rem; color:var(--gold); }
.hero-clubs{ display:flex; flex-direction:column; gap:.45rem; padding:4px clamp(20px,5vw,64px); overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.hero-clubs-track{ display:flex; align-items:center; gap:clamp(34px,4vw,60px); width:max-content; animation:marquee 42s linear infinite; }
.hero-clubs-top{ position:absolute; top:0; left:0; right:0; z-index:3; padding:15px clamp(20px,5vw,64px) 14px;
  background:linear-gradient(180deg, oklch(0.10 0.02 250 / .9) 30%, oklch(0.10 0.02 250 / 0)); }
.hero-club{ flex:none; display:grid; place-items:center; height:46px; }
.hero-club img{ max-height:46px; max-width:86px; width:auto; object-fit:contain; display:block; filter:drop-shadow(0 3px 8px oklch(0.05 0.02 250 / .7)); }
.hero-players{ display:flex; flex-direction:column; gap:.5rem;
  padding:8px clamp(20px,5vw,64px) 12px; overflow:hidden; border-top:1px solid var(--line-soft);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.hero-players-label{ font-family:var(--display); text-transform:uppercase; letter-spacing:.18em;
  font-size:.66rem; color:var(--gold); }
.hero-players-track{ display:flex; gap:clamp(26px,3vw,46px); width:max-content; animation:marquee 48s linear infinite; }
.hplayer{ display:flex; align-items:center; gap:.7rem; white-space:nowrap; }
.hp-av{ width:42px; height:42px; border-radius:50%; flex:none; border:1px solid var(--line); overflow:hidden;
  background:repeating-linear-gradient(135deg, var(--surface) 0 7px, var(--bg-2) 7px 14px); box-shadow:0 4px 12px oklch(0.05 0.02 250 / .5); }
.hp-av img{ width:100%; height:100%; object-fit:cover; object-position:50% 26%; display:block; }
.hp-meta{ display:flex; flex-direction:column; line-height:1.12; }
.hp-meta b{ font-family:var(--display); text-transform:uppercase; letter-spacing:.02em; font-weight:600; font-size:.9rem; color:var(--text); }
.hp-meta i{ font-style:normal; color:var(--gold); font-size:.66rem; font-family:var(--display); letter-spacing:.1em; text-transform:uppercase; margin-top:1px; }
.hero:has(.hero-foot) .hero-inner{ padding:clamp(80px,11vw,120px) var(--pad) clamp(108px,13vw,150px); }
@media (max-width:600px){ .hp-meta i{ display:none; } }
.video-tag{
  position:absolute; top:22px; right:22px; z-index:3;
  font-family:ui-monospace,monospace; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); background:oklch(0.1 0.02 250 / .6); border:1px solid var(--line);
  padding:.5em .85em; border-radius:99px; display:flex; align-items:center; gap:.5em;
}
.video-tag .rec{ width:8px; height:8px; border-radius:50%; background:var(--red); animation:blink 1.4s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:.25; } }
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(48px,7vw,92px); }
.hero h1{ max-width:16ch; }
.hero h1 .l2{ color:var(--gold); display:block; }
.hero-sub{ margin-top:1.2rem; font-size:clamp(1.15rem,2vw,1.6rem); color:var(--text); font-weight:500; max-width:32ch; }
.hero-actions{ margin-top:2.2rem; display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.hero-scroll{ display:flex; align-items:center; gap:.7rem; color:var(--muted); font-size:.85rem; letter-spacing:.16em; text-transform:uppercase; font-family:var(--display); }

/* ---------- Section header ---------- */
.sec-head{ display:flex; flex-direction:column; gap:1rem; margin-bottom:clamp(40px,5vw,68px); max-width:62ch; }
.sec-head.center{ align-items:center; text-align:center; margin-inline:auto; }
.sec-head.spread{ flex-direction:row; align-items:flex-end; justify-content:space-between; max-width:none; gap:2rem; }

/* ---------- Expertise / cards layout ---------- */
.expertise-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,4vw,60px); align-items:center; }
.story-video{
  position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/5;
  border:1px solid var(--line); background:
    repeating-linear-gradient(135deg, var(--surface) 0 14px, var(--bg-2) 14px 28px);
  box-shadow:var(--shadow);
}
.story-video .play{
  position:absolute; inset:0; display:grid; place-items:center;
}
.play-btn{ width:84px; height:84px; border-radius:50%; background:var(--gold);
  display:grid; place-items:center; box-shadow:var(--shadow-gold); transition:transform .2s; }
.play-btn:hover{ transform:scale(1.08); }
.play-btn svg{ width:30px; height:30px; fill:oklch(0.99 0.01 240); margin-left:4px; }
.story-meta{ position:absolute; left:18px; bottom:18px; right:18px; display:flex; justify-content:space-between; align-items:flex-end; }
.story-meta .placeholder-tag{ font-family:ui-monospace,monospace; font-size:.68rem; color:var(--muted); letter-spacing:.08em; }

/* ---------- FIFA Player Card ---------- */
.card-stack{ display:flex; gap:clamp(14px,2vw,26px); flex-wrap:wrap; justify-content:center; perspective:1400px; }
.fifa-card{
  position:relative; width:clamp(220px,23vw,272px); aspect-ratio:0.66; border-radius:18px 18px 22px 22px;
  background:
    radial-gradient(120% 70% at 50% 0%, oklch(0.92 0.13 88), oklch(0.83 0.13 80) 45%, oklch(0.7 0.14 66) 100%);
  color:#231703; padding:18px 16px 16px; box-shadow:0 30px 60px -22px oklch(0.05 0.02 250 / .9);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s; transform-style:preserve-3d;
  isolation:isolate; overflow:hidden;
}
.fifa-card::after{ /* shine */
  content:""; position:absolute; inset:0; z-index:4; pointer-events:none; mix-blend-mode:overlay; opacity:.5;
  background:linear-gradient(125deg, transparent 35%, oklch(1 0 0 / .8) 48%, transparent 60%);
  background-size:250% 250%; background-position:120% 0; transition:background-position .6s ease;
}
.fifa-card:hover{ transform:translateY(-10px) rotateX(4deg) rotateY(-5deg); box-shadow:0 44px 80px -24px oklch(0.05 0.02 250 / .95); }
.fifa-card:hover::after{ background-position:-30% 0; }
.fifa-card.variant-blue{ background:radial-gradient(120% 70% at 50% 0%, oklch(0.8 0.11 245), oklch(0.62 0.13 250) 50%, oklch(0.42 0.12 255) 100%); color:oklch(0.98 0.01 250); }
.fifa-card.variant-special{ background:radial-gradient(120% 70% at 50% 0%, oklch(0.3 0.03 252), oklch(0.2 0.03 252) 60%, oklch(0.14 0.02 252) 100%); color:var(--text); border:1px solid oklch(0.6 0.13 235 / .6); }
.fifa-card .fc-top{ display:flex; gap:6px; }
.fc-rating{ display:flex; flex-direction:column; align-items:center; font-family:var(--display); font-weight:700; line-height:.86; }
.fc-rating .ovr{ font-size:2.5rem; }
.fc-rating .pos{ font-size:.92rem; font-weight:600; letter-spacing:.04em; }
.fc-rating .flag{ width:26px; height:17px; border-radius:3px; margin-top:6px; overflow:hidden; border:1px solid oklch(0 0 0 / .25); display:flex; }
.fc-rating .badge{ width:24px; height:27px; margin-top:6px; border-radius:4px 4px 7px 7px; border:1px solid oklch(0 0 0 / .25);
  background:linear-gradient(160deg, oklch(1 0 0 / .25), transparent); display:grid; place-items:center; font-size:.5rem; font-weight:700; }
.fc-portrait{ flex:1; position:relative; min-height:104px; }
.fc-portrait .ph{ position:absolute; inset:0 -16px -2px 0;
  background:repeating-linear-gradient(135deg, oklch(0 0 0 / .08) 0 10px, oklch(0 0 0 / .03) 10px 20px);
  display:grid; place-items:center; }
.fc-portrait .fc-photo{ position:absolute; inset:0 -16px -2px 0; width:calc(100% + 16px); height:calc(100% + 2px); object-fit:cover; object-position:60% 16%; }
.fc-portrait .ph span{ font-family:ui-monospace,monospace; font-size:.62rem; opacity:.6; text-align:center; padding:0 8px; }
.fc-name{ font-family:var(--display); font-weight:700; text-transform:uppercase; text-align:center; font-size:1.32rem; letter-spacing:.01em;
  border-top:2px solid oklch(0 0 0 / .25); padding-top:7px; margin-top:2px; }
.fifa-card.variant-special .fc-name, .fifa-card.variant-blue .fc-name{ border-color:oklch(1 0 0 / .25); }
.fc-stats{ display:grid; grid-template-columns:1fr 1fr; gap:1px 16px; margin-top:8px; font-family:var(--display); }
.fc-stats .st{ display:flex; align-items:baseline; gap:7px; font-size:.86rem; font-weight:600; letter-spacing:.02em; }
.fc-stats .st b{ font-size:.98rem; font-weight:700; min-width:1.6em; }
.fc-stats .st span{ opacity:.72; font-size:.74rem; letter-spacing:.06em; }
/* real-career card (no fake stats) */
.fc-rating .pos-lg{ font-family:var(--display); font-weight:700; font-size:1.65rem; line-height:.88; letter-spacing:.02em; }
.fc-cv{ list-style:none; display:flex; flex-direction:column; gap:.32rem; margin-top:7px; }
.fc-cv li{ font-family:var(--display); font-weight:600; text-transform:uppercase; font-size:.8rem; letter-spacing:.02em; line-height:1.06; }
.fc-cv li span{ display:block; font-weight:400; opacity:.72; font-size:.62rem; letter-spacing:.03em; text-transform:none; margin-top:1px; }
/* CV with club crests (Rousset) */
.fc-cv-logos{ gap:.28rem; }
.fc-cv-logos li{ position:relative; display:flex; flex-direction:column; justify-content:center; min-height:26px; padding-left:32px; }
.fc-cv-logos li b{ font-weight:600; font-size:.78rem; line-height:1.04; }
.cv-crest{ position:absolute; left:0; top:50%; transform:translateY(-50%); width:24px; height:24px; object-fit:contain; filter:drop-shadow(0 1px 2px oklch(0 0 0 / .35)); }
.fifa-card:has(.fc-cv-logos){ aspect-ratio:auto; }
.fifa-card:has(.fc-cv-logos) .fc-portrait{ min-height:96px; }
.fc-foot{ display:flex; justify-content:center; gap:14px; margin-top:9px; font-family:var(--display); font-size:.66rem; letter-spacing:.1em; opacity:.7; text-transform:uppercase; }

.expert-caption{ margin-top:1.4rem; }
.expert-caption .role{ color:var(--gold); font-family:var(--display); letter-spacing:.16em; text-transform:uppercase; font-size:.82rem; font-weight:500; }
.expert-list{ display:flex; flex-direction:column; gap:.5rem; margin-top:1.4rem; }
.expert-list li{ display:flex; gap:.7rem; align-items:flex-start; color:var(--muted); font-size:.98rem; list-style:none; }
.expert-list li svg{ width:18px; height:18px; flex:none; margin-top:3px; stroke:var(--gold); }

/* ---------- Profiles (experts) ---------- */
.profiles{ display:flex; flex-direction:column; }
.profile{ padding-block:clamp(40px,5vw,68px); }
.profile:first-child{ padding-top:0; }
.profile + .profile{ border-top:1px solid var(--line-soft); }
.profile-head{ display:flex; align-items:center; gap:1.3rem; margin-bottom:clamp(26px,3.2vw,42px); }
.profile-crest{ height:clamp(56px,6vw,76px); width:auto; flex:none; filter:drop-shadow(0 8px 20px oklch(0.05 0.02 250 / .5)); }
.profile-id{ flex:1; min-width:0; }
.profile-id h3{ font-size:clamp(1.8rem,3vw,2.6rem); line-height:1.02; }
.profile-role{ color:var(--gold); font-family:var(--display); text-transform:uppercase; letter-spacing:.16em; font-size:clamp(.78rem,1vw,.95rem); font-weight:500; margin-top:.7rem; }
.profile-media{ display:grid; grid-template-columns:1.5fr .9fr; gap:clamp(20px,2.6vw,40px); align-items:stretch; }
.profile-video{ position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:280px;
  border:1px solid var(--line); box-shadow:var(--shadow);
  background:repeating-linear-gradient(135deg, var(--surface) 0 14px, var(--bg-2) 14px 28px);
  display:grid; place-items:center; }
.profile-video .play-btn{ position:relative; z-index:1; }
.profile-video .placeholder-tag{ position:absolute; left:16px; bottom:14px; font-family:ui-monospace,monospace; font-size:.68rem; color:var(--muted); letter-spacing:.08em; }
.profile-video.has-video{ background:#000; display:block; }
.profile-vid{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; object-position:center; display:block; background:#000; }
.profile-cardwrap{ display:grid; place-items:center; padding:clamp(8px,1.5vw,18px) 0; }
.profile-resume{ color:var(--muted); max-width:74ch; margin-top:clamp(24px,3vw,38px); font-size:1.04rem; line-height:1.65; text-wrap:pretty; }
.swipe-hint{ display:none; }   /* indice de swipe : visible sur mobile uniquement */
@keyframes swipeNudge{ 0%,100%{ transform:translateX(0); opacity:.6; } 50%{ transform:translateX(7px); opacity:1; } }

/* recruited players carousel */
.recruited{ margin-top:clamp(28px,3.5vw,46px); }
.recruited-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:1.1rem; }
.recruited-head .rh-note{ font-family:ui-monospace,monospace; font-size:.7rem; color:var(--faint); letter-spacing:.04em; margin-top:.5rem; }
.pcarousel-nav{ display:flex; gap:.5rem; flex:none; }
.pcnav{ width:42px; height:42px; border-radius:50%; border:1px solid var(--line); color:var(--text); display:grid; place-items:center; transition:border-color .18s, color .18s, background .18s; }
.pcnav:hover{ border-color:var(--gold); color:var(--gold); }
.pcnav svg{ width:20px; height:20px; }
.pcarousel-track{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x proximity; scroll-behavior:smooth;
  padding-bottom:10px; -webkit-overflow-scrolling:touch; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.pcarousel-track::-webkit-scrollbar{ height:6px; }
.pcarousel-track::-webkit-scrollbar-track{ background:transparent; }
.pcarousel-track::-webkit-scrollbar-thumb{ background:var(--line); border-radius:99px; }
.pcard{ flex:0 0 auto; width:clamp(148px,42vw,190px); scroll-snap-align:start; margin:0; }
.pcard-photo{ display:block; width:100%; aspect-ratio:3/4; border-radius:var(--r); overflow:hidden;
  background:repeating-linear-gradient(135deg, var(--surface) 0 12px, var(--bg-2) 12px 24px); border:1px solid var(--line); }
.pcard-photo img{ width:100%; height:100%; object-fit:cover; object-position:50% 20%; display:block; }
.pcard-name{ font-family:var(--display); text-transform:uppercase; letter-spacing:.03em; font-weight:600; font-size:1rem; margin-top:.7rem; line-height:1.1; }
.pcard-sub{ color:var(--gold); font-size:.74rem; font-family:var(--display); text-transform:uppercase; letter-spacing:.12em; margin-top:.2rem; }
@media (max-width:600px){ .pcarousel-nav{ display:none; } }

/* ---------- Offers ---------- */
.offers-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,2.4vw,32px); }
/* Onglets des offres : masqués sur desktop (les 2 offres sont côte à côte) */
.offer-tabs{ display:none; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:8px; margin-bottom:clamp(20px,3vw,28px); }
.offer-tab{ min-width:0; display:flex; flex-direction:column; align-items:center; gap:.3rem;
  padding:.7rem .6rem; border:1px solid var(--line); border-radius:12px; background:var(--surface);
  color:var(--muted); font-family:var(--display); text-transform:uppercase; letter-spacing:.04em;
  font-size:.76rem; font-weight:600; line-height:1.15; text-align:center; transition:.2s; }
.offer-tab .ot-num{ font-weight:700; color:var(--faint); font-size:.82rem; }
.offer-tab .ot-label{ display:block; width:100%; }
.offer-tab.is-active{ border-color:var(--gold); color:var(--text); background:var(--surface-2); }
.offer-tab.is-active .ot-num{ color:var(--gold); }
.offer-card{
  position:relative; border-radius:var(--r-lg); border:1px solid var(--line); overflow:hidden;
  background:var(--surface); display:flex; flex-direction:column; min-height:480px;
  transition:transform .25s, border-color .25s, box-shadow .3s;
}
.offer-card:hover{ transform:translateY(-6px); border-color:oklch(0.6 0.13 235 / .6); box-shadow:var(--shadow); }
.offer-top{ position:relative; padding:clamp(26px,3vw,38px); flex:0 0 auto; display:flex; flex-direction:column; }
.offer-eyebrow{ display:flex; align-items:center; gap:.8rem; margin-bottom:1.4rem; }
.offer-num{ font-family:var(--display); font-weight:700; font-size:1rem; width:38px; height:38px; border-radius:50%;
  border:1.5px solid var(--gold); color:var(--gold); display:grid; place-items:center; }
.offer-card h3{ font-size:clamp(1.6rem,2.4vw,2.2rem); margin-bottom:.7rem; }
.offer-card .offer-desc{ color:var(--muted); margin-bottom:1.5rem; }
.offer-points{ display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.8rem; }
.offer-points li{ display:flex; gap:.7rem; align-items:flex-start; list-style:none; font-size:.96rem; }
.offer-points li svg{ width:18px; height:18px; flex:none; margin-top:3px; stroke:var(--gold); }
.offer-foot{ margin-top:auto; flex:0 0 auto; flex-direction:row; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-top:1.2rem; border-top:1px solid var(--line-soft); }
.offer-price{ font-family:var(--display); white-space:nowrap; }
.offer-price .amt{ font-size:1.9rem; font-weight:700; color:var(--text); }
.offer-price .from{ font-size:.78rem; color:var(--faint); text-transform:uppercase; letter-spacing:.14em; display:block; }
.offer-visual{ position:relative; flex:1 1 auto; padding:clamp(22px,3vw,34px); background:var(--bg-2); border-top:1px solid var(--line-soft); display:flex; flex-direction:column; }

/* floating 3D radar */
.result-row{ display:flex; gap:26px; align-items:center; flex-wrap:wrap; justify-content:center; }
.result-caption{ flex-basis:100%; text-align:center; margin-top:.6rem; }
.result-caption p{ max-width:48ch; margin-inline:auto; }
.radar-float{ position:relative; width:200px; flex:none; animation:levitate 5.5s ease-in-out infinite; will-change:transform; }
.radar-disc{ width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle at 50% 30%, #1c2b46, #0b1320 74%);
  border:1px solid var(--line); display:grid; place-items:center;
  box-shadow:inset 0 2px 26px oklch(1 0 0 / .05), inset 0 -10px 30px oklch(0.05 0.02 250 / .6), 0 38px 46px -22px #000;
  transform:perspective(1100px) rotateY(-15deg) rotateX(9deg); }
.radar-disc svg{ width:94%; height:94%; display:block; overflow:visible; }
.radar-float::after{ content:""; position:absolute; left:16%; right:16%; bottom:-24px; height:22px; border-radius:50%;
  background:radial-gradient(ellipse, oklch(0.04 0.02 250 / .65), transparent 70%); filter:blur(4px); z-index:-1;
  animation:levShadow 5.5s ease-in-out infinite; }
@keyframes levitate{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-13px); } }
@keyframes levShadow{ 0%,100%{ transform:scaleX(1); opacity:.55; } 50%{ transform:scaleX(.84); opacity:.32; } }
@media (prefers-reduced-motion:reduce){ .radar-float,.radar-float::after{ animation:none; } }

/* logo wall (stage) */
.logo-wall{ display:grid; grid-template-columns:repeat(auto-fill, minmax(78px,1fr)); gap:10px; }
.logo-wall .club-crest{ width:100%; height:58px; border-radius:7px 7px 10px 10px; }

/* league logos — clean uniform white tiles */
.league-wall{ display:flex; flex-wrap:wrap; align-items:stretch; gap:12px; }
.league-chip{ background:#fff; border-radius:12px; width:84px; height:60px; display:inline-flex; align-items:center; justify-content:center; padding:9px 11px; box-shadow:0 10px 26px -16px oklch(0.05 0.02 250 / .85); }
.league-chip img{ max-height:100%; max-width:100%; width:auto; object-fit:contain; display:block; }

/* network carousels (stage.html) — clubs ltr, leagues rtl */
.netcar{ overflow:hidden; padding-block:10px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.netcar-track{ display:flex; align-items:center; gap:clamp(30px,4vw,52px); width:max-content; animation:marquee 38s linear infinite; padding-inline:30px; }
.netcar-track.rev{ animation-direction:reverse; }
.netcar:hover .netcar-track{ animation-play-state:paused; }
.netcar-club{ flex:none; height:56px; display:grid; place-items:center; }
.netcar-club img{ max-height:56px; max-width:60px; width:auto; object-fit:contain; display:block; filter:drop-shadow(0 3px 8px oklch(0.05 0.02 250 / .6)); }
.netcar-league{ flex:none; background:#fff; border-radius:12px; display:inline-flex; align-items:center; justify-content:center; padding:9px 16px; box-shadow:0 10px 24px -16px oklch(0.05 0.02 250 / .8); }
.netcar-league img{ height:44px; width:auto; max-width:none; object-fit:contain; display:block; }

/* ---------- 3D rotating league drum (neon DA) ---------- */
.ring3d{ position:relative; height:150px; perspective:1000px; margin-top:2px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 16%,#000 84%,transparent); }
.ring3d::before{ /* neon levitation glow */
  content:""; position:absolute; left:50%; top:50%; width:min(440px,72%); height:120px; transform:translate(-50%,-46%);
  background:radial-gradient(58% 80% at 50% 50%, oklch(0.72 0.14 245 / .6), oklch(0.66 0.14 248 / .22) 55%, transparent 76%);
  filter:blur(22px); pointer-events:none; }
.ring3d-rotor{ position:absolute; inset:0; margin:auto; width:140px; height:72px; transform-style:preserve-3d;
  animation:ring-spin 30s linear infinite; }
.ring3d:hover .ring3d-rotor{ animation-play-state:paused; }
.ring-face{ position:absolute; inset:0; display:grid; place-items:center;
  background:linear-gradient(180deg,#fff, #eaf0f9); border-radius:0; padding:10px 18px;
  border-left:1px solid oklch(0.72 0.14 245 / .35); border-right:1px solid oklch(0.72 0.14 245 / .12);
  box-shadow:0 18px 38px -10px oklch(0.6 0.15 250 / .7), 0 -14px 30px -14px oklch(0.7 0.15 248 / .45);
  -webkit-backface-visibility:hidden; backface-visibility:hidden; }
.ring-face img{ height:36px; width:auto; max-width:92px; object-fit:contain; display:block; }
@keyframes ring-spin{ to{ transform:rotateY(-360deg); } }
@media (prefers-reduced-motion:reduce){ .ring3d-rotor{ animation:none; } }
/* club crest strip (transparent, no bg) */
.club-strip{ display:flex; flex-wrap:wrap; align-items:center; gap:14px 16px; }
.club-strip img{ height:38px; width:auto; object-fit:contain; display:block; filter:drop-shadow(0 3px 7px oklch(0.05 0.02 250 / .55)); }

/* ---------- Chooser modal ---------- */
.modal-scrim{ position:fixed; inset:0; z-index:200; background:oklch(0.08 0.02 250 / .72); backdrop-filter:blur(8px);
  display:grid; grid-template-columns:minmax(0,1fr); padding:24px; overflow-y:auto; -webkit-overflow-scrolling:touch;
  opacity:0; pointer-events:none; transition:opacity .25s; }
.modal-scrim.open{ opacity:1; pointer-events:auto; }
.modal{ width:min(820px,100%); margin:auto; background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(28px,4vw,48px); box-shadow:var(--shadow); transform:translateY(14px) scale(.98); transition:transform .3s; }
.modal-scrim.open .modal{ transform:none; }
.modal-head{ text-align:center; margin-bottom:2rem; }
.modal-head h3{ font-size:clamp(1.6rem,3vw,2.3rem); }
.modal-head p{ color:var(--muted); margin-top:.6rem; }
.choice-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.choice{ display:block; border:1px solid var(--line); border-radius:var(--r); padding:26px; background:var(--surface);
  transition:transform .2s, border-color .2s, background .2s; }
.choice:hover{ transform:translateY(-4px); border-color:var(--gold); background:var(--surface-2); }
.choice .ico{ width:46px; height:46px; border-radius:12px; background:var(--gold-soft); display:grid; place-items:center; margin-bottom:1rem; }
.choice .ico svg{ width:24px; height:24px; stroke:var(--gold); }
.choice h4{ font-family:var(--display); text-transform:uppercase; font-size:1.3rem; font-weight:600; }
.choice p{ color:var(--muted); font-size:.92rem; margin-top:.4rem; }
.choice .go{ margin-top:1.1rem; color:var(--gold); font-family:var(--display); text-transform:uppercase; letter-spacing:.1em; font-size:.85rem; display:flex; align-items:center; gap:.5em; }
.modal-close{ position:absolute; }
.close-x{ position:absolute; top:18px; right:18px; width:40px; height:40px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--muted); }
.close-x:hover{ color:var(--text); border-color:var(--text); }

/* ---------- Footer ---------- */
.site-footer{ border-top:1px solid var(--line-soft); background:var(--bg-2); padding-block:clamp(48px,6vw,80px) 32px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.5rem; margin-bottom:3rem; }
.footer-grid h5{ font-family:var(--display); text-transform:uppercase; letter-spacing:.14em; font-size:.82rem; color:var(--faint); margin-bottom:1.1rem; font-weight:500; }
.footer-grid a{ display:block; color:var(--muted); font-size:.95rem; padding:.3rem 0; }
.footer-grid a:hover{ color:var(--gold); }
.footer-about p{ color:var(--muted); max-width:38ch; margin-top:1rem; font-size:.95rem; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center;
  border-top:1px solid var(--line-soft); padding-top:1.6rem; color:var(--faint); font-size:.85rem; }

/* ---------- Stat band ---------- */
.stat-band{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:var(--r); overflow:hidden; }
.stat-band .stat{ background:var(--bg-2); padding:clamp(22px,3vw,34px); }
.stat-band .num{ font-family:var(--display); font-weight:700; font-size:clamp(2rem,3.4vw,3rem); color:var(--gold); line-height:1; }
.stat-band .stat-ico{ width:clamp(2.2rem,3.8vw,3.2rem); height:clamp(2.2rem,3.8vw,3.2rem); display:block; }
.stat-band .lab{ color:var(--muted); margin-top:.5rem; font-size:.92rem; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } .marquee-track,.hero-sweep{ animation:none; } }

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .expertise-grid{ grid-template-columns:1fr; }
  .profile-media{ grid-template-columns:1fr; }
  .profile-video{ aspect-ratio:16/9; min-height:0; }
  .offers-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  /* Onglets actifs : une seule offre affichée à la fois */
  .offer-tabs{ display:grid; }
  .offers-grid .offer-card{ display:none; }
  .offers-grid .offer-card.offer-active{ display:flex; }
}
@media (max-width:760px){
  /* Fiche expert : carrousel swipe (carte joueur → vidéo) */
  .profile-media{
    display:flex; gap:14px; overflow-x:auto; overflow-y:hidden;
    scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    align-items:stretch; scrollbar-width:none;
    scroll-padding-inline:var(--pad);
    margin-inline:calc(var(--pad) * -1); padding-inline:var(--pad);   /* slides jusqu'aux bords */
  }
  .profile-media::-webkit-scrollbar{ display:none; }
  .profile-media > div{ flex:0 0 82%; scroll-snap-align:center; min-height:0; }
  .profile-cardwrap{ order:0; }                      /* carte joueur d'abord */
  .profile-video{ order:1; aspect-ratio:4/5; }       /* vidéo ensuite, format carte */
  .profile-cardwrap .fifa-card{ width:100%; max-width:240px; }
  .swipe-hint{
    display:flex; align-items:center; justify-content:flex-end; gap:.45rem;
    margin-top:12px; font-family:var(--display); text-transform:uppercase;
    letter-spacing:.14em; font-size:.7rem; color:var(--gold);
  }
  .swipe-hint svg{ width:16px; height:16px; animation:swipeNudge 1.6s ease-in-out infinite; }
}
@media (max-width:760px){
  :root{ --pad:16px; }   /* gouttière plus serrée sur mobile */
  /* --- Header mobile : burger + menu déroulant --- */
  .site-header .wrap{ height:64px; gap:.75rem; }
  .brand-lockup img.vpsa{ height:38px; }
  .np-logo{ height:28px; }
  .header-cta .btn-gold{ display:none; }      /* CTA redondant avec le hero */
  .header-cta .btn-ghost{ display:none; }
  .menu-toggle{ display:grid; place-items:center; width:44px; height:44px; border:1px solid var(--line); border-radius:10px; background:var(--surface); color:var(--text); }

  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0; margin-left:0;
    background:oklch(0.16 0.024 250 / .98); backdrop-filter:blur(16px) saturate(1.2);
    border-bottom:1px solid var(--line); padding:.4rem .9rem 1rem;
    transform:translateY(-8px); opacity:0; pointer-events:none; transition:opacity .2s, transform .2s;
  }
  .site-header.menu-open .nav-links{ display:flex; transform:none; opacity:1; pointer-events:auto; }
  .site-header.menu-open .menu-toggle{ border-color:var(--gold); color:var(--gold); }
  .nav-links a{ padding:.95rem .3rem; font-size:1.05rem; border-bottom:1px solid var(--line-soft); color:var(--text); }
  .nav-links a:last-child{ border-bottom:0; }
  .nav-links .nav-cta{ display:block; margin-top:.9rem; border:0; padding:0; }
  .nav-links .nav-cta .btn{ display:flex; width:100%; justify-content:center; }

  .sec-head.spread{ flex-direction:column; align-items:flex-start; }
  .choice-grid{ grid-template-columns:1fr; }
  .stat-band{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  body{ font-size:16px; }
}
