
:root{--or:#F4803A;--tl:#3ABFB8;--yw:#F9C846;--co:#F26A50;--dk:#0f1221;--dk2:#161c36;--bg:#F2EDE8;--wh:#fff;--tx:#1a1f3a;--bd:#e8e2da;--mu:#7a7f9a;--sw:260px;--rd:14px;--rd2:22px;--sh:0 2px 16px rgba(0,0,0,.07);--sh2:0 8px 40px rgba(0,0,0,.13);--tr:.2s cubic-bezier(.4,0,.2,1);}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-overflow-scrolling:touch;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--tx);display:flex;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
button,input,select,textarea{font-family:'Plus Jakarta Sans',sans-serif;}

/* SIDEBAR */
#sidebar{width:var(--sw);min-height:100vh;background:linear-gradient(180deg,var(--dk),var(--dk2));position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:60;transition:transform .3s cubic-bezier(.4,0,.2,1);border-right:1px solid rgba(255,255,255,.04);overflow:hidden;will-change:transform;}
.sb-head{padding:1.4rem 1.1rem 1rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.05);}
.sb-logo{width:84px;height:84px;border-radius:50%;background:rgba(255,255,255,.96);padding:5px;margin:0 auto .55rem;box-shadow:0 0 0 3px rgba(244,128,58,.25),0 6px 24px rgba(244,128,58,.3);overflow:hidden;transition:var(--tr);cursor:pointer;}
.sb-logo:hover{transform:scale(1.06);}
.sb-nav a{min-height:44px;}
.sb-logo img{width:100%;height:100%;object-fit:contain;border-radius:50%;}
.sb-brand{font-family:'Pacifico',cursive;font-size:.95rem;color:var(--yw);margin-bottom:.1rem;}
.sb-since{font-size:.58rem;color:rgba(255,255,255,.25);font-weight:600;letter-spacing:1.8px;text-transform:uppercase;}
.sb-counters{display:flex;gap:.35rem;margin-top:.65rem;justify-content:center;}
.sb-ctr{flex:1;background:rgba(255,255,255,.05);border-radius:10px;padding:.32rem .3rem;text-align:center;border:1px solid rgba(255,255,255,.06);}
.sb-ctr strong{display:block;font-size:.78rem;font-weight:800;color:var(--yw);}
.sb-ctr span{font-size:.52rem;color:rgba(255,255,255,.3);font-weight:600;letter-spacing:.6px;text-transform:uppercase;}
.sb-nav{flex:1;padding:.7rem .65rem;list-style:none;display:flex;flex-direction:column;gap:.15rem;overflow-y:auto;}
.sb-nav a{display:flex;align-items:center;gap:.65rem;padding:.62rem .85rem;border-radius:12px;color:rgba(255,255,255,.45);font-weight:600;font-size:.84rem;cursor:pointer;transition:var(--tr);position:relative;border:1px solid transparent;}
.sb-nav a:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.06);}
.sb-nav a.active{color:#fff;background:linear-gradient(90deg,rgba(244,128,58,.25),rgba(244,128,58,.08));border-color:rgba(244,128,58,.3);}
.sb-nav a.active::before{content:'';position:absolute;left:0;top:25%;bottom:25%;width:3px;border-radius:0 3px 3px 0;background:var(--or);}
.sb-nav .ni{font-size:.9rem;width:1.15rem;text-align:center;flex-shrink:0;}
.sb-sep{height:1px;background:rgba(255,255,255,.05);margin:.4rem .85rem;}
.sb-sec-lbl{font-size:.57rem;color:rgba(255,255,255,.2);font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:.15rem .85rem .3rem;}
.sb-foot{padding:.8rem .95rem;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:.58rem;}
.sb-av{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--or),var(--yw));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;color:var(--dk);overflow:hidden;border:2px solid rgba(255,255,255,.12);}
.sb-av img{width:100%;height:100%;object-fit:cover;}
.sb-ui{flex:1;min-width:0;}
.sb-nm{font-weight:700;font-size:.79rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-rl{font-size:.62rem;color:rgba(255,255,255,.3);font-weight:500;}
.sb-out{background:none;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);cursor:pointer;font-size:1.1rem;padding:.45rem .7rem;border-radius:8px;transition:var(--tr);}
.sb-out:hover{color:#e74c3c;background:rgba(231,76,60,.12);border-color:rgba(231,76,60,.3);}
#btn-notifs:hover{background:rgba(255,255,255,.08)!important;}

/* MAIN */
#main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-height:100vh;}
#main.locked{filter:blur(8px);pointer-events:none;user-select:none;}
#topbar{display:none;}
#burger{display:none;}

/* BOTTOM NAV — mobile only */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--dk);border-top:1px solid rgba(255,255,255,.08);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 24px rgba(0,0,0,.25);backdrop-filter:blur(20px);}
#bottom-nav ul{display:flex;list-style:none;margin:0;padding:0;}
#bottom-nav ul li{flex:1;}
#bottom-nav ul li a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:.6rem .3rem .5rem;color:rgba(255,255,255,.38);font-size:.56rem;font-weight:700;letter-spacing:.6px;text-transform:uppercase;cursor:pointer;transition:var(--tr);position:relative;border-top:2px solid transparent;}
#bottom-nav ul li a .bn-ic{font-size:1.3rem;line-height:1;transition:transform .2s;}
#bottom-nav ul li a.active{color:var(--or);border-top-color:var(--or);}
#bottom-nav ul li a.active .bn-ic{transform:scale(1.18);}
#bottom-nav ul li a:not(.active):hover{color:rgba(255,255,255,.65);}
.bn-badge{position:absolute;top:6px;right:50%;transform:translateX(14px);background:#e74c3c;color:#fff;border-radius:50%;width:17px;height:17px;font-size:.52rem;font-weight:800;display:none;align-items:center;justify-content:center;border:2px solid var(--dk);}

/* MORE MENU */
.more-item{display:flex;align-items:center;gap:.85rem;padding:.82rem .6rem;border-radius:var(--rd);cursor:pointer;transition:var(--tr);text-decoration:none;color:var(--tx);border:1.5px solid transparent;}
.more-item:hover,.more-item:active{background:var(--bg);border-color:var(--bd);}
.more-ic{font-size:1.3rem;width:2.1rem;height:2.1rem;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:10px;flex-shrink:0;}
.more-lbl{font-weight:700;font-size:.9rem;color:var(--tx);}
#more-menu-ov{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .25s ease;}
#more-menu-ov.open{opacity:1;pointer-events:all;}
#more-menu{position:fixed;bottom:0;left:0;right:0;z-index:501;background:var(--wh);border-radius:22px 22px 0 0;padding:0 0 calc(env(safe-area-inset-bottom) + .8rem);box-shadow:0 -8px 40px rgba(0,0,0,.22);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);pointer-events:none;}
#more-menu.open{transform:translateY(0);pointer-events:all;}
#btn-more-nav.menu-open{color:var(--or);}
#btn-more-nav.menu-open .bn-ic{transform:scale(1.18);}
.more-item-admin{background:linear-gradient(135deg,rgba(124,58,237,.05),rgba(124,58,237,.02));border-color:rgba(124,58,237,.18)!important;}
.more-item-admin:hover{background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(124,58,237,.06))!important;border-color:rgba(124,58,237,.35)!important;}
.more-ic-admin{background:linear-gradient(135deg,#4c1d95,#7c3aed)!important;color:#fff!important;}
.more-admin-badge{margin-left:auto;background:linear-gradient(135deg,#4c1d95,#7c3aed);color:#fff;font-size:.58rem;font-weight:800;padding:.18rem .55rem;border-radius:50px;letter-spacing:.5px;}

/* PAGES */
.page{display:none;}
.page.active{display:block;animation:pgIn .28s ease;}
@keyframes pgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{position:relative;overflow:hidden;text-align:center;padding:3.5rem 2rem 3rem;background:linear-gradient(150deg,#0f1221 0%,#1e1248 40%,#3a1a0a 80%,#F4803A 100%);}
.hero-bg{position:absolute;inset:0;pointer-events:none;}
.hero-bg::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(244,128,58,.18) 0%,transparent 60%);top:-200px;right:-150px;animation:pulse-orb 6s ease-in-out infinite;}
.hero-bg::after{content:'';position:absolute;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(58,191,184,.15) 0%,transparent 60%);bottom:-120px;left:-80px;animation:pulse-orb 8s ease-in-out infinite reverse;}
.hero-particle{position:absolute;border-radius:50%;pointer-events:none;animation:drift linear infinite;}
@keyframes drift{0%{opacity:0;transform:translateY(0) scale(0);}10%{opacity:.7;}90%{opacity:.3;}100%{opacity:0;transform:translateY(-80px) scale(1);}}
@keyframes pulse-orb{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.15);opacity:.7;}}
.hero-logo{width:108px;height:108px;border-radius:50%;object-fit:contain;background:rgba(255,255,255,.96);padding:6px;display:block;margin:0 auto 1.1rem;box-shadow:0 0 0 4px rgba(244,128,58,.2),0 12px 40px rgba(244,128,58,.4);animation:float 3.5s ease-in-out infinite;position:relative;z-index:1;}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-badge{display:inline-flex;align-items:center;gap:.45rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.75);font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:.28rem .9rem;border-radius:50px;margin-bottom:.8rem;position:relative;z-index:1;backdrop-filter:blur(12px);}
.hero h1{font-family:'Pacifico',cursive;color:#fff;font-size:clamp(2rem,5vw,3.2rem);line-height:1.08;margin-bottom:.85rem;position:relative;z-index:1;text-shadow:0 2px 20px rgba(0,0,0,.3);}
.hero p{color:rgba(255,255,255,.72);font-size:.95rem;font-weight:500;max-width:460px;margin:0 auto 1.6rem;line-height:1.75;position:relative;z-index:1;}
.hero-stats{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.8rem;position:relative;z-index:1;}
.hero-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(12px);border-radius:var(--rd);padding:.65rem 1rem;text-align:center;}
.hero-stat strong{display:block;font-family:'Pacifico',cursive;font-size:1.3rem;color:var(--yw);}
.hero-stat span{font-size:.62rem;color:rgba(255,255,255,.45);font-weight:600;letter-spacing:.8px;text-transform:uppercase;}
.hero-actions{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.4rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.87rem;padding:.65rem 1.5rem;border-radius:50px;border:none;cursor:pointer;text-decoration:none;transition:var(--tr);white-space:nowrap;line-height:1;min-height:44px;-webkit-tap-highlight-color:transparent;}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;}
.btn:focus-visible{outline:3px solid var(--or);outline-offset:2px;}
.btn-yw{background:var(--yw);color:var(--dk);box-shadow:0 4px 16px rgba(249,200,70,.3);}
.btn-yw:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 22px rgba(249,200,70,.4);}
.btn-gh{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45);}
.btn-gh:hover:not(:disabled){background:rgba(255,255,255,.1);}
.btn-or{background:linear-gradient(135deg,var(--or),var(--co));color:#fff;box-shadow:0 4px 16px rgba(244,128,58,.3);}
.btn-or:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px 22px rgba(244,128,58,.4);}
.btn-tl{background:linear-gradient(135deg,var(--tl),#22a89e);color:#fff;}
.btn-tl:hover:not(:disabled){transform:translateY(-2px);}
.btn-rd{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;}
.btn-ol{background:transparent;color:var(--or);border:2px solid var(--or);}
.btn-ol:hover:not(:disabled){background:rgba(244,128,58,.07);}
.btn-sm{padding:.42rem .95rem;font-size:.76rem;}
.btn-xs{padding:.3rem .7rem;font-size:.7rem;}
.btn-bl{width:100%;justify-content:center;}

/* LAYOUT */
.wrap{padding:2rem 2rem;max-width:940px;}
.wrap-sm{max-width:560px;}
.sec-t{font-family:'Pacifico',cursive;font-size:1.6rem;color:var(--or);margin-bottom:.2rem;}
.sec-s{color:var(--mu);font-weight:500;font-size:.82rem;margin-bottom:1.6rem;}

/* CARDS */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.9rem;}
.feat-card{background:var(--wh);border-radius:var(--rd2);padding:1.4rem 1.2rem;text-align:center;box-shadow:var(--sh);border:1.5px solid var(--bd);transition:var(--tr);}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--sh2);border-color:rgba(244,128,58,.3);}
.feat-ic{font-size:1.9rem;margin-bottom:.65rem;}
.feat-card h3{font-size:.9rem;font-weight:800;color:var(--tx);margin-bottom:.28rem;}
.feat-card p{font-size:.78rem;color:var(--mu);line-height:1.65;}

