:root{
  --ink:#f4f1ea;
  --paper:#1a1a24;
  --blood:#7c5cff;
  --blood-deep:#5a3fd4;
  --blood-soft:#a897ff;
  --acid:#f3ff3d;
  --cream-dark:#ebe7dc;
  --card:#ffffff;
  --rule:rgba(26,26,36,.1);
  --rule-strong:rgba(26,26,36,.2);
  --muted:rgba(26,26,36,.6);
  --success:#22c55e;
  --success-soft:#dcfce7;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:'Inter Tight','Inter',system-ui,-apple-system,sans-serif;
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
img,svg{display:block;max-width:100%}
input,textarea,select{font-family:inherit;font-size:1rem}

.layout{
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100vh;
}

aside.sidebar{
  background:var(--paper);
  color:var(--ink);
  padding:1.5rem 0;
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  flex-direction:column;
  overflow-y:auto;
}
.sidebar-logo{
  padding:0 1.5rem 2rem;
  border-bottom:1px solid rgba(244,241,234,.08);
  margin-bottom:1.5rem;
}
.sidebar-logo svg{height:44px;width:auto}
.sidebar-nav{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:.25rem;
  padding:0 .75rem;
}
.nav-link{
  display:flex;
  align-items:center;
  gap:.9rem;
  padding:.9rem 1rem;
  border-radius:10px;
  color:rgba(244,241,234,.7);
  transition:all .15s;
  font-weight:500;
  font-size:.95rem;
}
.nav-link:hover{
  background:rgba(244,241,234,.05);
  color:var(--ink);
}
.nav-link.active{
  background:var(--blood);
  color:var(--ink);
}
.nav-link .icon{
  width:22px;
  height:22px;
  flex-shrink:0;
}
.nav-link .icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.8}

.sidebar-bottom{
  padding:1rem .75rem 0;
  border-top:1px solid rgba(244,241,234,.08);
  margin-top:1rem;
}
.user-card{
  background:rgba(244,241,234,.05);
  padding:.85rem 1rem;
  border-radius:10px;
  display:flex;
  align-items:center;
  gap:.7rem;
  margin-bottom:.5rem;
}
.user-avatar{
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  flex-shrink:0;
}
.user-info{flex:1;min-width:0;overflow:hidden}
.user-name{font-weight:600;font-size:.85rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:.75rem;color:rgba(244,241,234,.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logout-link{
  display:block;
  padding:.7rem 1rem;
  color:rgba(244,241,234,.5);
  font-size:.8rem;
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.1em;
  text-transform:uppercase;
  border-radius:10px;
  transition:all .15s;
}
.logout-link:hover{background:rgba(244,241,234,.05);color:var(--ink)}

main.main{
  min-width:0;
  background:var(--ink);
}

.topbar{
  padding:1.5rem 2.5rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  background:var(--ink);
  position:sticky;
  top:0;
  z-index:10;
}
.page-title{
  font-family:'Anton','Archivo Black',sans-serif;
  font-size:2.2rem;
  line-height:1;
  letter-spacing:-.02em;
  text-transform:uppercase;
  color:var(--paper);
}
.page-title em{
  font-family:'Instrument Serif','Times New Roman',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
  letter-spacing:-.01em;
}
.topbar-badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  background:rgba(124,92,255,.1);
  color:var(--blood-deep);
  padding:.4rem .9rem;
  border-radius:999px;
  font-size:.8rem;
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.08em;
}
.topbar-badge::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--blood);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

.content{padding:1rem 2.5rem 4rem}

.next-step-banner{
  background:var(--paper);
  color:var(--ink);
  border-radius:14px;
  padding:1.5rem 2rem;
  margin-bottom:2rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  position:relative;
  overflow:hidden;
}
.next-step-banner::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:40%;
  height:100%;
  background:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 12px,
      rgba(124,92,255,.15) 12px,
      rgba(124,92,255,.15) 24px
    );
  pointer-events:none;
}
.next-step-text{position:relative;z-index:2}
.next-step-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--acid);
  margin-bottom:.4rem;
}
.next-step-title{
  font-family:'Anton',sans-serif;
  font-size:1.8rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.01em;
}
.next-step-btn{
  position:relative;
  z-index:2;
  background:var(--acid);
  color:var(--paper);
  padding:1rem 1.5rem;
  border-radius:10px;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  transition:transform .15s;
  white-space:nowrap;
}
.next-step-btn:hover{transform:translateX(4px)}

.section-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--blood);
  margin-bottom:.75rem;
}
.section-title{
  font-family:'Anton',sans-serif;
  font-size:2.4rem;
  line-height:1;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:1.5rem;
}
.section-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-bottom:2rem;
}
.stat-card{
  background:var(--card);
  border-radius:14px;
  padding:1.4rem;
  border:1px solid var(--rule);
}
.stat-card.highlight{
  background:var(--paper);
  color:var(--ink);
}
.stat-card.highlight .stat-label{color:rgba(244,241,234,.6)}
.stat-card.highlight .stat-value{color:var(--acid)}
.stat-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.6rem;
}
.stat-value{
  font-family:'Anton',sans-serif;
  font-size:2.6rem;
  line-height:1;
  letter-spacing:-.02em;
  color:var(--paper);
}
.stat-sub{
  font-size:.8rem;
  color:var(--muted);
  margin-top:.4rem;
}

.grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  margin-bottom:2rem;
}

.panel{
  background:var(--card);
  border-radius:14px;
  padding:1.5rem 1.8rem;
  border:1px solid var(--rule);
}
.panel-title{
  font-family:'Anton',sans-serif;
  font-size:1.3rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:1.2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.5rem;
}
.panel-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}

.ranking-tabs{
  display:flex;
  gap:.3rem;
  margin-bottom:1rem;
  background:var(--cream-dark);
  padding:.25rem;
  border-radius:10px;
}
.tab-btn{
  flex:1;
  padding:.55rem .8rem;
  border-radius:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  transition:all .15s;
}
.tab-btn.active{
  background:var(--paper);
  color:var(--ink);
}

.ranking-list{list-style:none}
.ranking-item{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:.9rem 0;
  border-bottom:1px solid var(--rule);
}
.ranking-item:last-child{border:none}
.ranking-rank{
  width:32px;
  height:32px;
  border-radius:50%;
  border:2px solid var(--blood);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.8rem;
  color:var(--blood);
  flex-shrink:0;
}
.ranking-item.top3 .ranking-rank{
  background:var(--blood);
  color:var(--ink);
}
.ranking-name{
  flex:1;
  font-weight:600;
  font-size:.95rem;
}
.ranking-date{
  font-size:.8rem;
  color:var(--muted);
  margin-right:1rem;
}
.ranking-amount{
  font-family:'Anton',sans-serif;
  font-size:1.15rem;
  color:var(--blood);
  text-align:right;
}
.ranking-amount-sub{
  font-size:.7rem;
  color:var(--muted);
  text-align:right;
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.cta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  margin-bottom:2rem;
}
.cta-card{
  padding:2rem;
  border-radius:14px;
  color:var(--ink);
  position:relative;
  overflow:hidden;
  min-height:220px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.cta-card.violet{background:var(--blood)}
.cta-card.dark{background:var(--paper)}
.cta-card-icon{
  width:56px;
  height:56px;
  border-radius:14px;
  background:rgba(244,241,234,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1rem;
}
.cta-card-icon svg{width:32px;height:32px;stroke:var(--ink);fill:none;stroke-width:1.8}
.cta-card h3{
  font-family:'Anton',sans-serif;
  font-size:1.7rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:.5rem;
}
.cta-card h3 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--acid);
  text-transform:lowercase;
}
.cta-card.dark h3 em{color:var(--blood-soft)}
.cta-card p{
  font-size:.9rem;
  opacity:.85;
  line-height:1.5;
  margin-bottom:1.2rem;
}
.cta-card-btn{
  align-self:flex-start;
  background:var(--ink);
  color:var(--paper);
  padding:.8rem 1.2rem;
  border-radius:10px;
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  transition:all .15s;
}
.cta-card-btn:hover{
  background:var(--acid);
  color:var(--paper);
}
.cta-card.dark .cta-card-btn{background:var(--acid);color:var(--paper)}
.cta-card.dark .cta-card-btn:hover{background:var(--blood-soft);color:var(--paper)}

.alert-box{
  background:#fff4e5;
  border:1px solid #ffb84d;
  border-radius:12px;
  padding:1rem 1.3rem;
  display:flex;
  gap:.9rem;
  align-items:center;
  margin-bottom:1.5rem;
  color:#663c00;
}
.alert-icon{
  width:40px;
  height:40px;
  flex-shrink:0;
  background:#ffb84d;
  border-radius:10px;
  color:var(--paper);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:1.2rem;
}
.alert-text{font-size:.9rem;line-height:1.45}
.alert-text strong{font-family:'Archivo Black',sans-serif;letter-spacing:.05em}
.alert-text a{color:var(--blood);font-weight:600;text-decoration:underline}

