.event-h {
  position:absolute; inset:0; border-radius:50%;
  display:none; animation:ehp 2.2s ease-in-out infinite;
}
.event-h.on { display:block; }
.race-pill {
  display:inline-block; font-family:'Share Tech Mono',monospace; font-size: 12px; letter-spacing:1px;
  padding:3px 9px; border-radius:3px; border:1px solid; margin:2px;
}

.log-box {
  background:var(--bg); border:1px solid var(--border);
  border-radius:6px; padding:9px; font-family:'Share Tech Mono',monospace;
  font-size: 11px; line-height:1.9; max-height:110px; overflow-y:auto;
  color:var(--textsoft);
}
.log-ok { color:var(--success); }
.log-w  { color:var(--warn); }
.log-n  { color:var(--accent); }

.energy-row { margin-top:auto; }
.er-top { display:flex; justify-content:space-between; margin-bottom:4px; }
.er-label { font-size: 12px; color:var(--textmid); }
.er-val { font-family:'Share Tech Mono',monospace; font-size: 12px; color:var(--accent); }

.race-sidebar {
  width:68px; flex-shrink:0;
  background:var(--surface); border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  box-shadow:4px 0 20px rgba(0,10,30,0.3);
}
.rb {
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; cursor:pointer; transition:all 0.2s;
  border-bottom:1px solid var(--border); padding:8px 4px;
  border-left:3px solid transparent;
}
.rb:hover { background:rgba(var(--accent2-rgb),0.07); }
.rb.act { background:rgba(var(--accent2-rgb),0.1); }
.rb[data-r="anciens"].act { border-left-color:var(--ancient); background:rgba(224,230,240,0.07); }
.rb[data-r="asgard"].act { border-left-color:var(--asgard); background:rgba(58,184,232,0.07); }
.rb[data-r="goauld"].act { border-left-color:var(--goauld); background:rgba(216,184,0,0.07); }
.rb[data-r="replic"].act { border-left-color:var(--replic); background:rgba(224,64,64,0.07); }
/* ══ AUTH OVERLAY ══ */
#authOverlay {
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center;
  background:url('../background.png') center/cover no-repeat;
}
#authOverlay::before {
  content:''; position:absolute; inset:0;
  background:rgba(8,16,30,0.15);
  backdrop-filter:none;
}
#authOverlay > .auth-box { position:relative; z-index:1; }
.auth-box {
  width:400px; max-height:90vh; overflow-y:auto;
  background:rgba(10,18,35,0.88); border:1px solid var(--border2);
  border-radius:12px; padding:36px;
  box-shadow:0 20px 60px rgba(0,10,30,0.8), var(--inset);
  backdrop-filter:blur(12px);
  animation:modalGlow 3s ease-in-out infinite;
}
@keyframes modalGlow {
  0%,100% { box-shadow:0 0 30px rgba(var(--accent-rgb),0.1), 0 20px 60px rgba(0,10,30,0.6); }
  50%     { box-shadow:0 0 50px rgba(var(--accent-rgb),0.2), 0 20px 60px rgba(0,10,30,0.6); }
}
.auth-logo {
  font-family:'Orbitron',monospace; font-size:16px; font-weight:900;
  letter-spacing:5px;
  background:linear-gradient(135deg,var(--accent2),var(--gold2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 8px rgba(var(--accent2-rgb),0.4));
  text-align:center; margin-bottom:4px;
}
.auth-sub {
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  letter-spacing:3px; color:var(--textsoft); text-align:center;
  margin-bottom:24px; text-transform:uppercase;
}
.auth-tabs { display:flex; gap:4px; margin-bottom:20px; }
.auth-tab {
  flex:1; padding:9px; font-family:'Orbitron',monospace; font-size: 11px;
  font-weight:700; letter-spacing:1px; text-transform:uppercase;
  border:1px solid var(--border); border-radius:5px; cursor:pointer;
  color:var(--textsoft); background:transparent; transition:all 0.2s; text-align:center;
}
.auth-tab:hover { color:var(--accent2); }
.auth-tab.active { color:var(--accent); border-color:rgba(var(--accent2-rgb),0.4); background:rgba(var(--accent2-rgb),0.08); }
.auth-field { margin-bottom:14px; }
.auth-label {
  font-family:'Share Tech Mono',monospace; font-size: 11px;
  color:var(--textsoft); letter-spacing:1px; margin-bottom:5px; display:block;
}
.auth-input {
  width:100%; padding:10px 12px; border-radius:6px;
  background:var(--surface2); border:1px solid var(--border);
  color:var(--textbright); font-family:'Share Tech Mono',monospace; font-size: 12px;
  outline:none; transition:border-color 0.2s;
}
.auth-input:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(var(--accent2-rgb),0.15); }
.auth-btn {
  width:100%; padding:12px; margin-top:8px; border-radius:6px;
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; cursor:pointer;
  border:1px solid var(--accent); color:var(--accent);
  background:rgba(var(--accent2-rgb),0.1); transition:all 0.2s;
}
.auth-btn:hover { background:rgba(var(--accent2-rgb),0.18); box-shadow:0 0 16px rgba(var(--accent2-rgb),0.3); transform:translateY(-1px); }
.auth-pw-wrap { position:relative; display:flex; align-items:center; }
.auth-pw-wrap .auth-input { padding-right:36px; }
.auth-pw-toggle {
  position:absolute; right:6px; top:50%; transform:translateY(-50%);
  background:none; border:none; cursor:pointer; font-size:14px;
  opacity:0.5; transition:opacity 0.2s; padding:4px; line-height:1;
}
.auth-pw-toggle:hover { opacity:0.9; }
.auth-pw-toggle.visible { opacity:0.9; }
/* ══ LOGIN BONUS — 7-day calendar ══ */
.login-bonus-overlay {
  position:fixed; inset:0; z-index:9500;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
  animation:fadeIn 0.3s;
}
.lb-calendar-box {
  background:rgba(10,18,35,0.95); border:1px solid var(--gold);
  border-radius:12px; padding:30px 34px; text-align:center;
  box-shadow:0 0 40px rgba(255,192,64,0.2), 0 20px 60px rgba(0,10,30,0.8);
  max-width:560px; width:92vw; animation:slideInUp 0.4s;
}
.lb-title {
  font-family:'Orbitron',monospace; font-size:20px; font-weight:900;
  letter-spacing:2px; color:var(--gold2); margin-bottom:4px;
}
.lb-sub {
  font-family:'Share Tech Mono',monospace; font-size: 15px;
  color:var(--textsoft); margin-bottom:8px;
}
.lb-streak {
  font-family:'Share Tech Mono',monospace; font-size: 15px;
  color:var(--accent); margin-bottom:12px; letter-spacing:0.5px;
}
.lb-calendar {
  display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:16px;
}
.lb-day {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:4px; min-height:95px; border-radius:8px; padding:8px 4px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
  transition:all 0.2s;
}
.lb-day-lbl {
  font-family:'Orbitron',monospace; font-size: 13px; font-weight:700;
  letter-spacing:1px; color:var(--textsoft);
}
.lb-day-amt {
  font-family:'Share Tech Mono',monospace; font-size: 14px; color:var(--textsoft);
}
.lb-day-amt-gold { color:var(--success); font-weight:700; }
.lb-day-check {
  font-size:22px; color:var(--success);
}
.lb-day-done {
  background:rgba(0,200,100,0.10); border-color:rgba(0,200,100,0.35);
}
.lb-day-active {
  background:rgba(255,192,64,0.12); border-color:var(--gold);
  box-shadow:0 0 14px rgba(255,192,64,0.25);
  animation:lbPulse 2s ease-in-out infinite;
}
@keyframes lbPulse {
  0%,100% { box-shadow:0 0 10px rgba(255,192,64,0.2); }
  50%     { box-shadow:0 0 22px rgba(255,192,64,0.45); }
}
.lb-day-active .lb-day-lbl { color:var(--gold); }
.lb-day-locked { opacity:0.55; }
.lb-day-missed { opacity:0.45; }
.lb-btn {
  padding:14px 44px; border-radius:6px; border:1px solid var(--gold);
  background:rgba(255,192,64,0.12); color:var(--gold2);
  font-family:'Orbitron',monospace; font-size: 15px; font-weight:700;
  letter-spacing:1px; cursor:pointer; transition:all 0.2s;
}
.lb-btn:hover { background:rgba(255,192,64,0.22); box-shadow:0 0 12px rgba(255,192,64,0.3); }
@media (max-width:480px) {
  .lb-calendar { grid-template-columns:repeat(4,1fr); }
  .lb-calendar-box { padding:18px 14px; }
}

