/*
Theme Name: Les Allobroges Goshindo
Theme URI: https://lesallobrogesgoshindo.fr
Author: Les Allobroges Goshindo
Author URI: https://lesallobrogesgoshindo.fr
Description: Theme one-page sur mesure pour le club d'arts martiaux Les Allobroges Goshindo (Seyssel, 74). Disciplines, horaires, partenaires et coordonnees editables depuis l'outil de personnalisation WordPress (Apparence > Personnaliser). Pages Inscription et Boutique integrant des widgets HelloAsso.
Version: 1.1.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: allobroges-goshindo
*/


  @font-face{font-family:'Hoshiko';src:url('assets/fonts/Hoshiko.ttf') format('truetype');font-display:swap}
  @font-face{font-family:'ImpactLogo';src:url('assets/fonts/ImpactLogo.ttf') format('truetype');font-display:swap}
  :root{
    --noir:#0a0a0b;--noir-2:#101013;--noir-3:#16161a;
    --rouge:#e2231a;--rouge-d:#b3160f;--rouge-clair:#ff463b;
    --blanc:#f4f4f5;--gris:#a9a9af;--gris-f:#74747a;
    --ligne:rgba(255,255,255,.09);
    --display:'ImpactLogo','Anton',sans-serif;--sans:"Barlow",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth;scroll-padding-top:78px}
  body{background:var(--noir);color:var(--blanc);font-family:var(--sans);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
  ::selection{background:var(--rouge);color:#fff}
  a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
  .wrap{max-width:1280px;margin:0 auto;padding:0 5vw}

  /* accents graphiques */
  .claw{width:54px;height:42px;flex-shrink:0}
  .claw path{fill:var(--rouge)}
  .brush{display:block;height:15px;width:min(260px,62%)}
  .brush path{fill:var(--rouge)}

  /* boutons */
  .btn{font-family:var(--sans);font-weight:800;font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;padding:13px 24px;border-radius:40px;transition:.25s;cursor:pointer;border:1.5px solid transparent;display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
  .btn.red{background:var(--rouge);color:#fff}
  .btn.red:hover{background:var(--rouge-clair);transform:translateY(-2px);box-shadow:0 14px 30px rgba(226,35,26,.45)}
  .btn.ghost{background:transparent;color:var(--blanc);border-color:rgba(255,255,255,.34)}
  .btn.ghost:hover{border-color:var(--rouge);color:var(--rouge-clair)}
  .btn.big{font-size:14.5px;padding:16px 30px}
  .btn svg{width:17px;height:17px}

  /* HEADER */
  header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.35s}
  .hbar{display:flex;align-items:center;justify-content:space-between;padding:13px 5vw;transition:.35s}
  header.scrolled .hbar{padding:8px 5vw;background:rgba(10,10,11,.93);backdrop-filter:blur(14px);border-bottom:1px solid var(--ligne)}
  .brand{display:flex;align-items:center;gap:11px}
  .brand img{height:46px;transition:.35s}
  header.scrolled .brand img{height:40px}
  .brand .bt{display:flex;flex-direction:column;line-height:.92}
  .brand .bt b{font-family:'Hoshiko',var(--sans);font-size:24px;font-weight:400;color:var(--blanc);letter-spacing:.005em}
  .brand .bt i{font-family:'ImpactLogo','Anton',var(--sans);font-size:13.5px;font-style:normal;color:var(--rouge);letter-spacing:.16em;text-transform:uppercase;margin-top:1px}
  nav.main{display:flex;align-items:center;gap:30px}
  nav.main .nl{font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;position:relative;padding:5px 0}
  nav.main .nl::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--rouge);transition:width .28s}
  nav.main .nl:hover::after{width:100%}
  .actions{display:flex;align-items:center;gap:11px}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{width:27px;height:2.5px;background:var(--blanc);border-radius:2px;transition:.3s}
  .burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .mobile{position:fixed;inset:0;z-index:95;background:rgba(8,8,9,.98);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;opacity:0;pointer-events:none;transition:.35s}
  .mobile.show{opacity:1;pointer-events:auto}
  .mobile .nl{font-family:var(--display);font-size:30px;text-transform:uppercase}
  .mobile .actions{flex-direction:column;width:74%;margin-top:12px}
  .mobile .btn{width:100%;justify-content:center}

  /* HERO */
  .hero{position:relative;min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;align-items:center;overflow:hidden;background:var(--noir)}
  .hero-emblem{position:absolute;inset:0 1% 0 43%;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none;overflow:hidden}
  .hero-anim{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}
  .hero-anim .flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:20}
  .hero-anim .anim-svg{position:absolute;height:min(165vh,1700px);width:auto;opacity:1;filter:drop-shadow(0 18px 46px rgba(0,0,0,.45))}
  .hero-anim .logo-final{position:absolute;height:min(165vh,1700px);width:auto;opacity:0;transform:scale(.95);transition:opacity .6s ease,transform .6s ease;z-index:5;filter:drop-shadow(0 18px 46px rgba(0,0,0,.45))}
  .hero-anim .logo-final.visible{opacity:1!important;transform:scale(1);z-index:10}
  .hero-anim .particle{position:absolute;border-radius:50%;pointer-events:none;opacity:0}
  .hero-glow{position:absolute;z-index:0;left:46%;top:50%;width:50vw;height:50vw;transform:translateY(-50%);background:radial-gradient(circle,rgba(226,35,26,.34),transparent 62%);filter:blur(16px);pointer-events:none}
  .hero-kanji{position:absolute;right:3%;top:50%;transform:translateY(-50%);z-index:1;writing-mode:vertical-rl;font-size:clamp(7rem,27vh,23rem);font-weight:900;color:rgba(226,35,26,.13);letter-spacing:-.08em;pointer-events:none;user-select:none;line-height:.9}
  .hero-inner{position:relative;z-index:2;padding:118px 0 132px;grid-column:1}
  .eyebrow{display:inline-flex;align-items:center;gap:13px;font-size:12.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;margin-bottom:22px}
  .eyebrow .dot{background:var(--rouge);color:#fff;padding:5px 12px;border-radius:4px;letter-spacing:.13em}
  .hero h1{font-family:var(--display);font-size:clamp(3.3rem,8.5vw,7.4rem);line-height:.84;text-transform:uppercase;margin-bottom:4px}
  .hero h1 .red{color:var(--rouge)}
  .hero .subs{font-family:var(--display);font-size:clamp(1.1rem,2.5vw,1.8rem);text-transform:uppercase;letter-spacing:.03em;margin:20px 0 18px}
  .hero .subs .red{color:var(--rouge)}
  .hero p.lead{font-size:1.12rem;color:var(--gris);max-width:430px;margin-bottom:34px}
  .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
  .statbar{position:absolute;bottom:0;left:0;right:0;z-index:3;border-top:1px solid var(--ligne);background:rgba(8,8,9,.84);backdrop-filter:blur(10px)}
  .statbar .wrap{display:flex;align-items:stretch}
  .statbar .it{flex:1;padding:18px 12px;display:flex;align-items:center;justify-content:center;gap:15px;position:relative}
  .statbar .it+.it::before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--ligne)}
  .statbar .fig{display:flex;align-items:baseline;gap:8px;font-family:var(--display);line-height:.85;white-space:nowrap}
  .statbar .fig .n{font-size:clamp(2.1rem,4.3vw,3.4rem);color:var(--rouge)}
  .statbar .fig .u{font-size:clamp(.95rem,1.9vw,1.4rem);text-transform:uppercase}
  .statbar .cap{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gris);font-weight:600;line-height:1.35}

  /* MARQUEE */
  .marquee{background:var(--rouge);overflow:hidden}
  .marquee .track{display:flex;gap:40px;white-space:nowrap;padding:14px 0;width:max-content;animation:scroll 28s linear infinite}
  .marquee span{font-family:var(--display);font-size:1.3rem;text-transform:uppercase;letter-spacing:.05em;color:#fff;display:inline-flex;align-items:center;gap:40px}
  .marquee span::after{content:"✕";color:rgba(255,255,255,.5);font-size:.7rem}
  @keyframes scroll{to{transform:translateX(-50%)}}

  /* DISCIPLINE BANNERS */
  .disc-banner{position:relative;overflow:hidden;border-top:1px solid var(--ligne);background:var(--noir)}
  .disc-banner .grid{display:grid;grid-template-columns:1fr 1fr;min-height:90vh}
  .disc-banner .media{position:relative;min-height:560px;background:#000}
  .disc-banner .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  .disc-banner .media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--noir),rgba(10,10,11,.15) 38%,transparent 72%)}
  .disc-banner.rev .media{order:-1}
  .disc-banner.rev .media::after{background:linear-gradient(270deg,var(--noir),rgba(10,10,11,.15) 38%,transparent 72%)}
  .disc-banner .content{position:relative;z-index:3;padding:clamp(54px,7vw,110px) 6vw;display:flex;flex-direction:column;justify-content:center;background:var(--noir)}
  .disc-banner .kanjibg{position:absolute;z-index:0;font-weight:900;font-size:min(46vh,42vw);color:rgba(255,255,255,.028);writing-mode:vertical-rl;top:50%;right:4%;transform:translateY(-50%);pointer-events:none;user-select:none;line-height:.9}
  .disc-banner.rev .kanjibg{right:auto;left:4%}
  .d-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:14px}
  .d-eyebrow .num{font-family:var(--display);font-size:1.1rem;color:#fff;background:var(--rouge);min-width:42px;height:42px;padding:0 6px;border-radius:50px;display:flex;align-items:center;justify-content:center}
  .d-eyebrow .kj{font-size:1.5rem;color:rgba(255,255,255,.55);font-weight:700;letter-spacing:.1em}
  .bigtitle{font-family:var(--display);font-size:clamp(3.4rem,8.5vw,7.2rem);line-height:.82;text-transform:uppercase;color:var(--rouge)}
  .tagline{font-family:var(--display);font-size:clamp(1.1rem,2.4vw,1.7rem);text-transform:uppercase;color:var(--blanc);letter-spacing:.02em;margin:16px 0 16px}
  .desc{color:#dfdfe3;max-width:480px;margin-bottom:20px;font-size:1.09rem;line-height:1.68;font-weight:400}
  .chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;max-width:520px}
  .chips .c{font-size:12.5px;font-weight:600;color:var(--blanc);background:rgba(255,255,255,.06);border:1px solid var(--ligne);padding:7px 14px;border-radius:40px}
  .ency{font-size:.9rem;color:#b8b8be;margin-bottom:26px;border-left:3px solid var(--rouge);padding-left:13px;line-height:1.45}
  .ency b{color:var(--blanc);font-weight:700;margin-right:6px}
  .d-subhead{font-family:var(--display);font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;color:var(--rouge-clair);margin:2px 0 9px}
  .d-sched{max-width:480px;margin-bottom:16px}
  .ds-row{display:flex;justify-content:space-between;gap:16px;padding:8px 0;border-bottom:1px solid var(--ligne);font-size:.93rem}
  .ds-row .ds-d{color:var(--gris)}
  .ds-row .ds-t{color:var(--blanc);font-weight:700;white-space:nowrap}
  .ds-loc{display:flex;gap:8px;align-items:flex-start;margin-top:11px;font-size:.85rem;color:var(--gris)}
  .ds-loc svg{color:var(--rouge);flex-shrink:0;margin-top:2px}

  /* SECTION générique */
  section.s{padding:clamp(70px,10vw,128px) 0;position:relative}
  .lbl{display:inline-flex;align-items:center;gap:10px;background:var(--rouge);color:#fff;font-weight:800;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;padding:8px 16px;border-radius:5px;margin-bottom:20px}
  .h2{font-family:var(--display);font-size:clamp(2.4rem,6vw,4.6rem);text-transform:uppercase;line-height:.9;margin-bottom:16px}
  .h2 .red{color:var(--rouge)}
  .sec-intro{max-width:680px;color:var(--gris);font-size:1.1rem;margin-bottom:52px}

  /* CLUB */
  .about{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
  .about-media{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--ligne)}
  .about-media img{width:100%;height:100%;object-fit:cover}
  .about-media .badge{position:absolute;left:16px;bottom:16px;background:var(--rouge);color:#fff;font-family:var(--display);font-size:1rem;text-transform:uppercase;padding:9px 15px;border-radius:8px;letter-spacing:.04em}
  .about p{color:var(--gris);margin-bottom:15px}.about p strong{color:var(--blanc)}
  .vals{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:28px}
  .val{border-left:3px solid var(--rouge);padding-left:14px}
  .val b{font-family:var(--display);font-size:2rem;display:block;line-height:1}
  .val span{font-size:12.5px;color:var(--gris);text-transform:uppercase;letter-spacing:.07em;font-weight:600}

  /* HORAIRES */
  .horaires{background:var(--noir-2);border-top:1px solid var(--ligne);border-bottom:1px solid var(--ligne)}
  .h-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .h-card{background:var(--noir);border:1px solid var(--ligne);border-radius:14px;padding:28px 26px;transition:.35s}
  .h-card:hover{border-color:rgba(226,35,26,.45);transform:translateY(-5px)}
  .hc-top{display:flex;align-items:center;gap:12px;margin-bottom:18px}
  .hc-top .k{font-family:var(--display);font-size:1.5rem;color:var(--rouge)}
  .hc-top h4{font-family:var(--display);font-size:1.45rem;text-transform:uppercase}
  .h-line{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--ligne);font-size:.95rem}
  .h-line:last-of-type{border-bottom:0}
  .h-line .d{color:var(--gris)}.h-line .t{color:var(--blanc);font-weight:700;white-space:nowrap}
  .h-loc{margin-top:15px;font-size:.84rem;color:var(--gris-f);display:flex;gap:8px;align-items:flex-start}
  .h-loc svg{flex-shrink:0;color:var(--rouge);margin-top:2px}

  /* ESSAI */
  .essai{position:relative;text-align:center;overflow:hidden}
  .essai .glow{position:absolute;left:50%;top:0;width:60vw;height:60vw;transform:translateX(-50%);background:radial-gradient(circle,rgba(226,35,26,.2),transparent 62%);pointer-events:none}
  .essai .lbl{background:#fff;color:var(--rouge)}
  .essai h2{font-family:var(--display);font-size:clamp(2.6rem,7vw,5.4rem);text-transform:uppercase;line-height:.9;margin:0 auto 16px;max-width:16ch}
  .essai h2 .red{color:var(--rouge)}
  .essai p{color:var(--gris);max-width:520px;margin:0 auto 32px;font-size:1.12rem}
  .essai .hero-actions{justify-content:center}

  /* CONTACT */
  .contact{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
  .info-block .it{display:flex;gap:16px;margin-bottom:22px}
  .info-block .ic{flex-shrink:0;width:46px;height:46px;border-radius:11px;background:rgba(226,35,26,.13);display:flex;align-items:center;justify-content:center;color:var(--rouge-clair)}
  .info-block h5{font-family:var(--display);font-size:1.12rem;text-transform:uppercase;margin-bottom:4px}
  .info-block p,.info-block a{color:var(--gris);font-size:.96rem;line-height:1.5}
  .info-block a:hover{color:var(--rouge-clair)}
  .socials{display:flex;gap:12px;margin-top:6px}
  .socials a{width:44px;height:44px;border-radius:11px;border:1px solid var(--ligne);display:flex;align-items:center;justify-content:center;transition:.25s}
  .socials a:hover{background:var(--rouge);border-color:var(--rouge);transform:translateY(-3px)}
  .map{border-radius:16px;overflow:hidden;border:1px solid var(--ligne);min-height:430px}
  .map iframe{width:100%;height:100%;min-height:430px;border:0;filter:grayscale(.3) contrast(1.05)}
  .map-consent{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;min-height:430px;padding:28px;background:var(--noir-2)}
  .map-consent p{color:var(--gris);max-width:42ch;font-size:.95rem;line-height:1.5}

  /* FOOTER */
  .partenaires{background:var(--noir-2);border-top:1px solid var(--ligne);border-bottom:1px solid var(--ligne)}
  .part-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
  .part{background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;padding:22px;aspect-ratio:3/2;transition:transform .3s,box-shadow .3s}
  .part:hover{transform:translateY(-5px);box-shadow:0 16px 34px rgba(0,0,0,.45)}
  .part img{max-width:100%;max-height:80px;width:auto;height:auto;object-fit:contain}
  .part .pname{font-family:var(--sans);font-weight:700;color:#1a1a1a;text-align:center;font-size:1rem;letter-spacing:.01em}
  @media(max-width:980px){.part-grid{grid-template-columns:repeat(2,1fr)}}
  footer{background:var(--noir-2);border-top:1px solid var(--ligne);padding:58px 0 28px}
  .f-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;margin-bottom:44px}
  .f-brand img{height:96px;margin-bottom:16px}
  .f-brand p{color:var(--gris);font-size:.92rem;max-width:320px}
  .f-col h6{font-family:var(--display);font-size:1.05rem;text-transform:uppercase;color:var(--blanc);margin-bottom:16px}
  .f-col a{display:block;color:var(--gris);font-size:.95rem;margin-bottom:11px;transition:.2s}
  .f-col a:hover{color:var(--rouge-clair);padding-left:4px}
  .f-bottom{border-top:1px solid var(--ligne);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px 22px;font-size:.84rem;color:var(--gris-f)}
  .f-legal{display:flex;flex-wrap:wrap;gap:18px}
  .f-bottom a{color:var(--gris-f);transition:.2s}
  .f-bottom a:hover{color:var(--rouge-clair)}

  .reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  @media(max-width:980px){
    nav.main .nl,.actions .btn{display:none}
    .burger{display:flex}
    .hero{grid-template-columns:1fr;min-height:auto;background:var(--noir)}
    .hero-emblem{position:relative;inset:auto;order:-1;padding:22px 0 2px;height:min(48vh,380px)}
    .hero-anim .anim-svg,.hero-anim .logo-final{height:min(108vh,1000px)}
    header.at-hero .brand{opacity:0;visibility:hidden;pointer-events:none}
    .hero-glow{display:none}
    .hero-inner{padding:18px 0 30px}
    .hero p.lead{max-width:none}
    .statbar{position:static;background:var(--noir-2)}
    .disc-banner .grid{grid-template-columns:1fr;min-height:auto}
    .disc-banner .media{min-height:auto;height:44vh;order:-1!important}
    .disc-banner .content{padding-top:32px;padding-bottom:46px}
    .disc-banner .media::after,.disc-banner.rev .media::after{background:linear-gradient(180deg,transparent 38%,var(--noir))}
    .disc-banner .kanjibg{display:none}
    .about{grid-template-columns:1fr;gap:32px}.about-media{order:-1;aspect-ratio:16/10}
    .contact{grid-template-columns:1fr;gap:32px}
    .f-top{grid-template-columns:1fr;gap:30px}
  }
  @media(max-width:560px){
    .hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}
    .statbar .wrap{flex-direction:column}
    .statbar .it{flex-direction:row;justify-content:flex-start;gap:14px;padding:13px 2px}
    .statbar .it+.it::before{top:0;left:0;width:100%;height:1px}
    .vals{grid-template-columns:1fr}.f-bottom{flex-direction:column}
    .brush{width:70%}
  }


  .actus .head{text-align:center;max-width:700px;margin:0 auto 44px}
  .actus .head .desc{margin:0 auto;color:#dfdfe3;max-width:640px}
  .so-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .so-card{position:relative;display:flex;flex-direction:column;background:var(--noir-2);border:1px solid var(--ligne);border-radius:20px;padding:30px 28px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .3s,border-color .3s}
  .so-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.2)}
  .so-card .bar{position:absolute;top:0;left:0;right:0;height:4px}
  .so-card .so-glow{position:absolute;inset:0;opacity:.12;pointer-events:none}
  .so-card.ig .bar,.so-card.ig .so-ico{background:linear-gradient(45deg,#f09433,#e6683c 25%,#dc2743 55%,#cc2366 75%,#bc1888)}
  .so-card.ig .so-glow{background:radial-gradient(75% 80% at 82% 0%,#dc2743,transparent 60%)}
  .so-card.fb .bar,.so-card.fb .so-ico{background:#1877f2}
  .so-card.fb .so-glow{background:radial-gradient(75% 80% at 82% 0%,#1877f2,transparent 60%)}
  .so-top{display:flex;align-items:center;gap:15px;margin-bottom:18px;position:relative;z-index:1}
  .so-ico{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;color:#fff;flex:none}
  .so-ico svg{width:28px;height:28px}
  .so-name{font-family:var(--display);font-size:1.55rem;line-height:1;text-transform:uppercase;letter-spacing:.02em}
  .so-handle{color:var(--gris);font-size:.9rem;margin-top:3px}
  .so-card p.t{position:relative;z-index:1;color:#dfdfe3;margin:0 0 18px;font-size:1.02rem}
  .so-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px;position:relative;z-index:1}
  .so-tags span{font-size:12px;font-weight:600;color:var(--blanc);background:rgba(255,255,255,.06);border:1px solid var(--ligne);padding:6px 12px;border-radius:30px}
  .so-card .go{margin-top:auto;position:relative;z-index:1;border:none;color:#fff;justify-content:center}
  .so-card.ig .go{background:linear-gradient(45deg,#f09433,#dc2743 55%,#bc1888)}
  .so-card.fb .go{background:#1877f2}
  .so-card:hover .go{filter:brightness(1.08)}
  .yt-bar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:22px;background:var(--noir-2);border:1px solid var(--ligne);border-radius:16px;padding:16px 24px;text-decoration:none;color:inherit;transition:border-color .3s}
  .yt-bar:hover{border-color:rgba(255,255,255,.2)}
  .yt-bar .so-ico{width:46px;height:46px;border-radius:12px;background:#ff0000}
  .yt-bar .yt-tx{flex:1;min-width:200px}
  .yt-bar .yt-tx b{display:block;font-weight:700}
  .yt-bar .yt-tx span{color:var(--gris);font-size:.9rem}
  .actus .foot-note{text-align:center;color:var(--gris-f);font-size:.92rem;margin:30px auto 0;max-width:640px;border-left:none;padding:0}
  @media(max-width:760px){.so-grid{grid-template-columns:1fr}}


  .feed{margin-top:28px;background:var(--noir-2);border:1px solid var(--ligne);border-radius:20px;padding:24px;max-width:600px;margin:28px auto 0}
  .feed-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
  .feed-head .so-ico{background:#1877f2}
  .feed-inner{background:#fff;border-radius:12px;overflow:hidden;min-height:380px}
  .feed-inner iframe{display:block;width:100%;border:none}
  .feed-fallback{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;margin-top:16px;color:var(--gris);font-size:.92rem}
  .feed-fallback .btn.fbbtn{background:#1877f2;color:#fff;border:none}


/* ===== Pages Inscription & Boutique ===== */

  .ins-hero{padding-top:clamp(120px,16vh,180px)}
  .ins-hero .lead{max-width:620px}
  .ha-card{margin-top:38px;background:var(--noir-2);border:1px solid var(--ligne);border-radius:18px;padding:14px;box-shadow:0 30px 80px rgba(0,0,0,.45);position:relative;overflow:hidden}
  .ha-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 60% at 50% -10%,rgba(226,35,26,.10),transparent 60%);pointer-events:none}
  .ha-card .inner{background:#fff;border-radius:12px;overflow:hidden;position:relative;z-index:1}
  .ha-card iframe{display:block;border-radius:12px}
  .ha-fallback{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:22px;color:var(--gris)}
  .ha-note{font-size:.9rem;color:var(--gris-f);margin-top:26px;border-left:3px solid var(--rouge);padding-left:13px;line-height:1.5;max-width:620px}
  /* Boutique : emplacement en attente de l'iframe HelloAsso */
  .shop-soon{margin-top:38px;background:var(--noir-2);border:1px solid var(--ligne);border-radius:18px;padding:clamp(40px,7vw,72px) clamp(24px,5vw,56px);box-shadow:0 30px 80px rgba(0,0,0,.45);position:relative;overflow:hidden;text-align:center}
  .shop-soon::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 60% at 50% -10%,rgba(226,35,26,.12),transparent 60%);pointer-events:none}
  .shop-soon .ico{position:relative;z-index:1;width:72px;height:72px;border-radius:18px;background:rgba(226,35,26,.13);display:flex;align-items:center;justify-content:center;color:var(--rouge-clair);margin:0 auto 22px}
  .shop-soon .ico svg{width:36px;height:36px}
  .shop-soon h3{position:relative;z-index:1;font-family:var(--display);font-size:clamp(1.8rem,4.5vw,2.8rem);text-transform:uppercase;line-height:.95;margin-bottom:14px}
  .shop-soon h3 .red{color:var(--rouge)}
  .shop-soon p{position:relative;z-index:1;color:var(--gris);max-width:520px;margin:0 auto 28px;font-size:1.06rem}
  .shop-soon .hero-actions{position:relative;z-index:1;justify-content:center}
  /* Quand l'iframe HelloAsso sera ajoutée, réutilise .ha-card / .ha-fallback comme sur la page Inscription */
  .ha-card{margin-top:38px;background:var(--noir-2);border:1px solid var(--ligne);border-radius:18px;padding:14px;box-shadow:0 30px 80px rgba(0,0,0,.45);position:relative;overflow:hidden}
  .ha-card .inner{background:#fff;border-radius:12px;overflow:hidden;position:relative;z-index:1}
  .ha-card iframe{display:block;border-radius:12px}
  @media(max-width:760px){.ins-hero{padding-top:clamp(100px,14vh,140px)}.ha-card{padding:8px}}

.page-content{color:var(--gris);max-width:760px}
.page-content h2,.page-content h3{font-family:var(--display);text-transform:uppercase;margin:22px 0 12px;color:var(--blanc)}
.page-content a{color:var(--rouge-clair)}
.page-content p{margin-bottom:14px}