.success-box{
  background:var(--success-soft);
  border-left:4px solid var(--success);
  border-radius:10px;
  padding:1rem 1.3rem;
  color:#14532d;
  font-size:.92rem;
  line-height:1.5;
}
.success-box strong{color:#14532d;font-weight:700}

.missions-filter{
  display:flex;
  align-items:center;
  gap:.8rem;
  margin-bottom:1.5rem;
  flex-wrap:wrap;
  background:var(--card);
  padding:1rem 1.2rem;
  border-radius:12px;
  border:1px solid var(--rule);
}
.filter-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
}
.filter-chip{
  padding:.5rem .9rem;
  border-radius:999px;
  background:var(--cream-dark);
  font-size:.85rem;
  font-weight:600;
  color:var(--paper);
  transition:all .15s;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}
.filter-chip.active{
  background:var(--blood);
  color:var(--ink);
}
.filter-chip:hover{background:var(--blood-soft)}
.filter-chip.active:hover{background:var(--blood-deep)}

.missions-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.3rem;
}
.mission-card{
  background:var(--card);
  border-radius:14px;
  padding:1.5rem;
  border:1px solid var(--rule);
  transition:all .2s;
  display:flex;
  flex-direction:column;
}
.mission-card:hover{
  border-color:var(--blood);
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(124,92,255,.12);
}
.mission-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:.5rem;
  margin-bottom:.9rem;
}
.mission-level{
  background:var(--cream-dark);
  padding:.3rem .7rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--paper);
}
.mission-level.active-level{
  background:var(--blood);
  color:var(--ink);
}
.mission-locked-badge{
  background:#fee2e2;
  color:#991b1b;
  padding:.3rem .7rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:.3rem;
}
.mission-icon{
  width:54px;
  height:54px;
  border-radius:12px;
  background:var(--cream-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1rem;
  font-size:1.8rem;
}
.mission-title{
  font-family:'Anton',sans-serif;
  font-size:1.3rem;
  line-height:1.05;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin-bottom:.6rem;
}
.mission-desc{
  font-size:.88rem;
  color:var(--muted);
  line-height:1.5;
  margin-bottom:1.3rem;
  flex:1;
}
.mission-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.6rem;
  margin-bottom:1.2rem;
}
.mission-stat{
  background:var(--cream-dark);
  padding:.75rem .9rem;
  border-radius:10px;
  text-align:center;
}
.mission-stat-value{
  font-family:'Anton',sans-serif;
  font-size:1.5rem;
  line-height:1;
  color:var(--paper);
}
.mission-stat-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.6rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:.3rem;
}
.mission-btn{
  width:100%;
  padding:.95rem;
  border-radius:10px;
  background:var(--blood);
  color:var(--ink);
  font-family:'Archivo Black',sans-serif;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  transition:all .15s;
}
.mission-btn:hover{background:var(--blood-deep)}
.mission-btn.locked{
  background:var(--cream-dark);
  color:var(--muted);
  cursor:not-allowed;
}
.mission-card.locked{opacity:.7}
.mission-card.locked .mission-icon{opacity:.4}

.support-hero{
  background:var(--paper);
  color:var(--ink);
  border-radius:16px;
  padding:3rem 2.5rem;
  margin-bottom:2rem;
  position:relative;
  overflow:hidden;
}
.support-hero::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:50%;
  height:100%;
  background:
    radial-gradient(circle at center, rgba(124,92,255,.3) 0%, transparent 70%);
  pointer-events:none;
}
.support-hero-content{position:relative;z-index:2;max-width:600px}
.support-hero h2{
  font-family:'Anton',sans-serif;
  font-size:2.8rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin-bottom:.8rem;
}
.support-hero h2 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood-soft);
  text-transform:lowercase;
}
.support-hero p{
  font-size:1.05rem;
  line-height:1.5;
  color:rgba(244,241,234,.8);
}

.rewards-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
}
.reward-card{
  background:var(--card);
  border-radius:16px;
  padding:0;
  overflow:hidden;
  border:1px solid var(--rule);
  display:flex;
  flex-direction:column;
}
.reward-header{
  padding:2rem;
  color:var(--ink);
  position:relative;
  min-height:200px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
}
.reward-header.gold{background:linear-gradient(135deg,#1a1a24 0%,#3d2f0e 70%,#8b6914 100%)}
.reward-header.green{background:linear-gradient(135deg,#1a1a24 0%,#0d4a3e 70%,#1d9e75 100%)}
.reward-header.purple{background:var(--blood)}
.reward-header.orange{background:linear-gradient(135deg,#1a1a24 0%,#3d200e 70%,#d85a30 100%)}
.reward-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(244,241,234,.7);
  margin-bottom:.4rem;
}
.reward-name{
  font-family:'Anton',sans-serif;
  font-size:1.6rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:.3rem;
}
.reward-freq{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  opacity:.6;
}
.reward-value{
  font-family:'Anton',sans-serif;
  font-size:3rem;
  line-height:1;
  margin-top:auto;
}
.reward-value-sub{
  font-size:.8rem;
  opacity:.8;
  margin-top:.2rem;
}
.reward-body{
  padding:1.3rem 1.8rem;
  flex:1;
}
.reward-body p{
  font-size:.9rem;
  color:var(--muted);
  line-height:1.5;
}
.reward-progress{
  margin-top:1rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.85rem;
}
.reward-progress strong{font-weight:700;color:var(--paper)}

.progress-bar{
  height:8px;
  background:var(--cream-dark);
  border-radius:999px;
  overflow:hidden;
  margin:.6rem 0;
}
.progress-fill{
  height:100%;
  background:var(--blood);
  border-radius:999px;
  transition:width .4s;
}

.quote-box{
  background:var(--cream-dark);
  border-left:3px solid var(--blood);
  padding:.9rem 1.1rem;
  margin-top:1rem;
  border-radius:6px;
  font-size:.85rem;
  line-height:1.5;
  font-style:italic;
  color:var(--paper);
}
.quote-box strong{font-style:normal;font-weight:700;color:var(--blood-deep)}

.support-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  margin-bottom:2rem;
}
.support-card{
  background:var(--card);
  border-radius:14px;
  padding:1.8rem;
  border:1px solid var(--rule);
}
.support-card-icon{
  width:60px;
  height:60px;
  border-radius:14px;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:1.2rem;
}
.support-card-icon svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:2}
.support-card h3{
  font-family:'Anton',sans-serif;
  font-size:1.5rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:.4rem;
}
.support-card .card-sub{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--blood);
  margin-bottom:1rem;
}
.support-card p{font-size:.92rem;color:var(--muted);line-height:1.55;margin-bottom:1.2rem}
.support-btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.9rem 1.4rem;
  border-radius:10px;
  background:var(--blood);
  color:var(--ink);
  font-family:'Archivo Black',sans-serif;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  transition:all .15s;
  width:100%;
  justify-content:center;
}
.support-btn:hover{background:var(--blood-deep)}
.support-btn.ghost{
  background:transparent;
  color:var(--paper);
  border:2px solid var(--paper);
}
.support-btn.ghost:hover{background:var(--paper);color:var(--ink)}

.meetings-list{list-style:none;margin-top:.5rem}
.meeting-item{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:.7rem 0;
  border-bottom:1px dashed var(--rule);
  font-size:.9rem;
}
.meeting-item:last-child{border:none}
.meeting-day{
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.05em;
  min-width:90px;
  color:var(--paper);
}
.meeting-type{color:var(--muted);flex:1}

.training-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.3rem;
}
.training-card{
  background:var(--card);
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--rule);
  transition:all .2s;
}
.training-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(124,92,255,.1);
  border-color:var(--blood);
}
.training-thumb{
  height:170px;
  background:var(--paper);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
}
.training-thumb::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(124,92,255,.08) 20px,rgba(124,92,255,.08) 40px);
}
.training-thumb-title{
  position:relative;
  z-index:2;
  font-family:'Anton',sans-serif;
  font-size:1.8rem;
  line-height:.95;
  text-transform:uppercase;
  letter-spacing:-.01em;
  text-align:center;
  padding:0 1rem;
}
.training-thumb-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood-soft);
  text-transform:lowercase;
}
.training-body{padding:1.3rem 1.5rem}
.training-tags{display:flex;gap:.4rem;margin-bottom:.8rem;flex-wrap:wrap}
.training-tag{
  padding:.3rem .7rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.tag-free{background:#dcfce7;color:#14532d}
.tag-premium{background:#fef3c7;color:#78350f}
.tag-new{background:var(--acid);color:var(--paper)}
.training-body h3{
  font-family:'Anton',sans-serif;
  font-size:1.3rem;
  line-height:1.05;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:.5rem;
}
.training-body p{font-size:.87rem;color:var(--muted);line-height:1.5;margin-bottom:1rem}

.footer-crm{
  margin-top:3rem;
  padding:1.5rem 0;
  text-align:center;
  color:var(--muted);
  font-size:.82rem;
  border-top:1px solid var(--rule);
}
.footer-crm a{color:var(--muted);margin:0 .5rem}
.footer-crm a:hover{color:var(--blood)}

.mobile-menu-btn{display:none}
.mobile-overlay{display:none}

@media(max-width:1100px){
  .missions-grid{grid-template-columns:repeat(2,1fr)}
  .training-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  aside.sidebar{
    position:fixed;
    top:0;
    left:0;
    width:280px;
    height:100vh;
    z-index:100;
    transform:translateX(-100%);
    transition:transform .25s ease;
    box-shadow:0 0 40px rgba(0,0,0,.3);
  }
  aside.sidebar.open{transform:translateX(0)}
  .mobile-overlay{
    display:none;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.5);
    z-index:99;
  }
  .mobile-overlay.visible{display:block}
  .mobile-menu-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    border-radius:10px;
    background:var(--paper);
    color:var(--ink);
  }
  .mobile-menu-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2.2}
  .topbar{padding:1rem 1.25rem}
  .page-title{font-size:1.5rem}
  .content{padding:0 1.25rem 3rem}
  .next-step-banner{padding:1.2rem 1.4rem;flex-direction:column;align-items:flex-start}
  .next-step-title{font-size:1.2rem}
  .section-title{font-size:1.8rem}
  .grid-2{grid-template-columns:1fr}
  .cta-grid{grid-template-columns:1fr}
  .rewards-grid{grid-template-columns:1fr}
  .support-grid{grid-template-columns:1fr}
  .support-hero{padding:2rem 1.5rem}
  .support-hero h2{font-size:1.8rem}
}