/* ══ ACHIEVEMENT POPUP ══ */
.ach-pop-overlay {
  position:fixed; inset:0; z-index:9400;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
  animation:fadeIn 0.3s;
}
.ach-pop-box {
  background:rgba(10,18,35,0.95); border:1px solid var(--gold);
  border-radius:12px; padding:28px 32px; text-align:center;
  box-shadow:0 0 50px rgba(255,192,64,0.25), 0 20px 60px rgba(0,10,30,0.8);
  max-width:380px; width:88vw; animation:slideInUp 0.4s, modalGlowGold 3s ease-in-out 0.4s infinite;
  backdrop-filter:blur(10px);
}
@keyframes modalGlowGold {
  0%,100% { box-shadow:0 0 30px rgba(255,192,64,0.15), 0 20px 60px rgba(0,10,30,0.6); }
  50%     { box-shadow:0 0 60px rgba(255,192,64,0.3), 0 20px 60px rgba(0,10,30,0.6); }
}
.ach-pop-label {
  font-family:'Orbitron',monospace; font-size: 11px; font-weight:700;
  letter-spacing:3px; color:var(--gold); margin-bottom:10px;
}
.ach-pop-badge {
  font-size:56px; margin-bottom:8px;
  filter:drop-shadow(0 0 18px rgba(255,192,64,0.5));
  animation:achGlow 2s ease-in-out infinite;
}
@keyframes achGlow {
  0%,100% { filter:drop-shadow(0 0 14px rgba(255,192,64,0.4)); }
  50%     { filter:drop-shadow(0 0 28px rgba(255,192,64,0.8)); }
}
.ach-pop-title {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:900;
  letter-spacing:1px; color:var(--textbright); margin-bottom:6px;
}
.ach-pop-desc {
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  color:var(--textsoft); margin-bottom:14px; line-height:1.6;
}
.ach-pop-rewards {
  display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:16px;
}
.ach-pop-rew {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--success); font-weight:700;
}
.ach-pop-btn {
  padding:10px 32px; border-radius:6px; border:1px solid var(--gold);
  background:rgba(255,192,64,0.12); color:var(--gold2);
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:2px; cursor:pointer; transition:all 0.2s;
}
.ach-pop-btn:hover { background:rgba(255,192,64,0.25); box-shadow:0 0 16px rgba(255,192,64,0.35); transform:translateY(-1px); }
.ach-pop-btn:disabled { opacity:0.5; cursor:wait; }