/* EVENTS PAGE HERO */
.ev-page-hero-content{position:relative;z-index:1;}
.ev-page-hero-emoji{font-size:2.4rem;line-height:1;margin-bottom:.5rem;animation:float 3.5s ease-in-out infinite;}
.ev-page-hero-title{font-family:'Pacifico',cursive;font-size:2rem;color:#fff;margin-bottom:.3rem;text-shadow:0 2px 16px rgba(0,0,0,.3);}
.ev-page-hero-sub{font-size:.8rem;color:rgba(255,255,255,.5);font-weight:600;letter-spacing:.5px;margin-bottom:1rem;}

/* EVENTS — BASE */
.adm-bar{display:none;background:var(--dk);border-radius:var(--rd);padding:.9rem 1.2rem;margin-bottom:1.5rem;align-items:center;gap:.75rem;flex-wrap:wrap;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel{background:#1e2340;border-radius:20px;padding:1.2rem 1.3rem;display:flex;gap:1rem;align-items:flex-start;}
.skel-block{background:linear-gradient(90deg,rgba(255,255,255,.05) 25%,rgba(255,255,255,.09) 50%,rgba(255,255,255,.05) 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:8px;}

/* ── HERO PAGE ÉVÉNEMENTS ─────────────────────────────── */

/* ── CARTE ─────────────────────────────────────────────── */
.ev-card{
  position:relative;overflow:hidden;
  border-radius:22px;
  background:#16192e;
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 2px 16px rgba(0,0,0,.35);
  display:flex;flex-direction:column;
  transition:transform .28s cubic-bezier(.34,1.56,.64,1),box-shadow .28s ease,border-color .2s;
  animation:cardIn .38s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
.ev-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 48px rgba(0,0,0,.5);
  border-color:rgba(255,255,255,.13);
}

/* ── HEADER : bande colorée + date + infos côte à côte ── */
.ev-card-header{
  display:flex;align-items:stretch;
  background:linear-gradient(135deg,
    color-mix(in srgb,var(--ev-col,var(--or)) 90%,#000 10%) 0%,
    color-mix(in srgb,var(--ev-col,var(--or)) 60%,#0a0e1a 40%) 100%
  );
  position:relative;overflow:hidden;
  min-height:110px;
}
/* Motif géométrique en fond */
.ev-card-header::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(
    -45deg,rgba(255,255,255,.04) 0px,rgba(255,255,255,.04) 1px,
    transparent 1px,transparent 20px
  );
}
/* Orbe lumineuse */
.ev-card-header::after{
  content:'';position:absolute;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.18) 0%,transparent 60%);
  right:-40px;top:-60px;pointer-events:none;
}

/* Bloc DATE à gauche dans le header */
.ev-card-datebox{
  position:relative;z-index:1;
  flex-shrink:0;width:90px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:1.1rem .5rem;
  border-right:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  backdrop-filter:blur(4px);
  gap:0;
}
.ev-card-datebox .ev-dow{
  font-size:.55rem;font-weight:800;letter-spacing:2.5px;
  text-transform:uppercase;color:rgba(255,255,255,.7);
  margin-bottom:2px;
}
.ev-card-datebox .ev-day{
  font-family:'Pacifico',cursive;font-size:2.8rem;
  line-height:1;color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.3);
}
.ev-card-datebox .ev-mon{
  font-size:.6rem;font-weight:800;letter-spacing:1px;
  text-transform:uppercase;color:rgba(255,255,255,.65);
  margin-top:2px;
}
.ev-card-datebox .ev-yr{
  font-size:.48rem;font-weight:600;color:rgba(255,255,255,.3);
  margin-top:1px;
}

/* Info principale à droite dans le header */
.ev-card-headerinfo{
  position:relative;z-index:1;
  flex:1;min-width:0;
  display:flex;flex-direction:column;justify-content:center;
  padding:1rem 1.1rem;gap:.5rem;
}
.ev-card-title{
  font-size:1.15rem;font-weight:800;color:#fff;line-height:1.25;
  text-shadow:0 1px 8px rgba(0,0,0,.3);
  /* garde la casse originale du nom */
}
.ev-card-infopills{display:flex;flex-wrap:wrap;gap:.38rem;align-items:center;}
.ev-pill{
  display:inline-flex;align-items:center;gap:.28rem;
  font-size:.69rem;font-weight:700;
  padding:.26rem .7rem;border-radius:50px;
  white-space:nowrap;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
}
.ev-pill-loc{
  background:rgba(0,0,0,.3);border-color:rgba(255,255,255,.2);
  color:#fff;text-decoration:none;cursor:pointer;
  transition:background .18s;
}
.ev-pill-loc:hover{background:rgba(0,0,0,.45);}
.ev-pill-time{background:rgba(0,0,0,.4);border-color:rgba(255,255,255,.25);color:#fff;}

/* Badge inscrits en haut à droite du header */
.ev-card-header-badge{
  position:absolute;top:.7rem;right:.8rem;z-index:2;
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.62rem;font-weight:800;
  padding:.28rem .75rem;border-radius:50px;
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  backdrop-filter:blur(12px);
}

/* ── CORPS ──────────────────────────────────────────────── */
.ev-card-body{
  display:flex;flex-direction:column;gap:.75rem;
  padding:1rem 1.15rem 0;
}

/* Badges statut */
.ev-badges-row{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;}
.ev-badge-reg{
  display:inline-flex;align-items:center;gap:.28rem;
  background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);
  color:#4ade80;font-size:.66rem;font-weight:800;
  padding:.26rem .78rem;border-radius:50px;
}
.ev-badge-past{
  display:inline-flex;align-items:center;gap:.28rem;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.35);font-size:.66rem;font-weight:800;
  padding:.26rem .78rem;border-radius:50px;
}
.ev-badge-countdown{
  display:inline-flex;align-items:center;gap:.28rem;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.7);font-size:.66rem;font-weight:800;
  padding:.26rem .78rem;border-radius:50px;
}