@media(max-width:600px){
  .stats-grid{grid-template-columns:1fr 1fr;gap:.7rem}
  .stat-card{padding:1rem}
  .stat-value{font-size:2rem}
  .missions-grid{grid-template-columns:1fr}
  .training-grid{grid-template-columns:1fr}
  .missions-filter{padding:.8rem 1rem}
  .section-title{font-size:1.5rem}
  .page-title{font-size:1.3rem}
  .topbar-badge{display:none}
}

/* ═══════════════════════════════════════════════════
   PAGES AUTHENTIFICATION (connexion/inscription)
   ═══════════════════════════════════════════════════ */

.auth-wrapper{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--ink);
}

.auth-visual{
  background:var(--paper);
  color:var(--ink);
  padding:3rem 3.5rem;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.auth-visual::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 40px,
      rgba(124,92,255,.06) 40px,
      rgba(124,92,255,.06) 80px
    );
  pointer-events:none;
}
.auth-visual-logo{position:relative;z-index:2}
.auth-visual-logo svg{height:52px;width:auto}

.auth-visual-content{position:relative;z-index:2;max-width:500px}
.auth-visual-eyebrow{
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--acid);
  margin-bottom:1.2rem;
  display:inline-flex;
  align-items:center;
  gap:.6rem;
}
.auth-visual-eyebrow::before{
  content:"";
  width:10px;
  height:10px;
  background:var(--acid);
  border-radius:50%;
  animation:pulse 2s infinite;
}
.auth-visual h2{
  font-family:'Anton',sans-serif;
  font-size:4rem;
  line-height:.95;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:1.5rem;
}
.auth-visual h2 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood-soft);
  text-transform:lowercase;
}
.auth-visual p{
  font-size:1.05rem;
  color:rgba(244,241,234,.75);
  line-height:1.6;
  margin-bottom:2rem;
}

.auth-highlights{position:relative;z-index:2;display:flex;flex-direction:column;gap:1rem}
.auth-highlight{
  display:flex;
  align-items:center;
  gap:.9rem;
  font-size:.95rem;
}
.auth-highlight-check{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
}
.auth-highlight span{color:rgba(244,241,234,.85)}
.auth-highlight strong{color:var(--ink);font-weight:600}

.auth-visual-footer{
  position:relative;
  z-index:2;
  font-size:.8rem;
  color:rgba(244,241,234,.5);
  font-family:'Archivo Black',sans-serif;
  letter-spacing:.15em;
  text-transform:uppercase;
}

.auth-form-side{
  padding:3rem 3.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:var(--ink);
  overflow-y:auto;
}
.auth-form-wrap{
  max-width:420px;
  margin:0 auto;
  width:100%;
}

.auth-form-header{margin-bottom:2rem}
.auth-form-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--blood);
  margin-bottom:.8rem;
}
.auth-form-header h1{
  font-family:'Anton',sans-serif;
  font-size:2.8rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin-bottom:.6rem;
}
.auth-form-header h1 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}
.auth-form-header p{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.5;
}

.google-btn{
  width:100%;
  padding:1rem 1.2rem;
  background:var(--card);
  color:var(--paper);
  border:2px solid var(--paper);
  border-radius:12px;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.8rem;
  transition:all .15s;
  cursor:pointer;
  margin-bottom:1.5rem;
}
.google-btn:hover{
  background:var(--paper);
  color:var(--ink);
}
.google-btn:hover .google-icon-bg{background:var(--ink)}
.google-icon{width:22px;height:22px;flex-shrink:0}

.auth-divider{
  display:flex;
  align-items:center;
  gap:1rem;
  margin:1.5rem 0;
  color:var(--muted);
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
}
.auth-divider::before,
.auth-divider::after{
  content:"";
  flex:1;
  height:1px;
  background:var(--rule-strong);
}

.form-group{margin-bottom:1.2rem}
.form-label{
  display:block;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--paper);
  margin-bottom:.5rem;
}
.form-input{
  width:100%;
  padding:.95rem 1.1rem;
  background:var(--card);
  border:1px solid var(--rule-strong);
  border-radius:10px;
  font-size:.95rem;
  color:var(--paper);
  transition:all .15s;
  font-family:inherit;
}
.form-input:focus{
  outline:none;
  border-color:var(--blood);
  box-shadow:0 0 0 3px rgba(124,92,255,.15);
}
.form-input::placeholder{color:var(--muted)}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.8rem;
}

.form-hint{
  font-size:.78rem;
  color:var(--muted);
  margin-top:.4rem;
  line-height:1.4;
}

.form-checkbox-wrap{
  display:flex;
  gap:.7rem;
  align-items:flex-start;
  margin:1rem 0 1.5rem;
}
.form-checkbox{
  width:20px;
  height:20px;
  accent-color:var(--blood);
  margin-top:2px;
  flex-shrink:0;
  cursor:pointer;
}
.form-checkbox-label{
  font-size:.85rem;
  color:var(--muted);
  line-height:1.5;
  cursor:pointer;
}
.form-checkbox-label a{
  color:var(--blood);
  text-decoration:underline;
  font-weight:600;
}

.primary-btn{
  width:100%;
  padding:1.1rem;
  background:var(--blood);
  color:var(--ink);
  border:none;
  border-radius:12px;
  font-family:'Archivo Black',sans-serif;
  font-size:.9rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  transition:all .15s;
}
.primary-btn:hover{
  background:var(--blood-deep);
  transform:translateY(-1px);
}
.primary-btn:active{transform:translateY(0)}

.auth-switch{
  margin-top:1.8rem;
  text-align:center;
  font-size:.9rem;
  color:var(--muted);
}
.auth-switch a{
  color:var(--blood);
  font-weight:600;
  text-decoration:underline;
}

.auth-form-footer{
  margin-top:auto;
  padding-top:2.5rem;
  font-size:.78rem;
  color:var(--muted);
  text-align:center;
}
.auth-form-footer a{color:var(--muted);margin:0 .4rem}
.auth-form-footer a:hover{color:var(--blood)}

.forgot-link{
  display:block;
  text-align:right;
  font-size:.82rem;
  color:var(--blood);
  margin-top:.4rem;
  font-weight:500;
}
.forgot-link:hover{text-decoration:underline}

