/* ══════════════════════════════════════════════════════════
   LAG974 — Design System · Noir & Doré
   ══════════════════════════════════════════════════════════ */

/* ── FONTS ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Orbitron:wght@400;700;900&family=Crimson+Pro:ital,wght@0,300;0,400;1,300&display=swap');

/* ── TOKENS ────────────────────────────────────────────── */
:root {
  --gold:        #D4AC52;
  --gold-light:  #F0D070;
  --gold-dark:   #8B6E20;
  --gold-dim:    rgba(212,172,82,.13);
  --gold-border: rgba(212,172,82,.32);
  --gold-glow:   rgba(212,172,82,.45);
  --black:       #080809;
  --black-2:     #0F0F12;
  --black-3:     #161619;
  --black-4:     #1E1E24;
  --black-5:     #27272F;
  --white:       #F0EDE5;
  --white-60:    rgba(240,237,229,.6);
  --white-30:    rgba(240,237,229,.3);
  --white-10:    rgba(240,237,229,.1);
  --red:         #C93B3B;
  --green:       #2DAF6F;
  --blue:        #3B7CC9;
  --sidebar-w:   256px;
  --topbar-h:    60px;
}

/* ── RESET ─────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Rajdhani',sans-serif; background:var(--black); color:var(--white); min-height:100vh; overflow-x:hidden; }
::selection { background:var(--gold-dim); color:var(--gold); }
a { text-decoration:none; color:inherit; }
button { font-family:'Rajdhani',sans-serif; cursor:pointer; border:none; background:none; }
input,select,textarea { font-family:'Rajdhani',sans-serif; }
img { max-width:100%; }

/* ── SCROLLBAR ─────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--black-2); }
::-webkit-scrollbar-thumb { background:var(--gold-dark); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--gold); }

/* ══════════════════════════════════════════════════════════
   UTILITIES
   ══════════════════════════════════════════════════════════ */
.glitch { animation: glitch 9s infinite; }
@keyframes glitch {
  0%,88%,100% { text-shadow:0 0 18px var(--gold-glow); }
  90% { text-shadow:-2px 0 rgba(201,59,59,.8),2px 0 rgba(59,124,201,.8),0 0 18px var(--gold-glow); transform:translate(1px,0); }
  92% { text-shadow:2px 0 rgba(201,59,59,.8),-2px 0 rgba(59,124,201,.8),0 0 18px var(--gold-glow); transform:translate(-1px,0); }
  94% { text-shadow:0 0 18px var(--gold-glow); transform:none; }
}
.fade-in { animation:fadeIn .5s ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:none} }

.section-chip { display:inline-block; font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); border:1px solid var(--gold-border); padding:4px 14px; border-radius:2px; margin-bottom:16px; font-weight:600; }
.gold-line { width:48px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); margin-bottom:20px; }
.section-title-xl { font-family:'Orbitron',monospace; font-size:clamp(24px,4vw,42px); font-weight:900; line-height:1.1; color:var(--white); margin-bottom:14px; }
.section-title-xl span { color:var(--gold); }
.section-body { font-family:'Crimson Pro',serif; font-size:18px; font-weight:300; color:var(--white-60); line-height:1.75; max-width:540px; }

/* ── BUTTONS ──────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:10px 22px; border-radius:4px; font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; transition:all .22s; cursor:pointer; }
.btn-gold { background:linear-gradient(135deg,var(--gold-dark),var(--gold)); color:var(--black); border:none; }
.btn-gold:hover { box-shadow:0 0 22px rgba(201,168,76,.4); filter:brightness(1.08); }
.btn-outline { border:1px solid var(--gold-border); color:var(--white-60); background:transparent; }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-red { background:var(--red); color:var(--white); border:none; }
.btn-red:hover { filter:brightness(1.1); }
.btn-sm { padding:6px 14px; font-size:10px; letter-spacing:1.5px; }
.btn-green { background:var(--green); color:var(--white); border:none; }
.btn-green:hover { filter:brightness(1.1); }

/* ── FORMS ────────────────────────────────────────────── */
.form-field { margin-bottom:16px; }
.form-label { display:block; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); margin-bottom:6px; font-weight:700; }
.form-input { width:100%; padding:10px 13px; background:var(--black-4); border:1px solid var(--gold-border); border-radius:6px; color:var(--white); font-size:13px; outline:none; transition:border-color .2s; }
.form-input:focus { border-color:var(--gold); }
.form-input::placeholder { color:var(--white-30); }
select.form-input { appearance:none; cursor:pointer; }
textarea.form-input { resize:vertical; min-height:100px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-error { color:var(--red); font-size:12px; margin-top:4px; }

/* ── FLASH MESSAGES ───────────────────────────────────── */
.flash { padding:12px 20px; border-radius:6px; font-size:13px; margin-bottom:20px; border:1px solid; letter-spacing:.3px; }
.flash-success { background:rgba(45,175,111,.1); border-color:rgba(45,175,111,.3); color:var(--green); }
.flash-error   { background:rgba(201,59,59,.1);  border-color:rgba(201,59,59,.3);  color:var(--red); }

/* ── BADGES ───────────────────────────────────────────── */
.badge { font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; padding:3px 9px; border-radius:3px; }
.badge-draft    { background:rgba(201,168,76,.12); color:var(--gold); }
.badge-pending  { background:rgba(59,124,201,.12); color:#5BA3F5; }
.badge-approved   { background:rgba(45,175,111,.12);  color:var(--green); }
.badge-scheduled  { background:rgba(232,160,96,.12);  color:#E8A060; }
.badge-income   { background:rgba(45,175,111,.12); color:var(--green); }
.badge-expense  { background:rgba(201,59,59,.12);  color:var(--red); }
.badge-validated{ background:rgba(45,175,111,.12); color:var(--green); }
.badge-rejected { background:rgba(201,59,59,.12);  color:var(--red); }

/* ── PRIORITY ─────────────────────────────────────────── */
.prio { font-size:8px; font-weight:700; letter-spacing:1px; padding:2px 7px; border-radius:3px; text-transform:uppercase; }
.prio-high   { background:rgba(201,59,59,.18);   color:#E06060; }
.prio-medium { background:rgba(201,168,76,.18);  color:var(--gold); }
.prio-low    { background:rgba(45,175,111,.15);  color:var(--green); }

/* ══════════════════════════════════════════════════════════
   PUBLIC LAYOUT — NAVBAR
   ══════════════════════════════════════════════════════════ */
.pub-nav { position:fixed; top:0; left:0; right:0; z-index:500; height:70px; padding:0 5vw; display:flex; align-items:center; justify-content:space-between; background:rgba(8,8,9,.9); border-bottom:1px solid rgba(201,168,76,.12); backdrop-filter:blur(14px); transition:background .3s; }
.pub-nav-logo img { height:44px; width:auto; }
.pub-nav-links { display:flex; align-items:center; gap:28px; }
.pub-nav-links a { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--white-60); font-weight:600; transition:color .2s; position:relative; }
.pub-nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transition:transform .2s; }
.pub-nav-links a:hover, .pub-nav-links a.active { color:var(--gold); }
.pub-nav-links a:hover::after, .pub-nav-links a.active::after { transform:scaleX(1); }
.pub-nav-cta { display:flex; align-items:center; gap:10px; }
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--white-60); transition:all .3s; }