/* Description */
.ev-card-desc{
  font-size:.84rem;
  color:rgba(255,255,255,.55);
  line-height:1.75;
}

/* COUNTDOWN */
.ev-countdown{
  display:flex;align-items:center;gap:.5rem;
  padding:.6rem .9rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;
}
.ev-countdown-segments{display:flex;gap:.35rem;align-items:center;}
.ev-cd-seg{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  border-radius:9px;padding:.3rem .55rem;min-width:40px;
}
.ev-cd-num{
  font-family:'Pacifico',cursive;font-size:1.15rem;
  color:#fff;line-height:1;
}
.ev-cd-lbl{font-size:.4rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:2px;}
.ev-cd-dot{font-size:.85rem;color:rgba(255,255,255,.2);font-weight:800;line-height:1.6;}
.ev-countdown-label{font-size:.69rem;font-weight:700;color:rgba(255,255,255,.3);}

/* JAUGE */
.ev-prog-wrap{display:flex;flex-direction:column;gap:.4rem;}
.ev-prog-header{display:flex;justify-content:space-between;align-items:center;}
.ev-prog-label-txt{font-size:.7rem;font-weight:700;color:rgba(255,255,255,.45);}
.ev-prog-count{font-size:.7rem;font-weight:800;color:rgba(255,255,255,.75);}
.prog-bar{height:6px;background:rgba(255,255,255,.06);border-radius:10px;overflow:hidden;}
.prog-fill{
  height:100%;border-radius:10px;
  transition:width 1s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.prog-fill::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  animation:shimmer-glow 2.5s ease-in-out infinite;
}
@keyframes shimmer-glow{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}

/* ── FOOTER ACTIONS ─────────────────────────────────────── */
.ev-card-actions{
  display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;
  padding:.85rem 1.15rem 1rem;
  margin-top:.75rem;
  border-top:1px solid rgba(255,255,255,.06);
}
.pcnt-btn{
  display:inline-flex;align-items:center;gap:.3rem;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  border-radius:50px;padding:.38rem 1rem;
  font-size:.71rem;font-weight:700;
  color:rgba(255,255,255,.45);cursor:pointer;
  transition:all .18s;font-family:inherit;
}
.pcnt-btn:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.2);}
.btn-join-main{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--ev-col,var(--or));
  color:#fff;border:none;border-radius:50px;
  padding:.6rem 1.6rem;font-size:.84rem;font-weight:800;
  cursor:pointer;font-family:inherit;
  box-shadow:0 4px 20px rgba(0,0,0,.35),0 0 0 0 var(--ev-col,var(--or));
  transition:all .22s cubic-bezier(.34,1.56,.64,1);
  letter-spacing:.2px;
  position:relative;overflow:hidden;
}
.btn-join-main::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 60%);
  border-radius:50px;
}
.btn-join-main:hover{
  transform:scale(1.06);
  box-shadow:0 8px 28px rgba(0,0,0,.4),0 0 0 3px color-mix(in srgb,var(--ev-col,var(--or)) 30%,transparent);
}

/* Toggle desc */
.ev-desc-toggle{
  background:none;border:none;color:rgba(255,255,255,.3);
  font-size:.72rem;font-weight:700;cursor:pointer;
  padding:.05rem 0;font-family:inherit;
  transition:color .15s;display:inline-flex;align-items:center;gap:.2rem;
}
.ev-desc-toggle:hover{color:rgba(255,255,255,.6);}

/* CARTE PASSÉE */
.ev-card-past{opacity:.45;filter:grayscale(50%);}
.ev-card-past:hover{opacity:.7;filter:grayscale(20%);}

/* SÉPARATEUR */
.ev-sep-past{display:flex;align-items:center;gap:.7rem;padding:.8rem 0 .2rem;}
.ev-sep-past span{font-size:.63rem;font-weight:800;color:rgba(255,255,255,.2);text-transform:uppercase;letter-spacing:1.5px;white-space:nowrap;}
.ev-sep-past::before,.ev-sep-past::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.06);}

/* ÉTAT VIDE */
.ev-empty-state{text-align:center;padding:3.5rem 1.5rem;background:rgba(255,255,255,.02);border-radius:20px;border:1.5px dashed rgba(255,255,255,.07);}
.ev-empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.35;display:block;}
.ev-empty-state-title{font-weight:800;color:rgba(255,255,255,.4);font-size:.95rem;margin-bottom:.4rem;}
.ev-empty-state-sub{font-size:.79rem;color:rgba(255,255,255,.2);}

/* ── HERO PAGE ÉVÉNEMENTS ─────────────────────────────── */