/* Page "en attente de validation" */
.pending-wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:2rem;
  background:var(--ink);
}
.pending-card{
  max-width:560px;
  background:var(--paper);
  color:var(--ink);
  padding:3.5rem 3rem;
  border-radius:20px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.pending-card::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
  background:
    repeating-linear-gradient(
      45deg,
      transparent,
      transparent 30px,
      rgba(124,92,255,.08) 30px,
      rgba(124,92,255,.08) 60px
    );
  pointer-events:none;
}
.pending-card > *{position:relative;z-index:2}
.pending-icon{
  width:80px;
  height:80px;
  border-radius:50%;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.8rem;
  font-size:2.4rem;
}
.pending-card h1{
  font-family:'Anton',sans-serif;
  font-size:2.8rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.02em;
  margin-bottom:1rem;
}
.pending-card h1 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--acid);
  text-transform:lowercase;
}
.pending-card p{
  color:rgba(244,241,234,.8);
  font-size:1.02rem;
  line-height:1.6;
  margin-bottom:1rem;
}
.pending-steps{
  background:rgba(244,241,234,.05);
  border-radius:14px;
  padding:1.5rem;
  margin:2rem 0;
  text-align:left;
}
.pending-step{
  display:flex;
  align-items:flex-start;
  gap:1rem;
  padding:.9rem 0;
  border-bottom:1px solid rgba(244,241,234,.08);
}
.pending-step:last-child{border:none;padding-bottom:0}
.pending-step:first-child{padding-top:0}
.pending-step-num{
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  flex-shrink:0;
}
.pending-step.done .pending-step-num{background:var(--acid);color:var(--paper)}
.pending-step-content{flex:1;text-align:left}
.pending-step-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  letter-spacing:.05em;
  margin-bottom:.2rem;
  color:var(--ink);
}
.pending-step-desc{
  font-size:.85rem;
  color:rgba(244,241,234,.6);
  line-height:1.45;
}

/* Responsive auth */
@media(max-width:900px){
  .auth-wrapper{grid-template-columns:1fr}
  .auth-visual{padding:2rem 1.5rem;min-height:auto}
  .auth-visual h2{font-size:2.5rem}
  .auth-visual p{margin-bottom:1.2rem}
  .auth-highlights{margin-bottom:1rem}
  .auth-visual-footer{display:none}
  .auth-form-side{padding:2rem 1.5rem}
  .auth-form-header h1{font-size:2.2rem}
  .form-row{grid-template-columns:1fr}
  .pending-card{padding:2.5rem 1.8rem}
  .pending-card h1{font-size:2.2rem}
}

/* ═══════════════════════════════════════════════════
   PAGES ADMIN
   ═══════════════════════════════════════════════════ */

.admin-badge{
  background:var(--acid);
  color:var(--paper);
  padding:.3rem .8rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  display:inline-block;
}

.sidebar-section-label{
  padding:1rem 1.25rem .5rem;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(244,241,234,.3);
}

.admin-table-wrap{
  background:var(--card);
  border-radius:14px;
  padding:1.5rem;
  border:1px solid var(--rule);
  overflow-x:auto;
}
.admin-table{
  width:100%;
  border-collapse:collapse;
  font-size:.92rem;
}
.admin-table thead{
  border-bottom:2px solid var(--rule-strong);
}
.admin-table th{
  text-align:left;
  padding:.8rem 1rem;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
}
.admin-table td{
  padding:1rem;
  border-bottom:1px solid var(--rule);
}
.admin-table tr:last-child td{border:none}
.admin-table tr:hover{background:var(--cream-dark)}

.admin-row-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  background:var(--blood);
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  flex-shrink:0;
}
.admin-row-name{
  display:flex;
  align-items:center;
  gap:.8rem;
}
.admin-row-info{
  flex:1;
  min-width:0;
}
.admin-row-prenom{
  font-weight:600;
  color:var(--paper);
}
.admin-row-email{
  font-size:.8rem;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.status-badge{
  padding:.3rem .7rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  display:inline-block;
}
.status-candidat{background:#fef3c7;color:#78350f}
.status-vendeur{background:var(--success-soft);color:#14532d}
.status-admin{background:var(--blood);color:var(--ink)}

.admin-actions{
  display:flex;
  gap:.4rem;
  white-space:nowrap;
}
.admin-btn{
  padding:.5rem .9rem;
  border-radius:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  transition:all .15s;
  border:none;
  cursor:pointer;
}
.admin-btn-success{background:var(--success);color:#fff}
.admin-btn-success:hover{background:#16a34a}
.admin-btn-danger{background:#ef4444;color:#fff}
.admin-btn-danger:hover{background:#dc2626}
.admin-btn-ghost{background:transparent;color:var(--paper);border:1px solid var(--rule-strong)}
.admin-btn-ghost:hover{background:var(--cream-dark)}

.empty-state{
  text-align:center;
  padding:3rem 1.5rem;
  color:var(--muted);
}
.empty-state-icon{
  font-size:3rem;
  margin-bottom:1rem;
  opacity:.3;
}
.empty-state-title{
  font-family:'Anton',sans-serif;
  font-size:1.5rem;
  color:var(--paper);
  margin-bottom:.4rem;
  text-transform:uppercase;
}
.empty-state-desc{
  font-size:.9rem;
  max-width:40ch;
  margin:0 auto;
  line-height:1.55;
}

/* Modale pour éditer une mission */
.modal-overlay{
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  width:100%;
  height:100%;
  background:rgba(26,26,36,.75);
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:1rem;
  overflow-y:auto;
}
.modal-overlay.visible{display:flex}
.modal{
  background:var(--ink);
  border-radius:16px;
  max-width:560px;
  width:100%;
  max-height:90vh;
  overflow-y:auto;
  padding:2rem;
}
.modal-title{
  font-family:'Anton',sans-serif;
  font-size:1.8rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:1.5rem;
}
.modal-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}
.modal-actions{
  display:flex;
  gap:.6rem;
  justify-content:flex-end;
  margin-top:1.5rem;
  padding-top:1.5rem;
  border-top:1px solid var(--rule);
}

@media(max-width:900px){
  .admin-table-wrap{padding:.8rem}
  .admin-table{font-size:.85rem}
  .admin-table th, .admin-table td{padding:.6rem .5rem}
  .admin-row-email{display:none}
  .admin-actions{flex-direction:column}
}

/* ═══════════════════════════════════════════════════
   MODALE MISSION (confirmation de prise)
   ═══════════════════════════════════════════════════ */

.mission-modal{
  background:var(--ink);
  border-radius:16px;
  max-width:620px;
  width:100%;
  max-height:90vh;
  overflow-y:auto;
  padding:0;
}
.mission-modal-header{
  background:var(--paper);
  color:var(--ink);
  padding:2rem 2.5rem;
  border-radius:16px 16px 0 0;
  position:relative;
  overflow:hidden;
}
.mission-modal-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 30px,rgba(124,92,255,.1) 30px,rgba(124,92,255,.1) 60px);
  pointer-events:none;
}
.mission-modal-header > *{position:relative;z-index:2}
.mission-modal-eyebrow{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--acid);
  margin-bottom:.7rem;
}
.mission-modal-header h2{
  font-family:'Anton',sans-serif;
  font-size:2rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.01em;
}
.mission-modal-header h2 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood-soft);
  text-transform:lowercase;
}
.mission-modal-body{padding:2rem 2.5rem}
.mission-modal-body h3{
  font-family:'Anton',sans-serif;
  font-size:1.2rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin:1.5rem 0 .6rem;
  color:var(--paper);
}
.mission-modal-body h3:first-child{margin-top:0}
.mission-modal-body p{
  font-size:.95rem;
  color:rgba(26,26,36,.75);
  line-height:1.65;
  margin-bottom:.8rem;
}
.mission-modal-footer{
  padding:1.5rem 2.5rem;
  border-top:1px solid var(--rule);
  display:flex;
  gap:.8rem;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.whatsapp-btn{
  background:#25D366;
  color:#fff;
  padding:.9rem 1.4rem;
  border-radius:10px;
  font-family:'Archivo Black',sans-serif;
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  transition:all .15s;
  border:none;
  cursor:pointer;
}
.whatsapp-btn:hover{background:#1ea952;transform:translateY(-1px)}

/* ═══════════════════════════════════════════════════
   PAGE DÉCLARER UNE VENTE
   ═══════════════════════════════════════════════════ */

.declare-wrap{
  max-width:720px;
  margin:0 auto;
  background:var(--card);
  border-radius:16px;
  padding:2.5rem;
  border:1px solid var(--rule);
}
.declare-mission-pick{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:.8rem;
  margin-bottom:1.5rem;
}
.mission-pick{
  background:var(--cream-dark);
  border:2px solid transparent;
  border-radius:10px;
  padding:1rem;
  cursor:pointer;
  transition:all .15s;
  text-align:left;
  font-family:inherit;
}
.mission-pick:hover{border-color:var(--blood-soft)}
.mission-pick.selected{
  background:var(--blood);
  color:var(--ink);
  border-color:var(--blood);
}
.mission-pick-icon{font-size:1.5rem;margin-bottom:.4rem}
.mission-pick-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-bottom:.3rem;
}
.mission-pick-commission{
  font-size:.8rem;
  opacity:.75;
}

/* Statut pastille sur les ventes */
.statut-badge{
  padding:.3rem .7rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  display:inline-block;
}
.statut-en_attente{background:#fef3c7;color:#78350f}
.statut-validee{background:#dcfce7;color:#14532d}
.statut-payee{background:#dbeafe;color:#1e40af}
.statut-refusee{background:#fee2e2;color:#991b1b}

/* Zone article lecture */
.article-content{
  background:var(--card);
  border-radius:16px;
  padding:2.5rem 3rem;
  border:1px solid var(--rule);
  max-width:780px;
  margin:0 auto;
}
.article-content h1{
  font-family:'Anton',sans-serif;
  font-size:2.6rem;
  line-height:1;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:.8rem;
}
.article-content h1 em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}
.article-content .article-meta{
  color:var(--muted);
  font-size:.85rem;
  margin-bottom:2rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--rule);
}
.article-content p{
  font-size:1.02rem;
  line-height:1.75;
  color:var(--paper);
  margin-bottom:1.2rem;
}

@media(max-width:600px){
  .declare-wrap, .article-content{padding:1.5rem}
  .mission-modal-header, .mission-modal-body, .mission-modal-footer{padding:1.5rem}
  .article-content h1{font-size:1.8rem}
}


/* ═══════════════════════════════════════════════════
   CHAT DU CLUB — VERSION PRO
   ═══════════════════════════════════════════════════ */

.chat-layout{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:1.5rem;
  height:calc(100vh - 180px);
  min-height:600px;
}

.chat-sidebar-panel{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--rule);
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.chat-sidebar-title{
  font-family:'Anton',sans-serif;
  font-size:1.3rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:var(--paper);
  margin-bottom:.3rem;
}
.chat-sidebar-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}
.chat-sidebar-count{
  font-size:.8rem;
  color:var(--muted);
  margin-bottom:1.2rem;
  padding-bottom:1.2rem;
  border-bottom:1px solid var(--rule);
}
.chat-online-dot{
  display:inline-block;
  width:8px;
  height:8px;
  background:var(--success);
  border-radius:50%;
  margin-right:.4rem;
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{opacity:1}
  50%{opacity:.5}
}
.chat-rules-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.6rem;
}
.chat-rule{
  font-size:.82rem;
  line-height:1.55;
  color:var(--paper);
  padding:.5rem 0;
  display:flex;
  gap:.5rem;
  align-items:flex-start;
}
.chat-rule-icon{
  flex-shrink:0;
  font-size:.95rem;
}

.chat-main{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--rule);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.chat-main-header{
  padding:1.3rem 1.5rem;
  border-bottom:1px solid var(--rule);
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:linear-gradient(180deg, var(--cream-dark) 0%, var(--card) 100%);
}
.chat-main-header-title{
  font-family:'Anton',sans-serif;
  font-size:1.4rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:var(--paper);
  display:flex;
  align-items:center;
  gap:.6rem;
}
.chat-main-header-sub{
  font-size:.8rem;
  color:var(--muted);
  margin-top:.15rem;
}
.chat-refresh-btn{
  background:transparent;
  border:1px solid var(--rule-strong);
  color:var(--paper);
  width:40px;
  height:40px;
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .15s;
}
.chat-refresh-btn:hover{
  background:var(--blood);
  color:var(--ink);
  border-color:var(--blood);
  transform:rotate(180deg);
}
.chat-refresh-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2}

.chat-scroll{
  flex:1;
  overflow-y:auto;
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  gap:.9rem;
  background:
    linear-gradient(180deg, rgba(244,241,234,1) 0%, rgba(244,241,234,.5) 100%),
    repeating-linear-gradient(45deg, transparent, transparent 20px, rgba(124,92,255,.02) 20px, rgba(124,92,255,.02) 40px);
}

.chat-day-separator{
  display:flex;
  align-items:center;
  gap:1rem;
  margin:1rem 0 .5rem;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--muted);
}
.chat-day-separator::before,
.chat-day-separator::after{
  content:"";
  flex:1;
  height:1px;
  background:var(--rule);
}