/* ══ QUEST POPUP ══ */
.quest-pop-overlay {
  position:fixed; inset:0; z-index:9400;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
  animation:fadeIn 0.3s;
}
.quest-pop-box {
  background:rgba(10,18,35,0.95); border:1px solid var(--accent);
  border-radius:12px; padding:28px 32px; text-align:center;
  box-shadow:0 0 50px rgba(58,184,232,0.25), 0 20px 60px rgba(0,10,30,0.8);
  max-width:380px; width:88vw; animation:slideInUp 0.4s, modalGlow 3s ease-in-out 0.4s infinite;
  backdrop-filter:blur(10px);
}
.quest-pop-label {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  letter-spacing:3px; color:var(--accent); margin-bottom:10px;
}
.quest-pop-badge {
  font-size:56px; margin-bottom:8px;
  filter:drop-shadow(0 0 18px rgba(58,184,232,0.5));
  animation:questGlow 2s ease-in-out infinite;
}
@keyframes questGlow {
  0%,100% { filter:drop-shadow(0 0 14px rgba(58,184,232,0.4)); }
  50%     { filter:drop-shadow(0 0 28px rgba(58,184,232,0.8)); }
}
.quest-pop-title {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:900;
  letter-spacing:1px; color:var(--textbright); margin-bottom:6px;
}
.quest-pop-desc {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--textsoft); margin-bottom:14px; line-height:1.6;
}
.quest-pop-rewards {
  display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:16px;
}
.quest-pop-rew {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--success); font-weight:700;
}
.quest-pop-actions {
  display:flex; gap:10px; justify-content:center;
}
.quest-pop-btn {
  padding:10px 24px; border-radius:6px; border:1px solid var(--accent);
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  letter-spacing:2px; cursor:pointer; transition:all 0.2s;
}
.quest-pop-btn.claim {
  background:rgba(58,184,232,0.12); color:var(--accent);
}
.quest-pop-btn.claim:hover { background:rgba(58,184,232,0.25); box-shadow:0 0 16px rgba(58,184,232,0.35); transform:translateY(-1px); }
.quest-pop-btn.claim:disabled { opacity:0.5; cursor:wait; }
.quest-pop-btn.later {
  background:transparent; color:var(--textmid); border-color:var(--border);
}
.quest-pop-btn.later:hover { background:rgba(255,255,255,0.05); color:var(--textsoft); }
.race-popup-overlay {
  position:fixed; inset:0; z-index:9100; background:rgba(2,4,12,0.92);
  display:flex; justify-content:center; align-items:center;
  backdrop-filter:blur(12px); animation:fadeIn 0.25s ease;
}
.race-popup {
  background:linear-gradient(180deg,var(--surface2) 0%,var(--bg2) 100%);
  border:1px solid rgba(var(--accent-rgb),0.3); border-radius:18px;
  width:560px; max-width:92vw; max-height:90vh; overflow-y:auto;
  padding:0; box-shadow:0 0 80px rgba(var(--accent-rgb),0.15),0 20px 60px rgba(0,0,0,0.6);
  animation:evPop 0.3s ease, modalGlow 3s ease-in-out 0.3s infinite;
  backdrop-filter:blur(10px);
}
.race-popup-title {
  font-family:'Orbitron',monospace; font-size:24px; font-weight:900;
  text-align:center; margin-bottom:8px; letter-spacing:4px;
  text-shadow:0 0 30px currentColor;
}
.race-popup-lore {
  font-family:'Rajdhani',sans-serif; font-size:16px; font-weight:500; color:var(--text);
  text-align:center; margin-bottom:20px; line-height:1.8; letter-spacing:0.3px;
}
.race-popup-bonuses { display:flex; flex-direction:column; gap:10px; }
.race-bonus-row {
  display:flex; align-items:center; gap:12px;
  padding:10px 16px; border-radius:10px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.08);
}
.race-bonus-icon { font-size:24px; flex-shrink:0; }
.race-bonus-text { flex:1; font-family:'Rajdhani',sans-serif; font-size:15px; font-weight:500; color:var(--text); }
.race-bonus-val { font-family:'Rajdhani',sans-serif; font-size:16px; font-weight:bold; color:var(--success); }
.race-unlock-row {
  display:flex; flex-direction:column; align-items:flex-start; gap:10px;
  padding:18px 20px; cursor:pointer; border-radius:12px;
  background:rgba(var(--accent-rgb),0.04); border:1px solid rgba(var(--accent-rgb),0.15);
  transition:all 0.2s;
}
.race-unlock-row:hover {
  background:rgba(var(--accent-rgb),0.12); border-color:rgba(var(--accent-rgb),0.35);
  box-shadow:0 0 20px rgba(var(--accent-rgb),0.2);
}
.race-popup-close {
  display:block; margin:0 auto; padding:14px 48px; border-radius:8px;
  background:rgba(var(--accent-rgb),0.08); border:1px solid var(--accent); color:var(--accent);
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700; cursor:pointer; letter-spacing:2px;
  transition:all 0.2s;
}
.race-popup-close:hover { background:rgba(var(--accent-rgb),0.2); }
/* Race colors */
.race-goauld   { color:#ffe040; }
.race-ancien   { color:#55d8ff; }
.race-asgard   { color:#88ccff; }
.race-tokra    { color:#ffaa44; }
.race-nox      { color:#66ff99; }
.race-tollan   { color:#cc99ff; }
.race-ori      { color:#ff8866; }
.race-wraith   { color:#aa88ff; }

.event-overlay { position:fixed; inset:0; z-index:9000; display:flex; align-items:center; justify-content:center; background:rgba(4,8,18,0.88); backdrop-filter:blur(8px); }
.event-popup { width:440px; background:var(--surface); border:1px solid var(--border); border-radius:14px; overflow:hidden; box-shadow:0 0 50px rgba(var(--accent-rgb),0.18); animation:evPop 0.25s ease, modalGlow 3s ease-in-out 0.25s infinite; backdrop-filter:blur(10px); }
.event-popup-hdr { padding:20px 20px 10px; text-align:center; border-bottom:1px solid rgba(var(--accent-rgb),0.15); }
.event-popup-icon { font-size:48px; margin-bottom:6px; display:block; }
.event-popup-title { font-family:'Orbitron',monospace; font-size: 17px; font-weight:700; letter-spacing:2px; color:var(--textbright); }
.event-popup-msg { font-family:'Share Tech Mono',monospace; font-size: 15px; color:var(--textsoft); line-height:1.65; padding:12px 20px 6px; text-align:center; }
.event-popup-effect { margin:0 20px 14px; padding:8px 14px; border-radius:6px; text-align:center; font-family:'Share Tech Mono',monospace; font-size: 15px; font-weight:bold; letter-spacing:0.5px; }
.event-popup-effect.good { background:rgba(0,220,120,0.08); border:1px solid rgba(0,220,120,0.35); color:var(--success); }
.event-popup-effect.bad  { background:rgba(255,60,60,0.08);  border:1px solid rgba(255,60,60,0.35);  color:var(--danger); }
.event-popup-effect.info { background:rgba(var(--accent-rgb),0.08); border:1px solid rgba(var(--accent-rgb),0.35); color:var(--accent); }
.event-popup-footer { padding:10px 20px 18px; display:flex; justify-content:center; }
.event-popup-btn { padding:12px 38px; font-family:'Orbitron',monospace; font-size: 15px; font-weight:700; letter-spacing:1.5px; border-radius:6px; cursor:pointer; border:1px solid var(--accent); color:var(--accent); background:rgba(var(--accent-rgb),0.08); transition:background 0.2s; }
.event-popup-btn:hover { background:rgba(var(--accent-rgb),0.2); }
/* Event log */
.ev-log { background:var(--surface2); border:1px solid var(--border); border-radius:8px; overflow:hidden; margin-bottom:12px; }
.ev-log-row { display:flex; align-items:center; gap:8px; padding:6px 12px; border-bottom:1px solid rgba(var(--accent-rgb),0.08); font-family:'Share Tech Mono',monospace; font-size: 14px; }
.ev-log-row:last-child { border-bottom:none; }
.ev-log-icon { font-size:13px; flex-shrink:0; }
.ev-log-title { flex:1; color:var(--textbright); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ev-log-effect { font-weight:bold; white-space:nowrap; font-size: 14px; }
.ev-log-effect.good { color:var(--success); } .ev-log-effect.bad { color:var(--danger); } .ev-log-effect.info { color:var(--accent); }
/* Event boost bar */
.ev-boost-bar {
  display:flex; align-items:center; gap:10px;
  background:linear-gradient(90deg, rgba(224,168,48,0.08), rgba(224,168,48,0.03));
  border:1px solid rgba(224,168,48,0.38); border-radius:8px;
  border-left:3px solid rgba(224,168,48,0.7);
  padding:8px 14px; margin-bottom:10px;
  font-family:'Share Tech Mono',monospace; font-size:11px;
  box-shadow:0 2px 12px rgba(224,168,48,0.08);
}
/* Global event banner */

/* ══ TUTORIAL COACH WIDGET ══ */
.tut-coach {
  position:fixed; bottom:18px; right:18px; z-index:8500;
  width:380px; flex-direction:column;
  background:rgba(8,16,32,0.95); border:1px solid rgba(var(--accent-rgb),0.5);
  border-radius:14px; box-shadow:0 6px 40px rgba(var(--accent-rgb),0.2), 0 0 60px rgba(var(--accent-rgb),0.06);
  backdrop-filter:blur(14px); overflow:hidden;
  animation:tutSlideIn 0.4s ease;
}
.tut-coach-enter { animation:tutSlideIn 0.4s ease; }
@keyframes tutSlideIn {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.tut-coach-header {
  display:flex; align-items:center; gap:10px;
  padding:14px 18px; border-bottom:1px solid rgba(var(--accent-rgb),0.25);
  background:rgba(var(--accent-rgb),0.08);
}
.tut-coach-logo {
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  letter-spacing:2px; color:var(--accent); flex:1;
  text-shadow:0 0 10px rgba(var(--accent-rgb),0.4);
}
.tut-coach-counter {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--gold); letter-spacing:1px; font-weight:700;
}
.tut-toggle-btn {
  background:none; border:none; color:var(--textsoft);
  font-size:14px; cursor:pointer; padding:2px 6px;
}
.tut-coach-progress {
  height:4px; background:rgba(255,255,255,0.08);
}
.tut-coach-progress-fill {
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  border-radius:2px; transition:width 0.4s ease;
  box-shadow:0 0 8px rgba(var(--accent-rgb),0.5);
}
.tut-coach-body {
  display:flex; flex-direction:column; gap:10px;
  padding:16px 18px;
}
.tut-directive-label {
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:2.5px; color:var(--gold);
  text-shadow:0 0 6px rgba(240,192,64,0.3);
}
.tut-directive-title {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:700;
  color:var(--textbright); letter-spacing:0.5px; line-height:1.4;
}
.tut-directive-desc {
  font-family:'Rajdhani',sans-serif; font-size:14px; font-weight:500;
  color:var(--text); line-height:1.7;
}
.tut-coach-actions {
  display:flex; gap:8px; margin-top:4px;
}
.tut-btn {
  flex:1; padding:10px 12px; border-radius:6px;
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:1px; cursor:pointer; transition:all 0.2s; text-align:center;
}
.tut-btn-go {
  border:1px solid var(--success); color:var(--success);
  background:rgba(0,200,100,0.12);
}
.tut-btn-go:hover { background:rgba(0,200,100,0.25); transform:translateY(-1px); }
.tut-btn-locate {
  border:1px solid var(--accent); color:var(--accent);
  background:rgba(var(--accent-rgb),0.1);
}
.tut-btn-locate:hover { background:rgba(var(--accent-rgb),0.22); transform:translateY(-1px); }
.tut-tip {
  margin-top:5px; padding:6px 10px; border-radius:5px;
  background:rgba(var(--accent-rgb),0.08); border-left:3px solid var(--accent);
  font-size:12px; color:var(--textmid); font-style:italic;
}
.tut-btn-skip {
  border:1px solid var(--border); color:var(--textsoft);
  background:transparent;
}
.tut-btn-skip:hover { color:var(--textmid); border-color:var(--textsoft); transform:translateY(-1px); }
.tut-btn-dismiss {
  background:none; border:none; color:var(--textsoft);
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  cursor:pointer; padding:4px 0; text-align:center;
  opacity:0.6; transition:opacity 0.2s;
}
.tut-btn-dismiss:hover { opacity:1; color:var(--danger); }

/* ══ TUTORIAL CELEBRATION OVERLAY ══ */
.tut-complete-overlay {
  position:fixed; inset:0; z-index:9600;
  display:flex; align-items:center; justify-content:center;
  background:rgba(2,4,12,0.92); backdrop-filter:blur(12px);
  animation:fadeIn 0.4s ease;
}
.tut-complete-box {
  text-align:center; padding:40px 48px;
  background:linear-gradient(180deg,var(--surface2) 0%,var(--bg2) 100%);
  border:1px solid var(--gold); border-radius:18px;
  box-shadow:0 0 80px rgba(255,192,64,0.2), 0 20px 60px rgba(0,0,0,0.6);
  animation:evPop 0.4s ease; max-width:420px; width:90%;
}
.tut-complete-medal {
  font-size:72px; margin-bottom:16px;
  filter:drop-shadow(0 0 24px rgba(255,192,64,0.6));
  animation:tutMedalGlow 2s ease-in-out infinite;
}
@keyframes tutMedalGlow {
  0%,100% { filter:drop-shadow(0 0 24px rgba(255,192,64,0.4)); }
  50%     { filter:drop-shadow(0 0 40px rgba(255,192,64,0.8)); }
}
.tut-complete-title {
  font-family:'Orbitron',monospace; font-size:24px; font-weight:900;
  letter-spacing:4px; color:var(--gold);
  text-shadow:0 0 30px rgba(255,192,64,0.4);
  margin-bottom:8px;
  animation:tutTitleGlow 2.5s ease-in-out infinite;
}
@keyframes tutTitleGlow {
  0%,100% { text-shadow:0 0 20px rgba(255,192,64,0.3); }
  50%     { text-shadow:0 0 40px rgba(255,192,64,0.6), 0 0 60px rgba(255,192,64,0.2); }
}
.tut-complete-sub {
  font-family:'Rajdhani',sans-serif; font-size:16px; font-weight:500;
  color:var(--text); margin-bottom:20px;
}
.tut-complete-phases {
  display:flex; flex-direction:column; gap:8px; margin-bottom:24px;
}
.tut-complete-phase {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--success); padding:8px 16px;
  background:rgba(0,200,100,0.06); border:1px solid rgba(0,200,100,0.2);
  border-radius:6px;
}
.tut-complete-btn {
  padding:14px 36px; border-radius:8px; cursor:pointer;
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  letter-spacing:2px; border:1px solid var(--gold); color:var(--gold);
  background:rgba(255,192,64,0.12); transition:all 0.2s;
}
.tut-complete-btn:hover {
  background:rgba(255,192,64,0.25);
  box-shadow:0 0 20px rgba(255,192,64,0.3);
  transform:translateY(-2px);
}

/* ══ TUTORIAL CELEBRATION OVERLAY ══ */
.tut-complete-overlay {
  position:fixed; inset:0; z-index:9600;
  display:flex; align-items:center; justify-content:center;
  background:rgba(2,4,12,0.92); backdrop-filter:blur(12px);
  animation:fadeIn 0.4s ease;
}
.tut-complete-box {
  text-align:center; padding:40px 48px;
  background:linear-gradient(180deg,var(--surface2) 0%,var(--bg2) 100%);
  border:1px solid var(--gold); border-radius:18px;
  box-shadow:0 0 80px rgba(255,192,64,0.2), 0 20px 60px rgba(0,0,0,0.6);
  animation:evPop 0.4s ease; max-width:420px; width:90%;
}
.tut-complete-medal {
  font-size:72px; margin-bottom:16px;
  filter:drop-shadow(0 0 24px rgba(255,192,64,0.6));
  animation:tutMedalGlow 2s ease-in-out infinite;
}
@keyframes tutMedalGlow {
  0%,100% { filter:drop-shadow(0 0 24px rgba(255,192,64,0.4)); }
  50%     { filter:drop-shadow(0 0 40px rgba(255,192,64,0.8)); }
}
.tut-complete-title {
  font-family:'Orbitron',monospace; font-size:24px; font-weight:900;
  letter-spacing:4px; color:var(--gold);
  text-shadow:0 0 30px rgba(255,192,64,0.4);
  margin-bottom:8px;
  animation:tutTitleGlow 2.5s ease-in-out infinite;
}
@keyframes tutTitleGlow {
  0%,100% { text-shadow:0 0 20px rgba(255,192,64,0.3); }
  50%     { text-shadow:0 0 40px rgba(255,192,64,0.6), 0 0 60px rgba(255,192,64,0.2); }
}
.tut-complete-sub {
  font-family:'Rajdhani',sans-serif; font-size:16px; font-weight:500;
  color:var(--text); margin-bottom:20px;
}
.tut-complete-phases {
  display:flex; flex-direction:column; gap:8px; margin-bottom:24px;
}
.tut-complete-phase {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--success); padding:8px 16px;
  background:rgba(0,200,100,0.06); border:1px solid rgba(0,200,100,0.2);
  border-radius:6px;
}
.tut-complete-btn {
  padding:14px 36px; border-radius:8px; cursor:pointer;
  font-family:'Orbitron',monospace; font-size:13px; font-weight:700;
  letter-spacing:2px; border:1px solid var(--gold); color:var(--gold);
  background:rgba(255,192,64,0.12); transition:all 0.2s;
}
.tut-complete-btn:hover {
  background:rgba(255,192,64,0.25);
  box-shadow:0 0 20px rgba(255,192,64,0.3);
  transform:translateY(-2px);
}

/* ══ TUTORIAL SPOTLIGHT ══ */
.tut-spotlight-overlay {
  position:fixed; inset:0; z-index:8600;
  background:rgba(4,8,18,0.65);
  cursor:pointer;
}
.tut-spotlight-highlight {
  position:absolute;
  border:2px solid var(--accent);
  border-radius:8px;
  box-shadow:0 0 0 9999px rgba(4,8,18,0.65), 0 0 20px rgba(var(--accent-rgb),0.4);
  background:transparent;
  animation:tutPulse 1.8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes tutPulse {
  0%,100% { box-shadow:0 0 0 9999px rgba(4,8,18,0.65), 0 0 20px rgba(var(--accent-rgb),0.3); }
  50%     { box-shadow:0 0 0 9999px rgba(4,8,18,0.65), 0 0 35px rgba(var(--accent-rgb),0.6); }
}
.tut-spotlight-tooltip {
  position:absolute; padding:8px 16px;
  background:var(--surface); border:1px solid var(--accent);
  border-radius:6px; color:var(--accent);
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:1px; white-space:nowrap; pointer-events:none;
  box-shadow:0 4px 16px rgba(var(--accent-rgb),0.25);
}

/* ══ LORE BRIEFING OVERLAY ══ */
#loreOverlay {
  position:fixed; inset:0; z-index:9998;
  display:flex; align-items:center; justify-content:center;
  background:url('../background.png') center/cover no-repeat;
}
#loreOverlay::before {
  content:''; position:absolute; inset:0;
  background:rgba(8,16,30,0.5);
}
.lore-terminal {
  position:relative; z-index:1;
  max-width:700px; width:90%;
  background:rgba(10,18,35,0.88);
  border:1px solid var(--accent);
  border-radius:12px; padding:32px 36px;
  box-shadow:0 0 60px rgba(var(--accent-rgb),0.15);
}
.lore-header {
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  letter-spacing:3px; color:var(--accent);
  text-align:center; margin-bottom:24px;
  text-transform:uppercase;
}
.lore-body { display:flex; flex-direction:column; gap:6px; min-height:180px; }
.lore-line {
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--accent3); line-height:1.7;
  opacity:0; animation:loreFadeIn 0.5s ease forwards;
}
.lore-skip {
  margin-top:24px; display:none;
}
@keyframes loreFadeIn {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ══ FACTION SELECTOR ══ */
.faction-selector {
  display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-top:6px;
}
.faction-card {
  position:relative;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:8px 6px; border-radius:6px; cursor:pointer;
  background:rgba(10,18,32,0.7); border:1px solid var(--border);
  transition:all 0.2s; text-align:center;
}
.faction-info-btn {
  position:absolute; top:3px; right:3px;
  width:18px; height:18px; border-radius:50%;
  background:rgba(var(--accent-rgb),0.12); border:1px solid rgba(var(--accent-rgb),0.25);
  color:var(--accent); font-size:11px; font-weight:bold;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all 0.2s; line-height:1;
}
.faction-info-btn:hover { background:rgba(var(--accent-rgb),0.3); transform:scale(1.15); }
.faction-card:hover { border-color:var(--accent); background:rgba(var(--accent-rgb),0.08); }
.faction-card.active { border-color:var(--gold); background:rgba(255,192,64,0.10); box-shadow:0 0 12px rgba(255,192,64,0.2); }
.faction-card:last-child { grid-column:1/-1; }
.faction-icon { font-size:20px; }
.faction-name {
  font-family:'Orbitron',monospace; font-size:9px; font-weight:700;
  color:var(--textbright); letter-spacing:1px;
}
.faction-bonus {
  font-family:'Share Tech Mono',monospace; font-size:8px;
  color:var(--success); line-height:1.3;
}
.faction-card[data-faction="tauri"].active { border-color:#44cc44; box-shadow:0 0 18px rgba(68,204,68,0.5); }
.faction-card[data-faction="goauld"].active { border-color:#ffd000; box-shadow:0 0 18px rgba(255,208,0,0.5); }
.faction-card[data-faction="anciens"].active { border-color:#00e5ff; box-shadow:0 0 22px rgba(0,229,255,0.6); }
.faction-card[data-faction="wraith"].active { border-color:#bb66ff; box-shadow:0 0 18px rgba(187,102,255,0.5); }
.faction-card[data-faction="tokra"].active { border-color:#ff4040; box-shadow:0 0 18px rgba(255,64,64,0.5); }

/* Faction badge displayed in-game */
.faction-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-family:'Share Tech Mono',monospace; font-size:10px;
  padding:2px 8px; border-radius:10px; border:1px solid;
  text-shadow:0 0 8px currentColor;
}
.faction-badge.f-tauri   { color:#44cc44; border-color:rgba(68,204,68,0.55); background:rgba(68,204,68,0.08); }
.faction-badge.f-goauld  { color:#ffd000; border-color:rgba(255,208,0,0.55); background:rgba(255,208,0,0.08); }
.faction-badge.f-anciens { color:#00e5ff; border-color:rgba(0,229,255,0.6); background:rgba(0,229,255,0.10); }
.faction-badge.f-wraith  { color:#bb66ff; border-color:rgba(187,102,255,0.55); background:rgba(187,102,255,0.08); }
.faction-badge.f-tokra   { color:#ff4040; border-color:rgba(255,64,64,0.55); background:rgba(255,64,64,0.08); }

@media (max-width:480px) {
  .faction-selector { grid-template-columns:1fr 1fr; gap:4px; }
  .faction-card { padding:6px 4px; }
  .faction-icon { font-size:16px; }
}

/* ══ FACTION INFO POPUP (registration) ══ */
.fi-overlay {
  position:fixed; inset:0; z-index:10000; background:rgba(2,4,12,0.92);
  display:flex; justify-content:center; align-items:center;
  backdrop-filter:blur(12px); animation:fadeIn 0.25s ease;
}
.fi-popup {
  background:linear-gradient(180deg,var(--surface2) 0%,var(--bg2) 100%);
  border:1px solid; border-radius:16px;
  width:440px; max-width:90vw; max-height:85vh; overflow-y:auto;
  padding:28px 24px; position:relative;
  box-shadow:0 0 60px rgba(0,0,0,0.6);
  animation:evPop 0.3s ease;
}
.fi-title {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:900;
  text-align:center; letter-spacing:2px; margin-bottom:16px;
  text-shadow:0 0 20px currentColor;
}
.fi-lore {
  font-family:'Rajdhani',sans-serif; font-size:14px; font-weight:500;
  color:var(--text); text-align:center; line-height:1.7;
  margin-bottom:20px; opacity:0.85;
}
.fi-section {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  color:var(--textsoft); letter-spacing:2px; margin-bottom:10px;
  text-align:center;
}
.fi-bonuses { display:flex; flex-direction:column; gap:6px; margin-bottom:20px; }
.fi-bonus-row {
  display:flex; align-items:center; gap:10px;
  padding:8px 14px; border-radius:8px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
}
.fi-bonus-icon { font-size:18px; flex-shrink:0; }
.fi-bonus-lbl { flex:1; font-family:'Rajdhani',sans-serif; font-size:14px; color:var(--text); }
.fi-bonus-val { font-family:'Orbitron',monospace; font-size:13px; font-weight:700; }
.fi-choose {
  display:block; width:100%; padding:12px; border-radius:8px;
  background:rgba(255,255,255,0.04); border:1px solid;
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  cursor:pointer; letter-spacing:2px; transition:all 0.2s;
}
.fi-choose:hover { background:rgba(255,255,255,0.1); }
.fi-close {
  position:absolute; top:10px; right:14px;
  background:none; border:none; color:var(--textsoft);
  font-size:18px; cursor:pointer; padding:4px;
}
.fi-close:hover { color:var(--text); }

/* ═══ ASCENSION PAGE ═══ */
#ascensionContainer {
  min-height:100%;
  background: url('/img/ascension.png') center top / cover no-repeat fixed;
  padding:16px;
}
.asc-page { max-width:900px; margin:0 auto; }
.asc-hero {
  text-align:center; padding:28px 24px 20px;
  background:rgba(8,14,28,0.88); border-radius:10px;
  border:1px solid rgba(255,192,64,0.15);
  backdrop-filter:blur(10px); margin-bottom:0;
}
.asc-title { font-family:'Orbitron',monospace; font-size:24px; color:var(--gold); letter-spacing:4px; text-shadow:0 0 14px rgba(255,192,64,0.25); }
.asc-level { margin:10px 0 8px; }
.asc-level-num { font-family:'Orbitron',monospace; font-size:48px; color:var(--gold); text-shadow:0 0 24px rgba(255,192,64,0.3); }
.asc-level-label { font-size:18px; color:var(--textsoft); }
.asc-progress-bar { height:6px; background:rgba(255,255,255,0.06); border-radius:4px; overflow:hidden; margin:0 auto 8px; max-width:280px; }
.asc-progress-fill { height:100%; background:linear-gradient(90deg,var(--gold),#ffe080); border-radius:4px; transition:width .4s; }
.asc-bonus { font-family:'Share Tech Mono',monospace; font-size:15px; color:var(--text); margin:4px 0 2px; }
.asc-bonus-val { color:var(--gold); font-weight:700; font-size:17px; }
.asc-btn {
  display:inline-block; padding:14px 36px; margin-top:12px; border:1px solid var(--gold); border-radius:8px;
  background:linear-gradient(135deg,rgba(255,192,64,.15),rgba(255,224,128,.08));
  color:var(--gold); font-family:'Orbitron',monospace; font-size:14px; font-weight:700; letter-spacing:1.5px; cursor:pointer;
  transition:all .2s;
}
.asc-btn:hover:not(.disabled) { background:rgba(255,192,64,.25); box-shadow:0 0 16px rgba(255,192,64,.35); transform:translateY(-1px); }
.asc-btn.disabled { opacity:.35; cursor:not-allowed; }
.asc-warn { text-align:center; font-family:'Share Tech Mono',monospace; font-size:12px; color:var(--textsoft); padding:6px 0; }
.asc-warn.asc-max { color:var(--gold); font-size:13px; }

/* ═══ ASCENSION TABS ═══ */
.asc-tabs {
  display:flex; gap:0;
  background:rgba(8,14,28,0.92); border-radius:0 0 10px 10px;
  border:1px solid rgba(255,255,255,0.08); border-top:none;
  overflow:hidden; margin-bottom:14px;
}
.asc-tab {
  flex:1; padding:12px 8px; text-align:center;
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  letter-spacing:2px; color:var(--textsoft); cursor:pointer;
  transition:all 0.2s; border-right:1px solid rgba(255,255,255,0.05);
  text-transform:uppercase;
}
.asc-tab:last-child { border-right:none; }
.asc-tab:hover { color:var(--textbright); background:rgba(255,255,255,0.03); }
.asc-tab.active {
  color:var(--gold); background:rgba(255,192,64,0.08);
  box-shadow:inset 0 -2px 0 var(--gold);
}
.asc-tab-content { min-height:200px; }
.asc-empty {
  text-align:center; padding:40px 20px;
  font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--textsoft);
}

/* ═══ ASCENSION CARDS ═══ */
.asc-card {
  background:rgba(6,10,22,0.92); border:1px solid rgba(255,255,255,0.1);
  border-radius:8px; padding:16px; backdrop-filter:blur(12px);
}
.asc-card-title {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  letter-spacing:1.5px; margin-bottom:10px;
}
.asc-ct-green { color:#4dff90; }
.asc-ct-blue { color:#66aaff; }
.asc-ct-gold { color:var(--gold); }
.asc-ct-dim { color:var(--textsoft); }
.asc-dim { font-size:11px; color:var(--textsoft); }

/* ═══ TAB: PROCHAIN NIVEAU ═══ */
.asc-next-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:700px) { .asc-next-grid { grid-template-columns:1fr; } }

.asc-reward-row {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:rgba(255,255,255,0.9); padding:4px 0; line-height:1.6;
}
.asc-reward-row strong { color:#4dff90; }

.asc-perk-row {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.85); padding:5px 0; line-height:1.5;
}
.asc-perk-row-icon { font-size:16px; flex-shrink:0; }
.asc-perk-row strong { color:var(--gold); }

/* ═══ CONDITIONS ═══ */
.asc-cond-row {
  padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.04);
}
.asc-cond-row:last-child { border-bottom:none; }
.asc-cond-head {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.85);
}
.asc-cond-label { flex:1; }
.asc-cond-status { font-weight:700; width:16px; text-align:center; }
.asc-cond-row.met .asc-cond-status { color:#4dff90; }
.asc-cond-row:not(.met) .asc-cond-status { color:#ff5050; }
.asc-cond-val {
  font-size:11px; color:rgba(255,255,255,0.6); white-space:nowrap;
}
.asc-cond-bar {
  height:4px; background:rgba(255,255,255,0.06); border-radius:3px;
  overflow:hidden; margin-top:4px;
}
.asc-cond-fill {
  height:100%; background:#ff5050; border-radius:3px; transition:width .4s;
}
.asc-cond-fill.ok { background:#4dff90; }

/* ═══ RESET BLOCK ═══ */
.asc-reset-cols { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:8px; }
.asc-reset-col {
  padding:10px; border-radius:6px; font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.8); line-height:1.6;
}
.asc-reset-col.keep { background:rgba(0,220,120,0.04); border:1px solid rgba(0,220,120,0.15); }
.asc-reset-col.lose { background:rgba(255,60,60,0.04); border:1px solid rgba(255,60,60,0.15); }
.asc-reset-hd {
  font-family:'Orbitron',monospace; font-size:9px; font-weight:700;
  letter-spacing:1.5px; margin-bottom:6px;
}
.asc-reset-col.keep .asc-reset-hd { color:var(--success); }
.asc-reset-col.lose .asc-reset-hd { color:var(--danger); }
@media (max-width:520px) { .asc-reset-cols { grid-template-columns:1fr; } }

/* ═══ COLLAPSIBLE ═══ */
.asc-collapsible.collapsed .asc-collapsible-body { display:none; }
.asc-road-toggle { font-size:10px; transition:transform 0.2s; color:var(--textsoft); margin-left:6px; }
.asc-collapsible.collapsed .asc-road-toggle { transform:rotate(-90deg); }

/* ═══ PERK BADGES ═══ */
.asc-perk-badges { display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.asc-perk-badge {
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:20px;
  background:linear-gradient(135deg,rgba(255,192,64,0.08),rgba(224,168,48,0.04));
  border:1px solid rgba(255,192,64,0.3);
  cursor:default; transition:all 0.2s;
}
.asc-perk-badge:hover { border-color:var(--gold); box-shadow:0 0 8px rgba(255,192,64,0.15); }
.asc-pb-name { font-family:'Share Tech Mono',monospace; font-size:10px; color:var(--gold); font-weight:700; }
.asc-pb-lv { font-family:'Share Tech Mono',monospace; font-size:9px; color:var(--textsoft); }

/* ═══ TAB: SAISON ═══ */
.asc-season-meta { font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--text); margin:6px 0; }
.asc-season-score { font-family:'Share Tech Mono',monospace; font-size:14px; color:var(--text); margin:6px 0 10px; }
.asc-lb-table { width:100%; border-collapse:collapse; font-size:12px; margin-top:6px; }
.asc-lb-table th { font-family:'Orbitron',monospace; font-size:9px; color:var(--gold); text-align:left; padding:4px 6px; border-bottom:1px solid var(--border); letter-spacing:1px; }
.asc-lb-table td { padding:3px 6px; border-bottom:1px solid rgba(255,255,255,.04); font-family:'Share Tech Mono',monospace; }
.asc-lb-me { background:rgba(255,192,64,.08); }
.asc-lb-me td { color:var(--gold); }

/* ═══ ASCENSION PERK MODAL ═══ */
.asc-perk-overlay {
  position:fixed; inset:0; z-index:9200;
  display:flex; align-items:center; justify-content:center;
  background:rgba(4,8,18,0.85); backdrop-filter:blur(6px);
  animation:fadeIn 0.3s;
}
.asc-perk-modal {
  width:700px; max-width:92vw; max-height:90vh; overflow-y:auto;
  background:rgba(10,18,35,0.95); border:1px solid var(--gold);
  border-radius:12px; padding:24px;
  box-shadow:0 0 50px rgba(255,192,64,0.15), 0 20px 60px rgba(0,10,30,0.8);
  animation:slideInUp 0.35s ease;
}
.asc-perk-modal-header { text-align:center; margin-bottom:20px; }
.asc-perk-modal-title {
  font-family:'Orbitron',monospace; font-size:18px; font-weight:900;
  letter-spacing:3px; color:var(--gold);
  text-shadow:0 0 16px rgba(255,192,64,0.3);
}
.asc-perk-modal-sub {
  font-family:'Share Tech Mono',monospace; font-size:11px;
  color:var(--textsoft); margin-top:4px; letter-spacing:1px;
}
.asc-perk-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:16px; }
.asc-perk-card {
  display:flex; flex-direction:column; align-items:center;
  padding:18px 14px; border-radius:10px; cursor:pointer;
  background:rgba(255,192,64,0.03); border:1px solid rgba(255,192,64,0.15);
  transition:all 0.25s; text-align:center; gap:8px;
}
.asc-perk-card:hover {
  border-color:var(--gold); background:rgba(255,192,64,0.08);
  box-shadow:0 0 20px rgba(255,192,64,0.15);
  transform:translateY(-3px);
}
.asc-perk-card-icon { font-size:32px; }
.asc-perk-card-name {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  color:var(--gold); letter-spacing:1px;
}
.asc-perk-card-desc {
  font-family:'Share Tech Mono',monospace; font-size:10px;
  color:var(--textsoft); line-height:1.5;
}
.asc-perk-card-btn {
  margin-top:auto; padding:6px 16px; border-radius:4px;
  background:rgba(255,192,64,0.1); border:1px solid rgba(255,192,64,0.3);
  color:var(--gold); font-family:'Orbitron',monospace; font-size:9px;
  font-weight:700; letter-spacing:1px; transition:all 0.2s;
}
.asc-perk-card:hover .asc-perk-card-btn { background:rgba(255,192,64,0.2); }
.asc-perk-modal-warn {
  text-align:center; font-family:'Share Tech Mono',monospace;
  font-size:10px; color:var(--warn); margin-bottom:12px;
}
.asc-perk-modal-footer { display:flex; justify-content:center; }
.asc-perk-cancel {
  padding:8px 28px; border-radius:6px;
  border:1px solid var(--border); background:transparent;
  color:var(--textsoft); font-family:'Orbitron',monospace; font-size:10px;
  cursor:pointer; transition:all 0.2s;
}
.asc-perk-cancel:hover { color:var(--textbright); border-color:var(--textmid); }
@media (max-width:640px) {
  .asc-perk-cards { grid-template-columns:1fr; }
  .asc-perk-modal { padding:16px; }
}

/* ═══ ROADMAP — ALL LEVELS ═══ */
.asc-road-body { display:flex; flex-direction:column; gap:6px; }
.asc-road-row {
  border-radius:6px; border-left:3px solid transparent;
  cursor:pointer; overflow:hidden;
  transition:background 0.2s;
}
.asc-road-row:hover { background:rgba(255,255,255,0.03); }
.asc-road-header {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px;
}
.asc-road-arrow {
  margin-left:auto; font-size:10px; color:var(--textsoft);
  transition:transform 0.2s;
}
.asc-road-row.expanded .asc-road-arrow { transform:rotate(180deg); }
.asc-road-details { display:none; padding:2px 14px 12px; }
.asc-road-row.expanded .asc-road-details { display:block; }
.asc-road-section-title {
  font-family:'Orbitron',monospace; font-size:10px; font-weight:700;
  color:var(--gold); margin:8px 0 6px; text-transform:uppercase;
  letter-spacing:1px;
}
.asc-road-done { border-left-color:var(--success); background:rgba(0,200,100,0.05); }
.asc-road-current { border-left-color:var(--gold); background:rgba(224,180,40,0.1); }
.asc-road-locked { border-left-color:var(--border); opacity:0.85; }
.asc-road-lv {
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  white-space:nowrap; min-width:60px;
}
.asc-road-done .asc-road-lv { color:var(--success); }
.asc-road-current .asc-road-lv { color:var(--gold); }
.asc-road-bonus {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--accent2); font-weight:700;
}
.asc-road-cumul { font-size:11px; color:var(--textsoft); font-weight:400; }
.asc-road-perks { display:flex; flex-direction:column; gap:5px; }
.asc-road-perk {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  padding:6px 10px; border-radius:5px;
  background:rgba(255,192,64,0.04); border:1px solid rgba(255,192,64,0.12);
  color:var(--text);
}
.asc-road-perk strong { color:var(--gold); }
.asc-road-perk.chosen {
  border-color:var(--success); color:var(--success);
  background:rgba(0,200,100,0.06);
}
.asc-road-conds { display:flex; flex-direction:column; gap:4px; }
.asc-road-cond {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--text); padding:4px 10px; border-radius:5px;
  background:rgba(100,160,255,0.04); border:1px solid rgba(100,160,255,0.1);
}
.asc-road-cond strong { color:var(--accent2); }

/* ══ TALENT TREE ══ */
.tal-tree { display:flex; flex-direction:column; gap:14px; }
.tal-branch {
  background:rgba(14,24,44,0.93); border:1px solid rgba(255,255,255,0.12);
  border-radius:10px; padding:16px 18px; transition:border-color 0.2s, box-shadow 0.2s;
  border-left:3px solid var(--border); box-shadow:0 2px 10px rgba(0,0,0,0.4);
}
.tal-branch:hover { border-color:rgba(var(--accent-rgb),0.4); box-shadow:0 4px 16px rgba(0,10,30,0.5); }
.tal-b-guerre    { border-left-color:#ff5544; }
.tal-b-economie  { border-left-color:#44cc88; }
.tal-b-science   { border-left-color:#4488ff; }
.tal-b-expansion { border-left-color:#aa66ff; }
.tal-b-maitrise  { border-left-color:var(--gold); }
.tal-branch-head { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.tal-branch-icon { font-size:22px; }
.tal-branch-name {
  font-family:'Orbitron',monospace; font-size:14px; font-weight:700;
  color:var(--textbright); letter-spacing:1.5px; flex:1; text-transform:uppercase;
}
.tal-branch-rank {
  font-family:'Share Tech Mono',monospace; font-size:15px; color:var(--gold); font-weight:700;
}
.tal-bar { height:7px; background:rgba(255,255,255,0.07); border-radius:4px; overflow:hidden; margin-bottom:10px; }
.tal-bar-fill { height:100%; border-radius:4px; transition:width .3s; box-shadow:0 0 6px rgba(255,255,255,0.15); }
.tal-c-guerre    { background:linear-gradient(90deg,#ff4444,#ff8844); }
.tal-c-economie  { background:linear-gradient(90deg,#44cc88,#88ffaa); }
.tal-c-science   { background:linear-gradient(90deg,#4488ff,#66bbff); }
.tal-c-expansion { background:linear-gradient(90deg,#aa66ff,#dd88ff); }
.tal-c-maitrise  { background:linear-gradient(90deg,var(--gold),#ffe080); }
.tal-pp {
  font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--text);
  margin-bottom:10px; padding:6px 10px; border-radius:5px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.05);
}
.tal-milestones { display:flex; flex-direction:column; gap:5px; margin-bottom:10px; }
.tal-ms {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:13px;
  padding:4px 8px; border-radius:5px; transition:background 0.2s;
}
.tal-ms:hover { background:rgba(255,255,255,0.03); }
.tal-ms.reached { color:var(--gold); }
.tal-ms.locked { color:var(--textsoft); opacity:0.65; }
.tal-ms-dot { font-size:12px; }
.tal-ms-thr {
  min-width:22px; text-align:center; font-weight:700;
  font-size:11px; padding:2px 6px; border-radius:4px;
  background:rgba(255,255,255,0.06); color:var(--textmid);
}
.tal-ms.reached .tal-ms-thr { background:rgba(255,192,64,0.18); color:var(--gold); }
.tal-ms-desc { flex:1; }
.tal-branch-foot { display:flex; justify-content:flex-end; margin-top:4px; }
.tal-add {
  width:36px; height:36px; border-radius:50%; border:2px solid var(--gold);
  background:rgba(255,192,64,0.08); color:var(--gold);
  font-size:20px; font-weight:700; cursor:pointer; transition:all 0.2s;
  display:flex; align-items:center; justify-content:center;
}
.tal-add:hover:not(.disabled) { background:rgba(255,192,64,0.25); box-shadow:0 0 14px rgba(255,192,64,0.35); transform:scale(1.1); }
.tal-add.disabled { opacity:0.25; cursor:not-allowed; }
.tal-respec { text-align:center; margin-top:16px; }
.tal-respec-btn {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  padding:10px 24px; border-radius:6px; cursor:pointer;
  border:1px solid var(--danger); color:var(--danger);
  background:rgba(255,60,60,0.06); transition:all 0.2s; letter-spacing:0.5px;
}
.tal-respec-btn:hover { background:rgba(255,60,60,0.18); box-shadow:0 0 12px rgba(255,60,60,0.25); }
.tal-legend {
  background:rgba(0,6,18,0.85); border:1px solid rgba(255,192,64,0.25);
  border-radius:8px; padding:10px 14px; margin-bottom:14px;
  font-size:12px; color:var(--gold); line-height:1.5; text-align:center;
  backdrop-filter:blur(6px);
}

/* ══ FACTION SELECTOR ══ */
.faction-selector {
  display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-top:6px;
}
.faction-card {
  position:relative;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:8px 6px; border-radius:6px; cursor:pointer;
  background:rgba(10,18,32,0.7); border:1px solid var(--border);
  transition:all 0.2s; text-align:center;
}
.faction-info-btn {
  position:absolute; top:3px; right:3px;
  width:18px; height:18px; border-radius:50%;
  background:rgba(var(--accent-rgb),0.12); border:1px solid rgba(var(--accent-rgb),0.25);
  color:var(--accent); font-size:11px; font-weight:bold;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all 0.2s; line-height:1;
}
.faction-info-btn:hover { background:rgba(var(--accent-rgb),0.3); transform:scale(1.15); }
.faction-card:hover { border-color:var(--accent); background:rgba(var(--accent-rgb),0.08); }
.faction-card.active { border-color:var(--gold); background:rgba(255,192,64,0.10); box-shadow:0 0 12px rgba(255,192,64,0.2); }
.faction-card:last-child { grid-column:1/-1; }
.faction-icon { font-size:20px; }
.faction-name {
  font-family:'Orbitron',monospace; font-size: 11px; font-weight:700;
  color:var(--textbright); letter-spacing:1px;
}
.faction-bonus {
  font-family:'Share Tech Mono',monospace; font-size: 10px;
  color:var(--success); line-height:1.3;
}
.faction-card[data-faction="tauri"].active { border-color:#44cc44; box-shadow:0 0 18px rgba(68,204,68,0.5); }
.faction-card[data-faction="goauld"].active { border-color:#ffd000; box-shadow:0 0 18px rgba(255,208,0,0.5); }
.faction-card[data-faction="anciens"].active { border-color:#00e5ff; box-shadow:0 0 22px rgba(0,229,255,0.6); }
.faction-card[data-faction="wraith"].active { border-color:#bb66ff; box-shadow:0 0 18px rgba(187,102,255,0.5); }
.faction-card[data-faction="tokra"].active { border-color:#ff4040; box-shadow:0 0 18px rgba(255,64,64,0.5); }

/* Faction badge displayed in-game */
.faction-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  padding:2px 8px; border-radius:10px; border:1px solid;
  text-shadow:0 0 8px currentColor;
}
.faction-badge.f-tauri   { color:#44cc44; border-color:rgba(68,204,68,0.55); background:rgba(68,204,68,0.08); }
.faction-badge.f-goauld  { color:#ffd000; border-color:rgba(255,208,0,0.55); background:rgba(255,208,0,0.08); }
.faction-badge.f-anciens { color:#00e5ff; border-color:rgba(0,229,255,0.6); background:rgba(0,229,255,0.10); }
.faction-badge.f-wraith  { color:#bb66ff; border-color:rgba(187,102,255,0.55); background:rgba(187,102,255,0.08); }
.faction-badge.f-tokra   { color:#ff4040; border-color:rgba(255,64,64,0.55); background:rgba(255,64,64,0.08); }

@media (max-width:480px) {
  .faction-selector { grid-template-columns:1fr 1fr; gap:4px; }
  .faction-card { padding:6px 4px; }
  .faction-icon { font-size:16px; }
}

/* ══ FACTION INFO POPUP (registration) ══ */
.fi-overlay {
  position:fixed; inset:0; z-index:10000; background:rgba(2,4,12,0.92);
  display:flex; justify-content:center; align-items:center;
  backdrop-filter:blur(12px); animation:fadeIn 0.25s ease;
}
.fi-popup {
  background:linear-gradient(180deg,var(--surface2) 0%,var(--bg2) 100%);
  border:1px solid; border-radius:16px;
  width:440px; max-width:90vw; max-height:85vh; overflow-y:auto;
  padding:28px 24px; position:relative;
  box-shadow:0 0 60px rgba(0,0,0,0.6);
  animation:evPop 0.3s ease;
}
.fi-title {
  font-family:'Orbitron',monospace; font-size:15px; font-weight:900;
  text-align:center; letter-spacing:2px; margin-bottom:16px;
  text-shadow:0 0 20px currentColor;
}
.fi-lore {
  font-family:'Rajdhani',sans-serif; font-size:14px; font-weight:500;
  color:var(--text); text-align:center; line-height:1.7;
  margin-bottom:20px; opacity:0.85;
}
.fi-section {
  font-family:'Orbitron',monospace; font-size:11px; font-weight:700;
  color:var(--textsoft); letter-spacing:2px; margin-bottom:10px;
  text-align:center;
}
.fi-bonuses { display:flex; flex-direction:column; gap:6px; margin-bottom:20px; }
.fi-bonus-row {
  display:flex; align-items:center; gap:10px;
  padding:8px 14px; border-radius:8px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
}
.fi-bonus-icon { font-size:18px; flex-shrink:0; }
.fi-bonus-lbl { flex:1; font-family:'Rajdhani',sans-serif; font-size:14px; color:var(--text); }
.fi-bonus-val { font-family:'Orbitron',monospace; font-size:13px; font-weight:700; }
.fi-choose {
  display:block; width:100%; padding:12px; border-radius:8px;
  background:rgba(255,255,255,0.04); border:1px solid;
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  cursor:pointer; letter-spacing:2px; transition:all 0.2s;
}
.fi-choose:hover { background:rgba(255,255,255,0.1); }
.fi-close {
  position:absolute; top:10px; right:14px;
  background:none; border:none; color:var(--textsoft);
  font-size:18px; cursor:pointer; padding:4px;
}
.fi-close:hover { color:var(--text); }

/* ═══ ASCENSION PAGE ═══ */
#ascensionContainer {
  min-height:100%;
  background: url('/img/ascension.png') center top / cover no-repeat fixed;
  padding:16px;
}
.asc-page { max-width:900px; margin:0 auto; }
.asc-hero {
  text-align:center; padding:24px 20px 18px;
  background:rgba(8,14,28,0.88); border-radius:10px;
  border:1px solid rgba(255,192,64,0.15);
  backdrop-filter:blur(10px); margin-bottom:0;
}
.asc-title { font-family:'Orbitron',monospace; font-size:22px; color:var(--gold); letter-spacing:3px; text-shadow:0 0 14px rgba(255,192,64,0.25); }
.asc-level { margin:8px 0 6px; }
.asc-level-num { font-family:'Orbitron',monospace; font-size:40px; color:var(--gold); text-shadow:0 0 20px rgba(255,192,64,0.3); }
.asc-level-label { font-size:16px; color:var(--textsoft); }
.asc-progress-bar { height:6px; background:rgba(255,255,255,0.06); border-radius:4px; overflow:hidden; margin:0 auto 8px; max-width:280px; }
.asc-progress-fill { height:100%; background:linear-gradient(90deg,var(--gold),#ffe080); border-radius:4px; transition:width .4s; }
.asc-bonus { font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--text); }
.asc-bonus-val { color:var(--gold); font-weight:700; font-size:15px; }
.asc-btn {
  display:inline-block; padding:12px 32px; margin-top:10px; border:1px solid var(--gold); border-radius:8px;
  background:linear-gradient(135deg,rgba(255,192,64,.15),rgba(255,224,128,.08));
  color:var(--gold); font-family:'Orbitron',monospace; font-size:13px; font-weight:700; letter-spacing:1px; cursor:pointer;
  transition:all .2s;
}
.asc-btn:hover:not(.disabled) { background:rgba(255,192,64,.25); box-shadow:0 0 16px rgba(255,192,64,.35); transform:translateY(-1px); }
.asc-btn.disabled { opacity:.35; cursor:not-allowed; }
.asc-warn { text-align:center; font-family:'Share Tech Mono',monospace; font-size: 12px; color:var(--textsoft); padding:4px 0; }
.asc-warn.asc-max { color:var(--gold); font-size:12px; }

/* ═══ ASCENSION TABS ═══ */
.asc-tabs {
  display:flex; gap:0;
  background:rgba(8,14,28,0.92); border-radius:0 0 10px 10px;
  border:1px solid rgba(255,255,255,0.08); border-top:none;
  overflow:hidden; margin-bottom:14px;
}
.asc-tab {
  flex:1; padding:11px 8px; text-align:center;
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:1.5px; color:var(--textsoft); cursor:pointer;
  transition:all 0.2s; border-right:1px solid rgba(255,255,255,0.05);
}
.asc-tab:last-child { border-right:none; }
.asc-tab:hover { color:var(--textbright); background:rgba(255,255,255,0.03); }
.asc-tab.active {
  color:var(--gold); background:rgba(255,192,64,0.08);
  box-shadow:inset 0 -2px 0 var(--gold);
}
.asc-tab-content { min-height:200px; }
.asc-empty {
  text-align:center; padding:40px 20px;
  font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--textsoft);
}

/* ═══ ASCENSION CARDS ═══ */
.asc-card {
  background:rgba(6,10,22,0.92); border:1px solid rgba(255,255,255,0.1);
  border-radius:8px; padding:16px; backdrop-filter:blur(12px);
}
.asc-card-title {
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  letter-spacing:1.5px; margin-bottom:10px;
}
.asc-ct-green { color:#4dff90; }
.asc-ct-blue { color:#66aaff; }
.asc-ct-gold { color:var(--gold); }
.asc-ct-dim { color:var(--textsoft); }
.asc-dim { font-size: 12px; color:var(--textsoft); }

/* ═══ TAB: PROCHAIN NIVEAU ═══ */
.asc-next-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:700px) { .asc-next-grid { grid-template-columns:1fr; } }

.asc-reward-row {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:rgba(255,255,255,0.9); padding:4px 0; line-height:1.6;
}
.asc-reward-row strong { color:#4dff90; }

.asc-perk-row {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.85); padding:5px 0; line-height:1.5;
}
.asc-perk-row-icon { font-size:16px; flex-shrink:0; }
.asc-perk-row strong { color:var(--gold); }

/* ═══ CONDITIONS ═══ */
.asc-cond-row {
  padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.04);
}
.asc-cond-row:last-child { border-bottom:none; }
.asc-cond-head {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.85);
}
.asc-cond-label { flex:1; }
.asc-cond-status { font-weight:700; width:16px; text-align:center; }
.asc-cond-row.met .asc-cond-status { color:#4dff90; }
.asc-cond-row:not(.met) .asc-cond-status { color:#ff5050; }
.asc-cond-val {
  font-size: 12px; color:rgba(255,255,255,0.6); white-space:nowrap;
}
.asc-cond-hint {
  font-family:'Share Tech Mono',monospace; font-size:11px;
  color:rgba(255,255,255,0.4); margin-top:2px; padding-left:22px;
  line-height:1.4; font-style:italic;
}
.asc-cond-clickable { cursor:pointer; transition:background .2s; border-radius:6px; padding:6px 8px !important; margin:0 -8px; }
.asc-cond-clickable:hover { background:rgba(90,141,181,0.15); }
.asc-cond-clickable:active { background:rgba(90,141,181,0.25); }
.asc-cond-go {
  display:inline-block; font-style:normal; font-weight:700;
  color:#5a8db5; margin-left:8px; font-size:11px;
  background:rgba(90,141,181,0.12); padding:2px 8px; border-radius:4px;
  border:1px solid rgba(90,141,181,0.25);
}
.asc-cond-clickable:hover .asc-cond-go { color:#8ac4ff; background:rgba(90,141,181,0.25); border-color:rgba(90,141,181,0.5); }
.asc-cond-bar {
  height:4px; background:rgba(255,255,255,0.06); border-radius:3px;
  overflow:hidden; margin-top:4px;
}
.asc-cond-fill {
  height:100%; background:#ff5050; border-radius:3px; transition:width .4s;
}
.asc-cond-fill.ok { background:#4dff90; }

/* ═══ RESET BLOCK ═══ */
.asc-reset-cols { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:8px; }
.asc-reset-col {
  padding:10px; border-radius:6px; font-family:'Share Tech Mono',monospace; font-size:12px;
  color:rgba(255,255,255,0.8); line-height:1.6;
}
.asc-reset-col.keep { background:rgba(0,220,120,0.04); border:1px solid rgba(0,220,120,0.15); }
.asc-reset-col.lose { background:rgba(255,60,60,0.04); border:1px solid rgba(255,60,60,0.15); }
.asc-reset-hd {
  font-family:'Orbitron',monospace; font-size: 11px; font-weight:700;
  letter-spacing:1.5px; margin-bottom:6px;
}
.asc-reset-col.keep .asc-reset-hd { color:var(--success); }
.asc-reset-col.lose .asc-reset-hd { color:var(--danger); }
@media (max-width:520px) { .asc-reset-cols { grid-template-columns:1fr; } }

/* ═══ COLLAPSIBLE ═══ */
.asc-collapsible.collapsed .asc-collapsible-body { display:none; }
.asc-road-toggle { font-size: 12px; transition:transform 0.2s; color:var(--textsoft); margin-left:6px; }
.asc-collapsible.collapsed .asc-road-toggle { transform:rotate(-90deg); }

/* ═══ PERK BADGES ═══ */
.asc-perk-badges { display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.asc-perk-badge {
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:20px;
  background:linear-gradient(135deg,rgba(255,192,64,0.08),rgba(224,168,48,0.04));
  border:1px solid rgba(255,192,64,0.3);
  cursor:default; transition:all 0.2s;
}
.asc-perk-badge:hover { border-color:var(--gold); box-shadow:0 0 8px rgba(255,192,64,0.15); }
.asc-pb-name { font-family:'Share Tech Mono',monospace; font-size: 12px; color:var(--gold); font-weight:700; }
.asc-pb-lv { font-family:'Share Tech Mono',monospace; font-size: 11px; color:var(--textsoft); }

/* ═══ TAB: SAISON ═══ */
.asc-season-meta { font-family:'Share Tech Mono',monospace; font-size:13px; color:var(--text); margin:6px 0; }
.asc-season-score { font-family:'Share Tech Mono',monospace; font-size:14px; color:var(--text); margin:6px 0 10px; }
.asc-lb-table { width:100%; border-collapse:collapse; font-size:12px; margin-top:6px; }
.asc-lb-table th { font-family:'Orbitron',monospace; font-size: 11px; color:var(--gold); text-align:left; padding:4px 6px; border-bottom:1px solid var(--border); letter-spacing:1px; }
.asc-lb-table td { padding:3px 6px; border-bottom:1px solid rgba(255,255,255,.04); font-family:'Share Tech Mono',monospace; }
.asc-lb-me { background:rgba(255,192,64,.08); }
.asc-lb-me td { color:var(--gold); }

/* ═══ ASCENSION PERK MODAL ═══ */
.asc-perk-overlay {
  position:fixed; inset:0; z-index:9200;
  display:flex; align-items:center; justify-content:center;
  background:rgba(4,8,18,0.85); backdrop-filter:blur(6px);
  animation:fadeIn 0.3s;
}
.asc-perk-modal {
  width:700px; max-width:92vw; max-height:90vh; overflow-y:auto;
  background:rgba(10,18,35,0.95); border:1px solid var(--gold);
  border-radius:12px; padding:24px;
  box-shadow:0 0 50px rgba(255,192,64,0.15), 0 20px 60px rgba(0,10,30,0.8);
  animation:slideInUp 0.35s ease;
}
.asc-perk-modal-header { text-align:center; margin-bottom:20px; }
.asc-perk-modal-title {
  font-family:'Orbitron',monospace; font-size:18px; font-weight:900;
  letter-spacing:3px; color:var(--gold);
  text-shadow:0 0 16px rgba(255,192,64,0.3);
}
.asc-perk-modal-sub {
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  color:var(--textsoft); margin-top:4px; letter-spacing:1px;
}
.asc-perk-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:16px; }
.asc-perk-card {
  display:flex; flex-direction:column; align-items:center;
  padding:18px 14px; border-radius:10px; cursor:pointer;
  background:rgba(255,192,64,0.03); border:1px solid rgba(255,192,64,0.15);
  transition:all 0.25s; text-align:center; gap:8px;
}
.asc-perk-card:hover {
  border-color:var(--gold); background:rgba(255,192,64,0.08);
  box-shadow:0 0 20px rgba(255,192,64,0.15);
  transform:translateY(-3px);
}
.asc-perk-card-icon { font-size:32px; }
.asc-perk-card-name {
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  color:var(--gold); letter-spacing:1px;
}
.asc-perk-card-desc {
  font-family:'Share Tech Mono',monospace; font-size: 12px;
  color:var(--textsoft); line-height:1.5;
}
.asc-perk-card-btn {
  margin-top:auto; padding:6px 16px; border-radius:4px;
  background:rgba(255,192,64,0.1); border:1px solid rgba(255,192,64,0.3);
  color:var(--gold); font-family:'Orbitron',monospace; font-size: 11px;
  font-weight:700; letter-spacing:1px; transition:all 0.2s;
}
.asc-perk-card:hover .asc-perk-card-btn { background:rgba(255,192,64,0.2); }
.asc-perk-modal-warn {
  text-align:center; font-family:'Share Tech Mono',monospace;
  font-size: 12px; color:var(--warn); margin-bottom:12px;
}
.asc-perk-modal-footer { display:flex; justify-content:center; }
.asc-perk-cancel {
  padding:8px 28px; border-radius:6px;
  border:1px solid var(--border); background:transparent;
  color:var(--textsoft); font-family:'Orbitron',monospace; font-size: 12px;
  cursor:pointer; transition:all 0.2s;
}
.asc-perk-cancel:hover { color:var(--textbright); border-color:var(--textmid); }
@media (max-width:640px) {
  .asc-perk-cards { grid-template-columns:1fr; }
  .asc-perk-modal { padding:16px; }
}

/* ═══ ROADMAP — ALL LEVELS ═══ */
.asc-road-body { display:flex; flex-direction:column; gap:6px; }
.asc-road-row {
  border-radius:6px; border-left:3px solid transparent;
  cursor:pointer; overflow:hidden;
  transition:background 0.2s;
}
.asc-road-row:hover { background:rgba(255,255,255,0.03); }
.asc-road-header {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px;
}
.asc-road-arrow {
  margin-left:auto; font-size: 12px; color:var(--textsoft);
  transition:transform 0.2s;
}
.asc-road-row.expanded .asc-road-arrow { transform:rotate(180deg); }
.asc-road-details { display:none; padding:2px 14px 12px; }
.asc-road-row.expanded .asc-road-details { display:block; }
.asc-road-section-title {
  font-family:'Orbitron',monospace; font-size: 12px; font-weight:700;
  color:var(--gold); margin:8px 0 6px; text-transform:uppercase;
  letter-spacing:1px;
}
.asc-road-done { border-left-color:var(--success); background:rgba(0,200,100,0.05); }
.asc-road-current { border-left-color:var(--gold); background:rgba(224,180,40,0.1); }
.asc-road-locked { border-left-color:var(--border); opacity:0.85; }
.asc-road-lv {
  font-family:'Orbitron',monospace; font-size:12px; font-weight:700;
  white-space:nowrap; min-width:60px;
}
.asc-road-done .asc-road-lv { color:var(--success); }
.asc-road-current .asc-road-lv { color:var(--gold); }
.asc-road-bonus {
  font-family:'Share Tech Mono',monospace; font-size:13px;
  color:var(--accent2); font-weight:700;
}
.asc-road-cumul { font-size: 12px; color:var(--textsoft); font-weight:400; }
.asc-road-perks { display:flex; flex-direction:column; gap:5px; }
.asc-road-perk {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  padding:6px 10px; border-radius:5px;
  background:rgba(255,192,64,0.04); border:1px solid rgba(255,192,64,0.12);
  color:var(--text);
}
.asc-road-perk strong { color:var(--gold); }
.asc-road-perk.chosen {
  border-color:var(--success); color:var(--success);
  background:rgba(0,200,100,0.06);
}
.asc-road-conds { display:flex; flex-direction:column; gap:4px; }
.asc-road-cond {
  display:flex; align-items:center; gap:8px;
  font-family:'Share Tech Mono',monospace; font-size:12px;
  color:var(--text); padding:4px 10px; border-radius:5px;
  background:rgba(100,160,255,0.04); border:1px solid rgba(100,160,255,0.1);
}
.asc-road-cond strong { color:var(--accent2); }