/* legacy compat */
.ev-dt{border-radius:var(--rd);padding:.55rem .7rem;text-align:center;min-width:50px;background:var(--ev-col,var(--or));color:#fff;flex-shrink:0;}
.ev-dt .d{font-family:'Pacifico',cursive;font-size:1.4rem;line-height:1;}
.ev-dt .m{font-size:.58rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;opacity:.85;}
.ev-body h3{font-size:.95rem;font-weight:800;color:var(--tx);margin-bottom:.28rem;}
.ev-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem;}
.tag{font-size:.67rem;font-weight:700;padding:.15rem .52rem;border-radius:50px;background:rgba(244,128,58,.07);border:1px solid rgba(244,128,58,.18);color:var(--or);}
.tag.tl{background:rgba(58,191,184,.09);border-color:rgba(58,191,184,.25);color:#0a7c78;}
.ev-desc{font-size:.79rem;color:var(--mu);line-height:1.65;margin-bottom:.55rem;}
.ev-prog{margin-bottom:.3rem;max-width:260px;}
.ev-acts{display:flex;flex-direction:column;gap:.3rem;align-items:flex-end;flex-shrink:0;}
.club-ban{background:linear-gradient(140deg,var(--dk),var(--dk2));border-radius:var(--rd2);padding:2rem 1.7rem;text-align:center;margin-bottom:1.7rem;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.05);}
.club-ban::before{content:'';position:absolute;top:-40%;left:-20%;width:140%;height:140%;background:radial-gradient(circle,rgba(244,128,58,.1) 0%,transparent 55%);pointer-events:none;}
.club-ban h2{font-family:'Pacifico',cursive;color:var(--yw);font-size:1.65rem;margin-bottom:.3rem;position:relative;}
.club-ban p{color:rgba(255,255,255,.5);font-size:.86rem;font-weight:500;position:relative;}
.club-bdg{display:inline-block;background:linear-gradient(135deg,var(--or),var(--yw));color:var(--dk);font-weight:800;font-size:.7rem;padding:.25rem .88rem;border-radius:50px;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:1px;position:relative;}
.bens{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(205px,100%),1fr));gap:.8rem;margin-bottom:1.9rem;}
.ben{background:var(--wh);border-radius:var(--rd);padding:1.05rem;box-shadow:var(--sh);display:flex;gap:.72rem;align-items:flex-start;border:1.5px solid var(--bd);transition:var(--tr);}
.ben:hover{border-color:var(--tl);transform:translateY(-2px);}
.ben-ic{width:36px;height:36px;border-radius:9px;flex-shrink:0;background:linear-gradient(135deg,var(--tl),#22a89e);display:flex;align-items:center;justify-content:center;font-size:1rem;}
.ben h4{font-weight:800;color:var(--tx);font-size:.82rem;margin-bottom:.16rem;}
.ben p{font-size:.75rem;color:var(--mu);line-height:1.5;}
.pts{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:.7rem;}
.pt{background:var(--wh);border-radius:var(--rd);padding:1rem .75rem;text-align:center;box-shadow:var(--sh);border:1.5px solid var(--bd);transition:var(--tr);}
.pt:hover{border-color:var(--or);transform:scale(1.04);}
.pt-ic{font-size:1.65rem;margin-bottom:.28rem;}
.pt h5{font-size:.76rem;font-weight:800;color:var(--tx);margin-bottom:.07rem;}
.pt span{font-size:.65rem;color:var(--mu);}
.pt .pt-av{font-size:.63rem;color:var(--tl);font-weight:700;margin-top:.22rem;}

/* FORMS */
.f-g{margin-bottom:.72rem;}
.f-l{font-weight:700;font-size:.77rem;color:var(--tx);display:block;margin-bottom:.26rem;}
.f-i{width:100%;padding:.64rem .9rem;border:2px solid var(--bd);border-radius:var(--rd);font-family:inherit;font-size:1rem;color:var(--tx);background:var(--wh);outline:none;transition:var(--tr);-webkit-appearance:none;touch-action:manipulation;}
.f-i:focus{border-color:var(--or);box-shadow:0 0 0 3px rgba(244,128,58,.12);outline:none;}
.f-i::placeholder{color:#bab6c8;}
select.f-i:invalid,.f-i option[value=""]{color:#bab6c8;}
select.f-i:focus{border-color:var(--or);box-shadow:0 0 0 3px rgba(244,128,58,.12);}
.f-g2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;}
.f-g13{display:grid;grid-template-columns:1fr 2fr;gap:.7rem;}
.dob-row{display:flex;gap:.5rem;}
.dob-sel{flex:1;}
.f-err{display:none;background:#fef2f2;color:#dc2626;border-radius:9px;padding:.55rem .9rem;font-size:.76rem;font-weight:700;margin-top:.6rem;border-left:3px solid #e74c3c;line-height:1.5;}
.f-ok{display:none;background:rgba(34,197,94,.08);color:#16a34a;border-radius:9px;padding:.55rem .9rem;font-size:.76rem;font-weight:700;margin-top:.6rem;border-left:3px solid #22c55e;line-height:1.5;}
.f-note{background:rgba(58,191,184,.06);border:1.5px solid rgba(58,191,184,.2);border-radius:9px;padding:.68rem;font-size:.72rem;color:#555;line-height:1.55;}

/* TOGGLE PASSWORD */
.pw-wrap{position:relative;}
.pw-wrap .f-i{padding-right:2.8rem;}
.pw-eye{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--mu);font-size:1.1rem;padding:.2rem;line-height:1;transition:var(--tr);}
.pw-eye:hover{color:var(--or);}

/* AUTH WALL */
#auth-wall{position:fixed;inset:0;z-index:9999;background:linear-gradient(150deg,var(--dk) 0%,#1e1248 50%,#3a1a0a 85%,var(--or) 100%);display:flex;align-items:flex-start;justify-content:center;padding:env(safe-area-inset-top,1rem) 1rem 2rem;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.aw-box{width:100%;max-width:415px;}
.aw-logo{width:86px;height:86px;border-radius:50%;background:rgba(255,255,255,.92);padding:5px;margin:0 auto .7rem;display:block;box-shadow:0 0 0 3px rgba(244,128,58,.2),0 8px 28px rgba(244,128,58,.35);}
.aw-t{font-family:'Pacifico',cursive;color:var(--yw);font-size:1.6rem;text-align:center;margin-bottom:.18rem;}
.aw-s{color:rgba(255,255,255,.42);font-size:.79rem;font-weight:500;text-align:center;margin-bottom:1.1rem;}
.aw-tabs{display:flex;background:rgba(255,255,255,.08);border-radius:50px;padding:3px;margin-bottom:1rem;}
.aw-tab{flex:1;padding:.46rem;border:none;border-radius:50px;font-family:inherit;font-weight:700;font-size:.81rem;cursor:pointer;transition:var(--tr);}
.aw-tab.on{background:#fff;color:var(--dk);}
.aw-tab.off{background:transparent;color:rgba(255,255,255,.48);}
.aw-card{background:rgba(255,255,255,.97);border-radius:20px;padding:1.45rem 1.45rem 1.2rem;box-shadow:0 24px 60px rgba(0,0,0,.32);width:100%;max-width:420px;}
.aw-card.hidden{display:none;}

/* PROFILE */
/* NEXT EVENT ON HOME */
.next-ev-label{font-size:.62rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--or);margin-bottom:.55rem;display:flex;align-items:center;gap:.4rem;}
.next-ev-card{background:linear-gradient(135deg,var(--dk) 0%,var(--dk2) 100%);border-radius:var(--rd2);padding:1.2rem 1.3rem;color:#fff;position:relative;overflow:hidden;cursor:pointer;transition:var(--tr);border:1px solid rgba(255,255,255,.06);}
.next-ev-card::before{content:'';position:absolute;right:-30px;top:-30px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(244,128,58,.25) 0%,transparent 65%);}
.next-ev-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.2);}
.next-ev-card .nev-top{display:flex;align-items:center;gap:.9rem;margin-bottom:.7rem;}
.next-ev-card .nev-date{background:var(--or);border-radius:var(--rd);padding:.5rem .7rem;text-align:center;min-width:54px;flex-shrink:0;}
.next-ev-card .nev-date .nd{font-family:'Pacifico',cursive;font-size:1.7rem;line-height:1;color:#fff;}
.next-ev-card .nev-date .nm{font-size:.56rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.88);}
.next-ev-card .nev-info{flex:1;}
.next-ev-card .nev-title{font-size:1rem;font-weight:800;color:#fff;margin-bottom:.22rem;line-height:1.3;}
.next-ev-card .nev-meta{display:flex;flex-wrap:wrap;gap:.4rem;}
.next-ev-card .nev-chip{font-size:.66rem;font-weight:700;color:rgba(255,255,255,.6);display:inline-flex;align-items:center;gap:.2rem;}
.next-ev-card .nev-desc{font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.6;margin-bottom:.85rem;}
.next-ev-card .nev-cta{display:inline-flex;align-items:center;gap:.38rem;background:var(--or);color:#fff;font-size:.78rem;font-weight:800;padding:.45rem 1.1rem;border-radius:50px;border:none;cursor:pointer;transition:var(--tr);}
.next-ev-card .nev-cta:hover{background:#e06820;transform:scale(1.04);}
.next-ev-card .nev-registered{display:inline-flex;align-items:center;gap:.38rem;background:rgba(58,191,184,.25);color:#7ffffa;font-size:.76rem;font-weight:700;padding:.4rem 1rem;border-radius:50px;}

/* PROFILE HERO */
.pf-hero{background:linear-gradient(150deg,var(--dk) 0%,#1e1248 50%,#2a1a0a 100%);padding:2.5rem 1.5rem 3rem;text-align:center;position:relative;overflow:hidden;}
.pf-hero-bg{position:absolute;inset:0;pointer-events:none;}
.pf-hero-bg::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(244,128,58,.15) 0%,transparent 65%);top:-100px;right:-80px;}
.pf-hero-bg::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(58,191,184,.12) 0%,transparent 65%);bottom:-80px;left:-40px;}
.pf-avatar-wrap{position:relative;display:inline-block;margin-bottom:.9rem;}
#p-av{width:88px;height:88px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--or),var(--yw));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--dk);border:4px solid rgba(255,255,255,.2);box-shadow:0 0 0 4px rgba(244,128,58,.25),0 8px 32px rgba(0,0,0,.35);position:relative;z-index:1;}
#p-av img{width:100%;height:100%;object-fit:cover;}
.pf-avatar-ring{position:absolute;inset:-8px;border-radius:50%;border:2px dashed rgba(244,128,58,.4);animation:spin 12s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
#p-name{position:relative;z-index:1;}
#p-badge{position:relative;z-index:1;margin-top:.35rem;}
.pf-since{font-size:.62rem;color:rgba(255,255,255,.3);font-weight:600;letter-spacing:.8px;margin-top:.45rem;position:relative;z-index:1;}

/* PROFILE SECTIONS */
.pf-adh-banner{background:linear-gradient(135deg,#fff8f0,#ffe8d0);border:1.5px solid rgba(244,128,58,.35);border-radius:var(--rd2);padding:1.2rem;margin-bottom:1rem;display:flex;gap:1rem;align-items:flex-start;}
.pf-adh-banner-icon{font-size:2rem;flex-shrink:0;line-height:1;}
.pf-adh-banner-body h3{color:var(--or);font-weight:800;font-size:.9rem;margin-bottom:.2rem;}
.pf-adh-banner-body p{color:#8a4a12;font-size:.78rem;line-height:1.55;margin-bottom:.7rem;}
.pf-section{background:var(--wh);border-radius:var(--rd2);box-shadow:var(--sh);margin-bottom:.85rem;border:1.5px solid var(--bd);overflow:hidden;}
.pf-section-header{display:flex;align-items:center;gap:.65rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--bd);background:rgba(0,0,0,.018);}
.pf-section-icon{font-size:1.05rem;width:1.4rem;text-align:center;}
.pf-section-title{font-weight:800;font-size:.88rem;color:var(--tx);}
.pf-section-body{padding:1.1rem;}
.pf-danger .pf-section-header{background:rgba(220,38,38,.04);}
.pf-danger{border-color:rgba(220,38,38,.25);}

/* old compat */
.prof-hero{background:linear-gradient(140deg,var(--dk),var(--dk2));border-radius:var(--rd2);padding:1.55rem 1.4rem;text-align:center;margin-bottom:.95rem;border:1px solid rgba(255,255,255,.05);}
.prof-card{background:var(--wh);border-radius:var(--rd2);padding:1.4rem;box-shadow:var(--sh);margin-bottom:.9rem;border:1.5px solid var(--bd);}
.prof-card h3{font-weight:800;color:var(--tx);font-size:.9rem;margin-bottom:.95rem;}
.non-adh{background:linear-gradient(135deg,#fff8f0,#ffe8d0);border:1.5px solid rgba(244,128,58,.4);border-radius:var(--rd);padding:1.05rem;margin-bottom:.95rem;text-align:center;}
.non-adh h3{color:var(--or);font-weight:800;font-size:.88rem;margin-bottom:.25rem;}
.non-adh p{color:#8a4a12;font-size:.77rem;line-height:1.55;margin-bottom:.75rem;}
.adh-box.on{background:rgba(58,191,184,.07);border:1.5px solid rgba(58,191,184,.3);border-radius:var(--rd);padding:1rem;text-align:center;}

/* ADMIN */
/* ADMIN PANEL */
.adm-hero{background:linear-gradient(135deg,#0f1221 0%,#1a0a2e 50%,#0a1f1e 100%);padding:2rem 1.5rem 1.5rem;text-align:center;position:relative;overflow:hidden;}
.adm-hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(124,58,237,.2) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(58,191,184,.15) 0%,transparent 50%);}
.adm-hero-content{position:relative;z-index:1;}
.adm-hero-avatar{font-size:2.5rem;margin-bottom:.5rem;animation:float 4s ease-in-out infinite;}
.adm-hero-title{font-family:'Pacifico',cursive;font-size:1.8rem;color:#fff;margin-bottom:.25rem;}
.adm-hero-sub{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:600;letter-spacing:1px;}
.adm-kpis-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--dk2);border-bottom:1px solid rgba(255,255,255,.06);}
.adm-kpi{padding:.8rem .5rem;text-align:center;border-right:1px solid rgba(255,255,255,.06);}
.adm-kpi:last-child{border-right:none;}
.adm-kpi-n{display:block;font-family:'Pacifico',cursive;font-size:1.35rem;color:var(--or);line-height:1;}
.adm-kpi-l{display:block;font-size:.52rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:2px;}
.adm-tabs-wrap{background:var(--dk);border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;-webkit-overflow-scrolling:touch;}
.adm-tabs{display:flex;min-width:max-content;padding:.5rem .8rem;gap:.3rem;}
.adm-tab{background:none;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.45);font-family:inherit;font-weight:700;font-size:.76rem;padding:.48rem .9rem;border-radius:50px;cursor:pointer;transition:var(--tr);white-space:nowrap;}
.adm-tab:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.75);}
.adm-tab.active{background:linear-gradient(135deg,var(--or),var(--co));color:#fff;border-color:transparent;}
.adm-tab-panel{display:none;}
.adm-tab-panel.active{display:block;animation:pgIn .22s ease;}
.adm-card{background:var(--wh);border-radius:var(--rd2);padding:1.3rem;box-shadow:var(--sh);margin-bottom:1rem;border:1.5px solid var(--bd);}
.adm-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding-bottom:.7rem;border-bottom:1.5px solid var(--bd);}
.adm-card-icon{font-size:1.1rem;width:2rem;height:2rem;background:var(--bg);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.adm-card-header h3{font-weight:800;color:var(--tx);font-size:.9rem;margin:0;flex:1;}
.mem-row{display:flex;align-items:center;gap:.55rem;padding:.5rem .8rem;border-bottom:1px solid #f5f2ee;transition:background .15s;}
.mem-row:hover{background:#faf8f6;}
.mem-row:last-child{border-bottom:none;}
.mem-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--or),var(--yw));display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:var(--dk);flex-shrink:0;overflow:hidden;}
.mem-av img{width:100%;height:100%;object-fit:cover;}
.mem-info{flex:1;min-width:0;}
.mem-info strong{font-size:.79rem;color:var(--tx);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mem-info small{font-size:.67rem;color:var(--mu);}
.bdg-adh{font-size:.65rem;font-weight:700;padding:.12rem .55rem;border-radius:50px;flex-shrink:0;}
.bdg-adh.y{background:rgba(34,197,94,.12);color:#15803d;border:1px solid rgba(34,197,94,.25);}
.bdg-ban{background:rgba(220,38,38,.1);color:#dc2626;border:1px solid rgba(220,38,38,.25);font-size:.62rem;font-weight:700;padding:.12rem .5rem;border-radius:50px;}
.bdg-adh.n{background:#f5f2ee;color:#9ca3af;border:1px solid #e5e0da;}
/* SCROLLBAR CUSTOM */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:10px;}
::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25);}

/* MODALS */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px);}
.overlay.open{display:flex;}
.modal{background:var(--wh);border-radius:var(--rd2);padding:1.55rem;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.22);animation:mIn .22s cubic-bezier(.34,1.26,.64,1);max-height:90vh;overflow-y:auto;}
.modal.sm{max-width:420px;}
@keyframes mIn{from{transform:scale(.88) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.m-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;gap:.8rem;}
.m-head h3{font-family:'Pacifico',cursive;color:var(--or);font-size:1.15rem;}
.m-head p{color:var(--mu);font-size:.8rem;margin-top:.15rem;}
.m-cl{background:none;border:none;color:#c0c4d8;font-size:1.25rem;cursor:pointer;border-radius:8px;padding:.18rem .28rem;transition:var(--tr);flex-shrink:0;}
.m-cl:hover{color:#e74c3c;}
.resp-row{display:flex;gap:.5rem;margin-bottom:.9rem;flex-wrap:wrap;}
.resp-btn{flex:1;padding:.65rem;border:2px solid var(--bd);border-radius:var(--rd);background:var(--wh);cursor:pointer;font-family:inherit;font-weight:700;font-size:.81rem;transition:var(--tr);text-align:center;min-width:90px;}
.resp-btn:hover{border-color:var(--or);}
.resp-btn.sy{border-color:var(--tl);background:rgba(58,191,184,.07);color:#0a8580;}
.resp-btn.sm2{border-color:var(--yw);background:rgba(249,200,70,.08);color:#7a5d00;}
.resp-btn.sn{border-color:#ddd;background:#f8f8f8;color:#b0b4c8;}
.mf{margin-bottom:.9rem;display:none;}
.mf label{font-weight:700;font-size:.78rem;color:var(--tx);display:block;margin-bottom:.28rem;}
.part-item{display:flex;align-items:center;gap:.65rem;padding:.48rem .65rem;background:#faf8f6;border-radius:var(--rd);margin-bottom:.42rem;}
.part-av{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.82rem;color:#fff;overflow:hidden;}
.part-av img{width:100%;height:100%;object-fit:cover;}

/* BANNERS */
.fix-ban{position:fixed;bottom:0;left:0;right:0;z-index:8000;background:rgba(15,18,33,.97);backdrop-filter:blur(16px);border-top:1.5px solid rgba(244,128,58,.35);padding:.9rem 1.3rem;box-shadow:0 -6px 32px rgba(0,0,0,.45);}
.fix-ban .inner{max-width:520px;margin:0 auto;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;}
#rgpd-bar{position:fixed;bottom:0;left:0;right:0;z-index:7900;background:rgba(15,18,33,.97);backdrop-filter:blur(16px);padding:.85rem 1.3rem;display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;border-top:1.5px solid rgba(255,255,255,.06);}
#rgpd-bar p{flex:1;font-size:.77rem;color:rgba(255,255,255,.55);font-weight:500;min-width:160px;line-height:1.5;}
#rgpd-bar a{color:var(--yw);text-decoration:underline;cursor:pointer;}
#toast{position:fixed;bottom:1.2rem;right:1.2rem;background:var(--dk);color:#fff;padding:.75rem 1.15rem;border-radius:14px;font-weight:600;font-size:.81rem;box-shadow:0 8px 28px rgba(0,0,0,.28);transform:translateY(60px);opacity:0;transition:all .25s;z-index:9999;max-width:275px;border-left:4px solid var(--tl);pointer-events:none;}
#toast.ok{border-left-color:var(--tl);}
#toast.err{border-left-color:#e74c3c;background:#1c0808;}
#toast.on{transform:translateY(0);opacity:1;}
footer{background:var(--dk);color:rgba(255,255,255,.38);text-align:center;padding:1.2rem 1.5rem 2rem;font-size:.76rem;font-weight:500;}
footer a{color:var(--yw);text-decoration:none;transition:opacity .2s;}
footer a:hover{opacity:.75;}
.f-logo{font-family:'Pacifico',cursive;color:var(--yw);font-size:1.05rem;display:block;margin-bottom:.28rem;}
.rgpd-page h2{font-family:'Pacifico',cursive;color:var(--or);font-size:1.5rem;margin-bottom:.4rem;}
.rgpd-page h3{font-weight:800;color:var(--tx);font-size:.92rem;margin:1.2rem 0 .38rem;}
.rgpd-page p,.rgpd-page li{font-size:.84rem;color:#555;line-height:1.72;}
.rgpd-page ul{padding-left:1.2rem;margin-top:.22rem;}

/* RESPONSIVE */
@media(max-width:900px) and (min-width:741px){
  .wrap{padding:1.5rem 1.5rem;}
  .feat-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:740px){
  #sidebar{transform:translateX(-100%);}
  #sidebar.open{transform:translateX(0);}
  #sb-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:55;}
  #sb-ov.open{display:block;}
  #topbar{display:none!important;}
  #main{margin-left:0;padding-top:env(safe-area-inset-top);padding-bottom:calc(68px + env(safe-area-inset-bottom));}
  #bottom-nav{display:block;}
  .hero{padding-top:calc(2.2rem + env(safe-area-inset-top));padding-bottom:1.9rem;}
  .wrap{padding:1rem .75rem;}
  .f-g2,.f-g13{grid-template-columns:1fr;}
  .hero-stats{gap:.5rem;}
  .hero-stat{padding:.55rem .75rem;}
  .hero-stat strong{font-size:1.1rem;}
  .modal{padding:1.1rem;border-radius:var(--rd);}
  .aw-card{padding:1.1rem 1rem;}
  .prof-card{padding:1rem;}
  .bens{grid-template-columns:1fr;}
  #rgpd-bar{bottom:calc(68px + env(safe-area-inset-bottom));}
  #toast{bottom:calc(80px + env(safe-area-inset-bottom));}

  /* ── CARTES ÉVÉNEMENTS MOBILE ── */
  .ev-list{gap:.75rem;}
  .ev-card{border-radius:18px;}
  .ev-card-header{min-height:96px;}
  .ev-card-datebox{width:78px;padding:.9rem .4rem;}
  .ev-card-datebox .ev-day{font-size:2.4rem;}
  .ev-card-datebox .ev-mon{font-size:.55rem;}
  .ev-card-datebox .ev-yr{display:none;}
  .ev-card-headerinfo{padding:.85rem .9rem;}
  .ev-card-title{font-size:1rem;}
  .ev-card-body{padding:.85rem 1rem 0;}
  .ev-card-desc{font-size:.8rem;line-height:1.65;}
  .ev-card-actions{padding:.75rem 1rem .9rem;gap:.4rem;}
  .ev-cd-seg{min-width:34px;}
  .ev-cd-num{font-size:1rem;}
  .ev-filters-bar{padding:.65rem .85rem .4rem;gap:.4rem;}
  .ev-card-actions .btn{min-height:40px;font-size:.78rem;}
  .ev-registered{font-size:.72rem;padding:.32rem .75rem;}
  .pcnt-btn{font-size:.7rem;padding:.3rem .75rem;}

  /* Barre de progression */
  .ev-prog-wrap{margin-top:.1rem;}
  .ev-progress-fill,.prog-fill{height:6px;}

  /* Page hero événements */
  .ev-page-hero{padding:1.5rem 1rem 1.2rem;}
  .ev-page-hero-emoji{font-size:2rem;}
  .ev-page-hero-title{font-size:1.6rem;}

  /* ── PANNEAU ADMIN MOBILE ── */
  .adm-hero{padding:1.5rem 1rem 1.2rem;}
  .adm-hero-title{font-size:1.5rem;}
  .adm-kpis-bar{grid-template-columns:repeat(4,1fr);}
  .adm-kpi{padding:.65rem .3rem;}
  .adm-kpi-n{font-size:1.15rem;}
  .adm-kpi-l{font-size:.46rem;letter-spacing:.4px;}
  .adm-tabs{padding:.4rem .6rem;gap:.25rem;}
  .adm-tab{font-size:.7rem;padding:.42rem .75rem;}
  .adm-card{padding:1rem;border-radius:var(--rd);}
  .adm-card-header{margin-bottom:.75rem;padding-bottom:.55rem;}
  .adm-card-header h3{font-size:.85rem;}

  /* More menu admin item */
  .more-item-admin{background:linear-gradient(135deg,rgba(124,58,237,.06),rgba(124,58,237,.03));border-color:rgba(124,58,237,.2)!important;}
  .more-ic-admin{background:linear-gradient(135deg,#4c1d95,#7c3aed);color:#fff;}
  .more-admin-badge{margin-left:auto;background:linear-gradient(135deg,#4c1d95,#7c3aed);color:#fff;font-size:.58rem;font-weight:800;padding:.18rem .55rem;border-radius:50px;letter-spacing:.5px;}
}

/* ── HOVER CARDS RÉFÉRENTS (remplace onmouseover inline) ────────── */
.ref-card { transition: transform .2s ease, box-shadow .2s ease; }
.ref-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: 0 8px 24px rgba(0,0,0,.12); }

/* ── HOVER CARDS PARTENAIRES ────────────────────────────────────── */
.partner-card { transition: transform .2s ease, box-shadow .2s ease; }
.partner-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.1); }

/* ═══════════════════════════════════════════════════════
   NOUVELLES CLASSES VSC — AMÉLIORATIONS 2025
   ═══════════════════════════════════════════════════════ */

/* ── CLUB HERO ───────────────────────────────────────── */
.club-hero{position:relative;overflow:hidden;background:linear-gradient(140deg,var(--dk),var(--dk2));padding:2.4rem 1.5rem 2rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.05);}
.club-hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(244,128,58,.18) 0%,transparent 55%),radial-gradient(circle at 20% 80%,rgba(58,191,184,.12) 0%,transparent 50%);pointer-events:none;}
.club-hero-content{position:relative;z-index:1;}
.club-hero-crown{font-size:2.4rem;margin-bottom:.5rem;animation:float 3s ease-in-out infinite;}
.club-hero-title{font-family:'Pacifico',cursive;color:var(--yw);font-size:2rem;margin-bottom:.25rem;}
.club-hero-sub{color:rgba(255,255,255,.5);font-size:.85rem;font-weight:500;margin-bottom:1.4rem;}
.club-hero-stats{display:flex;align-items:center;justify-content:center;gap:0;background:rgba(255,255,255,.06);border-radius:16px;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.1);max-width:340px;margin:0 auto;}
.club-hero-stat{flex:1;text-align:center;}
.club-hero-stat-n{display:block;font-family:'Pacifico',cursive;font-size:1.45rem;color:var(--or);line-height:1.1;}
.club-hero-stat-l{display:block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.4);margin-top:.2rem;}
.club-hero-stat-div{width:1px;height:40px;background:rgba(255,255,255,.12);margin:0 .5rem;flex-shrink:0;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}

/* ── CLUB SECTIONS ───────────────────────────────────── */
.club-section-card{background:var(--wh);border-radius:var(--rd2);padding:1.4rem;box-shadow:var(--sh);margin-bottom:1.2rem;border:1.5px solid var(--bd);overflow:hidden;}
.club-section-header{display:flex;align-items:center;gap:.9rem;margin-bottom:1.1rem;}
.club-section-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.club-section-title{font-weight:800;color:var(--tx);font-size:.95rem;line-height:1.2;}
.club-section-sub{font-size:.73rem;color:var(--mu);margin-top:.1rem;}

/* ── FILTRES ÉVÉNEMENTS ──────────────────────────────── */
.ev-filters-bar{display:flex;gap:.5rem;padding:.8rem 1rem .4rem;overflow-x:auto;scrollbar-width:none;background:var(--bg);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--bd);}
.ev-filters-bar::-webkit-scrollbar{display:none;}
.ev-filter-btn{flex-shrink:0;padding:.42rem .95rem;border:1.5px solid var(--bd);border-radius:50px;font-family:inherit;font-weight:700;font-size:.78rem;cursor:pointer;background:var(--wh);color:var(--mu);transition:var(--tr);white-space:nowrap;}
.ev-filter-btn.active{background:var(--or);color:#fff;border-color:var(--or);}

/* ── SÉPARATEUR EVENTS PASSÉS ────────────────────────── */
.ev-sep-past{display:flex;align-items:center;gap:.8rem;padding:1rem 0 .4rem;margin:0;}
.ev-sep-past span{font-size:.72rem;font-weight:800;color:var(--mu);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;}
.ev-sep-past::before,.ev-sep-past::after{content:'';flex:1;height:1px;background:var(--bd);}

/* ── CARTE ÉVÉNEMENT PASSÉE ──────────────────────────── */
.ev-card-past{opacity:.65;filter:grayscale(20%);}
.ev-card-past .ev-card-date{background:rgba(0,0,0,.25) !important;}

/* ── DESCRIPTION EXPANDABLE ──────────────────────────── */
.ev-desc-toggle{background:none;border:none;color:var(--or);font-size:.74rem;font-weight:700;cursor:pointer;padding:.1rem 0;margin-top:.15rem;font-family:inherit;}
.ev-desc-toggle:hover{text-decoration:underline;}

/* ── MORE MENU — DÉCONNEXION ─────────────────────────── */
#more-nav-logout .more-ic{filter:hue-rotate(320deg);}

/* =========================================================
   VSC THUNDER FINAL — HOME + EVENTS WOW
   Patch visuel fort mais structure inchangée
   ========================================================= */

/* HOME HERO */
.hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 16% 20%, rgba(249,200,70,.10), transparent 18%),
    radial-gradient(circle at 86% 16%, rgba(244,128,58,.18), transparent 24%),
    radial-gradient(circle at 78% 76%, rgba(58,191,184,.10), transparent 18%),
    linear-gradient(145deg,#0a0d18 0%, #161042 45%, #2a130d 100%) !important;
  padding-top:4.05rem;
  padding-bottom:3.2rem;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:34px 34px;
  mask-image:radial-gradient(circle at center, rgba(0,0,0,1), rgba(0,0,0,.28) 74%, transparent 100%);
  -webkit-mask-image:radial-gradient(circle at center, rgba(0,0,0,1), rgba(0,0,0,.28) 74%, transparent 100%);
  opacity:.26;
  pointer-events:none;
}
.hero > *{position:relative; z-index:1;}
.hero-logo{
  box-shadow:
    0 0 0 5px rgba(244,128,58,.18),
    0 0 40px rgba(244,128,58,.22),
    0 18px 50px rgba(0,0,0,.28) !important;
}
.hero h1{
  font-size:clamp(2.55rem, 6vw, 4.5rem);
  line-height:1.02;
  text-shadow:0 10px 34px rgba(0,0,0,.36), 0 0 22px rgba(255,255,255,.07);
  margin-bottom:.85rem;
}
.hero p{
  font-size:1.05rem;
  line-height:1.8;
  max-width:820px;
  margin:0 auto 1.45rem;
  color:rgba(255,255,255,.88);
}
.hero a,.hero a:visited,.hero a:hover,.hero a:active{color:#fff!important;}

.home-hero-trust{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.6rem;
  margin:1.15rem auto 0;
  max-width:980px;
  position:relative;
  z-index:1;
}
.home-hero-trust span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.48rem .9rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.16);
  color:rgba(255,255,255,.86);
  font-size:.75rem;
  font-weight:700;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}

.hero-stat{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 14px 32px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.06);
  border-radius:18px;
  min-width:122px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.hero-stat:hover{
  transform:translateY(-5px) scale(1.03);
  box-shadow:0 22px 40px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.08);
}
.hero-stat strong{font-size:1.55rem;color:#ffd65a;}
.hero-stat span{color:rgba(255,255,255,.62);}

.btn-yw,.btn-or,.btn-gh{
  position:relative;
  overflow:hidden;
  min-height:52px;
  padding:.9rem 1.55rem;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.2px;
  transition:transform .22s ease, box-shadow .22s ease, filter .22s ease;
}
.btn-yw,.btn-or{box-shadow:0 14px 30px rgba(244,128,58,.25);}
.btn-gh{
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.30);
  box-shadow:0 10px 24px rgba(0,0,0,.14);
}
.btn-yw::after,.btn-or::after,.btn-gh::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.12) 30%, rgba(255,255,255,.34) 50%, rgba(255,255,255,.12) 70%, transparent 100%);
  transform:translateX(-130%);
  transition:transform .85s ease;
  pointer-events:none;
}
.btn-yw:hover::after,.btn-or:hover::after,.btn-gh:hover::after{transform:translateX(130%);}
.btn-yw:hover,.btn-or:hover,.btn-gh:hover{transform:translateY(-3px); filter:saturate(1.05);}
.btn-yw:hover,.btn-or:hover{box-shadow:0 18px 34px rgba(244,128,58,.30);}
.btn-gh:hover{box-shadow:0 15px 28px rgba(0,0,0,.18);}

/* HOME CONTENT */
#page-accueil .wrap{max-width:1120px;}
#page-accueil .sec-t{
  max-width:860px;
  font-size:clamp(1.95rem, 4vw, 2.9rem);
  line-height:1.12;
}
#page-accueil .sec-s{
  max-width:760px;
  font-size:.96rem;
  line-height:1.72;
  margin-bottom:1.45rem;
}
#page-accueil .feat-grid{gap:1rem;}
#page-accueil .feat-card{
  border-radius:24px;
  padding:1.5rem 1.25rem;
  box-shadow:0 16px 36px rgba(15,18,33,.07);
  border:1px solid rgba(15,18,33,.05);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
#page-accueil .feat-card:hover{
  transform:translateY(-7px);
  box-shadow:0 20px 48px rgba(15,18,33,.12);
  border-color:rgba(244,128,58,.22);
}
#page-accueil .feat-card p{font-size:.88rem; line-height:1.74;}

.home-band-wrap{max-width:1120px;}
.home-conviction-band{
  display:grid;
  grid-template-columns:1.4fr .95fr;
  gap:1rem;
  margin-top:1.65rem;
  margin-bottom:.2rem;
}
.home-conviction-left,.home-conviction-right{
  border-radius:26px;
  padding:1.45rem 1.35rem;
  box-shadow:0 18px 38px rgba(15,18,33,.08);
}
.home-conviction-left{
  color:#fff;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.14), transparent 22%),
    linear-gradient(135deg,#0f1221 0%, #21114f 42%, #4a2011 100%);
}
.home-conviction-right{
  background:linear-gradient(135deg,#fff 0%, #fff6ef 100%);
  border:1px solid rgba(244,128,58,.12);
}
.home-band-kicker{
  display:inline-block;
  margin-bottom:.6rem;
  font-size:.74rem;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--yw);
}
.home-band-kicker-or{color:var(--or);}
.home-conviction-left h3,.home-conviction-right h3{
  font-size:1.45rem;
  line-height:1.18;
  margin-bottom:.55rem;
}
.home-conviction-left p{
  color:rgba(255,255,255,.78);
  line-height:1.76;
  font-size:.93rem;
}
.home-conviction-right p{
  color:#616781;
  line-height:1.76;
  font-size:.92rem;
  margin-bottom:.95rem;
}
.home-band-points{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin-top:.95rem;
}
.home-band-points span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.48rem .82rem;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:.74rem;
  font-weight:700;
}
.home-conviction-right .btn{
  min-width:255px;
  box-shadow:0 14px 30px rgba(244,128,58,.22);
}

/* EVENTS */
.ev-page-hero{
  background:
    radial-gradient(circle at top right, rgba(244,128,58,.18), transparent 24%),
    radial-gradient(circle at bottom left, rgba(58,191,184,.10), transparent 22%),
    linear-gradient(145deg,#0a0e1a 0%, #0f1221 42%, #1c0a2e 72%, #2a1106 100%) !important;
}
.ev-page-hero-title{
  font-size:clamp(2.2rem, 5vw, 3.2rem);
  text-shadow:0 6px 25px rgba(0,0,0,.42);
}
.ev-page-hero-sub{
  font-size:.92rem;
  color:rgba(255,255,255,.78);
  letter-spacing:.1px;
  text-transform:none;
  max-width:670px;
  margin:0 auto .9rem;
}
.ev-hero-pills{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:.55rem;
  margin:0 auto 1.15rem;
  position:relative;
  z-index:1;
}
.ev-hero-pills span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.45rem .82rem;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.82);
  font-size:.74rem;
  font-weight:700;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.ev-filter-btn{
  border-radius:999px;
  padding:.5rem 1.05rem;
  font-size:.76rem;
}
.ev-filter-btn.active{box-shadow:0 10px 24px rgba(244,128,58,.34);}
.ev-page-upgrade{padding-top:1rem!important;}
.ev-top-note{
  margin-bottom:1rem;
  padding:1rem 1.05rem;
  border-radius:20px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.06);
}
.ev-top-note-kicker{
  display:inline-block;
  margin-bottom:.35rem;
  font-size:.7rem;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--or);
}
.ev-top-note h3{
  color:#fff;
  font-size:1.15rem;
  line-height:1.22;
  margin-bottom:.35rem;
}
.ev-top-note p{
  color:rgba(255,255,255,.62);
  font-size:.84rem;
  line-height:1.68;
  margin:0;
}
.ev-card{
  border-radius:24px;
  box-shadow:0 12px 32px rgba(0,0,0,.32);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.ev-card:hover{
  transform:translateY(-8px) scale(1.006);
  box-shadow:0 24px 56px rgba(0,0,0,.44);
  border-color:rgba(255,255,255,.14);
}
.ev-card-title{font-size:1.22rem;}
.ev-card-desc{font-size:.88rem; line-height:1.72;}
.btn-join-main{box-shadow:0 14px 30px rgba(0,0,0,.36);}

/* Mobile */
@media (max-width: 900px){
  .home-conviction-band{grid-template-columns:1fr;}
}
@media (max-width: 740px){
  .hero{
    padding-top:3.3rem;
    padding-bottom:2.8rem;
  }
  .hero h1{font-size:clamp(2.25rem, 12vw, 3.7rem);}
  .hero p{font-size:.98rem; line-height:1.68;}
  .home-hero-trust,.ev-hero-pills{gap:.45rem;}
  .home-hero-trust span,.ev-hero-pills span{
    font-size:.69rem;
    padding:.42rem .7rem;
  }
  .home-conviction-left h3,.home-conviction-right h3{font-size:1.24rem;}
  .home-conviction-right .btn{width:100%; min-width:0;}
  .ev-page-hero-title{font-size:2.15rem;}
  .ev-page-hero-sub{font-size:.84rem;}
  .ev-card:hover,.feat-card:hover,.hero-stat:hover,.btn-yw:hover,.btn-or:hover,.btn-gh:hover{
    transform:none;
  }
}

@media (max-width: 740px){
  .home-hero-trust span,
  .ev-hero-pills span{
    white-space:normal !important;
    text-align:center !important;
    min-height:unset !important;
  }
}

/* FINAL HOME BAND HOTFIX */
@media (min-width: 860px){
  .home-conviction-band-vfinal{
    grid-template-columns:1.25fr .95fr !important;
  }
  .home-conviction-band-vfinal > div:first-child{
    padding:26px 24px !important;
  }
  .home-conviction-band-vfinal > div:last-child{
    padding:26px 24px !important;
  }
  .home-conviction-band-vfinal > div:first-child > div:last-child{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

/* ── MOBILE OVERFLOW FIX ─────────────────── */
#page-club, #club-content, #club-locked {
  overflow-x: hidden;
  max-width: 100%;
}
.club-section-card {
  overflow: hidden;
  max-width: 100%;
}
.bens {
  max-width: 100%;
}
.ben {
  min-width: 0;
  overflow: hidden;
}

/* ═══════════════════════════════════════════════════
   VSC 2026 — MODERNISATION GLOBALE
   ═══════════════════════════════════════════════════ */

/* ── Bottom nav upgrades ──────────────────────────── */
#bottom-nav {
  background: rgba(10,12,22,.92) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
}
#bottom-nav ul li a {
  transition: color .18s, transform .18s !important;
}
#bottom-nav ul li a.active {
  color: var(--or) !important;
}
#bottom-nav ul li a.active .bn-ic {
  filter: drop-shadow(0 0 6px rgba(244,128,58,.5));
}

