/* =====================================================================
   CLUB BADMINTON RODEZ — Direction "Audacieuse" (hi-fi)
   Design system + page styles
   ===================================================================== */

:root{
  /* palette — d'après la serviette CBR : bordeaux + doré */
  --ink:#241015;
  --ink-2:#321820;
  --red:#8c1d22;            /* bordeaux — tweakable */
  --red-deep:#6a161a;
  --gold:#d7a23c;           /* doré — accent — tweakable */
  --gold-deep:#b9842a;
  --cream:#f7f1e7;
  --cream-2:#f0e6d4;
  --white:#ffffff;
  --line:#e6dcc8;
  --muted:#6f655a;

  /* type */
  --display:'Anton', system-ui, sans-serif;     /* tweakable */
  --sans:'Archivo', system-ui, sans-serif;

  /* rhythm */
  --space-scale:1;                              /* tweakable (density) */
  --tilt:1deg;                                  /* tweakable (diagonales) */
  --diag:14%;                                   /* diagonal cut depth */

  --shadow-hard:0 16px 34px -16px rgba(36,16,21,.32);
  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
section{position:relative;}

/* display type helper */
.display{
  font-family:var(--display);
  font-weight:400;
  line-height:.9;
  letter-spacing:.5px;
  text-transform:uppercase;
}
body.disp-rounded .display{font-family:'Baloo 2',var(--sans);font-weight:800;letter-spacing:-.5px;line-height:.95;}
body.disp-serif .display{font-family:'DM Serif Display',Georgia,serif;font-weight:400;letter-spacing:0;text-transform:none;line-height:.98;}

/* section number / eyebrow */
.eyebrow{
  font-family:var(--sans);font-weight:800;font-size:13px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--gold);}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.sec-num{font-family:var(--display);font-size:clamp(40px,6vw,78px);color:var(--ink);line-height:.8;}
body.disp-serif .sec-num{font-family:'DM Serif Display',serif;}
.sec-title{font-family:var(--display);font-size:clamp(30px,4.4vw,54px);line-height:.92;text-transform:uppercase;letter-spacing:.5px;}
body.disp-rounded .sec-title{font-family:'Baloo 2',sans-serif;font-weight:800;letter-spacing:-.5px;}
body.disp-serif .sec-title{font-family:'DM Serif Display',serif;text-transform:none;font-weight:400;}
.link-more{font-weight:800;font-size:14px;letter-spacing:.5px;color:var(--red);display:inline-flex;align-items:center;gap:7px;}
.link-more::after{content:"→";transition:transform .2s;}
.link-more:hover::after{transform:translateX(4px);}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:800;font-size:15px;letter-spacing:.3px;
  padding:14px 26px;border-radius:7px;cursor:pointer;border:1.5px solid var(--ink);
  background:var(--white);color:var(--ink);transition:transform .12s, box-shadow .12s, background .12s;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hard);}
