/* =========================================================
   PELICAN MUAY THAI — Refonte 2.0
   Old-school boxing poster · fond blanc · noir / rouge / laiton
   ========================================================= */

/* ---------- Polices auto-hébergées (RGPD : aucune connexion à Google) ---------- */
@font-face{font-family:"Anton";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/anton-400.woff2") format("woff2")}
@font-face{font-family:"Barlow";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/barlow-400.woff2") format("woff2")}
@font-face{font-family:"Barlow";font-style:normal;font-weight:500;font-display:swap;src:url("../fonts/barlow-500.woff2") format("woff2")}
@font-face{font-family:"Barlow";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/barlow-600.woff2") format("woff2")}
@font-face{font-family:"Barlow";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/barlow-700.woff2") format("woff2")}
@font-face{font-family:"Barlow Condensed";font-style:normal;font-weight:500;font-display:swap;src:url("../fonts/barlow-condensed-500.woff2") format("woff2")}
@font-face{font-family:"Barlow Condensed";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/barlow-condensed-600.woff2") format("woff2")}
@font-face{font-family:"Barlow Condensed";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/barlow-condensed-700.woff2") format("woff2")}

:root{
  --red:#c8102e;
  --red-dark:#9c0c23;
  --gold:#c9a24b;
  --gold-soft:#e7d3a1;
  --ink:#141210;
  --ink-soft:#33302c;
  --grey:#6e6a64;
  --line:#e6e2db;
  --bg:#ffffff;
  --cream:#f7f3ec;
  --black:#0b0a0a;
  --maxw:1200px;
  --shadow:0 20px 50px rgba(0,0,0,.16);
  --shadow-sm:0 8px 24px rgba(0,0,0,.08);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Barlow","Segoe UI",system-ui,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.62;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
svg{display:block}

h1,h2,h3,h4,.display{
  font-family:"Anton","Barlow",sans-serif;font-weight:400;
  text-transform:uppercase;line-height:.96;letter-spacing:.6px;
}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- Icons ---------- */
.ico svg{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- Sections ---------- */
.section{padding:96px 0;position:relative}
.section--cream{background:var(--cream)}
.section--dark{background:var(--black);color:#fff;position:relative}
.section--dark::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 2px,transparent 2px 9px),
    radial-gradient(1200px 400px at 50% -10%,rgba(200,16,46,.28),transparent 70%);
}
.section--dark>.container{position:relative;z-index:1}

.section-head{max-width:780px;margin:0 auto 60px;text-align:center}
.kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-family:"Barlow Condensed",sans-serif;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;font-size:13px;color:var(--red);margin-bottom:16px;
}
.kicker::before,.kicker::after{content:"";width:30px;height:2px;background:var(--red)}
.kicker.solo::before,.kicker.solo::after{display:none}
.section-title{font-size:clamp(34px,5.2vw,58px)}
.section-title .hl{color:var(--red)}
.section-sub{margin-top:18px;color:var(--grey);font-size:17.5px}
.section--dark .section-sub{color:#c4c0ba}
.section--dark .kicker{color:var(--gold)}
.section--dark .kicker::before,.section--dark .kicker::after{background:var(--gold)}

/* ornamental divider */
.orn{display:flex;align-items:center;justify-content:center;gap:14px;margin:18px auto 0;color:var(--red)}
.orn span{height:2px;width:46px;background:currentColor;opacity:.6}
.orn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Barlow Condensed",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;font-size:16px;
  padding:16px 32px;border:2px solid var(--red);background:var(--red);color:#fff;
  cursor:pointer;border-radius:2px;transition:.25s var(--ease);position:relative;
}
.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.4}
.btn:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);box-shadow:0 10px 24px rgba(200,16,46,.32)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--light{background:#fff;color:var(--ink);border-color:#fff}
.btn--light:hover{background:transparent;color:#fff;border-color:#fff}
.btn--outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--outline-light:hover{background:#fff;color:var(--ink);border-color:#fff}

/* ---------- Top bar ---------- */
.topbar{background:var(--black);color:#d8d4cd;font-family:"Barlow Condensed",sans-serif;font-size:14px;letter-spacing:.6px}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:42px}
.topbar .tb-left{display:flex;gap:26px;align-items:center}
.topbar a{display:inline-flex;align-items:center;gap:8px;color:#d8d4cd;transition:.2s}
.topbar a:hover{color:#fff}
.topbar svg{width:15px;height:15px;stroke:var(--gold);fill:none;stroke-width:2}
.topbar .tb-right{display:flex;gap:16px;align-items:center}
.topbar .tb-right .lbl{color:var(--gold);text-transform:uppercase;letter-spacing:2px;font-weight:600}
.topbar .tb-soc a{width:24px;height:24px;border:1px solid rgba(255,255,255,.25);border-radius:50%;justify-content:center;font-weight:700;font-size:12px}
.topbar .tb-soc a:hover{background:var(--red);border-color:var(--red)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:80;background:#fff;border-bottom:3px solid var(--ink)}
.site-header::after{content:"";display:block;height:3px;background:var(--red)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:58px;width:auto}
.brand b{font-family:"Anton",sans-serif;font-size:22px;letter-spacing:.5px;text-transform:uppercase;line-height:1;display:block}
.brand b span{color:var(--red)}
.brand small{display:block;font-family:"Barlow Condensed",sans-serif;font-size:11px;letter-spacing:3.5px;color:var(--grey);text-transform:uppercase;margin-top:3px}

.menu{display:flex;align-items:center;gap:2px}
.menu a{
  font-family:"Barlow Condensed",sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:1.2px;font-size:16.5px;padding:12px 16px;color:var(--ink-soft);position:relative;transition:color .2s;
}
.menu a::after{content:"";position:absolute;left:16px;right:16px;bottom:6px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.menu a:hover,.menu a.active{color:var(--red)}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.menu .btn{margin-left:14px;color:#fff;padding:13px 24px}
.menu .btn:hover{color:#fff}
.menu .btn::after{display:none}

.burger{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;flex-direction:column;justify-content:center;gap:6px}
.burger span{display:block;height:3px;width:28px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--black)}
.hero-media{position:relative;width:100%}
.hero-media>img{width:100%;height:auto;display:block}          /* image visible EN ENTIER */
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,6,6,.9) 0%,rgba(7,6,6,.6) 42%,rgba(7,6,6,.18) 100%)}
.hero-overlay::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.018) 0 2px,transparent 2px 10px)}
.hero-inner{position:absolute;inset:0;display:flex;align-items:center}
.hero-content{max-width:680px;color:#fff;position:relative;z-index:2}
.hero-content .kicker{color:var(--gold)}
.hero-content .kicker::before,.hero-content .kicker::after{background:var(--gold)}
.hero h1{font-size:clamp(42px,7.4vw,92px);color:#fff;text-shadow:0 6px 30px rgba(0,0,0,.55)}
.hero h1 span{color:var(--red)}
.hero p{margin:22px 0 34px;font-size:clamp(16px,2vw,20px);color:#e7e4df;max-width:540px}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px}

/* vintage stamp */
.stamp{
  position:absolute;right:38px;top:50%;transform:translateY(-50%) rotate(-8deg);z-index:3;
  width:170px;height:170px;border-radius:50%;
  border:3px double var(--gold);color:var(--gold);
  display:grid;place-items:center;text-align:center;
  background:rgba(11,10,10,.35);backdrop-filter:blur(2px);
}
.stamp .ring{position:absolute;inset:10px;border:1px solid rgba(201,162,75,.5);border-radius:50%}
.stamp b{font-family:"Anton",sans-serif;font-size:40px;color:var(--gold);line-height:.9}
.stamp small{display:block;font-family:"Barlow Condensed",sans-serif;letter-spacing:3px;font-size:11px;text-transform:uppercase;margin-top:4px}
.stamp .top,.stamp .bot{font-family:"Barlow Condensed",sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase}

/* stats band under hero */
.statband{background:var(--ink);color:#fff;border-bottom:3px solid var(--red)}
.statband .container{display:grid;grid-template-columns:repeat(4,1fr)}
.statband .st{padding:26px 18px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.statband .st:last-child{border-right:0}
.statband .st b{display:block;font-family:"Anton",sans-serif;font-size:38px;color:var(--gold);line-height:1}
.statband .st span{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:2px;font-size:13px;color:#c8c4be}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.about-text h2{font-size:clamp(32px,4.6vw,52px);margin-bottom:6px}
.about-text h2 span{color:var(--red)}
.about-text p{margin:16px 0;color:var(--ink-soft);font-size:17px}
.about-text .lead{font-size:19.5px;font-weight:600;color:var(--ink);border-left:4px solid var(--red);padding-left:18px}
.about-media{position:relative;padding:14px}
.about-media::before{content:"";position:absolute;inset:0;border:2px solid var(--ink);transform:translate(14px,14px);z-index:0}
.about-media img{position:relative;z-index:1;width:100%;object-fit:cover;aspect-ratio:4/5;box-shadow:var(--shadow)}
.about-media .tag{position:absolute;left:-14px;bottom:24px;z-index:2;background:var(--red);color:#fff;padding:16px 24px;box-shadow:var(--shadow)}
.about-media .tag b{font-family:"Anton",sans-serif;font-size:34px;line-height:1;display:block}
.about-media .tag span{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:12px}

/* value cards */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:64px}
.value{background:#fff;border:1px solid var(--line);padding:34px 26px;transition:.25s var(--ease);position:relative;overflow:hidden}
.value::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.value:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.value:hover::before{transform:scaleX(1)}
.value .ico{width:60px;height:60px;border:2px solid var(--red);border-radius:50%;display:grid;place-items:center;color:var(--red);margin-bottom:20px}
.value .ico svg{width:28px;height:28px}
.value h3{font-size:21px;margin-bottom:8px}
.value p{color:var(--grey);font-size:15px}

/* ---------- Coaches ---------- */
.coaches{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.coach{display:flex;gap:22px;background:#fff;border:1px solid var(--line);border-top:4px solid var(--red);padding:30px}
.coach .badge{flex:0 0 70px;width:70px;height:70px;border-radius:50%;background:var(--ink);color:var(--gold);display:grid;place-items:center;font-family:"Anton",sans-serif;font-size:26px;border:2px solid var(--gold)}
.coach h3{font-size:23px}
.coach .role{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:1.5px;color:var(--red);font-weight:700;font-size:13.5px;margin-bottom:10px}
.coach p{font-size:15px;color:var(--ink-soft)}
.coach .coach-photo{flex:0 0 92px;width:92px;height:92px;border-radius:50%;object-fit:cover;object-position:center 25%;border:2px solid var(--gold);background:#0e0e0e;box-shadow:var(--shadow-sm)}
/* Photo d'action (paysage) : on affiche l'image entière, cadre rond -> arrondi doux */
.coach .coach-photo--full{flex:0 0 120px;width:120px;height:120px;border-radius:14px;object-fit:contain;object-position:center}

/* ---------- Carousel ---------- */
.carousel{position:relative}
.carousel-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 0 18px;-ms-overflow-style:none;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 auto;width:350px;scroll-snap-align:center;overflow:hidden;box-shadow:var(--shadow);position:relative;background:#1a1a1a;border:1px solid rgba(255,255,255,.08)}
.slide img{width:100%;height:380px;object-fit:cover;object-position:center 28%;transition:transform .6s var(--ease)}
.slide::after{content:"";position:absolute;inset:0;border:2px solid transparent;transition:.3s}
.slide:hover img{transform:scale(1.06)}
.slide:hover::after{border-color:var(--gold)}
.carousel-nav{display:flex;justify-content:center;gap:16px;margin-top:26px}
.carousel-nav button{width:54px;height:54px;border-radius:50%;border:2px solid var(--ink);background:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s var(--ease);color:var(--ink)}
.carousel-nav button svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2.4}
.carousel-nav button:hover{background:var(--red);border-color:var(--red);color:#fff}
.section--dark .carousel-nav button{background:transparent;border-color:rgba(255,255,255,.7);color:#fff}
.section--dark .carousel-nav button:hover{background:var(--red);border-color:var(--red)}

/* ---------- Page banner ---------- */
.page-hero .hero-media>img{filter:brightness(.5)}
.page-hero .hero-overlay{background:linear-gradient(180deg,rgba(7,6,6,.55),rgba(7,6,6,.8))}
.page-hero .hero-inner{justify-content:center;text-align:center}
.page-hero .hero-content{max-width:860px}
.page-hero .kicker{justify-content:center}
.page-hero h1{font-size:clamp(40px,7.4vw,82px)}
.breadcrumb{font-family:"Barlow Condensed",sans-serif;letter-spacing:1.5px;text-transform:uppercase;color:#ddd;font-size:14px;margin-top:18px}
.breadcrumb a:hover{color:var(--gold)}

/* ---------- Schedule ---------- */
.sched{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.day{background:#fff;border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow-sm)}
.day .day-h{background:var(--ink);color:#fff;text-align:center;padding:18px;font-family:"Anton",sans-serif;font-size:25px;text-transform:uppercase;letter-spacing:1px;position:relative}
.day .day-h::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--red)}
.day .day-h.is-red{background:var(--red)}
.day .day-h.is-red::after{background:var(--gold)}
.slot{padding:18px 20px;border-bottom:1px solid var(--line)}
.slot:last-child{border-bottom:0}
.slot .time{font-family:"Barlow Condensed",sans-serif;font-weight:700;font-size:19px;color:var(--red)}
.slot .name{font-size:14.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.6px;font-weight:600}

/* ---------- Pricing ---------- */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.price-card{background:#fff;border:1px solid var(--line);padding:38px 30px;display:flex;flex-direction:column;transition:.25s var(--ease);position:relative}
.price-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.price-card.featured{border:2px solid var(--red);box-shadow:var(--shadow)}
.price-card .ribbon{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;font-size:13px;padding:6px 18px}
.price-card h3{font-size:27px;margin-bottom:6px}
.price-card .tagline{color:var(--grey);font-size:14px;margin-bottom:22px;min-height:20px}
.price-main{font-family:"Anton",sans-serif;font-size:56px;color:var(--red);line-height:1}
.price-main small{font-size:18px;color:var(--grey);font-family:"Barlow Condensed",sans-serif}
.price-list{margin:22px 0 26px;border-top:2px solid var(--ink)}
.price-list li{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.price-list li span:last-child{font-weight:700;color:var(--ink)}
.price-card .btn{margin-top:auto;justify-content:center}
.formules{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:34px}
.formule{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--ink);color:#fff;padding:28px 32px;border-left:5px solid var(--red)}
.formule h4{font-family:"Anton",sans-serif;font-size:22px;text-transform:uppercase;color:#fff}
.formule .f-price{font-family:"Anton",sans-serif;font-size:42px;color:var(--gold);white-space:nowrap}
.formule .f-price small{font-size:15px;color:#cfcbc4;opacity:.85}
.formule.is-red{background:var(--red);border-left-color:var(--gold)}
.formule.is-red .f-price{color:#fff}

/* ---------- Sections detail ---------- */
.sec-block{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-bottom:90px}
.sec-block:last-child{margin-bottom:0}
.sec-block.flip .sec-media{order:2}
.sec-media{position:relative;padding:14px}
.sec-media::before{content:"";position:absolute;inset:0;border:2px solid var(--red);transform:translate(-14px,14px)}
.sec-block.flip .sec-media::before{transform:translate(14px,14px)}
.sec-media img{position:relative;width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow)}
.sec-info .age{display:inline-block;background:var(--ink);color:var(--gold);font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:2px;font-weight:700;font-size:13px;padding:7px 16px;margin-bottom:14px;border:1px solid var(--gold)}
.sec-info h2{font-size:clamp(32px,4.6vw,50px)}
.sec-info h2 span{color:var(--red)}
.sec-info .desc{color:var(--ink-soft);margin:16px 0 26px;font-size:17.5px}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:28px}
.feature{display:flex;gap:14px;align-items:center;background:var(--cream);border-left:3px solid var(--red);padding:14px 16px}
.feature .ico{flex:0 0 38px;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--red)}
.feature .ico svg{width:20px;height:20px}
.feature b{font-size:14.5px;text-transform:uppercase;letter-spacing:.3px;font-family:"Barlow Condensed",sans-serif;font-weight:600}
.sched-inline{display:flex;flex-wrap:wrap;gap:12px}
.sched-inline .chip{background:var(--ink);color:#fff;padding:11px 18px;font-family:"Barlow Condensed",sans-serif;font-weight:600;letter-spacing:.5px}
.sched-inline .chip b{color:var(--gold);margin-right:8px}

/* ---------- Adhesion ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{background:#fff;border:1px solid var(--line);padding:34px 26px;position:relative;overflow:hidden}
.step .num{font-family:"Anton",sans-serif;font-size:88px;color:var(--red);line-height:.7;opacity:.12;position:absolute;top:10px;right:18px}
.step .stp{font-family:"Barlow Condensed",sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--red);font-weight:700;font-size:12px}
.step h3{font-size:22px;margin:6px 0 10px}
.step p{font-size:15px;color:var(--ink-soft)}
.docs-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.doc-list .doc{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border:1px solid var(--line);margin-bottom:14px;transition:.2s;color:var(--ink);min-width:0}
.doc-list .doc:hover{border-color:var(--red);box-shadow:var(--shadow-sm)}
.doc-list .di{flex:0 0 44px;width:44px;height:44px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700;font-family:"Barlow Condensed",sans-serif;font-size:13px}
.doc-list .doc-name{flex:1 1 auto;min-width:0}
.doc-list b{display:block;font-size:15.5px;line-height:1.25;overflow-wrap:break-word}
.doc-list .doc-name span{font-size:13px;color:var(--grey)}
.doc-list .opt{flex:0 0 auto;font-size:11px;background:var(--ink);color:var(--gold);padding:4px 9px;text-transform:uppercase;letter-spacing:.5px;font-family:"Barlow Condensed",sans-serif;white-space:nowrap}
.doc-list .dl-ico{flex:0 0 auto;color:var(--red)}
.doc-list .dl-ico svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2.2}
.doc-list .doc:hover .dl-ico{color:var(--red-dark)}
.note-card{background:var(--ink);color:#fff;padding:34px;border-top:4px solid var(--gold)}
.note-card h3{color:#fff;font-size:25px;margin-bottom:18px}
.note-card ul li{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);font-size:15px;color:#e1ddd6;display:flex;gap:12px}
.note-card ul li:last-child{border:0}
.note-card ul li svg{flex:0 0 18px;width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:2.4;margin-top:3px}
.note-card ul li{overflow-wrap:break-word;word-break:break-word}
.note-card a{overflow-wrap:anywhere}
.warn{background:#fff5f6;border:1px solid #f0c4cb;border-left:5px solid var(--red);padding:22px 26px;margin-top:28px;color:var(--ink-soft)}
.warn b{color:var(--red)}

/* equipment */
.equip{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;justify-content:center}
.equip .item{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);padding:13px 20px;border-radius:40px;font-weight:600;font-size:15px}
.equip .item svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:2.6}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:stretch}
.contact-info h2{font-size:clamp(32px,4.6vw,50px);color:#fff}
.contact-info h2 span{color:var(--red)}
.contact-info p{color:#cbc7c0;margin:16px 0 30px;font-size:17px}
.contact-lines li{display:flex;align-items:center;gap:18px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.contact-lines .ico{flex:0 0 52px;width:52px;height:52px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center}
.contact-lines .ico svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2}
.contact-lines small{display:block;text-transform:uppercase;letter-spacing:2px;font-size:11px;color:var(--gold);font-family:"Barlow Condensed",sans-serif;font-weight:600}
.contact-lines b{font-size:19px;color:#fff;font-weight:600}
.socials{display:flex;gap:14px;margin-top:28px}
.socials a{width:52px;height:52px;border-radius:50%;border:2px solid rgba(255,255,255,.3);display:grid;place-items:center;color:#fff;font-weight:700;font-family:"Barlow Condensed",sans-serif;transition:.2s}
.socials a:hover{background:var(--red);border-color:var(--red);transform:translateY(-3px)}
.contact-card{background:#fff;padding:40px;box-shadow:var(--shadow);border-top:4px solid var(--red)}
.contact-card h3{font-size:27px;margin-bottom:6px}
.contact-card h3 span{color:var(--red)}
.contact-card p{color:var(--grey);margin-bottom:26px;font-size:15px}
.field{margin-bottom:18px}
.field label{display:block;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-weight:600;font-size:13px;margin-bottom:7px;color:var(--ink-soft)}
.field input,.field textarea,.field select{width:100%;padding:14px 16px;border:1px solid var(--line);font-family:inherit;font-size:15px;background:#faf9f7;transition:.2s;border-radius:2px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red);background:#fff}
.contact-card .btn{width:100%;justify-content:center}
/* Affiches disciplines (page sections) */
.affiches{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:0}
.affiche{margin:0;padding:12px;background:#0e0e0e;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;transition:.25s var(--ease)}
.affiche::after{content:"";position:absolute;inset:0;border:2px solid transparent;transition:.25s}
.affiche:hover{transform:translateY(-6px)}
.affiche:hover::after{border-color:var(--gold)}
.affiche img{width:100%;height:auto;display:block}
@media (max-width:900px){.affiches{grid-template-columns:1fr 1fr;gap:18px}}
@media (max-width:680px){.affiches{grid-template-columns:1fr;max-width:420px;margin:0 auto}}

.map-wrap{margin-top:54px;border:3px solid var(--gold);box-shadow:var(--shadow);line-height:0}
.map-wrap iframe{display:block;filter:grayscale(.3) contrast(1.05)}

/* ---------- CTA strip ---------- */
.cta-strip{background:var(--red);color:#fff;text-align:center;padding:78px 0;position:relative;overflow:hidden}
.cta-strip::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(0,0,0,.05) 0 2px,transparent 2px 12px)}
.cta-strip>.container{position:relative}
.cta-strip h2{font-size:clamp(32px,5vw,54px);color:#fff}
.cta-strip p{font-size:18px;margin:16px 0 30px;color:#ffe0e4}
.cta-strip .btn--light{color:var(--red)}
.cta-strip .btn--light:hover{color:#fff;border-color:#fff}

/* ---------- Partners ---------- */
.partners{display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap;margin-top:10px}
.partners img{height:80px;width:auto;filter:grayscale(1);opacity:.65;transition:.25s}
.partners img:hover{filter:none;opacity:1}
.partners .partner-text{font-family:"Anton",sans-serif;font-size:42px;letter-spacing:1px;color:var(--ink);opacity:.55;transition:.25s}
.partners .partner-text:hover{opacity:1;color:var(--red)}

/* ---------- Footer ---------- */
.site-footer{background:#0a0908;color:#cfcbc4;padding:70px 0 0;border-top:4px solid var(--red)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:44px}
.foot-brand img{height:70px;margin-bottom:18px}
.foot-brand p{font-size:15px;color:#928e87;max-width:290px}
.foot-brand .fsoc{display:flex;gap:12px;margin-top:18px}
.foot-brand .fsoc a{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;font-family:"Barlow Condensed",sans-serif;font-weight:700;transition:.2s}
.foot-brand .fsoc a:hover{background:var(--red);border-color:var(--red);color:#fff}
.foot-col h2{font-family:"Anton",sans-serif;text-transform:uppercase;color:#fff;font-size:19px;letter-spacing:1px;margin-bottom:20px;position:relative;padding-bottom:12px}
.foot-col h2::after{content:"";position:absolute;left:0;bottom:0;width:34px;height:3px;background:var(--red)}
.foot-col a,.foot-col li{display:block;padding:8px 0;color:#b6b2ab;font-size:15px;transition:.2s}
.foot-col a:hover{color:var(--gold);padding-left:6px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:52px;padding:24px 0;text-align:center;font-size:13px;color:#9a958d}
.foot-bottom a{color:var(--gold);text-decoration:underline}
.foot-bottom .credit strong,.foot-bottom .credit a{color:var(--gold);letter-spacing:.5px;font-weight:700}
.foot-bottom .credit a{text-decoration:none}
.foot-bottom .credit a:hover{text-decoration:underline}

/* ---------- Lightbox / zoom ---------- */
.zoomable{cursor:zoom-in}
.affiche{cursor:zoom-in}
.lightbox{position:fixed;inset:0;background:rgba(6,6,6,.93);display:none;align-items:center;justify-content:center;z-index:200;padding:28px;cursor:zoom-out}
.lightbox.open{display:flex;animation:lbfade .2s ease}
@keyframes lbfade{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:96%;max-height:90vh;width:auto;height:auto;border:3px solid var(--gold);box-shadow:0 24px 70px rgba(0,0,0,.6)}
.lightbox .lb-close{position:absolute;top:16px;right:26px;color:#fff;font-size:46px;line-height:1;cursor:pointer;font-family:"Anton",sans-serif;transition:.2s}
.lightbox .lb-close:hover{color:var(--gold)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .values{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .sched{grid-template-columns:1fr 1fr}
  .stamp{width:140px;height:140px;right:24px}
  .stamp b{font-size:32px}
}
@media (max-width:900px){
  .topbar .tb-left .tb-hide{display:none}
  .menu{position:fixed;top:84px;right:0;left:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:3px solid var(--red);padding:14px 24px 26px;transform:translateY(-140%);transition:transform .35s var(--ease);box-shadow:var(--shadow);max-height:calc(100vh - 84px);overflow:auto}
  .menu.open{transform:none}
  .menu a{padding:15px 6px;border-bottom:1px solid var(--line);font-size:18px}
  .menu a::after{display:none}
  .menu .btn{margin:16px 0 0;justify-content:center}
  .burger{display:flex}
  .about-grid,.contact-grid,.docs-grid,.coaches,.sec-block,.sec-block.flip{grid-template-columns:1fr}
  .sec-block.flip .sec-media{order:0}
  .pricing{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .hero-overlay{background:linear-gradient(180deg,rgba(7,6,6,.35) 0%,rgba(7,6,6,.85) 100%)}
  .hero-inner{align-items:flex-end;padding-bottom:36px}
  .stamp{display:none}
  /* Phones/small tablets: image EN ENTIER en haut, texte dessous */
  .hero{display:flex;flex-direction:column}
  .hero-media{display:flex;flex-direction:column}
  .hero-overlay{display:none}
  .hero-inner{position:static;order:2;background:var(--black);width:100%;padding:36px 0 40px}
  .hero-content{max-width:none}
  .page-hero .hero-media>img{filter:none}
  .page-hero .hero-inner{text-align:center}
  .statband .container{grid-template-columns:1fr 1fr}
  .statband .st:nth-child(2){border-right:0}
  .statband .st{border-bottom:1px solid rgba(255,255,255,.1)}
}
@media (max-width:680px){
  .section{padding:66px 0}
  .container{padding:0 20px}
  .topbar{display:none}
  .values,.formules,.feature-grid,.sched,.steps{grid-template-columns:1fr}
  .partners{gap:34px}
  .partners img{height:60px}
  .slide{width:82vw}
  .slide img{height:400px}
  .formule{flex-direction:column;text-align:center;gap:12px}
  .about-media .tag{left:50%;transform:translateX(-50%);bottom:-20px}
  .about-media::before,.sec-media::before{display:none}
  .coach{flex-direction:column;text-align:center;align-items:center}
}

/* ---------- Logos réseaux sociaux (SVG de marque) ---------- */
.topbar .tb-soc a svg,.socials a svg,.foot-brand .fsoc a svg{fill:currentColor;stroke:none}
.topbar .tb-soc a svg{width:13px;height:13px}
.socials a svg{width:22px;height:22px}
.foot-brand .fsoc a svg{width:18px;height:18px}

/* =========================================================
   ADDITIONS 2.1 — carte sans cookie, FAQ, bandeau cookies,
   pages légales, page 404
   ========================================================= */

/* ---------- FAQ (accordéon) ---------- */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-left:4px solid var(--red);transition:.2s}
.faq-item[open]{box-shadow:var(--shadow-sm)}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:20px 24px;font-family:"Barlow Condensed",sans-serif;font-weight:700;font-size:19px;
  text-transform:uppercase;letter-spacing:.5px;color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .pm{flex:0 0 26px;width:26px;height:26px;position:relative}
.faq-item summary .pm::before,.faq-item summary .pm::after{content:"";position:absolute;background:var(--red);transition:.25s var(--ease)}
.faq-item summary .pm::before{top:12px;left:3px;right:3px;height:2px}
.faq-item summary .pm::after{left:12px;top:3px;bottom:3px;width:2px}
.faq-item[open] summary .pm::after{transform:scaleY(0)}
.faq-item .faq-body{padding:0 24px 22px;color:var(--ink-soft);font-size:16px;line-height:1.65}
.faq-item .faq-body a{color:var(--red);text-decoration:underline}

/* ---------- Bandeau cookies ---------- */
.cookie-banner{
  position:fixed;left:18px;right:18px;bottom:18px;z-index:300;max-width:560px;margin:0 auto;
  background:var(--ink);color:#e7e4df;border-top:4px solid var(--red);box-shadow:0 18px 50px rgba(0,0,0,.45);
  padding:22px 24px;transform:translateY(160%);transition:transform .45s var(--ease);
}
.cookie-banner.show{transform:none}
.cookie-banner h4{font-family:"Anton",sans-serif;color:#fff;font-size:19px;letter-spacing:.5px;margin-bottom:8px}
.cookie-banner p{font-size:14.5px;color:#c4c0ba;line-height:1.55}
.cookie-banner p a{color:var(--gold);text-decoration:underline}
.cookie-banner .cb-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.cookie-banner .cb-actions .btn{padding:12px 22px;font-size:14px}
.cookie-banner .btn--ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.cookie-banner .btn--ghost:hover{background:#fff;color:var(--ink)}

/* ---------- Contenu pages légales ---------- */
.legal{max-width:840px;margin:0 auto}
.legal h2{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:clamp(24px,3.6vw,32px);color:var(--ink);margin:42px 0 14px;padding-bottom:10px;border-bottom:2px solid var(--ink)}
.legal h2:first-child{margin-top:0}
.legal h2 span{color:var(--red)}
.legal h3{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.5px;font-size:20px;color:var(--ink);margin:26px 0 8px}
.legal p,.legal li{color:var(--ink-soft);font-size:16.5px;line-height:1.7;margin-bottom:12px}
.legal ul{list-style:disc;padding-left:22px;margin-bottom:14px}
.legal ul li{margin-bottom:6px}
.legal a{color:var(--red);text-decoration:underline;overflow-wrap:anywhere}
.legal .todo{background:#fff5f6;border:1px dashed var(--red);color:var(--red-dark);font-weight:600;padding:2px 8px;border-radius:3px}
.legal .updated{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:13px;color:var(--grey);margin-bottom:30px}

/* ---------- Page 404 ---------- */
.err-wrap{min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 0;background:var(--cream)}
.err-wrap .big{font-family:"Anton",sans-serif;font-size:clamp(96px,22vw,200px);line-height:.9;color:var(--red);letter-spacing:2px}
.err-wrap h1{font-family:"Anton",sans-serif;font-size:clamp(28px,4vw,42px);margin:8px 0 14px;text-transform:uppercase}
.err-wrap p{color:var(--grey);font-size:18px;max-width:520px;margin:0 auto 30px}
.err-wrap .hero-actions{justify-content:center}