/* ── Feat cards modernisées ────────────────────────── */
.feat-card {
  border-radius: 20px !important;
  padding: 1.5rem 1.25rem !important;
  border: 1px solid rgba(15,18,33,.06) !important;
  box-shadow: 0 4px 24px rgba(15,18,33,.07) !important;
  position: relative;
  overflow: hidden;
  transition: transform .25s cubic-bezier(.34,1.26,.64,1), box-shadow .25s ease, border-color .25s !important;
}
.feat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(244,128,58,.04) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .25s;
  pointer-events: none;
}
.feat-card:hover::before { opacity: 1; }
.feat-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 40px rgba(15,18,33,.12) !important;
  border-color: rgba(244,128,58,.2) !important;
}
.feat-ic {
  font-size: 2rem !important;
  margin-bottom: .75rem !important;
  display: inline-block;
  transition: transform .25s;
}
.feat-card:hover .feat-ic { transform: scale(1.15) rotate(-4deg); }
.feat-card h3 { font-size: .92rem !important; font-weight: 800 !important; margin-bottom: .32rem !important; }
.feat-card p { font-size: .8rem !important; line-height: 1.68 !important; }

/* ── Hero badge modernisé ─────────────────────────── */
.hero-badge {
  background: rgba(255,255,255,.09) !important;
  border: 1px solid rgba(255,255,255,.2) !important;
  backdrop-filter: blur(16px) !important;
  font-size: .7rem !important;
  letter-spacing: 1.8px !important;
  padding: .32rem 1rem !important;
  animation: fadeInDown .6s ease both !important;
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Hero stats modern ────────────────────────────── */
.hero-stat {
  transition: transform .22s ease !important;
}
.hero-stat:hover { transform: translateY(-4px) scale(1.04) !important; }

/* ── Buttons global upgrade ───────────────────────── */
.btn {
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.15) 50%, transparent 100%);
  transform: translateX(-130%);
  transition: transform .7s ease;
  pointer-events: none;
}
.btn:hover::after { transform: translateX(130%); }