.btn:active{transform:translate(0,0);box-shadow:0 6px 16px -8px rgba(23,23,28,.3);}
.btn.primary{background:var(--red);color:#fff;}
.btn.ghost-light{background:transparent;border-color:#fff;color:#fff;}
.btn.ghost-light:hover{box-shadow:0 14px 30px -14px rgba(0,0,0,.45);}

/* a gold accent button variant (use on burgundy / dark backgrounds) */
.btn.gold{background:var(--gold);color:var(--ink);border-color:var(--ink);}
.btn.gold:hover{box-shadow:0 16px 30px -14px rgba(36,16,21,.5);}
/* tag/chip */
.tag{display:inline-block;font-weight:800;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:#fff;background:var(--red);padding:5px 11px;border-radius:3px;}
.tag.ink{background:var(--ink);}
.tag.gold{background:var(--gold);color:var(--ink);}
.tag.outline{background:transparent;color:var(--ink);border:2px solid var(--ink);}

/* ===================== NAV ===================== */
.nav{position:sticky;top:0;z-index:40;background:var(--ink);color:#fff;border-bottom:2px solid var(--gold);}
.nav .wrap{display:flex;align-items:center;gap:24px;height:74px;}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:24px;letter-spacing:1px;text-transform:uppercase;}
.brand img{width:42px;height:42px;}
.nav-links{display:flex;gap:26px;margin-left:14px;flex:1;}
.nav-links a{font-weight:600;font-size:14.5px;color:#e9e9ec;position:relative;padding:4px 0;}
.nav-links a:hover{color:#fff;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2.5px;background:var(--gold);transition:width .2s;}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:#fff;}
.nav .btn{padding:11px 20px;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;}
.burger span{width:26px;height:3px;background:#fff;border-radius:2px;}

/* ===================== HERO ===================== */
.hero{background:var(--cream);overflow:hidden;border-bottom:1px solid var(--line);}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;
  padding-top:calc(40px*var(--space-scale));padding-bottom:calc(40px*var(--space-scale));position:relative;}
.hero-watermark{position:absolute;right:-120px;top:-60px;width:520px;opacity:.06;pointer-events:none;transform:rotate(8deg);}
.hero-copy{position:relative;z-index:2;}
.hero-eyebrow{margin-bottom:14px;}
.hero-title{font-size:clamp(50px,8vw,104px);}
.hero-title .l{display:block;overflow:hidden;}
.hero-title .l span{display:block;}
.hero-title .red{color:var(--red);}
.hero-sub{font-size:18px;color:var(--muted);max-width:430px;margin:20px 0 26px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-visual{position:relative;z-index:1;}
.hero-photo-frame{position:relative;}
.hero-photo-frame::before{
  content:"";position:absolute;inset:-18px -18px 18px 18px;background:var(--red);
  clip-path:polygon(var(--diag) 0,100% 0,100% 100%,0 100%);z-index:0;
}
.hero-photo{position:relative;z-index:1;width:100%;height:400px;border:1px solid var(--line);border-radius:6px;
  box-shadow:var(--shadow-hard);}
.hero-badge{position:absolute;z-index:2;bottom:-22px;left:-22px;background:var(--ink);color:#fff;
  padding:14px 18px;border-radius:6px;transform:rotate(calc(var(--tilt)*-2));box-shadow:0 12px 26px -10px rgba(23,23,28,.40);}
.hero-badge b{font-family:var(--display);font-size:30px;display:block;line-height:.9;color:var(--gold);}
.hero-badge small{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#cfcfd6;}

/* hover & marquee motion only (no fragile entrance animations) */

/* ===================== MARQUEE ===================== */
.marquee{background:var(--red);color:#fff;border-bottom:1px solid var(--line);overflow:hidden;padding:13px 0;}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scrollX 104s linear infinite;}
.marquee-track span{font-family:var(--display);font-size:24px;letter-spacing:1px;text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:26px;}
.marquee-track span::after{content:"●";font-size:12px;color:var(--gold);}
@keyframes scrollX{to{transform:translateX(-50%);}}

/* ===================== generic section spacing ===================== */
.block{padding:calc(72px*var(--space-scale)) 0;}
.block.tight{padding:calc(52px*var(--space-scale)) 0;}

/* ===================== ACTUS (news) ===================== */
.news-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:26px;margin-top:38px;}
.news-feature{position:relative;}
.news-feature .news-photo{width:100%;height:330px;object-fit:cover;display:block;border:1px solid var(--line);border-radius:6px;box-shadow:var(--shadow-hard);}
.news-feature .news-meta{display:flex;align-items:center;gap:12px;margin:18px 0 8px;}
.news-feature h3{font-family:var(--display);font-size:34px;line-height:.95;text-transform:uppercase;margin:0 0 8px;}
body.disp-rounded .news-feature h3,body.disp-rounded .news-item h4{font-family:'Baloo 2',sans-serif;font-weight:800;text-transform:none;}
body.disp-serif .news-feature h3,body.disp-serif .news-item h4{font-family:'DM Serif Display',serif;text-transform:none;}
.news-feature p{color:var(--muted);margin:0;max-width:520px;}
.news-list{display:flex;flex-direction:column;gap:18px;}
.news-item{display:grid;grid-template-columns:104px 1fr;gap:16px;align-items:center;background:var(--white);
  border:1px solid var(--line);border-radius:6px;padding:12px;transition:transform .14s,box-shadow .14s;}
.news-item:hover{transform:translateY(-3px);box-shadow:0 16px 32px -18px rgba(23,23,28,.26);}
.news-item .news-thumb{width:104px;height:84px;object-fit:cover;display:block;border-radius:4px;border:2px solid var(--ink);}
.news-item .date{font-size:12px;color:var(--muted);font-weight:600;}
.news-item h4{margin:5px 0 0;font-family:var(--display);font-size:19px;line-height:1;text-transform:uppercase;letter-spacing:.4px;}

/* ===================== PRATIQUER (cards) ===================== */
.practice{background:var(--cream-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.practice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px;}
.pcard{background:var(--white);border:1px solid var(--line);border-radius:8px;overflow:hidden;
  transition:transform .16s,box-shadow .16s;}
.pcard:nth-child(1){transform:none;}
.pcard:nth-child(2){transform:translateY(calc(12px*var(--space-scale)));}
.pcard:nth-child(3){transform:none;}
.pcard:hover{transform:translateY(-6px) rotate(0deg);box-shadow:var(--shadow-hard);}
.pcard .pcard-top{height:150px;position:relative;display:flex;align-items:flex-end;padding:14px;border-bottom:1px solid var(--line);}
.pcard .pcard-num{font-family:var(--display);font-size:64px;color:#fff;line-height:.7;opacity:.9;}
.pcard .pcard-body{padding:20px;}
.pcard h3{font-family:var(--display);font-size:26px;text-transform:uppercase;margin:0 0 8px;letter-spacing:.5px;}
body.disp-rounded .pcard h3{font-family:'Baloo 2',sans-serif;font-weight:800;text-transform:none;}
body.disp-serif .pcard h3{font-family:'DM Serif Display',serif;text-transform:none;}
.pcard p{margin:0 0 14px;color:var(--muted);font-size:15px;}
.pcard .pcard-link{font-weight:800;color:var(--red);font-size:14px;display:inline-flex;gap:7px;align-items:center;}
.pcard .pcard-link::after{content:"→";transition:transform .2s;}
.pcard:hover .pcard-link::after{transform:translateX(4px);}

/* ===================== STATS ===================== */
.stats{background:var(--ink);color:#fff;border-bottom:2px solid var(--red);}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:calc(54px*var(--space-scale)) 28px;}
.stat{text-align:center;position:relative;}
.stat:not(:last-child)::after{content:"";position:absolute;right:-10px;top:10%;height:80%;width:2px;background:rgba(255,255,255,.14);}
.stat .num{font-family:var(--display);font-size:clamp(46px,6vw,72px);color:var(--gold);line-height:.9;}
body.disp-serif .stat .num{font-family:'DM Serif Display',serif;}
.stat .lbl{font-weight:600;font-size:14px;letter-spacing:1px;text-transform:uppercase;color:#d7d7dd;margin-top:6px;}

/* ===================== INFOS PRATIQUES ===================== */
.infos-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:26px;margin-top:38px;align-items:start;}
.schedule{background:var(--white);border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-hard);}
.schedule .srow{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:16px 20px;border-bottom:2px solid var(--line);}
.schedule .srow:last-child{border-bottom:none;}
.schedule .sday{font-family:var(--display);font-size:22px;text-transform:uppercase;min-width:78px;}
body.disp-serif .schedule .sday{font-family:'DM Serif Display',serif;}
.schedule .sinfo{color:var(--muted);font-size:14.5px;}
.schedule .sinfo b{color:var(--ink);display:block;font-size:16px;}
.schedule .stime{font-weight:800;background:var(--cream-2);border:2px solid var(--ink);border-radius:4px;padding:6px 12px;font-size:14px;white-space:nowrap;}
.venue{background:var(--white);border:1px solid var(--line);border-radius:8px;overflow:hidden;}
.venue .venue-map{height:200px;border-bottom:1px solid var(--line);}
.venue .venue-body{padding:18px 20px;}
.venue .venue-body h4{font-family:var(--display);font-size:22px;text-transform:uppercase;margin:0 0 6px;}
body.disp-serif .venue .venue-body h4{font-family:'DM Serif Display',serif;text-transform:none;}
.venue .venue-body p{margin:0 0 4px;color:var(--muted);font-size:14.5px;}

/* ===================== INSCRIPTION CTA ===================== */
.join{background:var(--red);color:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;}
.join .wrap{position:relative;padding:calc(70px*var(--space-scale)) 28px;display:grid;grid-template-columns:1.3fr .7fr;gap:30px;align-items:center;}
.join-watermark{position:absolute;right:-60px;bottom:-90px;width:360px;opacity:.12;pointer-events:none;transform:rotate(-12deg);}
.join h2{font-family:var(--display);font-size:clamp(40px,6vw,72px);line-height:.9;text-transform:uppercase;margin:0;position:relative;}
body.disp-rounded .join h2{font-family:'Baloo 2',sans-serif;font-weight:800;text-transform:none;}
body.disp-serif .join h2{font-family:'DM Serif Display',serif;text-transform:none;}
.join p{margin:18px 0 0;font-size:18px;max-width:460px;color:rgba(255,255,255,.92);position:relative;}
.join-actions{display:flex;flex-direction:column;gap:14px;position:relative;}
.join-actions .btn{width:100%;background:#fff;border-color:var(--ink);}
.join-actions .btn.gold{background:var(--gold);color:var(--ink);}
.join-actions .btn.alt{background:var(--ink);color:#fff;}
.join-actions .btn:hover{box-shadow:0 16px 30px -14px rgba(0,0,0,.5);}

/* ===================== PARTENAIRES ===================== */
.partners-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:34px;}
.partner{height:84px;background:var(--white);border:1px solid var(--line);border-radius:6px;display:flex;
  align-items:center;justify-content:center;color:var(--muted);font-weight:700;font-size:12px;letter-spacing:.5px;
  text-align:center;padding:8px;transition:transform .14s;}
.partner:hover{transform:translateY(-4px);box-shadow:0 12px 26px -10px rgba(23,23,28,.40);}

/* ===================== FOOTER ===================== */
.footer{background:var(--ink);color:#fff;border-top:2px solid var(--red);}
.footer .wrap{padding:calc(56px*var(--space-scale)) 28px 30px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;}
.footer-brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:30px;text-transform:uppercase;}
.footer-brand img{width:46px;height:46px;}
.footer-brand + p{color:#b9b9c2;font-size:14.5px;margin-top:16px;max-width:280px;}
.footer h5{font-family:var(--sans);font-weight:800;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin:0 0 16px;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.footer ul a{color:#d6d6dd;font-size:14.5px;}
.footer ul a:hover{color:#fff;}
.footer-bottom{margin-top:40px;padding-top:22px;border-top:2px solid rgba(255,255,255,.12);display:flex;
  justify-content:space-between;gap:16px;flex-wrap:wrap;color:#8d8d97;font-size:13px;}
.socials{display:flex;gap:10px;}
.socials a{width:38px;height:38px;border:2px solid rgba(255,255,255,.25);border-radius:6px;display:flex;
  align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;transition:.15s;}
.socials a:hover{background:var(--red);border-color:var(--red);}

/* image-slot inherits */
image-slot{display:block;}

/* ===================== reduced motion ===================== */
@media (prefers-reduced-motion: reduce){
  .hero-title .l span,.hero-sub,.hero-cta{animation:none !important;transform:none !important;opacity:1 !important;}
  .marquee-track{animation:none;}
}

/* ===================== responsive ===================== */
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:46px;}
  .hero-visual{order:-1;}
  .news-grid{grid-template-columns:1fr;}
  .practice-grid{grid-template-columns:1fr;}
  .pcard{transform:none !important;}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:34px 20px;}
  .stat:nth-child(2)::after{display:none;}
  .infos-grid{grid-template-columns:1fr;}
  .join .wrap{grid-template-columns:1fr;}
  .partners-grid{grid-template-columns:repeat(3,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media (max-width:680px){
  .nav-links,.nav .btn{display:none;}
  .burger{display:flex;}
  .partners-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr;}
  .stat:not(:last-child)::after{display:none;}
}