/* ── PUBLIC SECTIONS ──────────────────────────────────── */
.pub-section { padding:100px 5vw; position:relative; }
.pub-section-alt { background:var(--black-2); }
.section-inner { max-width:1160px; margin:0 auto; }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }

/* ── HERO ─────────────────────────────────────────────── */
.pub-hero { min-height:100vh; display:flex; align-items:center; position:relative; overflow:hidden; padding:0 5vw; }
.hero-grid-bg { position:absolute; inset:0; background-image:linear-gradient(rgba(201,168,76,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.04) 1px,transparent 1px); background-size:60px 60px; mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%); pointer-events:none; }
.hero-glow { position:absolute; top:50%; left:45%; transform:translate(-50%,-50%); width:600px; height:600px; background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%); pointer-events:none; }
.hero-scanline { position:absolute; inset:0; background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.07) 3px,rgba(0,0,0,.07) 4px); pointer-events:none; opacity:.4; }
.hero-content { position:relative; z-index:2; max-width:700px; padding-top:80px; }
.hero-eyebrow { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:22px; display:flex; align-items:center; gap:12px; }
.hero-eyebrow::before { content:''; display:block; width:28px; height:1px; background:var(--gold); }
.hero-logo { height:90px; width:auto; margin-bottom:20px; filter:drop-shadow(0 0 20px rgba(201,168,76,.35)); }
.hero-sub { font-family:'Orbitron',monospace; font-size:clamp(12px,1.8vw,17px); font-weight:400; color:var(--white-60); letter-spacing:4px; margin-bottom:14px; }
.hero-desc { font-family:'Crimson Pro',serif; font-size:19px; font-weight:300; color:var(--white-60); line-height:1.7; margin-bottom:36px; max-width:480px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.hero-stats { display:flex; gap:36px; margin-top:50px; padding-top:28px; border-top:1px solid var(--gold-border); flex-wrap:wrap; }
.hero-stat-val { font-family:'Orbitron',monospace; font-size:26px; font-weight:900; color:var(--gold); }
.hero-stat-lbl { font-size:10px; letter-spacing:2px; color:var(--white-30); text-transform:uppercase; margin-top:3px; }
.hero-cards { position:absolute; right:5vw; top:50%; transform:translateY(-50%); display:flex; flex-direction:column; gap:14px; z-index:2; }
.hero-float-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:14px 18px; min-width:200px; animation:float 4s ease-in-out infinite; }
.hero-float-card:nth-child(2){animation-delay:1.5s;animation-duration:4.5s}
.hero-float-card:nth-child(3){animation-delay:3s;animation-duration:5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hfc-label { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); margin-bottom:6px; }
.hfc-val { font-family:'Orbitron',monospace; font-size:16px; font-weight:700; color:var(--gold); }
.hfc-sub { font-size:11px; color:var(--white-60); margin-top:3px; }

/* ── VALUE / TEAM / PROJECT CARDS ─────────────────────── */
.cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:40px; }
.cards-grid-2 { grid-template-columns:repeat(2,1fr); }
.v-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:26px; position:relative; overflow:hidden; transition:border-color .2s,transform .2s; }
.v-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.v-card:hover { border-color:var(--gold); transform:translateY(-4px); }
.v-card-icon { font-size:26px; margin-bottom:12px; }
.v-card-title { font-size:13px; font-weight:700; letter-spacing:1px; color:var(--white); margin-bottom:8px; text-transform:uppercase; }
.v-card-text { font-family:'Crimson Pro',serif; font-size:15px; font-weight:300; color:var(--white-60); line-height:1.6; }

.team-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:22px; text-align:center; transition:border-color .2s; }
.team-card:hover { border-color:var(--gold); }
.team-avatar { width:64px; height:64px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Orbitron',monospace; font-size:18px; font-weight:700; color:var(--black); margin:0 auto 12px; border:2px solid var(--gold-border); }
.team-name { font-size:14px; font-weight:600; color:var(--white); margin-bottom:3px; }
.team-role { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); }

/* ── TIMELINE ─────────────────────────────────────────── */
.timeline { position:relative; padding-left:28px; margin-top:32px; }
.timeline::before { content:''; position:absolute; left:0; top:0; bottom:0; width:1px; background:var(--gold-border); }
.tl-item { position:relative; padding-bottom:28px; }
.tl-dot { position:absolute; left:-32px; top:4px; width:9px; height:9px; border-radius:50%; background:var(--gold); border:2px solid var(--black-2); }
.tl-year { font-family:'Orbitron',monospace; font-size:11px; font-weight:700; color:var(--gold); margin-bottom:5px; letter-spacing:2px; }
.tl-title { font-size:14px; font-weight:600; color:var(--white); margin-bottom:4px; }
.tl-text { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.5; }