/* ── Next event card modernisée ───────────────────── */
.next-ev-card {
  background: linear-gradient(135deg, #111428 0%, #1a1535 50%, #1e1008 100%) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.22), 0 0 0 1px rgba(244,128,58,.08) !important;
}
.next-ev-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,.3), 0 0 0 1px rgba(244,128,58,.15) !important;
}

/* ── Profil hero upgrade ──────────────────────────── */
.pf-hero {
  background: linear-gradient(150deg, #0a0d18 0%, #141038 45%, #251506 100%) !important;
}

/* ── Modal upgrade ────────────────────────────────── */
.modal {
  border-radius: 24px !important;
}
.overlay {
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

/* ── Toast modernisé ─────────────────────────────── */
#toast {
  border-radius: 16px !important;
  font-size: .83rem !important;
  padding: .85rem 1.2rem !important;
  box-shadow: 0 12px 36px rgba(0,0,0,.32) !important;
}

/* ── Section titles ───────────────────────────────── */
.sec-t {
  line-height: 1.12 !important;
}

/* ── Page animations ──────────────────────────────── */
.page.active {
  animation: pgIn .3s cubic-bezier(.34,1.12,.64,1) !important;
}

/* ── Mobile overflow fix global ───────────────────── */
#page-club, #club-content {
  overflow-x: hidden;
  max-width: 100%;
}
.club-section-card { overflow: hidden; }
.bens { max-width: 100%; }
.ben { min-width: 0; }