.chat-empty-pro{
  margin:auto;
  text-align:center;
  padding:3rem 1.5rem;
  max-width:400px;
}
.chat-empty-emoji{
  font-size:4rem;
  margin-bottom:1rem;
  display:inline-block;
  animation:bounce 2s infinite;
}
@keyframes bounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.chat-empty-title-pro{
  font-family:'Anton',sans-serif;
  font-size:2rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:var(--paper);
  margin-bottom:.5rem;
}
.chat-empty-title-pro em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--blood);
  text-transform:lowercase;
}
.chat-empty-desc{
  color:var(--muted);
  line-height:1.6;
}

.msg{
  display:flex;
  gap:.8rem;
  max-width:75%;
  align-items:flex-start;
  animation:slideUp .3s ease-out;
}
@keyframes slideUp{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.msg.mine{
  align-self:flex-end;
  flex-direction:row-reverse;
}

.msg-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--blood) 0%, var(--blood-deep) 100%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.8rem;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(124,92,255,.25);
  border:2px solid var(--card);
}
.msg.mine .msg-avatar{
  background:linear-gradient(135deg, var(--acid) 0%, #e6f23a 100%);
  color:var(--paper);
}
.msg.admin .msg-avatar{
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 100%);
  color:var(--acid);
  border:2px solid var(--acid);
  box-shadow:0 2px 8px rgba(243,255,61,.35);
}

.msg-content{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:.25rem;
}

.msg-meta{
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.72rem;
  padding:0 .3rem;
}
.msg.mine .msg-meta{flex-direction:row-reverse}

.msg-author{
  font-family:'Archivo Black',sans-serif;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--blood);
}
.msg.admin .msg-author{color:var(--blood-deep)}

.msg-badge{
  background:var(--paper);
  color:var(--acid);
  padding:.15rem .45rem;
  border-radius:999px;
  font-size:.58rem;
  letter-spacing:.1em;
  font-family:'Archivo Black',sans-serif;
}

.msg-time{
  color:var(--muted);
  font-size:.7rem;
  font-weight:500;
}

.msg-bubble{
  background:var(--card);
  border:1px solid var(--rule);
  padding:.75rem 1rem;
  border-radius:16px;
  border-top-left-radius:4px;
  box-shadow:0 1px 2px rgba(26,26,36,.04);
  position:relative;
}
.msg.mine .msg-bubble{
  background:linear-gradient(135deg, var(--blood) 0%, var(--blood-deep) 100%);
  color:#fff;
  border-color:transparent;
  border-radius:16px;
  border-top-right-radius:4px;
  box-shadow:0 2px 12px rgba(124,92,255,.2);
}
.msg.admin .msg-bubble{
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--paper);
  box-shadow:0 2px 10px rgba(26,26,36,.15);
}
.msg.admin.mine .msg-bubble{
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 100%);
}

.msg-text{
  font-size:.94rem;
  line-height:1.5;
  color:var(--paper);
  white-space:pre-wrap;
  word-wrap:break-word;
  word-break:break-word;
}
.msg.mine .msg-text{color:#fff}
.msg.admin .msg-text{color:var(--ink)}
.msg.admin.mine .msg-text{color:var(--ink)}

.msg-delete{
  opacity:0;
  font-size:.7rem;
  color:var(--muted);
  background:none;
  border:none;
  padding:.2rem .4rem;
  cursor:pointer;
  font-family:inherit;
  margin-top:.2rem;
  transition:opacity .15s;
}
.msg:hover .msg-delete{opacity:.8}
.msg-delete:hover{color:#ef4444;opacity:1!important}

/* Zone de saisie premium */
.chat-input-area{
  padding:1rem 1.5rem 1.5rem;
  border-top:1px solid var(--rule);
  background:var(--card);
}
.chat-input-box{
  background:var(--cream-dark);
  border:2px solid var(--rule);
  border-radius:16px;
  padding:.5rem .5rem .5rem 1.1rem;
  display:flex;
  align-items:flex-end;
  gap:.6rem;
  transition:all .2s;
}
.chat-input-box:focus-within{
  border-color:var(--blood);
  background:var(--card);
  box-shadow:0 0 0 4px rgba(124,92,255,.08);
}
.chat-textarea{
  flex:1;
  background:transparent;
  border:none;
  resize:none;
  font-family:inherit;
  font-size:.95rem;
  color:var(--paper);
  max-height:120px;
  min-height:36px;
  padding:.5rem 0;
  outline:none;
  line-height:1.5;
}
.chat-textarea::placeholder{color:var(--muted)}
.chat-send{
  width:44px;
  height:44px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--blood) 0%, var(--blood-deep) 100%);
  color:#fff;
  border:none;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .2s;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(124,92,255,.3);
}
.chat-send:hover{
  transform:scale(1.05) rotate(-8deg);
  box-shadow:0 4px 16px rgba(124,92,255,.45);
}
.chat-send:active{transform:scale(.95)}
.chat-send:disabled{
  opacity:.4;
  cursor:not-allowed;
  transform:none;
}
.chat-send svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.5;transform:translateX(1px)}