/* ── PROJECT CARDS ────────────────────────────────────── */
.project-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; overflow:hidden; transition:border-color .25s,transform .25s; display:flex; flex-direction:column; }
.project-card:hover { border-color:var(--gold); transform:translateY(-5px); }
.pc-header { padding:22px 22px 0; display:flex; justify-content:space-between; align-items:flex-start; }
.pc-icon { width:48px; height:48px; border-radius:10px; background:var(--gold-dim); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; font-size:20px; }
.pc-status { font-size:9px; letter-spacing:1.5px; text-transform:uppercase; font-weight:700; padding:3px 9px; border-radius:3px; }
.pc-status-active   { background:rgba(45,175,111,.15); color:var(--green); }
.pc-status-upcoming { background:rgba(201,168,76,.15);  color:var(--gold); }
.pc-status-done     { background:rgba(59,124,201,.15);  color:#5BA3F5; }
.pc-body { padding:18px 22px; flex:1; }
.pc-title { font-size:15px; font-weight:700; color:var(--white); margin-bottom:7px; }
.pc-desc { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.6; margin-bottom:14px; }
.pc-tags { display:flex; flex-wrap:wrap; gap:5px; }
.pc-tag { font-size:8px; letter-spacing:1px; text-transform:uppercase; padding:2px 8px; border:1px solid var(--gold-border); border-radius:2px; color:var(--white-60); }
.pc-footer { padding:14px 22px; border-top:1px solid rgba(201,168,76,.07); display:flex; justify-content:space-between; align-items:center; }
.pc-date { font-size:10px; color:var(--white-30); letter-spacing:1px; }

.featured-project { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:36px; display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; margin-bottom:18px; transition:border-color .25s; }
.featured-project:hover { border-color:var(--gold); }
.fp-eyebrow { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.fp-title { font-family:'Orbitron',monospace; font-size:clamp(18px,2.5vw,28px); font-weight:900; color:var(--white); margin-bottom:12px; line-height:1.2; }
.fp-desc { font-family:'Crimson Pro',serif; font-size:16px; font-weight:300; color:var(--white-60); line-height:1.7; margin-bottom:20px; }
.fp-stats { display:flex; gap:28px; }
.fp-stat-val { font-family:'Orbitron',monospace; font-size:20px; font-weight:900; color:var(--gold); }
.fp-stat-lbl { font-size:9px; letter-spacing:2px; color:var(--white-30); text-transform:uppercase; }
.fp-visual { background:var(--black-4); border:1px solid var(--gold-border); border-radius:10px; padding:24px; min-height:180px; display:flex; align-items:center; justify-content:center; }
.bracket-team { background:var(--black-5); border:1px solid var(--gold-border); border-radius:4px; padding:5px 10px; font-size:10px; letter-spacing:1px; color:var(--white-60); flex:1; text-align:center; }
.bracket-team.winner { border-color:var(--gold); color:var(--gold); }

/* ── AWARENESS ────────────────────────────────────────── */
.awareness-hero { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:40px; margin-bottom:40px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.aw-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:24px; transition:border-color .2s,transform .2s; }
.aw-card:hover { border-color:var(--gold); transform:translateY(-3px); }
.aw-number { font-family:'Orbitron',monospace; font-size:32px; font-weight:900; color:var(--gold); opacity:.3; margin-bottom:8px; line-height:1; }
.aw-title { font-size:13px; font-weight:700; letter-spacing:1px; color:var(--white); margin-bottom:7px; text-transform:uppercase; }
.aw-text { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.6; }
.tips-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:40px; }
.tip-item { display:flex; gap:12px; align-items:flex-start; background:var(--black-3); border:1px solid rgba(201,168,76,.1); border-radius:8px; padding:16px; }
.tip-num { font-family:'Orbitron',monospace; font-size:10px; font-weight:900; color:var(--gold); opacity:.7; flex-shrink:0; padding-top:1px; }
.tip-text { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.5; }
.awareness-cta { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:40px; margin-top:40px; text-align:center; }

/* ── CONTACT ──────────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:40px; }
.contact-info-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:28px; }
.ci-item { display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-bottom:1px solid rgba(201,168,76,.07); }
.ci-item:last-child { border-bottom:none; }
.ci-icon { width:38px; height:38px; border-radius:8px; background:var(--gold-dim); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.ci-label { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); margin-bottom:3px; }
.ci-value { font-size:13px; color:var(--white-60); }
.social-links { display:flex; gap:10px; margin-top:16px; }
.social-btn { width:38px; height:38px; border-radius:8px; background:var(--black-4); border:1px solid var(--gold-border); display:flex; align-items:center; justify-content:center; font-size:15px; transition:border-color .2s,background .2s; cursor:pointer; }
.social-btn:hover { border-color:var(--gold); background:var(--gold-dim); }
.contact-form-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:32px; }
.adhesion-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:12px; padding:36px; margin-top:18px; display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start; }
.step-num { font-family:'Orbitron',monospace; font-size:10px; font-weight:900; color:var(--black); background:var(--gold); width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.step-text { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.5; padding-top:2px; }

/* ── FOOTER ───────────────────────────────────────────── */
.pub-footer { background:var(--black-2); border-top:1px solid var(--gold-border); padding:44px 5vw 22px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr; gap:44px; margin-bottom:36px; }
.footer-brand-logo img { height:40px; width:auto; margin-bottom:10px; }
.footer-brand-text { font-family:'Crimson Pro',serif; font-size:14px; font-weight:300; color:var(--white-60); line-height:1.6; max-width:300px; }
.footer-col-title { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; font-weight:700; }
.footer-links { display:flex; flex-direction:column; gap:7px; }
.footer-links a { font-size:12px; color:var(--white-60); transition:color .2s; letter-spacing:.3px; }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:20px; border-top:1px solid rgba(201,168,76,.07); }
.footer-copy, .footer-flag { font-size:11px; color:var(--white-30); letter-spacing:1px; }

/* ══════════════════════════════════════════════════════════
   PRIVATE APP — SIDEBAR
   ══════════════════════════════════════════════════════════ */