/* ── Club section cards upgrade ───────────────────── */
.club-section-card {
  transition: box-shadow .22s ease !important;
}
.club-hero-stats {
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* ── Trust pills (home hero) ─────────────────────── */
.home-hero-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 10px;
  max-width: 1080px;
  margin: 20px auto 0;
  padding: 0 16px;
  position: relative;
  z-index: 2;
}
.hero-trust-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(12,15,28,.42);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-size: .8rem;
  font-weight: 800;
  line-height: 1.2;
  box-shadow: 0 8px 24px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .2s, background .2s;
  white-space: nowrap;
}
.hero-trust-pill:hover {
  transform: translateY(-2px);
  background: rgba(20,24,44,.55);
}
@media (max-width: 740px) {
  .hero-trust-pill { font-size: .72rem; padding: 7px 13px; white-space: normal; text-align: center; }
  .home-hero-trust { gap: 7px; }
}


/* ===== VSC OPTIMISATION CONVERSION 2026 ===== */
.vsc-conversion-wrap,
.vsc-social-proof-wrap{
  max-width:1120px;
}

.vsc-conversion{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(310px,.9fr);
  gap:18px;
  align-items:stretch;
  margin-top:22px;
}

.vsc-conversion-card{
  border-radius:28px;
  padding:28px 26px;
  box-shadow:0 18px 42px rgba(15,18,33,.10);
  min-width:0;
}