.chat-input-hint{
  font-size:.7rem;
  color:var(--muted);
  margin-top:.6rem;
  padding:0 .5rem;
}
.chat-input-hint kbd{
  background:var(--cream-dark);
  border:1px solid var(--rule);
  padding:.1rem .35rem;
  border-radius:4px;
  font-family:inherit;
  font-size:.68rem;
  margin:0 .15rem;
}

.chat-disabled-notice{
  padding:1.2rem 1.5rem;
  background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  color:#78350f;
  text-align:center;
  font-size:.9rem;
  line-height:1.5;
  border-top:1px solid #fbbf24;
}

@media(max-width:900px){
  .chat-layout{grid-template-columns:1fr;height:auto}
  .chat-sidebar-panel{order:2;max-height:none}
  .chat-main{height:70vh;min-height:500px;order:1}
}
@media(max-width:600px){
  .msg{max-width:92%}
  .chat-scroll{padding:1rem}
  .chat-input-area{padding:.8rem 1rem 1rem}
  .chat-main{height:75vh}
}

/* ═══════════════════════════════════════════════════
   ARTICLES DE FORMATION PREMIUM
   ═══════════════════════════════════════════════════ */

.reading-progress-wrap{
  position:fixed;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:rgba(124,92,255,.1);
  z-index:9999;
}
.reading-progress{
  height:100%;
  background:linear-gradient(90deg, var(--blood) 0%, var(--blood-soft) 50%, var(--acid) 100%);
  width:0%;
  transition:width .1s;
}

/* HERO de l'article */
.article-hero{
  border-radius:20px;
  overflow:hidden;
  margin-bottom:3rem;
}
.article-hero-inner{
  padding:4rem 3rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.article-hero-inner::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg, transparent, transparent 60px, rgba(255,255,255,.04) 60px, rgba(255,255,255,.04) 120px);
  pointer-events:none;
}
.article-hero-inner > *{position:relative;z-index:2}
.article-hero-emoji{
  font-size:5rem;
  margin-bottom:1rem;
  display:inline-block;
  animation:float 3s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.article-hero-category{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  opacity:.9;
  margin-bottom:1.2rem;
}
.article-hero-title{
  font-family:'Anton',sans-serif;
  font-size:clamp(2.5rem, 5vw, 4.5rem);
  line-height:.95;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:1rem;
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
}
.article-hero-subtitle{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-size:clamp(1.2rem, 2.5vw, 1.7rem);
  line-height:1.4;
  opacity:.92;
  font-weight:400;
  max-width:700px;
  margin:0 auto 1.8rem;
}
.article-hero-meta{
  display:flex;
  gap:.6rem;
  justify-content:center;
  flex-wrap:wrap;
  font-size:.85rem;
  opacity:.85;
  font-weight:500;
}

/* LAYOUT 2 colonnes : sommaire sticky + contenu */
.article-layout{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:3rem;
  max-width:1100px;
  margin:0 auto;
  align-items:start;
}

.article-toc{
  position:sticky;
  top:2rem;
  padding:1.2rem;
  background:var(--card);
  border-radius:14px;
  border:1px solid var(--rule);
  max-height:calc(100vh - 4rem);
  overflow-y:auto;
}
.toc-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.8rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--rule);
}
.toc-item{
  display:block;
  padding:.5rem .7rem;
  font-size:.85rem;
  color:var(--paper);
  border-radius:6px;
  text-decoration:none;
  margin-bottom:.2rem;
  transition:all .15s;
  line-height:1.4;
}
.toc-item:hover{
  background:var(--blood);
  color:var(--ink);
  transform:translateX(3px);
}

/* BODY de l'article */
.article-body{
  background:var(--card);
  border-radius:20px;
  padding:3.5rem 4rem;
  border:1px solid var(--rule);
  max-width:780px;
}

.article-intro{
  font-size:1.25rem;
  line-height:1.6;
  color:var(--paper);
  font-weight:500;
  padding:1.5rem 0 2.5rem;
  margin-bottom:2.5rem;
  border-bottom:2px solid var(--rule);
  font-family:'Instrument Serif',serif;
  font-style:italic;
}

.article-section{
  margin-bottom:2.5rem;
}
.article-h2{
  font-family:'Anton',sans-serif;
  font-size:2rem;
  line-height:1.1;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin:2.5rem 0 1.2rem;
  color:var(--paper);
  padding-top:1rem;
}
.article-text{
  font-size:1.05rem;
  line-height:1.75;
  color:var(--paper);
}
.article-text br{margin-bottom:.5rem}
.article-text strong{
  font-weight:700;
  color:var(--blood);
  background:linear-gradient(180deg, transparent 65%, rgba(243,255,61,.35) 65%);
  padding:0 .15em;
}

/* CALLOUTS (encarts spéciaux) */
.article-callout{
  border-radius:14px;
  padding:1.5rem 1.8rem;
  margin:2rem 0;
  border-left:5px solid var(--blood);
  background:var(--cream-dark);
}
.callout-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:.8rem;
  color:var(--paper);
}
.article-callout > div:last-child{
  font-size:.98rem;
  line-height:1.7;
  color:var(--paper);
}

/* Warning (rouge) */
.callout-warning{
  background:#fef2f2;
  border-left-color:#ef4444;
}
.callout-warning .callout-title{color:#991b1b}

/* Tip (jaune/acide) */
.callout-tip{
  background:#fffce8;
  border-left-color:var(--acid);
}
.callout-tip .callout-title{color:#854d0e}

/* Script (violet foncé) */
.callout-script{
  background:linear-gradient(135deg, rgba(124,92,255,.08) 0%, rgba(124,92,255,.03) 100%);
  border-left-color:var(--blood);
}
.callout-script .callout-title{color:var(--blood-deep)}
.script-content{
  background:var(--paper);
  color:var(--ink);
  padding:1.2rem 1.5rem;
  border-radius:10px;
  margin-top:.8rem;
  font-family:Georgia, 'Times New Roman', serif;
  font-style:italic;
  line-height:1.7;
  font-size:1rem;
}

/* Objection (bleu) */
.callout-objection{
  background:#eff6ff;
  border-left-color:#3b82f6;
}
.callout-objection .callout-title{color:#1e40af}

/* Technique (orange) */
.callout-technique{
  background:#fff7ed;
  border-left-color:#f97316;
}
.callout-technique .callout-title{color:#9a3412}

/* À RETENIR (violet final) */
.article-takeaway{
  margin-top:3rem;
  padding:2rem 2.5rem;
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 100%);
  color:var(--ink);
  border-radius:16px;
  position:relative;
  overflow:hidden;
}
.article-takeaway::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:5px;
  background:linear-gradient(90deg, var(--blood) 0%, var(--acid) 100%);
}
.takeaway-title{
  font-family:'Anton',sans-serif;
  font-size:1.6rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:1.2rem;
  color:var(--acid);
}
.article-takeaway > div:last-child{
  font-size:1rem;
  line-height:1.8;
}
.article-takeaway strong{color:var(--acid)}

/* Navigation de fin */
.article-end-nav{
  text-align:center;
  margin-top:3rem;
  padding-top:2rem;
}

@media(max-width:900px){
  .article-layout{grid-template-columns:1fr;gap:1.5rem}
  .article-toc{position:static;max-height:none}
  .article-body{padding:2rem 1.5rem}
  .article-hero-inner{padding:2.5rem 1.5rem}
  .article-hero-emoji{font-size:3.5rem}
}

/* ═══════════════════════════════════════════════════
   TRAINING CARDS PREMIUM (page formation)
   ═══════════════════════════════════════════════════ */

.training-card-pro{
  background:var(--card);
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--rule);
  transition:all .2s;
  display:flex;
  flex-direction:column;
}
.training-card-pro:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(26,26,36,.1);
  border-color:var(--blood-soft);
}

.training-thumb-pro{
  padding:2rem 1.5rem 1.5rem;
  text-align:left;
  position:relative;
  overflow:hidden;
  min-height:180px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.training-thumb-pro::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg, transparent, transparent 40px, rgba(255,255,255,.04) 40px, rgba(255,255,255,.04) 80px);
  pointer-events:none;
}
.training-thumb-pro > *{position:relative;z-index:2}