.app-wrap { display:flex; min-height:100vh; }
.sidebar { width:var(--sidebar-w); min-height:100vh; background:var(--black-2); border-right:1px solid var(--gold-border); display:flex; flex-direction:column; position:fixed; left:0; top:0; bottom:0; z-index:100; transition:transform .3s; }
.sb-logo { padding:22px 18px 18px; border-bottom:1px solid var(--gold-border); }
.sb-logo-img { height:38px; width:auto; filter:drop-shadow(0 0 10px rgba(201,168,76,.3)); }
.sb-logo-sub { font-size:8px; letter-spacing:3px; text-transform:uppercase; color:var(--white-30); margin-top:4px; }
.sb-user { padding:14px 16px; border-bottom:1px solid rgba(201,168,76,.07); display:flex; align-items:center; gap:10px; }
.sb-avatar { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Orbitron',monospace; font-size:11px; font-weight:700; color:var(--black); flex-shrink:0; border:1px solid var(--gold-border); }
.sb-user-name { font-size:12px; font-weight:600; color:var(--white); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-user-role { font-size:9px; letter-spacing:1px; color:var(--gold); text-transform:uppercase; }
.sb-nav { flex:1; padding:8px 0; overflow-y:auto; }
.sb-section { font-size:7px; letter-spacing:3px; text-transform:uppercase; color:var(--white-30); padding:14px 16px 4px; font-weight:700; }
.sb-item { display:flex; align-items:center; gap:9px; padding:9px 16px; cursor:pointer; transition:all .2s; border-left:2px solid transparent; font-size:12px; font-weight:600; letter-spacing:.5px; color:var(--white-60); text-decoration:none; }
.sb-item:hover { color:var(--white); background:var(--gold-dim); }
.sb-item.active { color:var(--gold); border-left-color:var(--gold); background:var(--gold-dim); }
.sb-icon { font-size:13px; width:16px; text-align:center; flex-shrink:0; }
.sb-badge { margin-left:auto; background:var(--gold); color:var(--black); font-size:8px; font-weight:700; padding:2px 6px; border-radius:8px; font-family:'Orbitron',monospace; }
.sb-bottom { padding:12px 16px; border-top:1px solid var(--gold-border); }
.sb-site-link { display:block; text-align:center; padding:6px; margin-bottom:7px; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); border:1px solid rgba(201,168,76,.1); border-radius:4px; transition:all .2s; }
.sb-site-link:hover { color:var(--gold); border-color:var(--gold-border); }
.sb-logout { width:100%; padding:7px; background:transparent; border:1px solid rgba(201,168,76,.2); border-radius:4px; color:var(--white-60); font-size:10px; letter-spacing:2px; text-transform:uppercase; font-weight:600; transition:all .2s; }
.sb-logout:hover { border-color:var(--gold); color:var(--gold); }

/* ── TOPBAR ───────────────────────────────────────────── */
.app-main { margin-left:var(--sidebar-w); flex:1; display:flex; flex-direction:column; min-height:100vh; }
.topbar { height:var(--topbar-h); background:var(--black-2); border-bottom:1px solid var(--gold-border); display:flex; align-items:center; padding:0 22px; gap:12px; position:sticky; top:0; z-index:50; }
.topbar-title { font-size:14px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--white); flex:1; }
.icon-btn { width:32px; height:32px; background:var(--black-3); border:1px solid var(--gold-border); border-radius:6px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s; font-size:13px; position:relative; text-decoration:none; }
.icon-btn:hover { border-color:var(--gold); background:var(--gold-dim); }
.notif-dot { width:7px; height:7px; background:var(--gold); border-radius:50%; position:absolute; top:5px; right:5px; border:1px solid var(--black-2); }

/* ── PAGE ─────────────────────────────────────────────── */
.page-content { padding:22px; flex:1; }
.page-header { margin-bottom:20px; }
.page-header h1 { font-family:'Rajdhani',sans-serif; font-size:18px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:2px; }
.page-header p { font-size:12px; color:var(--white-60); }
.page-actions { display:flex; align-items:center; gap:10px; margin-bottom:18px; flex-wrap:wrap; }