.vsc-conversion-main{
  color:#fff;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.15), transparent 26%),
    linear-gradient(135deg,#0f1221 0%,#21114f 45%,#4a2011 100%);
}

.vsc-conversion-side{
  background:linear-gradient(135deg,#ffffff 0%,#fff7f1 100%);
  border:1px solid rgba(244,128,58,.14);
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.vsc-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin-bottom:12px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:var(--yw);
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.vsc-kicker-orange{
  background:rgba(244,128,58,.10);
  color:var(--or);
}

.vsc-conversion h2,
.vsc-social-proof h2{
  margin:0 0 10px;
  font-size:clamp(1.55rem,2.35vw,2.35rem);
  line-height:1.08;
  letter-spacing:-.035em;
  font-weight:800;
}

.vsc-conversion-main h2{color:#fff;max-width:13ch;}
.vsc-conversion-side h2{color:var(--tx);max-width:12ch;}

.vsc-conversion p,
.vsc-social-proof p{
  margin:0;
  font-size:14px;
  line-height:1.78;
}

.vsc-conversion-main p{color:rgba(255,255,255,.82);}
.vsc-conversion-main .vsc-lead{
  color:rgba(255,255,255,.96);
  font-weight:750;
  margin-bottom:8px;
}
.vsc-conversion-side p{
  color:#5f667f;
  margin-bottom:18px;
}

.vsc-proof-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:16px;
}
.vsc-proof-grid span{
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:15px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  text-align:center;
  font-size:13px;
  font-weight:750;
  line-height:1.32;
}

.vsc-conversion-btn{
  width:100%;
  justify-content:center;
  min-height:50px;
}

.vsc-social-proof{
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:18px;
  align-items:center;
  margin-top:22px;
  padding:26px;
  border-radius:28px;
  background:#fff;
  border:1px solid rgba(232,226,218,.9);
  box-shadow:var(--sh);
}
.vsc-social-proof h2{color:var(--tx);max-width:14ch;}
.vsc-social-proof p{color:var(--mu);}
.vsc-mini-testimonials{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.vsc-mini-testimonials span{
  display:block;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(135deg,#fff7f1,#fff);
  border:1px solid rgba(244,128,58,.12);
  color:#30354f;
  font-size:13px;
  font-weight:700;
  line-height:1.55;
}

.ev-cal-btn,
.btn-cal{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:.35rem !important;
  background:rgba(58,191,184,.12) !important;
  color:#6ee7df !important;
  border:1px solid rgba(58,191,184,.28) !important;
  border-radius:50px !important;
  padding:.42rem .95rem !important;
  font-size:.74rem !important;
  font-weight:800 !important;
  cursor:pointer !important;
  min-height:38px !important;
}

.ev-card-actions .btn-join-main{
  flex:1 1 180px;
  justify-content:center;
}

.ev-top-note{
  position:relative;
  overflow:hidden;
}
.ev-top-note:after{
  content:'';
  position:absolute;
  right:-40px;
  top:-40px;
  width:150px;
  height:150px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(244,128,58,.18),transparent 68%);
  pointer-events:none;
}

@media (max-width:900px){
  .vsc-conversion,
  .vsc-social-proof{
    grid-template-columns:1fr;
  }
  .vsc-conversion-main h2,
  .vsc-conversion-side h2,
  .vsc-social-proof h2{
    max-width:none;
  }
}

@media (max-width:640px){
  .vsc-conversion-wrap,
  .vsc-social-proof-wrap{
    padding-left:14px !important;
    padding-right:14px !important;
  }
  .vsc-conversion{
    gap:14px;
    margin-top:18px;
  }
  .vsc-conversion-card,
  .vsc-social-proof{
    border-radius:22px;
    padding:18px 16px;
  }
  .vsc-conversion h2,
  .vsc-social-proof h2{
    font-size:1.45rem;
    line-height:1.13;
  }
  .vsc-conversion p,
  .vsc-social-proof p{
    font-size:14px;
    line-height:1.7;
  }
  .vsc-proof-grid{
    grid-template-columns:1fr;
    gap:8px;
  }
  .ev-card-actions{
    gap:.55rem;
  }
  .ev-cal-btn,
  .btn-cal,
  .btn-join-main{
    width:100% !important;
  }
}

/* Accessibilité et confort */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.001ms !important;
  }
}