.training-emoji{
  font-size:2.5rem;
  margin-bottom:.5rem;
}
.training-category{
  font-family:'Archivo Black',sans-serif;
  font-size:.6rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  opacity:.85;
  margin-bottom:.5rem;
}
.training-thumb-title-pro{
  font-family:'Anton',sans-serif;
  font-size:1.5rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-.01em;
}

.training-body-pro{
  padding:1.5rem;
  flex:1;
  display:flex;
  flex-direction:column;
}
.training-body-pro h3{
  font-family:'Inter Tight',sans-serif;
  font-weight:700;
  font-size:1.15rem;
  line-height:1.3;
  margin:.7rem 0 .5rem;
  color:var(--paper);
}
.training-body-pro p{
  font-size:.9rem;
  line-height:1.55;
  color:var(--muted);
  margin-bottom:1rem;
  flex:1;
}
.training-meta{
  display:flex;
  gap:.5rem;
  font-size:.78rem;
  color:var(--muted);
  margin-bottom:1rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--rule);
}
.training-btn-pro{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  background:var(--paper);
  color:var(--ink);
  padding:.8rem 1.2rem;
  border-radius:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .15s;
  align-self:flex-start;
}
.training-btn-pro:hover{
  background:var(--blood);
  color:var(--ink);
  transform:translateX(3px);
}

/* ═══════════════════════════════════════════════════
   BADGES DE NOTIFICATION
   ═══════════════════════════════════════════════════ */

.nav-badge{
  background:#ef4444;
  color:#fff;
  font-family:'Archivo Black',sans-serif;
  font-size:.65rem;
  letter-spacing:.05em;
  padding:.1rem .5rem;
  border-radius:999px;
  margin-left:auto;
  min-width:20px;
  height:20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 0 0 0 rgba(239,68,68,.6);
  animation:pulseBadge 2s infinite;
}
@keyframes pulseBadge{
  0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.6)}
  50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}
}

/* ═══════════════════════════════════════════════════
   PAGE PARRAINAGE
   ═══════════════════════════════════════════════════ */

.parrainage-hero{
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 100%);
  border-radius:20px;
  padding:3rem 3rem;
  margin-bottom:2rem;
  position:relative;
  overflow:hidden;
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
}
.parrainage-hero::before{
  content:"🎁";
  position:absolute;
  top:-30px;
  right:-10px;
  font-size:12rem;
  opacity:.08;
  pointer-events:none;
}
.parrainage-hero-content{position:relative;z-index:2;max-width:500px}

.parrainage-link-wrap{
  background:var(--card);
  border-radius:16px;
  padding:2rem;
  border:1px solid var(--rule);
}
.parrainage-link-box{
  display:flex;
  gap:.6rem;
  align-items:center;
  background:var(--cream-dark);
  padding:1rem 1.3rem;
  border-radius:12px;
  border:2px dashed var(--rule-strong);
  margin-bottom:1.2rem;
  flex-wrap:wrap;
}
.parrainage-link-text{
  flex:1;
  font-family:'Courier New', monospace;
  font-size:.92rem;
  color:var(--paper);
  word-break:break-all;
  min-width:200px;
}
.parrainage-copy-btn{
  background:var(--blood);
  color:var(--ink);
  border:none;
  padding:.7rem 1.2rem;
  border-radius:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
}
.parrainage-copy-btn:hover{
  background:var(--blood-deep);
  color:#fff;
  transform:scale(1.03);
}

.parrainage-share-buttons{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
}
.parrainage-share-btn{
  flex:1;
  min-width:130px;
  padding:.9rem 1rem;
  border-radius:10px;
  text-align:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:all .15s;
}
.parrainage-share-btn:hover{transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════
   PAGE STATS ADMIN
   ═══════════════════════════════════════════════════ */

.charts-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(400px, 1fr));
  gap:1.5rem;
  margin-bottom:1.5rem;
}
.chart-card{
  background:var(--card);
  border-radius:16px;
  padding:1.5rem;
  border:1px solid var(--rule);
}
.chart-card-title{
  font-family:'Anton',sans-serif;
  font-size:1.1rem;
  text-transform:uppercase;
  letter-spacing:-.005em;
  margin-bottom:1.2rem;
  color:var(--paper);
}

.top-row{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:.9rem 0;
  border-bottom:1px solid var(--rule);
}
.top-row:last-child{border:none}
.top-rank{
  font-family:'Archivo Black',sans-serif;
  font-size:1.1rem;
  color:var(--blood);
  min-width:40px;
}
.top-avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--blood) 0%, var(--blood-deep) 100%);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Archivo Black',sans-serif;
  font-size:.8rem;
}
.top-info{flex:1;min-width:0}
.top-name{
  font-weight:600;
  color:var(--paper);
  margin-bottom:.1rem;
}
.top-sub{
  font-size:.8rem;
  color:var(--muted);
}
.top-amount{
  font-family:'Archivo Black',sans-serif;
  font-size:1.05rem;
  color:var(--blood-deep);
}

@media(max-width:700px){
  .charts-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════
   PAGE TÂCHES ADMIN
   ═══════════════════════════════════════════════════ */

.taches-filtres{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  margin-bottom:1.5rem;
}
.filter-btn{
  background:var(--card);
  border:1.5px solid var(--rule);
  color:var(--paper);
  padding:.6rem 1rem;
  border-radius:999px;
  font-family:'Inter Tight',sans-serif;
  font-size:.85rem;
  font-weight:500;
  cursor:pointer;
  transition:all .15s;
}
.filter-btn:hover{
  border-color:var(--blood);
  color:var(--blood);
}
.filter-btn.active{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}

.tache-card{
  background:var(--card);
  border-radius:14px;
  padding:1.3rem 1.5rem;
  margin-bottom:.8rem;
  border:1px solid var(--rule);
  display:flex;
  gap:1.2rem;
  align-items:flex-start;
  transition:all .15s;
}
.tache-card:hover{
  border-color:var(--blood-soft);
  box-shadow:0 4px 16px rgba(124,92,255,.08);
}
.tache-card.priorite-urgent{
  border-left:5px solid #ef4444;
}
.tache-card.priorite-faible{
  opacity:.75;
}
.tache-card.tache-fait{
  background:#f0fdf4;
  opacity:.7;
}
.tache-card.tache-fait .tache-titre{
  text-decoration:line-through;
}

.tache-icon{
  font-size:1.8rem;
  flex-shrink:0;
  margin-top:-.2rem;
}

.tache-body{flex:1;min-width:0}

.tache-header{
  display:flex;
  align-items:center;
  gap:.7rem;
  margin-bottom:.3rem;
  flex-wrap:wrap;
}
.tache-titre{
  font-weight:600;
  font-size:1rem;
  color:var(--paper);
  line-height:1.3;
}
.tache-tag-urgent{
  background:#ef4444;
  color:#fff;
  font-family:'Archivo Black',sans-serif;
  font-size:.62rem;
  letter-spacing:.1em;
  padding:.2rem .5rem;
  border-radius:4px;
  animation:pulseBadge 2s infinite;
}
.tache-montant{
  background:var(--blood);
  color:var(--ink);
  font-family:'Archivo Black',sans-serif;
  font-size:.78rem;
  padding:.2rem .55rem;
  border-radius:4px;
  margin-left:.4rem;
}

.tache-description{
  color:var(--muted);
  font-size:.9rem;
  line-height:1.5;
  margin-bottom:.6rem;
}

.tache-meta{
  display:flex;
  gap:1rem;
  font-size:.75rem;
  color:var(--muted);
  margin-bottom:.8rem;
  flex-wrap:wrap;
}
.tache-echeance{
  color:#f59e0b;
  font-weight:500;
}
.tache-notes-fait{
  color:var(--success);
  font-style:italic;
}

.tache-actions-row{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  align-items:center;
  padding-top:.7rem;
  border-top:1px solid var(--rule);
}
.tache-assignee-select,
.tache-priorite-select{
  background:var(--cream-dark);
  border:1px solid var(--rule);
  border-radius:8px;
  padding:.4rem .7rem;
  font-size:.8rem;
  color:var(--paper);
  cursor:pointer;
}
.tache-action-btn{
  background:var(--cream-dark);
  border:1px solid var(--rule);
  color:var(--paper);
  padding:.45rem .9rem;
  border-radius:8px;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  transition:all .15s;
}
.tache-action-btn:hover{
  background:var(--paper);
  color:var(--ink);
}
.tache-action-btn.primary{
  background:var(--success);
  color:#fff;
  border-color:var(--success);
}
.tache-action-btn.primary:hover{
  background:#16a34a;
  border-color:#16a34a;
}

/* ═══════════════════════════════════════════════════
   BLOC PROGRESSION NIVEAU
   ═══════════════════════════════════════════════════ */

.niveau-progress-card{
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 100%);
  color:var(--ink);
  border-radius:16px;
  padding:1.8rem 2rem;
  position:relative;
  overflow:hidden;
}
.niveau-progress-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg, transparent, transparent 30px, rgba(124,92,255,.08) 30px, rgba(124,92,255,.08) 60px);
  pointer-events:none;
}
.niveau-progress-card > *{position:relative;z-index:2}