/* ── STATS CARDS ──────────────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:22px; }
.stat-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:16px; position:relative; overflow:hidden; transition:border-color .2s; }
.stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.stat-card:hover { border-color:var(--gold); }
.sc-label { font-size:8px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); margin-bottom:7px; font-weight:700; }
.sc-val { font-family:'Orbitron',monospace; font-size:24px; font-weight:900; color:var(--gold); }
.sc-sub { font-size:10px; color:var(--white-30); margin-top:4px; }
.sc-icon { position:absolute; right:13px; top:13px; font-size:18px; opacity:.15; }

/* ── DASH CARDS ───────────────────────────────────────── */
.dash-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.dash-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; overflow:hidden; }
.dash-card-hdr { padding:12px 16px; border-bottom:1px solid rgba(201,168,76,.07); display:flex; align-items:center; justify-content:space-between; }
.dash-card-title { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:700; }
.dash-card-body { padding:12px 16px; }
.act-item { display:flex; gap:9px; align-items:flex-start; padding:8px 0; border-bottom:1px solid rgba(201,168,76,.04); }
.act-item:last-child { border-bottom:none; }
.act-dot { width:6px; height:6px; border-radius:50%; margin-top:4px; flex-shrink:0; }
.act-text { font-size:11px; color:var(--white-60); line-height:1.5; }
.act-text strong { color:var(--white); }
.act-time { font-size:10px; color:var(--white-30); margin-top:1px; }
.bud-bar { margin-bottom:10px; }
.bud-bar-lbl { display:flex; justify-content:space-between; font-size:10px; margin-bottom:3px; color:var(--white-60); }
.bud-bar-lbl span:last-child { color:var(--gold); font-family:'Orbitron',monospace; font-size:10px; }
.bud-bar-track { height:4px; background:var(--black-5); border-radius:3px; overflow:hidden; }
.bud-bar-fill { height:100%; border-radius:3px; background:linear-gradient(90deg,var(--gold-dark),var(--gold)); }
.bud-bar-fill-red { background:linear-gradient(90deg,#5A1A1A,#C93B3B); }

/* ── TABLES ───────────────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; }
.data-table th { font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); padding:10px 14px; text-align:left; border-bottom:1px solid var(--gold-border); font-weight:700; }
.data-table td { padding:12px 14px; font-size:12px; color:var(--white-60); border-bottom:1px solid rgba(201,168,76,.05); vertical-align:middle; }
.data-table tr:hover td { background:var(--black-4); }
.data-table tr:last-child td { border-bottom:none; }
.table-wrap { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; overflow:hidden; }

/* ── KANBAN ───────────────────────────────────────────── */
.kanban-board { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; align-items:start; }
.kb-col { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; overflow:hidden; min-height:200px; }
.kb-col-hdr { padding:12px 13px; border-bottom:1px solid rgba(201,168,76,.07); display:flex; align-items:center; justify-content:space-between; }
.kb-col-title { font-size:9px; letter-spacing:2px; text-transform:uppercase; font-weight:700; }
.kb-count { background:var(--black-5); color:var(--white-30); font-size:9px; padding:2px 6px; border-radius:8px; font-family:'Orbitron',monospace; }
.kb-body { padding:9px; display:flex; flex-direction:column; gap:7px; }
.kb-body.drag-over { background:var(--gold-dim); border-radius:6px; }
.kb-card { background:var(--black-4); border:1px solid rgba(201,168,76,.1); border-radius:7px; padding:10px; cursor:grab; transition:border-color .2s,transform .15s; user-select:none; }
.kb-card:hover { border-color:var(--gold-border); transform:translateY(-1px); }
.kb-card.dragging { opacity:.45; cursor:grabbing; transform:scale(.97); }
.kb-card-title { font-size:11px; font-weight:600; color:var(--white); margin-bottom:7px; line-height:1.4; }
.kb-card-footer { display:flex; align-items:center; justify-content:space-between; }
.kb-avatar { width:19px; height:19px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:7px; font-weight:700; color:var(--black); font-family:'Orbitron',monospace; flex-shrink:0; }
.kb-due { font-size:9px; color:var(--white-30); margin-top:5px; }

/* ── MEMBERS ──────────────────────────────────────────── */
.members-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.mem-card { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:20px; text-align:center; transition:border-color .2s; position:relative; overflow:hidden; }
.mem-card:hover { border-color:var(--gold); }
.mem-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold-border),transparent); }
.mem-avatar { width:54px; height:54px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Orbitron',monospace; font-size:16px; font-weight:700; color:var(--black); margin:0 auto 11px; border:2px solid var(--gold-border); }
.mem-name { font-size:13px; font-weight:600; color:var(--white); margin-bottom:3px; }
.mem-role { font-size:8px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.mem-stats { display:flex; justify-content:center; gap:18px; margin-top:10px; border-top:1px solid rgba(201,168,76,.07); padding-top:11px; }
.mem-sv { font-family:'Orbitron',monospace; font-size:13px; font-weight:700; color:var(--gold); }
.mem-sl { font-size:7px; letter-spacing:1.5px; text-transform:uppercase; color:var(--white-30); }
.mem-actions { display:flex; gap:6px; justify-content:center; margin-top:11px; }

/* ── NOTIFICATIONS ────────────────────────────────────── */
.notif-list { max-width:640px; }
.notif-item { background:var(--black-3); border:1px solid var(--gold-border); border-radius:8px; padding:13px 16px; margin-bottom:8px; display:flex; gap:11px; align-items:flex-start; transition:border-color .2s; }
.notif-item:hover { border-color:var(--gold); }
.notif-item.unread { border-left:2px solid var(--gold); }
.notif-icon { width:34px; height:34px; border-radius:8px; background:var(--gold-dim); display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.notif-title { font-size:12px; font-weight:700; color:var(--white); margin-bottom:2px; letter-spacing:.2px; }
.notif-desc { font-family:'Crimson Pro',serif; font-size:13px; font-weight:300; color:var(--white-60); line-height:1.5; }
.notif-time { font-size:10px; color:var(--white-30); margin-top:4px; }
.notif-udot { width:6px; height:6px; background:var(--gold); border-radius:50%; margin-top:5px; flex-shrink:0; }

/* ── MODAL ────────────────────────────────────────────── */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.75); z-index:600; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.modal-overlay.open { display:flex; }
.modal { background:var(--black-2); border:1px solid var(--gold-border); border-radius:13px; padding:26px; width:90%; max-width:440px; position:relative; animation:fadeIn .25s ease; }
.modal-title { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:18px; font-weight:700; }
.modal-close { position:absolute; top:13px; right:13px; background:none; border:none; color:var(--white-60); font-size:15px; cursor:pointer; width:24px; height:24px; display:flex; align-items:center; justify-content:center; border-radius:4px; transition:all .2s; }
.modal-close:hover { background:var(--gold-dim); color:var(--gold); }
.modal-actions { display:flex; gap:9px; justify-content:flex-end; margin-top:18px; }

/* ── SEARCH BOX ───────────────────────────────────────── */
.search-box { display:flex; align-items:center; gap:8px; background:var(--black-3); border:1px solid var(--gold-border); border-radius:6px; padding:0 11px; flex:1; max-width:280px; }
.search-box input { background:none; border:none; outline:none; color:var(--white); font-size:12px; padding:8px 0; width:100%; }
.search-box input::placeholder { color:var(--white-30); }

/* ── FILTER TABS ──────────────────────────────────────── */
.ftabs { display:flex; gap:5px; }
.ftab { padding:5px 11px; border-radius:14px; font-size:10px; font-weight:600; letter-spacing:.5px; cursor:pointer; border:1px solid var(--gold-border); color:var(--white-60); background:transparent; transition:all .2s; }
.ftab.active, .ftab:hover { background:var(--gold-dim); border-color:var(--gold); color:var(--gold); }

/* ── BUDGET CARDS ─────────────────────────────────────── */
.bud-summary { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:20px; }
.bud-stat { background:var(--black-3); border:1px solid var(--gold-border); border-radius:10px; padding:18px; text-align:center; position:relative; overflow:hidden; }
.bud-stat::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; }
.bud-stat.solde::after  { background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.bud-stat.rev::after    { background:linear-gradient(90deg,transparent,var(--green),transparent); }
.bud-stat.dep::after    { background:linear-gradient(90deg,transparent,var(--red),transparent); }
.bud-stat-lbl { font-size:8px; letter-spacing:2px; text-transform:uppercase; color:var(--white-30); font-weight:700; margin-bottom:7px; }
.bud-stat-val { font-family:'Orbitron',monospace; font-size:22px; font-weight:900; }
.bud-stat.solde .bud-stat-val { color:var(--gold); }
.bud-stat.rev .bud-stat-val   { color:var(--green); }
.bud-stat.dep .bud-stat-val   { color:var(--red); }

/* ── ARTICLE LIST ─────────────────────────────────────── */
.art-list { display:flex; flex-direction:column; gap:9px; }
.art-item { background:var(--black-3); border:1px solid var(--gold-border); border-radius:8px; padding:14px 16px; display:flex; align-items:center; gap:12px; transition:border-color .2s; flex-wrap:wrap; }
.art-item:hover { border-color:var(--gold); }
.art-sdot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.art-content { flex:1; min-width:200px; }
.art-title { font-size:12px; font-weight:600; color:var(--white); margin-bottom:3px; }
.art-meta { font-size:10px; color:var(--white-30); display:flex; gap:10px; flex-wrap:wrap; }
.art-actions { display:flex; gap:6px; align-items:center; flex-shrink:0; flex-wrap:wrap; }

/* ── LOGIN ────────────────────────────────────────────── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; flex-direction:column; position:relative; overflow:hidden; }
.login-deco { position:absolute; inset:0; pointer-events:none; }
.login-bg-txt { position:absolute; font-family:'Orbitron',monospace; font-size:160px; font-weight:900; color:rgba(201,168,76,.025); letter-spacing:-8px; white-space:nowrap; transform:rotate(-12deg); }
.login-deco-line { position:absolute; height:1px; background:linear-gradient(90deg,transparent,rgba(201,168,76,.1),transparent); width:100%; }
.login-logo { height:70px; width:auto; margin-bottom:6px; filter:drop-shadow(0 0 18px rgba(201,168,76,.4)); }
.login-tagline { font-size:10px; letter-spacing:4px; text-transform:uppercase; color:var(--white-30); margin-bottom:40px; }
.login-box { background:var(--black-2); border:1px solid var(--gold-border); border-radius:13px; padding:30px; width:330px; position:relative; }
.login-box-title { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); margin-bottom:20px; text-align:center; font-weight:700; }
.login-btn { width:100%; padding:11px; background:linear-gradient(135deg,var(--gold-dark),var(--gold)); border:none; border-radius:6px; color:var(--black); font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; margin-top:5px; transition:all .22s; }
.login-btn:hover { filter:brightness(1.1); letter-spacing:3px; }
.login-hint { text-align:center; font-size:10px; color:var(--white-30); margin-top:12px; letter-spacing:1px; }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media(max-width:1100px) {
  .stats-grid,.bud-summary { grid-template-columns:repeat(2,1fr); }
  .dash-grid { grid-template-columns:1fr; }
  .kanban-board { grid-template-columns:repeat(2,1fr); }
  .members-grid { grid-template-columns:repeat(2,1fr); }
  .cards-grid { grid-template-columns:repeat(2,1fr); }
  .art-grid { grid-template-columns:1fr; }
  .featured-project,.adhesion-card { grid-template-columns:1fr; }
  .two-col { grid-template-columns:1fr; }
  .hero-cards,.tips-grid { display:none; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .awareness-hero { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .app-main { margin-left:0; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .kanban-board,.members-grid,.cards-grid { grid-template-columns:1fr; }
  .page-content { padding:14px; }
  .pub-nav-links { display:none; }
  .pub-nav-links.mob-open { display:flex; flex-direction:column; position:absolute; top:70px; left:0; right:0; background:var(--black-2); border-bottom:1px solid var(--gold-border); padding:18px; gap:14px; }
  .hamburger { display:flex; }
  .footer-top { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
}

/* ── LOGO DARK BG BLEND ──────────────────────────────── */
.pub-nav-logo img,
.footer-brand-logo img,
.sb-logo-img,
.hero-logo,
.login-logo {
  mix-blend-mode: lighten;
}

/* ══════════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
   ══════════════════════════════════════════════════════════ */
.theme-toggle {
  position: relative;
  width: 50px;
  height: 26px;
  background: var(--black-4);
  border: 1px solid var(--gold-border);
  border-radius: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 0 5px;
  justify-content: space-between;
  transition: border-color .25s, background .25s;
  flex-shrink: 0;
}
.theme-toggle:hover { border-color: var(--gold); }
.tt-icon { font-size: 11px; line-height: 1; position: relative; z-index: 1; user-select: none; pointer-events: none; }
.tt-ball {
  position: absolute;
  width: 18px;
  height: 18px;
  background: linear-gradient(135deg, var(--gold-dark), var(--gold));
  border-radius: 50%;
  top: 3px;
  left: 4px;
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 1px 6px rgba(0,0,0,.35);
  pointer-events: none;
}
[data-theme="light"] .tt-ball { transform: translateX(24px); }

/* ══════════════════════════════════════════════════════════
   LIGHT THEME — tokens
   ══════════════════════════════════════════════════════════ */
[data-theme="light"] {
  --black:       #FFFFFF;
  --black-2:     #F4F5F7;
  --black-3:     #E8EAF0;
  --black-4:     #D8DBE8;
  --black-5:     #C8CCDA;
  --white:       #1A1B2E;
  --white-60:    rgba(26,27,46,.65);
  --white-30:    rgba(26,27,46,.40);
  --white-10:    rgba(26,27,46,.10);
  --gold-dim:    rgba(180,140,50,.12);
  --gold-border: rgba(180,140,50,.30);
}

/* Body explicitement blanc */
[data-theme="light"] body { background: #FFFFFF; color: #1A1B2E; }

/* Navbar publique blanche */
[data-theme="light"] .pub-nav {
  background: rgba(255,255,255,.97);
  border-bottom-color: rgba(180,140,50,.18);
}
[data-theme="light"] .pub-nav-links a { color: rgba(26,27,46,.65); }
[data-theme="light"] .pub-nav-links a:hover,
[data-theme="light"] .pub-nav-links a.active { color: var(--gold); }
[data-theme="light"] .pub-nav-links.mob-open { background: #F4F5F7; }

/* Sidebar & topbar privés : restent sombres (logo visible + cohérence app) */
[data-theme="light"] .sidebar {
  --black:       #080809;
  --black-2:     #0F0F12;
  --black-3:     #161619;
  --black-4:     #1E1E24;
  --black-5:     #27272F;
  --white:       #F0EDE5;
  --white-60:    rgba(240,237,229,.6);
  --white-30:    rgba(240,237,229,.3);
  --white-10:    rgba(240,237,229,.1);
  --gold-border: rgba(212,172,82,.32);
  --gold-dim:    rgba(212,172,82,.13);
  background: #0F0F12;
  border-right-color: rgba(212,172,82,.32);
}
[data-theme="light"] .topbar {
  --black-2:     #0F0F12;
  --black-3:     #161619;
  --black-4:     #1E1E24;
  --white:       #F0EDE5;
  --white-60:    rgba(240,237,229,.6);
  --gold-border: rgba(212,172,82,.32);
  --gold-dim:    rgba(212,172,82,.13);
  background: #0F0F12;
  border-bottom-color: rgba(212,172,82,.32);
}

/* Logos sur fond blanc : filtre pour les rendre visibles */
[data-theme="light"] .pub-nav-logo img,
[data-theme="light"] .footer-brand-logo img,
[data-theme="light"] .hero-logo { mix-blend-mode: normal; filter: brightness(0.1); }

/* Footer public */
[data-theme="light"] .pub-footer {
  background: #F4F5F7;
  border-top-color: rgba(180,140,50,.20);
}

/* Modals sur fond blanc */
[data-theme="light"] .modal-overlay { background: rgba(0,0,0,.40); }
[data-theme="light"] .modal { box-shadow: 0 8px 40px rgba(0,0,0,.12); }

/* Search box */
[data-theme="light"] .search-box input { color: #1A1B2E; }

/* Table hover */
[data-theme="light"] .data-table tr:hover td { background: #E8EAF0; }

/* Texte sur fond doré : forcer couleur sombre pour lisibilité */
[data-theme="light"] .btn-gold,
[data-theme="light"] .login-btn,
[data-theme="light"] .sb-badge,
[data-theme="light"] .step-num { color: #1A1B2E; }

/* Scrollbar */
[data-theme="light"] ::-webkit-scrollbar-track { background: #F4F5F7; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: var(--gold-dark); }

/* ── BRACKET — light mode ─────────────────────────────── */
[data-theme="light"] .bk-t {
  background: #E8EAF0;
  color: #1A1B2E;
  border-left-color: rgba(140,105,30,.35);
}
[data-theme="light"] .bk-t-top  { border-bottom-color: rgba(140,105,30,.55); }
[data-theme="light"] .bk-t-bot  { border-top-color:    rgba(140,105,30,.55); }
[data-theme="light"] .bk-mid    { border-right-color:  rgba(140,105,30,.55); }
[data-theme="light"] .bk-col--last .bk-t-top { border-bottom-color: rgba(140,105,30,.30); border-right-color: rgba(140,105,30,.25); }
[data-theme="light"] .bk-col--last .bk-t-bot { border-right-color: rgba(140,105,30,.25); }
[data-theme="light"] .bk-t.bk-win      { background: rgba(180,140,50,.22); color: #1A1B2E; }
[data-theme="light"] .bk-t-name        { color: #1A1B2E; }
[data-theme="light"] .bk-col-label     { color: rgba(26,27,46,.45); }
[data-theme="light"] .bk-form-inner > span { color: rgba(26,27,46,.35); }
[data-theme="light"] .bk-inp {
  background: #D8DBE8;
  border-color: rgba(140,105,30,.40);
  color: #1A1B2E;
}
[data-theme="light"] .bk-champion-box  { background: rgba(180,140,50,.12); border-color: rgba(140,105,30,.40); }
[data-theme="light"] .bk-champion-name { color: #1A1B2E; }
[data-theme="light"] .bk-champion-lbl  { color: rgba(26,27,46,.45); }

/* ── PROFILE AVATAR UPLOAD HOVER ─────────────────────── */
.avatar-upload-label { transition: all .2s; }
.avatar-upload-label:hover { background: var(--gold-dim); }

/* ── STREAMING GRID (home) ───────────────────────────── */
.stream-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 28px;
  align-items: flex-start;
}
@media (max-width: 768px) {
  .stream-grid {
    grid-template-columns: 1fr;
  }
  .stream-grid .stream-player { order: 2; }
  .stream-grid .stream-planning { order: 1; }
}

/* ── ARTICLE CARD HOVER (home) ───────────────────────── */
.v-card[onclick] { transition: border-color .2s, transform .2s; }
.v-card[onclick]:hover { border-color: var(--gold); transform: translateY(-4px); }

/* ── AWARENESS STATS EDIT GRID ───────────────────────── */
#statsEditView .form-input { font-size:12px; padding:8px 11px; }

/* ── QUILL WYSIWYG DARK THEME ───────────────────────── */
.ql-toolbar.ql-snow {
  background: var(--black-2);
  border: 1px solid var(--gold-border) !important;
  border-bottom: 1px solid rgba(201,168,76,.1) !important;
  border-radius: 8px 8px 0 0;
  padding: 8px 12px;
}
.ql-container.ql-snow {
  background: var(--black-2);
  border: 1px solid var(--gold-border) !important;
  border-top: none !important;
  border-radius: 0 0 8px 8px;
  font-family: 'Crimson Pro', serif;
  font-size: 16px;
  color: var(--white-60);
  min-height: 320px;
}
.ql-editor {
  min-height: 300px;
  color: var(--white-60);
  line-height: 1.8;
  padding: 16px 20px;
}
.ql-editor.ql-blank::before {
  color: var(--white-30);
  font-style: italic;
}
.ql-snow .ql-stroke { stroke: var(--white-60); }
.ql-snow .ql-fill   { fill:   var(--white-60); }
.ql-snow .ql-picker  { color: var(--white-60); }
.ql-snow .ql-picker-label::before { color: var(--white-60); }
.ql-snow .ql-picker-options {
  background: var(--black-2);
  border: 1px solid var(--gold-border) !important;
  border-radius: 6px;
}
.ql-snow .ql-picker-options .ql-picker-item { color: var(--white-60); }
.ql-snow .ql-picker-options .ql-picker-item:hover { color: var(--gold); }
.ql-snow button:hover .ql-stroke,
.ql-snow .ql-active  .ql-stroke { stroke: var(--gold); }
.ql-snow button:hover .ql-fill,
.ql-snow .ql-active  .ql-fill   { fill:   var(--gold); }
.ql-snow button:hover,
.ql-snow .ql-active { color: var(--gold); }
.ql-editor h1, .ql-editor h2, .ql-editor h3 {
  color: var(--white);
  font-family: 'Rajdhani', sans-serif;
  margin: 14px 0 6px;
}
.ql-editor strong { color: var(--white); }
.ql-editor em     { color: var(--white-60); font-style: italic; }
.ql-editor a      { color: var(--gold); text-decoration: underline; }
.ql-editor blockquote {
  border-left: 3px solid var(--gold);
  padding-left: 14px;
  color: var(--white-30);
  margin: 10px 0;
}
.ql-editor pre { background: rgba(0,0,0,.4); border-radius: 6px; padding: 12px; color: var(--green); }
.ql-editor img {
  max-width: 100%;
  border-radius: 8px;
  margin: 12px 0;
  display: block;
  border: 1px solid var(--gold-border);
}

/* ── ARTICLE CARDS GRILLE HOME ──────────────────────── */
.art-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.art-card {
  background: var(--black-3);
  border: 1px solid var(--gold-border);
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  transition: border-color .2s, transform .2s;
  position: relative;
  text-decoration: none;
  color: inherit;
}
.art-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.art-card:hover { border-color: var(--gold); transform: translateY(-4px); }
.art-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--black-2);
  flex-shrink: 0;
}
.art-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .35s;
}
.art-card:hover .art-card-img img { transform: scale(1.04); }
.art-card-img--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  opacity: .25;
}
/* Bannière pleine largeur sur la page article */
.art-banner {
  width: 100%;
  aspect-ratio: 21/9;
  overflow: hidden;
  background: var(--black-2);
  border-radius: 12px;
  margin-bottom: 32px;
}
.art-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.art-card-body {
  padding: 22px 24px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.art-card-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: var(--white);
  line-height: 1.3;
  margin-bottom: 10px;
}
.art-card-excerpt {
  font-family: 'Crimson Pro', serif;
  font-size: 14px;
  font-weight: 300;
  color: var(--white-60);
  line-height: 1.6;
}

/* ── ARTICLE READ MODAL ──────────────────────────────── */
#articleReadContent h1,#articleReadContent h2,#articleReadContent h3 {
  color: var(--white); font-family: 'Rajdhani', sans-serif; margin: 14px 0 6px;
}
#articleReadContent p { margin-bottom: 10px; }
#articleReadContent strong { color: var(--white); font-style: italic; }

/* ══════════════════════════════════════════════════════════
   TOURNAMENT BRACKET — technique NCAA flexbox (cssscript.com)
   Connecteurs via border CSS sur les <li>, zéro JS, zéro SVG
   ══════════════════════════════════════════════════════════ */
.bk-wrap { overflow-x: auto; padding: 24px 0 32px; }

/* Conteneur global — flex row de colonnes */
.bk-bracket {
  display: flex;
  flex-direction: row;
  min-width: max-content;
  min-height: 300px;
}

/* ── Colonne = label + liste de matchs ── */
.bk-col {
  display: flex;
  flex-direction: column;
  min-width: 175px;
}

.bk-col-label {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(212,172,82,.55);
  text-align: center;
  padding: 0 0 12px;
  font-weight: 700;
  white-space: nowrap;
}

/* ── Liste des matchs d'un round ── */
.bk-round {
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Espaceurs : se partagent l'espace restant */
.bk-sp { flex-grow: 1; }
/* Demi-espace en haut et en bas = matches bien centrés */
.bk-sp:first-child,
.bk-sp:last-child { flex-grow: .5; }

/* ── Zone centrale entre les deux équipes ──
   border-right = branche verticale de l'arbre */
.bk-mid {
  flex-grow: 1;
  min-height: 40px;
  border-right: 2px solid rgba(212,172,82,.38);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px 4px 4px;
}

/* Dernière colonne (finale) : pas de branche vers la droite */
.bk-col--last .bk-mid { border-right: none; }

/* ── Ligne équipe ──
   border-bottom (game-top) et border-top (game-bottom)
   = bras horizontaux de l'arbre, dessinés par le navigateur
   sur toute la largeur du <li> jusqu'au border-right du .bk-mid */
.bk-t {
  background: rgba(8,8,9,.6);
  padding: 9px 10px;
  font-size: 12px;
  color: rgba(255,255,255,.42);
  margin-bottom: 10px;
  margin-left: 5px;
  border: 1px solid rgba(212,172,82,.38);
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  border-left: 3px solid rgba(212,172,82,.18);
  transition: background .15s;
}

/* Équipe du haut : bras horizontal bas → rejoint border-right du .bk-mid */
.bk-t-top {
  border-bottom: 2px solid rgba(212,172,82,.38);
  border-radius: 6px 0 0 0;
}

/* Équipe du bas : bras horizontal haut → rejoint border-right du .bk-mid */
.bk-t-bot {
  border-top: 2px solid rgba(212,172,82,.38);
  border-radius: 0 0 0 6px;
}

/* Finale : border complet (pas de bras vers la droite) */
.bk-col--last .bk-t { border-left-width: 3px; }
.bk-col--last .bk-t-top {
  border-bottom: 1px solid rgba(212,172,82,.2);
  border-right: 1px solid rgba(212,172,82,.18);
  border-radius: 6px 6px 0 0;
}
.bk-col--last .bk-t-bot {
  border-top: none;
  border-right: 1px solid rgba(212,172,82,.18);
  border-radius: 0 0 6px 6px;
}

/* Vainqueur du match */
.bk-t.bk-win {
  background: rgba(212,172,82,.1);
  color: #fff;
  font-weight: 700;
  border-left-color: rgba(212,172,82,.65);
}

.bk-t-name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bk-t-score {
  font-family: 'Orbitron', monospace;
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,.28);
  min-width: 18px;
  text-align: right;
  flex-shrink: 0;
}
.bk-t.bk-win .bk-t-score { color: var(--gold); }

/* ── Formulaire saisie score admin (dans .bk-mid) ── */
.bk-form-inner {
  display: flex;
  gap: 4px;
  align-items: center;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(212,172,82,.22);
  border-radius: 6px;
  padding: 4px 6px;
}
.bk-inp {
  width: 34px;
  padding: 2px 4px;
  background: var(--black-3);
  border: 1px solid var(--gold-border);
  border-radius: 3px;
  color: var(--white);
  text-align: center;
  font-family: 'Orbitron', monospace;
  font-size: 10px;
}
.bk-form-inner > span { color: rgba(255,255,255,.3); font-size: 10px; }

/* ── Champion ── */
.bk-champion-col {
  display: flex;
  align-items: center;
  padding-left: 20px;
}
.bk-champion-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, rgba(212,172,82,.16), rgba(212,172,82,.05));
  border: 1px solid rgba(212,172,82,.5);
  border-radius: 12px;
  padding: 20px 16px;
  text-align: center;
  box-shadow: 0 0 32px rgba(212,172,82,.14), inset 0 0 20px rgba(212,172,82,.04);
  min-width: 115px;
}
.bk-champion-trophy { font-size: 30px; line-height: 1; }
.bk-champion-name {
  font-family: 'Orbitron', monospace;
  font-size: 10px;
  font-weight: 900;
  color: var(--gold);
  letter-spacing: 1px;
  text-transform: uppercase;
  word-break: break-word;
  max-width: 100px;
}
.bk-champion-lbl {
  font-size: 8px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(212,172,82,.55);
  font-weight: 700;
}

/* Rétrocompatibilité */
.bracket-wrap { padding-bottom: 8px; }
.bracket-team.winner { color: var(--gold); font-weight: 700; }