.niveau-card-header{
  display:flex;
  align-items:center;
  gap:1.2rem;
  margin-bottom:1.2rem;
}
.niveau-emoji{
  font-size:3rem;
  line-height:1;
  filter:drop-shadow(0 4px 12px rgba(124,92,255,.4));
}
.niveau-next-emoji{
  font-size:2rem;
  opacity:.4;
  margin-left:auto;
}
.niveau-card-title{flex:1;min-width:0}
.niveau-card-label{
  font-family:'Anton',sans-serif;
  font-size:1.5rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:var(--acid);
  line-height:1.1;
  margin-bottom:.3rem;
}
.niveau-card-sub{
  font-size:.85rem;
  color:rgba(244,241,234,.7);
}

.niveau-progress-bar-wrap{
  position:relative;
  background:rgba(244,241,234,.08);
  border-radius:999px;
  height:14px;
  overflow:hidden;
  margin-bottom:.8rem;
}
.niveau-progress-bar{
  height:100%;
  background:linear-gradient(90deg, var(--blood) 0%, var(--blood-soft) 50%, var(--acid) 100%);
  border-radius:999px;
  transition:width 1s cubic-bezier(.4,0,.2,1);
  box-shadow:0 0 12px rgba(124,92,255,.5);
}
.niveau-progress-text{
  position:absolute;
  right:.7rem;
  top:50%;
  transform:translateY(-50%);
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.05em;
  color:var(--ink);
  text-shadow:0 1px 2px rgba(0,0,0,.3);
}

.niveau-progress-message{
  font-size:.92rem;
  color:rgba(244,241,234,.9);
  line-height:1.4;
}
.niveau-progress-message strong{
  color:var(--acid);
  font-weight:700;
}

/* ═══════════════════════════════════════════════════
   FORMATION PREMIUM (page cadeaux)
   ═══════════════════════════════════════════════════ */

.formation-premium-card{
  background:linear-gradient(135deg, var(--paper) 0%, #2a2a38 60%, #1a1a24 100%);
  color:var(--ink);
  border-radius:24px;
  overflow:hidden;
  position:relative;
  margin-bottom:2.5rem;
  box-shadow:0 20px 60px rgba(124,92,255,.25);
  border:1px solid rgba(243,255,61,.2);
}

.formation-premium-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:6px;
  background:linear-gradient(90deg, var(--blood) 0%, var(--blood-soft) 33%, var(--acid) 66%, var(--blood) 100%);
  background-size:200% 100%;
  animation:premiumShine 4s linear infinite;
}
@keyframes premiumShine{
  0%{background-position:0% 0%}
  100%{background-position:200% 0%}
}

.formation-premium-card::after{
  content:"⚡";
  position:absolute;
  top:-30px;
  right:-30px;
  font-size:14rem;
  opacity:.05;
  pointer-events:none;
}

.formation-premium-header{
  padding:3rem 3rem 2rem;
  text-align:center;
  position:relative;
  z-index:2;
}

.formation-premium-tag{
  display:inline-block;
  background:var(--acid);
  color:var(--paper);
  padding:.5rem 1.2rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.75rem;
  letter-spacing:.18em;
  margin-bottom:1.5rem;
  box-shadow:0 0 24px rgba(243,255,61,.4);
}

.formation-premium-title{
  font-family:'Anton',sans-serif;
  font-size:clamp(2.5rem, 5vw, 4rem);
  line-height:.95;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:1.2rem;
  color:#fff;
}
.formation-premium-title em{
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-weight:400;
  color:var(--acid);
  text-transform:lowercase;
}

.formation-premium-subtitle{
  font-size:1.1rem;
  line-height:1.6;
  color:rgba(244,241,234,.85);
  max-width:60ch;
  margin:0 auto;
}
.formation-premium-subtitle strong{
  color:var(--acid);
  font-weight:700;
}

.formation-premium-content{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:0;
  background:rgba(244,241,234,.03);
  border-top:1px solid rgba(244,241,234,.1);
  position:relative;
  z-index:2;
}

.formation-premium-features{
  padding:2.5rem 3rem;
  display:flex;
  flex-direction:column;
  gap:1.5rem;
  border-right:1px solid rgba(244,241,234,.08);
}

.formation-feature{
  display:flex;
  gap:1rem;
  align-items:flex-start;
}
.formation-feature-icon{
  font-size:1.8rem;
  flex-shrink:0;
  width:50px;
  height:50px;
  background:rgba(124,92,255,.15);
  border:1px solid rgba(124,92,255,.3);
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.formation-feature-title{
  font-family:'Archivo Black',sans-serif;
  font-size:.95rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:#fff;
  margin-bottom:.3rem;
  line-height:1.2;
}
.formation-feature-desc{
  font-size:.92rem;
  line-height:1.5;
  color:rgba(244,241,234,.7);
}
.formation-feature-desc strong{
  color:var(--acid);
  font-weight:600;
}

.formation-premium-cta-block{
  padding:2.5rem 2.5rem;
  background:linear-gradient(180deg, rgba(124,92,255,.12) 0%, rgba(124,92,255,.04) 100%);
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
  position:relative;
}

.formation-premium-price-label{
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(244,241,234,.6);
  margin-bottom:.3rem;
}

.formation-premium-price{
  font-family:'Anton',sans-serif;
  font-size:5.5rem;
  line-height:1;
  letter-spacing:-.03em;
  color:var(--acid);
  margin-bottom:.8rem;
  text-shadow:0 0 30px rgba(243,255,61,.3);
}
.formation-premium-price span{
  font-size:2.5rem;
  vertical-align:super;
  margin-left:.2rem;
  color:#fff;
  text-shadow:none;
}

.formation-premium-roi{
  font-size:.88rem;
  line-height:1.5;
  color:rgba(244,241,234,.85);
  margin-bottom:1.5rem;
  padding:.8rem 1rem;
  background:rgba(243,255,61,.08);
  border-radius:10px;
  border-left:3px solid var(--acid);
  text-align:left;
}
.formation-premium-roi strong{color:var(--acid)}

.formation-premium-btn{
  display:block;
  background:#25D366;
  color:#fff;
  padding:1.2rem 2rem;
  border-radius:14px;
  font-family:'Archivo Black',sans-serif;
  font-size:1rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  text-decoration:none;
  text-align:center;
  transition:all .2s;
  box-shadow:0 8px 24px rgba(37,211,102,.35);
}
.formation-premium-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(37,211,102,.5);
  background:#1ebd5a;
}

.formation-premium-guarantee{
  font-size:.75rem;
  color:rgba(244,241,234,.6);
  margin-top:1rem;
  line-height:1.5;
}

@media(max-width:850px){
  .formation-premium-header{padding:2rem 1.5rem 1.5rem}
  .formation-premium-content{grid-template-columns:1fr}
  .formation-premium-features{
    padding:2rem 1.5rem;
    border-right:none;
    border-bottom:1px solid rgba(244,241,234,.08);
  }
  .formation-premium-cta-block{padding:2rem 1.5rem}
  .formation-premium-price{font-size:4rem}
  .formation-premium-price span{font-size:2rem}
}

/* ═══════════════════════════════════════════════════
   FORMATION PREMIUM — PRIX BARRÉ & PROMO
   ═══════════════════════════════════════════════════ */

.formation-premium-promo-tag{
  display:inline-block;
  background:#ef4444;
  color:#fff;
  padding:.4rem 1rem;
  border-radius:999px;
  font-family:'Archivo Black',sans-serif;
  font-size:.7rem;
  letter-spacing:.15em;
  margin-bottom:1.2rem;
  box-shadow:0 0 20px rgba(239,68,68,.4);
  animation:pulsePromo 2s infinite;
}
@keyframes pulsePromo{
  0%, 100%{transform:scale(1)}
  50%{transform:scale(1.05)}
}

.formation-premium-price-old{
  font-family:'Anton',sans-serif;
  font-size:2rem;
  color:rgba(244,241,234,.5);
  text-decoration:line-through;
  text-decoration-color:#ef4444;
  text-decoration-thickness:3px;
  margin-bottom:.2rem;
  line-height:1;
}
