/* ══════════════════════════ PROMETHEE — main.css ══════════════════════════ */
:root {
  --bg-deep:    #03060c;
  --bg-panel:   #080e18;
  --bg-card:    #0d1620;
  --bg-hover:   #152030;
  --border:     #162240;
  --border-glow:#2a4870;
  --border-subtle: rgba(0,170,255,0.12);
  --text:       #b8cce0;
  --text-sec:   #6888a8;
  --text-muted: #405878;
  --accent:     #00aaff;
  --accent-dk:  #004e7a;
  --accent-glow:rgba(0,170,255,.18);
  --glass-bg:   rgba(8,14,24,0.82);
  --glass-border: rgba(0,170,255,0.18);
  --hp:         #c83838;
  --energy:     #3880cc;
  --pm:         #38b870;
  --exp:        #b89828;
  --gold:       #f0c040;
  --nexus:      #4a90d9;
  --parias:     #e8a84a;
  --eveil:      #7ae8a8;
  --font: 'Segoe UI',system-ui,sans-serif;
  --mono: 'Share Tech Mono','Courier New',monospace;
  --nav-h: 48px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --glow-sm: 0 0 12px rgba(0,170,255,0.15);
  --glow-md: 0 0 24px rgba(0,170,255,0.2);
  --shadow-panel: 0 4px 24px rgba(0,0,10,0.6);
}

/* ══ RARITY COLORS ══ */
:root {
  --rarity-common:    #8a9ab0;
  --rarity-uncommon:  #40c060;
  --rarity-rare:      #4090ff;
  --rarity-epic:      #b040e8;
  --rarity-legendary: #ff8c00;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg-deep);color:var(--text);font-family:var(--font);font-size:13px;overflow:hidden}
/* Scrollbars cohérentes */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--bg-deep)}
::-webkit-scrollbar-thumb{background:var(--border-glow);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--accent-dk)}
.screen{display:none;width:100%;height:100vh;flex:1}
.screen.active{display:flex;width:100%;height:100vh}
.hidden{display:none!important}

/* ══ SCROLLBAR ══ */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--bg-deep)}
::-webkit-scrollbar-thumb{background:var(--border-glow);border-radius:2px}

/* ══ BOUTONS ══ */
.btn-primary{
  width:100%;padding:11px;
  background:linear-gradient(135deg,rgba(0,78,122,0.9),rgba(0,136,200,0.7));
  border:1px solid rgba(0,170,255,0.4);
  border-radius:var(--radius-sm);color:#fff;
  font-family:var(--mono);font-size:.78rem;font-weight:600;letter-spacing:.1em;
  cursor:pointer;transition:all .25s;margin-top:4px;
  position:relative;overflow:hidden;
}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);transform:translateX(-100%);transition:transform .5s}
.btn-primary:hover::before{transform:translateX(100%)}
.btn-primary:hover{border-color:rgba(0,170,255,0.7);box-shadow:var(--glow-md);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{padding:6px 14px;background:rgba(255,255,255,0.03);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-sec);cursor:pointer;transition:all .2s;font-size:.78rem}
.btn-secondary:hover{border-color:rgba(0,170,255,0.4);color:var(--accent);background:rgba(0,170,255,0.06)}
.btn-sm{font-size:.75rem}
input[type=text],input[type=email],input[type=password]{width:100%;background:var(--bg-deep);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:9px 12px;font-size:.85rem;outline:none;transition:border-color .2s}
input:focus{border-color:rgba(0,170,255,0.5);box-shadow:0 0 0 2px rgba(0,170,255,0.1);outline:none;background:rgba(0,170,255,0.04)}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-size:.7rem;color:var(--text-sec);letter-spacing:.06em;text-transform:uppercase}
.form-error{color:#ff5050;font-size:.78rem;padding:7px 10px;background:rgba(255,50,50,.1);border-radius:6px}
.form-success{color:#50ff80;font-size:.78rem;padding:7px 10px;background:rgba(50,255,100,.1);border-radius:6px}
.badge{
  padding:2px 8px;border-radius:4px;
  font-size:.65rem;font-weight:700;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-subtle);
  color:var(--text-sec);
  font-family:var(--mono);letter-spacing:.06em;
}
.badge-faction{padding:2px 8px;border-radius:4px;font-size:.68rem;font-weight:700}

/* ══ AUTH ══ */
/* ══ AUTH SCREEN — PROMÉTHÉE ══ */
#screen-auth {
  position: relative;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #02040a;
  width: 100%;
  height: 100vh;
  box-sizing: border-box;
}
/* Quand actif : centrage flex */
#screen-auth.active {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#auth-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.auth-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 70% at 50% 40%, rgba(0,20,60,0.7) 0%, rgba(0,0,10,0.92) 100%);
  pointer-events: none;
  z-index: 1;
}
/* Particules flottantes */
.auth-particles { position: absolute; inset: 0; pointer-events: none; z-index: 1; overflow: hidden; }
.auth-particle {
  position: absolute;
  width: 2px; height: 2px;
  background: var(--accent);
  border-radius: 50%;
  opacity: 0;
  animation: auth-float 8s ease-in-out infinite;
}
.auth-particle:nth-child(1){left:12%;animation-delay:0s;animation-duration:9s}
.auth-particle:nth-child(2){left:28%;animation-delay:1.5s;animation-duration:11s;width:3px;height:3px;background:#4a90d9}
.auth-particle:nth-child(3){left:55%;animation-delay:3s;animation-duration:8s;background:#7ae8a8}
.auth-particle:nth-child(4){left:72%;animation-delay:4.5s;animation-duration:12s;width:2px;height:2px}
.auth-particle:nth-child(5){left:88%;animation-delay:2s;animation-duration:10s;background:#e8a84a;width:2px;height:2px}
.auth-particle:nth-child(6){left:42%;animation-delay:6s;animation-duration:9s;background:#c080ff}
@keyframes auth-float {
  0%   { transform: translateY(100vh) scale(0); opacity: 0; }
  10%  { opacity: 0.6; }
  90%  { opacity: 0.4; }
  100% { transform: translateY(-20px) scale(1); opacity: 0; }
}

/* Panel principal */
.auth-panel {
  position: relative;
  z-index: 2;
  width: min(420px, 96vw);
  background: rgba(8, 14, 24, 0.85);
  border: 1px solid rgba(0, 170, 255, 0.2);
  border-radius: 16px;
  padding: 32px 28px 24px;
  backdrop-filter: blur(12px);
  box-shadow:
    0 0 0 1px rgba(0, 170, 255, 0.06),
    0 8px 40px rgba(0, 0, 10, 0.8),
    0 0 80px rgba(0, 100, 200, 0.12);
  animation: auth-panel-in 0.6s cubic-bezier(.2,.8,.3,1) both;
}
@keyframes auth-panel-in {
  from { opacity: 0; transform: translateY(24px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Header */
.auth-header { text-align: center; margin-bottom: 24px; }
.auth-emblem {
  width: 60px; height: 60px;
  margin: 0 auto 14px;
  animation: auth-spin-slow 20s linear infinite;
}
@keyframes auth-spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.auth-title {
  font-family: var(--mono);
  font-size: 2rem;
  letter-spacing: .45em;
  color: var(--accent);
  text-shadow: 0 0 24px rgba(0,170,255,0.6), 0 0 60px rgba(0,170,255,0.2);
  animation: auth-title-glow 3s ease-in-out infinite alternate;
  margin-left: .45em; /* compensate letter-spacing */
}
@keyframes auth-title-glow {
  from { text-shadow: 0 0 20px rgba(0,170,255,0.5); }
  to   { text-shadow: 0 0 32px rgba(0,170,255,0.9), 0 0 80px rgba(0,170,255,0.3); }
}
.auth-subtitle {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .2em;
  color: var(--text-muted);
  margin-top: 4px;
  text-transform: uppercase;
}
.auth-status-bar {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  background: rgba(0,170,255,0.06);
  border: 1px solid rgba(0,170,255,0.15);
  border-radius: 4px;
  padding: 3px 10px;
  font-family: var(--mono);
  font-size: .6rem;
  color: var(--text-sec);
  letter-spacing: .08em;
}
.auth-status-dot {
  width: 6px; height: 6px;
  background: #40c080;
  border-radius: 50%;
  box-shadow: 0 0 6px #40c080;
  animation: auth-dot-pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes auth-dot-pulse {
  0%,100% { opacity: 1; box-shadow: 0 0 6px #40c080; }
  50%      { opacity: 0.5; box-shadow: 0 0 2px #40c080; }
}

/* Tabs */
.auth-tabs-new {
  display: flex;
  gap: 0;
  margin-bottom: 20px;
  border: 1px solid rgba(0,170,255,0.15);
  border-radius: 8px;
  overflow: hidden;
}
.auth-tab {
  flex: 1;
  padding: 9px;
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .1em;
  cursor: pointer;
  transition: all .25s;
  position: relative;
}
.auth-tab:hover { color: var(--accent); background: rgba(0,170,255,0.05); }
.auth-tab.active {
  background: rgba(0,170,255,0.1);
  color: var(--accent);
}
.auth-tab.active::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}

/* Forms */
.auth-form { display: none; flex-direction: column; gap: 14px; }
.auth-form.active { display: flex; animation: auth-form-in .3s ease both; }
@keyframes auth-form-in {
  from { opacity: 0; transform: translateX(8px); }
  to   { opacity: 1; transform: translateX(0); }
}
.auth-field { display: flex; flex-direction: column; gap: 5px; }
.auth-label {
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .12em;
  color: var(--text-muted);
}
.auth-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.auth-input-icon {
  position: absolute;
  left: 11px;
  width: 14px; height: 14px;
  color: var(--text-muted);
  pointer-events: none;
  flex-shrink: 0;
}
.auth-input-wrap .auth-input,
.auth-input {
  width: 100%;
  padding: 10px 40px 10px 34px !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(0,170,255,0.15) !important;
  border-radius: 7px;
  color: var(--text);
  font-size: .82rem;
  transition: border-color .2s, box-shadow .2s, background .2s;
  outline: none;
  box-sizing: border-box;
}
.auth-input::placeholder { color: var(--text-muted); }
.auth-input:focus {
  border-color: rgba(0,170,255,0.5);
  background: rgba(0,170,255,0.06);
  box-shadow: 0 0 0 3px rgba(0,170,255,0.08);
}
.auth-eye {
  position: absolute;
  right: 10px;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
}
.auth-eye:hover { color: var(--accent); }
.auth-eye svg { width: 14px; height: 14px; }

/* Errors / success */
.auth-error {
  font-size: .75rem;
  color: #e05050;
  background: rgba(224,80,80,0.08);
  border: 1px solid rgba(224,80,80,0.2);
  border-radius: 5px;
  padding: 7px 10px;
  animation: auth-form-in .2s ease;
}
.auth-success {
  font-size: .75rem;
  color: #40c080;
  background: rgba(64,192,128,0.08);
  border: 1px solid rgba(64,192,128,0.2);
  border-radius: 5px;
  padding: 7px 10px;
}

/* Primary button */
.auth-btn-primary {
  width: 100%;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(0,88,136,0.9), rgba(0,136,200,0.7));
  border: 1px solid rgba(0,170,255,0.4);
  border-radius: 8px;
  color: #fff;
  font-family: var(--mono);
  font-size: .75rem;
  letter-spacing: .12em;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all .25s;
  position: relative;
  overflow: hidden;
  margin-top: 4px;
}
.auth-btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  transform: translateX(-100%);
  transition: transform .5s;
}
.auth-btn-primary:hover::before { transform: translateX(100%); }
.auth-btn-primary:hover {
  border-color: rgba(0,170,255,0.7);
  box-shadow: 0 0 20px rgba(0,170,255,0.2), 0 4px 16px rgba(0,0,0,0.4);
  transform: translateY(-1px);
}
.auth-btn-primary:active { transform: translateY(0); }
.auth-btn-arrow {
  font-size: .9rem;
  transition: transform .2s;
}
.auth-btn-primary:hover .auth-btn-arrow { transform: translateX(3px); }

/* Forgot password link */
.auth-forgot-link {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: .72rem;
  cursor: pointer;
  text-align: center;
  padding: 4px;
  transition: color .2s;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.auth-forgot-link:hover { color: var(--accent); }

/* Forgot form header */
.auth-forgot-header { margin-bottom: 4px; }
.auth-forgot-desc {
  font-size: .73rem;
  color: var(--text-sec);
  line-height: 1.5;
  background: rgba(0,170,255,0.05);
  border: 1px solid rgba(0,170,255,0.1);
  border-radius: 6px;
  padding: 10px 12px;
}

/* Footer */
.auth-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
  font-family: var(--mono);
  font-size: .58rem;
  letter-spacing: .08em;
  color: var(--text-muted);
  opacity: 0.6;
}
.auth-footer-sep { opacity: 0.4; }

/* ── Auth layout avec leaderboard ── */
.auth-layout {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* Le panel de connexion est TOUJOURS au centre exact */
.auth-layout > .auth-panel {
  position: relative;
  z-index: 3;
}
/* Leaderboard — positionné à gauche, indépendant du panel centré */
.auth-leaderboard {
  position: absolute;
  left: clamp(16px, 3vw, 48px);
  top: 0;
  z-index: 3;
  width: 240px;
  background: rgba(6,10,18,0.82);
  border: 1px solid rgba(0,170,255,0.14);
  border-radius: 14px;
  padding: 16px 14px;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  animation: auth-panel-in 0.7s cubic-bezier(.2,.8,.3,1) both;
  animation-delay: .1s;
  max-height: 80vh;
  overflow-y: auto;
}

/* Changelog — miroir symétrique à droite */
.auth-changelog {
  position: absolute;
  right: clamp(16px, 3vw, 48px);
  top: 0;
  z-index: 3;
  width: 240px;
  background: rgba(6,10,18,0.82);
  border: 1px solid rgba(0,170,255,0.14);
  border-radius: 14px;
  padding: 16px 14px;
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  animation: auth-panel-in 0.7s cubic-bezier(.2,.8,.3,1) both;
  animation-delay: .2s;
  max-height: 80vh;
  overflow-y: auto;
}
.auth-cl-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--mono);
  font-size: .65rem;
  letter-spacing: .14em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(0,170,255,0.1);
}
.auth-cl-entry {
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.auth-cl-entry:last-child { border-bottom: none; margin-bottom: 0; }
.auth-cl-version {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.auth-cl-ver-tag {
  font-family: var(--mono);
  font-size: .62rem;
  font-weight: 700;
  color: var(--accent);
  background: rgba(0,170,255,0.1);
  border: 1px solid rgba(0,170,255,0.25);
  border-radius: 4px;
  padding: 1px 7px;
  letter-spacing: .06em;
}
.auth-cl-date {
  font-size: .58rem;
  color: var(--text-muted);
  font-family: var(--mono);
}
.auth-cl-items {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.auth-cl-item {
  font-size: .68rem;
  color: var(--text-sec);
  line-height: 1.4;
  display: flex;
  gap: 6px;
  align-items: flex-start;
}
.auth-cl-item::before {
  content: '›';
  color: var(--accent);
  flex-shrink: 0;
  font-weight: 700;
}
.auth-cl-item.new::before   { content: '✦'; color: #40c080; }
.auth-cl-item.fix::before   { content: '⚙'; color: #e0c040; }
.auth-cl-item.change::before{ content: '◈'; color: #a060ff; }

/* Responsive — cacher sur petits écrans */
@media (max-width: 1200px) { .auth-changelog { display: none; } }
.auth-lb-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--mono);
  font-size: .65rem;
  letter-spacing: .14em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(0,170,255,0.1);
}
.auth-lb-title svg { color: #f0c040; flex-shrink: 0; }
.auth-lb-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 12px;
}
.auth-lb-tab {
  flex: 1;
  padding: 5px;
  background: transparent;
  border: 1px solid rgba(0,170,255,0.12);
  border-radius: 5px;
  color: var(--text-muted);
  font-size: .65rem;
  font-family: var(--mono);
  cursor: pointer;
  transition: all .2s;
}
.auth-lb-tab:hover { color: var(--accent); border-color: rgba(0,170,255,0.3); }
.auth-lb-tab.active {
  background: rgba(0,170,255,0.12);
  border-color: rgba(0,170,255,0.4);
  color: var(--accent);
  text-shadow: 0 0 8px rgba(0,170,255,0.5);
  box-shadow: 0 0 10px rgba(0,170,255,0.08);
}
.auth-lb-body { display: flex; flex-direction: column; gap: 5px; transition: opacity .18s ease; }
.auth-lb-loading {
  color: var(--text-muted);
  font-size: .68rem;
  font-family: var(--mono);
  text-align: center;
  padding: 20px 0;
  opacity: .6;
}
.auth-lb-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  transition: background .2s ease, border-color .2s ease, transform .15s ease;
  cursor: default;
}
.auth-lb-row:hover { transform: translateX(2px); }
.auth-lb-row:hover { background: rgba(0,170,255,0.05); border-color: rgba(0,170,255,0.15); }
.auth-lb-rank {
  font-family: var(--mono);
  font-size: .6rem;
  color: var(--text-muted);
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}
.auth-lb-rank-1 { color: #f0c040; font-weight: 900; font-size: .72rem; }
.auth-lb-rank-2 { color: #b0b8c8; font-weight: 700; }
.auth-lb-rank-3 { color: #c08040; font-weight: 700; }
.auth-lb-name {
  flex: 1;
  font-size: .72rem;
  color: var(--text);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.auth-lb-faction-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.auth-lb-value {
  font-family: var(--mono);
  font-size: .68rem;
  font-weight: 700;
  color: var(--accent);
  flex-shrink: 0;
}
.auth-lb-value-gold { color: #f0c040; }

/* Footer liens externes */
.auth-links-footer {
  position: fixed;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 16px;
}
.auth-ext-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 20px;
  font-size: .7rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .2s;
  backdrop-filter: blur(6px);
  border: 1px solid transparent;
  letter-spacing: .04em;
}
.auth-discord {
  background: rgba(88,101,242,0.18);
  border-color: rgba(88,101,242,0.4);
  color: #848dfb;
}
.auth-discord:hover {
  background: rgba(88,101,242,0.3);
  border-color: rgba(88,101,242,0.7);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(88,101,242,0.3);
}
.auth-tipeee {
  background: rgba(255,80,80,0.14);
  border-color: rgba(255,80,80,0.35);
  color: #ff8080;
}
.auth-tipeee:hover {
  background: rgba(255,80,80,0.25);
  border-color: rgba(255,80,80,0.6);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(255,80,80,0.25);
}

/* Responsive — cacher leaderboard sur petits écrans */
@media (max-width: 900px) {
  .auth-leaderboard { display: none; }
  .auth-changelog { display: none; }
  .auth-layout { padding: 0 12px; }
}

/* ══════════════════════════════════════════════════════════════════════════
   SYSTÈME DE BOUTONS UNIVERSEL — cohérence graphique globale
   ══════════════════════════════════════════════════════════════════════════ */

/* Base commune */
.btn-game {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  font-family: var(--mono);
  font-size: .73rem;
  font-weight: 600;
  letter-spacing: .06em;
  cursor: pointer;
  transition: all .2s ease;
  border: 1px solid transparent;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  white-space: nowrap;
}
.btn-game::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,rgba(255,255,255,0.06),transparent);
  pointer-events: none;
}
.btn-game:hover { transform: translateY(-1px); }
.btn-game:active { transform: translateY(0) scale(.98); }
.btn-game:disabled { opacity: .45; cursor: not-allowed; transform: none !important; }

/* Variantes */
.btn-game-primary {
  background: linear-gradient(135deg,rgba(0,78,122,.9),rgba(0,130,190,.7));
  border-color: rgba(0,170,255,.45);
  color: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.btn-game-primary:hover { border-color: rgba(0,170,255,.8); box-shadow: var(--glow-sm), 0 4px 12px rgba(0,0,0,.4); }

.btn-game-success {
  background: rgba(48,160,96,.18);
  border-color: rgba(48,180,96,.4);
  color: #50e090;
}
.btn-game-success:hover { background: rgba(48,160,96,.32); border-color: rgba(64,200,112,.7); box-shadow: 0 0 14px rgba(48,180,96,.2); }

.btn-game-danger {
  background: rgba(180,40,40,.18);
  border-color: rgba(220,60,60,.4);
  color: #f06060;
}
.btn-game-danger:hover { background: rgba(200,50,50,.3); border-color: rgba(240,80,80,.7); box-shadow: 0 0 14px rgba(200,50,50,.2); }

.btn-game-warning {
  background: rgba(200,160,0,.15);
  border-color: rgba(240,192,0,.35);
  color: #f0c040;
}
.btn-game-warning:hover { background: rgba(220,180,0,.25); border-color: rgba(250,200,20,.65); box-shadow: 0 0 14px rgba(200,160,0,.2); }

.btn-game-ghost {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.1);
  color: var(--text-sec);
}
.btn-game-ghost:hover { background: rgba(0,170,255,.07); border-color: rgba(0,170,255,.25); color: var(--accent); }

.btn-game-purple {
  background: rgba(128,48,200,.18);
  border-color: rgba(160,64,224,.4);
  color: #b070ff;
}
.btn-game-purple:hover { background: rgba(144,56,216,.3); border-color: rgba(176,80,240,.7); box-shadow: 0 0 14px rgba(128,48,200,.25); }

/* Tailles */
.btn-game-sm  { padding: 4px 10px; font-size: .66rem; }
.btn-game-lg  { padding: 10px 20px; font-size: .82rem; }
.btn-game-full{ width: 100%; }

/* Back button */
.btn-game-back {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: .72rem;
  padding: 4px 0;
  cursor: pointer;
  font-family: var(--mono);
  letter-spacing: .04em;
  transition: color .15s;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.btn-game-back:hover { color: var(--accent); }

/* ── ogame-back-btn alias ── */
.ogame-back-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: .72rem;
  padding: 4px 0;
  cursor: pointer;
  font-family: var(--mono);
  letter-spacing: .04em;
  transition: color .15s;
}
.ogame-back-btn:hover { color: var(--accent); }

/* Legacy compat */
.auth-container { display: none; }
.tab-btn { display: none; }
.tab-content { display: none; }
.tab-content.active { display: none; }

/* ══ CREATE CHAR ══ */
#screen-create-char{
  align-items:center;justify-content:center;
  background:#03060c;overflow-y:auto;position:relative;
}
#screen-create-char.active{
  display:flex !important;
  align-items:center;justify-content:center;
}
#screen-create-char::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 40%,rgba(0,20,60,.7),transparent);
  pointer-events:none;
}
.create-char-container{
  position:relative;z-index:1;
  width:min(660px,96vw);max-height:94vh;overflow-y:auto;
  background:rgba(8,14,24,.88);
  border:1px solid rgba(0,170,255,.2);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  display:flex;flex-direction:column;gap:20px;
  box-shadow:0 0 0 1px rgba(0,170,255,.06),0 12px 48px rgba(0,0,10,.8);
  animation:auth-panel-in .5s cubic-bezier(.2,.8,.3,1) both;
}
.create-char-container h2{
  font-family:var(--mono);color:var(--accent);
  letter-spacing:.2em;font-size:1.1rem;text-align:center;
  text-shadow:0 0 20px rgba(0,170,255,.5);
  padding-bottom:12px;border-bottom:1px solid rgba(0,170,255,.12);
}
.subtitle{color:var(--text-sec);font-size:.8rem;margin-top:-8px}
.faction-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}
.faction-card{
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-md);
  padding:16px;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;
  position:relative;overflow:hidden;
}
.faction-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:transparent;transition:background .2s;
  border-radius:var(--radius-md) var(--radius-md) 0 0;
}
.faction-card:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.15);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.faction-card.selected{
  border-color:rgba(0,170,255,.5);
  box-shadow:var(--glow-md);
  background:rgba(0,170,255,.05);
}
.faction-card-name{
  font-family:var(--mono);font-weight:700;font-size:.88rem;
  margin-bottom:6px;letter-spacing:.06em;
}
.faction-card-desc{font-size:.72rem;color:var(--text-sec);margin-bottom:8px;line-height:1.45}
.faction-card-bonus{font-size:.68rem;color:#40d080;margin-bottom:4px;font-style:italic}
.faction-card-stats{font-size:.68rem;color:var(--accent);font-family:var(--mono)}

/* ══ SPECIALIZE ══ */
#screen-specialize{
  align-items:center;justify-content:center;
  background:#03060c;overflow-y:auto;position:relative;
}
#screen-specialize.active{
  display:flex !important;
  align-items:center;justify-content:center;
}
#screen-specialize::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 40%,rgba(90,0,120,.3),transparent);
  pointer-events:none;
}
.specialize-container{
  position:relative;z-index:1;
  width:min(960px,97vw);max-height:94vh;overflow-y:auto;
  background:rgba(8,14,24,.88);
  border:1px solid rgba(160,64,224,.25);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  display:flex;flex-direction:column;gap:20px;
  box-shadow:0 0 0 1px rgba(160,64,224,.06),0 12px 48px rgba(0,0,10,.8);
  animation:auth-panel-in .5s cubic-bezier(.2,.8,.3,1) both;
}
.specialize-container h2{
  font-family:var(--mono);letter-spacing:.2em;font-size:1.1rem;
  color:#c060ff;text-align:center;
  text-shadow:0 0 20px rgba(160,64,224,.5);
  padding-bottom:12px;border-bottom:1px solid rgba(160,64,224,.15);
}
.spec-class-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.class-card{
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-md);
  padding:14px;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;
  display:flex;flex-direction:column;gap:4px;
  position:relative;overflow:hidden;
}
.class-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.03),transparent);
  pointer-events:none;
}
.class-card:hover{
  transform:translateY(-3px) scale(1.01);
  background:rgba(255,255,255,.04);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.class-card.selected{
  border-color:rgba(160,64,224,.6);
  box-shadow:0 0 24px rgba(160,64,224,.25);
  background:rgba(160,64,224,.06);
}
.class-role-badge{font-size:.62rem;font-weight:700;letter-spacing:.1em}
.class-name{font-weight:700;font-size:.88rem}
.class-desc{font-size:.7rem;color:var(--text-sec);line-height:1.4}
.class-unique{font-size:.68rem;color:var(--exp);line-height:1.4}
.class-unique-block{margin-top:2px}
.class-unique-title{font-size:.68rem;color:var(--exp);font-weight:600;line-height:1.4}
.class-unique-desc{font-size:.64rem;color:var(--text-sec);line-height:1.35;margin-top:1px;opacity:.85}
.class-skills-list{margin-top:5px;display:flex;flex-wrap:wrap;gap:3px}
.class-skill-tag{font-size:.6rem;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:3px;padding:2px 5px;color:var(--text-sec);cursor:help;white-space:nowrap}
.class-stat-bonuses{font-size:.62rem;color:var(--accent);margin-top:2px}
.class-stat-bonuses{font-size:.68rem;color:var(--accent);margin-top:2px}

/* ══ GAME SCREEN ══ */
#screen-game{flex-direction:column;height:100vh;overflow:hidden}

/* ── Header ── */
#game-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 14px;
  background:var(--glass-bg);
  border-bottom:1px solid var(--glass-border);
  flex-shrink:0;height:var(--nav-h);gap:12px;
  box-shadow:0 1px 0 rgba(0,170,255,0.08), var(--shadow-panel);
  position:relative;z-index:10;
}
.header-identity{display:flex;align-items:center;gap:7px;min-width:200px}
#hud-name{font-weight:700;font-size:.9rem;color:var(--text)}
.header-right{display:flex;align-items:center;gap:10px;min-width:140px;justify-content:flex-end}
#hud-online{color:#50e090;font-size:.75rem}

/* ── Nav tabs ── */
#game-nav{display:flex;gap:3px;flex:1;justify-content:center}
.nav-btn{
  padding:0 14px;height:32px;
  background:transparent;border:none;
  border-bottom:2px solid transparent;
  border-radius:0;
  color:var(--text-muted);cursor:pointer;
  font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.08em;
  transition:color .2s, background .2s;
  white-space:nowrap;position:relative;
}
.nav-btn:hover{color:var(--text);background:rgba(0,170,255,0.04)}
.nav-btn.active{
  color:var(--accent);
  border-bottom-color:var(--accent);
  background:rgba(0,170,255,0.06);
  text-shadow:0 0 12px rgba(0,170,255,0.4);
}
.nav-btn.active::after{
  content:'';position:absolute;
  bottom:-1px;left:20%;right:20%;height:3px;
  background:var(--accent);
  border-radius:3px 3px 0 0;
  box-shadow:0 0 10px 2px rgba(0,170,255,0.55);
  animation:nav-glow .25s ease both;
}
@keyframes nav-glow{
  from{opacity:0;transform:scaleX(0)}
  to  {opacity:1;transform:scaleX(1)}
}

/* ── Panels ── */
#game-main{flex:1;overflow:hidden;position:relative}
.game-panel{
  display:none;width:100%;height:100%;overflow:hidden;
}
.game-panel.active{
  display:flex;
  animation:panel-enter .22s ease both;
}
#panel-bestiary.active{
  flex-direction:column;height:100%;
}
#panel-bestiary .panel-inner{
  display:flex;flex-direction:column;flex:1;overflow:hidden;
}
#bestiary-content{
  flex:1;overflow-y:auto;padding:14px 16px;
}
@keyframes panel-enter{
  from{opacity:0;transform:translateY(6px)}
  to  {opacity:1;transform:translateY(0)}
}
.game-panel.leaving{
  opacity:0;transform:translateY(-4px);
  transition:opacity .15s ease,transform .15s ease;
}
.panel-inner{flex:1;padding:20px;overflow-y:auto;scrollbar-gutter:stable}
.panel-title{
  font-family:var(--mono);
  font-size:.88rem;font-weight:600;
  color:var(--accent);letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:16px;
  padding-bottom:10px;
  border-bottom:1px solid var(--glass-border);
  text-shadow:0 0 16px rgba(0,170,255,0.3);
  display:flex;align-items:center;gap:8px;
}
.panel-title::before{
  content:'';display:block;
  width:3px;height:1.1em;
  background:var(--accent);
  border-radius:2px;
  box-shadow:0 0 8px var(--accent);
  flex-shrink:0;
}

/* ══ MAP PANEL ══ */
#panel-map{display:none;flex-direction:row}
#panel-map.active{display:flex;animation:none!important}

/* Sidebar gauche */
#map-sidebar{
  width:180px;flex-shrink:0;
  background:var(--glass-bg);
  border-right:1px solid var(--glass-border);
  padding:10px;display:flex;flex-direction:column;gap:10px;
  overflow-y:auto;
  min-height:0;   /* important pour flex child */
  height:100%;    /* fixe la hauteur pour éviter le layout shift */
}
.sidebar-section{display:flex;flex-direction:column;gap:5px}
.sidebar-label{font-family:var(--mono);font-size:.58rem;font-weight:700;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:1px;opacity:.7}
.sidebar-value{font-size:.82rem;color:var(--text);font-weight:600}
.sidebar-value.gold{color:var(--gold)}
.stat-bar-group{display:flex;flex-direction:column;gap:2px}
.stat-bar-label{display:flex;justify-content:space-between;font-size:.68rem;color:var(--text-sec)}
.stat-bar{
  height:6px;
  background:rgba(255,255,255,0.05);
  border-radius:3px;overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.5);
}
.bar-fill{
  height:100%;border-radius:3px;
  transition:width .3s ease;
  will-change:width;
}
.bar-hp{background:linear-gradient(90deg,#a02828,#d04040)}
.bar-energy{background:linear-gradient(90deg,#2860a0,#4090d0)}
.bar-pm{background:linear-gradient(90deg,#289060,#40c080)}
.bar-exp{background:linear-gradient(90deg,#907020,#c0a030)}
.action-btn{
  padding:7px 10px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-sm);
  color:var(--text-sec);cursor:pointer;
  font-size:.72rem;text-align:left;
  transition:all .2s;width:100%;
  font-family:var(--mono);letter-spacing:.03em;
}
.action-btn:hover{
  border-color:rgba(0,170,255,0.4);
  color:var(--accent);
  background:rgba(0,170,255,0.06);
  transform:translateX(2px);
}
.action-btn.city-btn{border-color:rgba(240,192,64,0.3);color:var(--gold)}
.action-btn.city-btn:hover{border-color:rgba(240,192,64,0.6);background:rgba(240,192,64,0.06);transform:translateX(2px)}

/* Carte centrale */
#map-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-deep);min-width:0}
#map-toolbar{padding:5px 12px;background:var(--bg-panel);border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;font-size:.7rem;color:var(--text-sec)}
#map-legend{display:flex;gap:8px;flex-wrap:wrap}
.legend-item{padding:1px 6px;border-radius:3px;font-size:.62rem;font-weight:600}
.legend-item.plains{background:#3a5c2a;color:#8fcc6f}
.legend-item.desert{background:#6e5020;color:#d0a050}
.legend-item.mountain{background:#3e3c50;color:#9898b8}
.legend-item.forest{background:#162e18;color:#50b060}
.legend-item.water{background:#061820;color:#4090d0}
.legend-item.ruins{background:#3c2c2c;color:#a07070}
.legend-item.toxic{background:#283e14;color:#80c030}
.legend-item.ice{background:#6890a8;color:#c8e8f8}

#map-viewport{flex:1;overflow:hidden;position:relative;cursor:crosshair}
#map-canvas{position:absolute;top:0;left:0;width:100%!important;height:100%!important}

/* Colonne droite permanente (journal + chat) */
#map-right{width:220px;flex-shrink:0;background:var(--glass-bg);border-left:1px solid var(--glass-border);display:flex;flex-direction:column;overflow:hidden}
#map-journal{flex:1;padding:8px 10px;display:flex;flex-direction:column;gap:4px;overflow:hidden;border-bottom:1px solid var(--border)}
#event-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;font-size:.67rem;font-family:var(--mono)}
.log-entry{
  line-height:1.45;padding:2px 5px;
  border-radius:3px;
  animation:log-in .2s ease both;
  font-size:.67rem;
}
@keyframes log-in{from{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:translateX(0)}}
.log-entry.info{color:var(--accent)}
.log-entry.success{color:var(--pm)}
.log-entry.warning{color:var(--exp)}
.log-entry.danger{color:var(--hp)}
.log-entry.system{color:var(--accent);font-weight:700;text-shadow:0 0 8px rgba(0,170,255,0.4)}
#map-chat{flex-shrink:0;padding:8px 10px;display:flex;flex-direction:column;gap:5px;height:240px}
#chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px;font-size:.7rem;background:var(--bg-deep);border-radius:5px;padding:6px}
#chat-messages-faction-sidebar{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px;font-size:.7rem;background:var(--bg-deep);border-radius:5px;padding:6px}
.chat-msg{line-height:1.4}
.chat-msg .chat-name{color:var(--accent);font-weight:700}
.chat-msg .chat-text{color:var(--text)}
.chat-msg .chat-time{color:var(--text-muted);font-size:.62rem}
#chat-input-row{display:flex;gap:4px;flex-shrink:0}
#chat-input{flex:1;font-size:.75rem;padding:5px 8px}
#btn-chat-send{padding:5px 9px;background:var(--accent-dk);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:.8rem;flex-shrink:0}
#btn-chat-send:hover{background:var(--accent)}

/* ══ CHAR PANEL ══ */
.char-sheet{display:grid;grid-template-columns:220px 1fr;gap:20px}
.char-avatar{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center;display:flex;flex-direction:column;gap:6px}
#char-avatar-icon{font-size:2.5rem}
#char-avatar-name{font-size:1rem;font-weight:700;color:var(--text)}
#char-avatar-class{font-size:.75rem;color:var(--text-sec)}
#char-avatar-faction{font-size:.75rem;font-weight:700}
.char-vitals{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.vital-row{display:flex;align-items:center;gap:6px;font-size:.7rem;color:var(--text-sec)}
.vital-row .stat-bar{flex:1}
.stats-title{font-size:.75rem;font-weight:700;color:var(--text-sec);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.badge-warn{background:rgba(240,192,64,.2);color:var(--gold);border:1px solid var(--gold)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;text-align:center;transition:border-color .2s}
.stat-card:hover{border-color:var(--accent)}
.stat-icon{font-size:1.1rem;margin-bottom:4px}
.stat-name{font-size:.65rem;color:var(--text-sec);text-transform:uppercase;letter-spacing:.06em}
.stat-val{font-size:1.2rem;font-weight:700;color:var(--accent);margin-top:2px}
.gold-card .stat-val{color:var(--gold)}

/* ══ SKILLS PANEL ══ */
.skills-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}
.skill-card{
  width:220px;flex-shrink:0;
  background:rgba(0,170,255,0.03);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-md);padding:12px;
  transition:border-color .2s, box-shadow .2s;
}
.skill-card:hover{border-color:rgba(0,170,255,0.3);box-shadow:var(--glow-sm)}
.skill-name{font-weight:700;font-size:.85rem;color:var(--text)}
.skill-type{font-size:.65rem;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}
.skill-desc{font-size:.72rem;color:var(--text-sec);line-height:1.4}
.skill-cost{font-size:.68rem;color:var(--energy);margin-top:2px}

/* ══ INVENTORY ══ */
.equipment-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.equip-slot{background:var(--bg-card);border:2px dashed var(--border);border-radius:8px;padding:10px 8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.75rem;color:var(--text-sec);min-height:80px}
.equip-slot:hover{border-color:var(--accent);color:var(--accent);cursor:pointer}
.equip-slot span{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em}
.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}
.inv-item{
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--radius-md);
  padding:8px 6px 7px;
  text-align:center;cursor:pointer;
  font-size:.65rem;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
  position:relative;overflow:hidden;
  min-height:88px;
}
.inv-item::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  background:transparent;
  transition:background .18s;
  border-radius:var(--radius-md) var(--radius-md) 0 0;
}
.inv-item:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 8px 24px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.05);
  z-index:2;
}
/* Rarity border glow on hover */
.inv-item[style*="#8a9ab0"]:hover,.inv-item.rarity-common:hover{ box-shadow:0 8px 24px rgba(138,154,176,0.25), 0 0 0 1px rgba(138,154,176,0.3); }
.inv-item[style*="#40c060"]:hover,.inv-item.rarity-uncommon:hover{ box-shadow:0 8px 24px rgba(64,192,96,0.25), 0 0 0 1px rgba(64,192,96,0.35); }
.inv-item[style*="#4090ff"]:hover,.inv-item.rarity-rare:hover{ box-shadow:0 8px 24px rgba(64,144,255,0.3), 0 0 0 1px rgba(64,144,255,0.4); }
.inv-item[style*="#b040e8"]:hover,.inv-item.rarity-epic:hover{ box-shadow:0 8px 24px rgba(176,64,232,0.35), 0 0 0 1px rgba(176,64,232,0.45); }
.inv-item[style*="#ff8c00"]:hover,.inv-item.rarity-legendary:hover{
  box-shadow:0 8px 32px rgba(255,140,0,0.4), 0 0 0 1px rgba(255,140,0,0.5);
  background:rgba(255,140,0,0.06);
}

/* ══ PARCELLE ══ */
.parcelle-layout{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.parcelle-module{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s}
.parcelle-module:hover{border-color:var(--accent)}
.mod-icon{font-size:1.6rem}
.mod-name{font-weight:700;font-size:.88rem;color:var(--text)}
.mod-level{font-size:.7rem;color:var(--accent)}
.mod-desc{font-size:.72rem;color:var(--text-sec);line-height:1.4;flex:1}
.btn-upgrade{padding:6px 10px;background:var(--accent-dk);border:1px solid var(--accent);border-radius:5px;color:#fff;font-size:.72rem;cursor:pointer;transition:all .2s;margin-top:4px}
.btn-upgrade:hover{background:var(--accent)}

/* ══ MARKET ══ */
.market-tabs{display:flex;gap:6px;margin-bottom:14px}
.market-tab{padding:6px 16px;background:transparent;border:1px solid var(--border);border-radius:5px;color:var(--text-sec);cursor:pointer;font-size:.78rem;transition:all .2s}
.market-tab:hover{border-color:var(--accent);color:var(--accent)}
.market-tab.active{background:var(--accent-dk);border-color:var(--accent);color:#fff}

/* ══ CHAT PANEL ══ */
#panel-chat .panel-inner{display:flex;flex-direction:column;height:100%}
#chat-messages-full{flex:1;overflow-y:auto;background:var(--bg-deep);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.chat-msg .chat-name{color:var(--accent);font-weight:700}
.chat-msg .chat-text{color:var(--text)}
.chat-msg .chat-time{color:var(--text-muted);font-size:.65rem}
#chat-input-row{display:flex;gap:8px;flex-shrink:0}
#chat-input{flex:1}
#btn-chat-send{padding:9px 14px;background:var(--accent-dk);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.8rem}
#btn-chat-send:hover{background:var(--accent)}

/* ══ MODAL VILLE ══ */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,10,0.88)}
.modal-content{
  position:relative;z-index:1;
  background:var(--glass-bg);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  overflow:hidden;width:700px;max-width:96vw;
  backdrop-filter:blur(16px);
  box-shadow:0 0 0 1px rgba(0,170,255,0.06), var(--shadow-panel), var(--glow-sm);
}
.city-header{
  padding:14px 20px;
  background:rgba(0,170,255,0.04);
  border-bottom:1px solid var(--glass-border);
  display:flex;align-items:center;gap:12px;
}
.city-header h2{font-size:1.2rem;color:var(--accent);flex:1}
.city-header p{color:var(--text-sec);font-size:.8rem}
.modal-close{background:transparent;border:none;color:var(--text-sec);font-size:1.3rem;cursor:pointer;padding:6px 10px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.modal-close:hover{color:#fff}
.city-map{position:relative;height:360px;background:radial-gradient(ellipse at 50% 50%,#0e2010,#050c08);overflow:hidden}
.city-building{position:absolute;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;transform:translate(-50%,-50%);transition:all .2s}
.city-building:hover .building-icon{transform:scale(1.2)}
.building-icon{font-size:1.8rem;filter:drop-shadow(0 0 6px rgba(0,170,255,.5))}
.building-label{font-size:.65rem;font-weight:700;color:#fff;background:rgba(0,0,0,.7);padding:2px 6px;border-radius:3px;white-space:nowrap;letter-spacing:.04em}
.city-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}

/* ══ HR ══ */
hr{border:none;border-top:1px solid var(--border);margin:4px 0}

/* ══ CARTE GLOBALE ══ */
.global-map-modal{max-width:890px;width:78vw;overflow:hidden}
.gmap-legend{display:flex;flex-direction:column;gap:4px;margin-top:6px;padding-right:2px}
.gmap-item{padding:3px 8px;border-radius:3px;font-size:.68rem;font-weight:600;color:rgba(255,255,255,0.85)}

/* ══ PM TIMER ══ */
#pm-timer{font-size:.65rem;color:var(--pm);font-family:var(--mono);margin-top:2px}

/* ══ COMBAT ══ */

/* ══ COMBAT MODAL REFONTE ══ */
.combat-modal{
  max-width:720px;width:96vw;
  height:92vh;max-height:92vh;
  display:flex;flex-direction:column;
  overflow:hidden;
  background:rgba(6,10,18,.95) !important;
  border:1px solid rgba(200,56,56,.3) !important;
  border-radius:var(--radius-lg) !important;
  box-shadow:0 0 0 1px rgba(200,56,56,.08),0 16px 64px rgba(0,0,10,.9),0 0 60px rgba(200,56,56,.08);
  animation:auth-panel-in .3s ease both;
}
.combat-header{
  padding:12px 16px;
  background:rgba(200,56,56,.08);
  border-bottom:1px solid rgba(200,56,56,.2);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;gap:8px;
}
.combat-header h2{color:var(--hp);letter-spacing:.08em;font-size:.95rem;flex:1;min-width:0}
.modal-close{
  background:transparent;border:1px solid var(--border);color:var(--text-sec);
  font-size:1.1rem;cursor:pointer;
  min-width:34px;min-height:34px;
  display:flex;align-items:center;justify-content:center;
  border-radius:6px;flex-shrink:0
}
.modal-close:hover{color:#fff;border-color:var(--text-sec)}
.combat-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.combat-arena{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:8px;padding:8px 12px;
  align-items:start;flex-shrink:0
}
.combat-vs{font-size:1.2rem;font-weight:900;color:var(--text-muted);text-align:center;padding-top:20px}
.combat-actions{display:flex;gap:6px;padding:0 12px;flex-shrink:0}
.combat-skills{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:6px;padding:6px 12px;flex-shrink:0
}
.combat-skill-btn{
  padding:9px 10px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(0,170,255,.15);
  border-radius:var(--radius-sm);color:var(--text);
  font-size:.7rem;cursor:pointer;
  transition:all .18s ease;
  text-align:left;
  display:flex;flex-direction:column;gap:3px;
  min-height:56px;justify-content:space-between;
  position:relative;overflow:hidden;
}
.combat-skill-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04),transparent);
  pointer-events:none;
}
.combat-skill-btn:hover:not([data-disabled]){
  border-color:rgba(0,170,255,.45);
  background:rgba(0,170,255,.07);
  transform:translateY(-1px);
  box-shadow:var(--glow-sm);
}
.combat-skill-btn[data-disabled]{opacity:.35;cursor:not-allowed}
.csb-top{display:flex;align-items:center;justify-content:space-between;gap:4px}
.csb-name{font-weight:700;font-size:.74rem;color:var(--text)}
.csb-range{font-size:.68rem;font-weight:700}
.csb-bottom{display:flex;align-items:center;justify-content:space-between;gap:4px}
.csb-desc{font-size:.6rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.skill-btn-info{font-size:.6rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}
.combat-result{
  margin:4px 12px;padding:8px;
  border-radius:6px;font-size:.8rem;
  font-weight:600;text-align:center;
  white-space:pre-line;flex-shrink:0
}
.combat-result.win{background:rgba(50,180,80,.15);border:1px solid #30b050;color:#50e080}
.combat-result.lose{background:rgba(200,50,50,.15);border:1px solid #a03030;color:#ff6060}
.combat-result.fled{background:rgba(100,100,200,.15);border:1px solid #5050a0;color:#8080d0}
.combat-log{
  margin:4px 12px 8px;
  background:rgba(0,0,10,.5);
  border:1px solid rgba(0,170,255,.08);
  border-radius:var(--radius-sm);
  padding:8px;
  flex:1;min-height:70px;
  overflow-y:auto;
  font-size:.67rem;font-family:var(--mono);
  display:flex;flex-direction:column;gap:2px;
  scroll-behavior:smooth;
}
.combat-log-entry{color:var(--text-sec);line-height:1.4}

/* ── Combatants ─────────────────────────────────────────────────────────── */
.combatant{
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-md);
  padding:12px 14px;
  display:flex;flex-direction:column;gap:5px;
  transition:box-shadow .2s;
}
.combatant-header{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.combatant-icon{font-size:1.8rem;flex-shrink:0;line-height:1}
.combatant-info{flex:1;min-width:0}
.combatant-badge{font-size:.63rem;color:var(--text-muted);margin-top:1px}
.dmg-preview{font-size:.63rem;color:#e08040;min-height:14px;margin-top:2px;text-align:center}
.combatant-stats{font-size:.6rem;color:var(--text-muted);margin-top:2px;display:flex;gap:6px;flex-wrap:wrap}
.cb-val{font-size:.63rem;color:var(--text-muted)}
.combatant.player-side{border-color:rgba(56,184,112,.4);background:rgba(56,184,112,.03)}
.combatant.enemy-side{border-color:rgba(200,56,56,.4);background:rgba(200,56,56,.03)}
.combatant-name{font-weight:700;font-size:.9rem;color:var(--text)}
.combatant-bars{display:flex;flex-direction:column;gap:4px}
.cb-row{display:flex;align-items:center;gap:6px;font-size:.68rem;color:var(--text-sec)}
.cb-row span:first-child{min-width:36px;flex-shrink:0}
.cb-row span:last-child{min-width:52px;text-align:right;font-family:var(--mono);font-size:.65rem}
.cb-bar{flex:1;height:7px;background:var(--bg-deep);border-radius:4px;overflow:hidden}
.cb-fill{height:100%;border-radius:4px;transition:width .4s}
.cb-hp{background:var(--hp)}
.cb-energy{background:var(--pm)}
.cb-spd{background:#e0c030}
.status-row{display:flex;flex-wrap:wrap;gap:3px;min-height:10px}
.status-badge{padding:1px 5px;background:var(--bg-deep);border:1px solid var(--border);border-radius:3px;font-size:.66rem;cursor:help}

/* ── Actions principales ─────────────────────────────────────────────────── */
.combat-action-btn{flex:1;padding:8px 6px;border-radius:6px;font-size:.78rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:opacity .15s}
.btn-attack{background:var(--hp);color:#fff;border-color:var(--hp)}
.btn-flee{background:transparent;border:1px solid var(--border);color:var(--text-sec)}
.combat-action-btn:disabled{opacity:.4;cursor:not-allowed}


/* ══ WARZONES ══ */
.warzones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.warzone-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:6px}
.wz-name{font-weight:700;font-size:.9rem;color:var(--text)}
.wz-desc{font-size:.72rem;color:var(--text-sec)}
.wz-status{font-size:.75rem}
.wz-progress-bar{height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}
.wz-fill{height:100%;border-radius:3px;transition:width .5s}
.wz-pts{font-size:.68rem;display:flex;gap:8px;flex-wrap:wrap}

/* ══ ÉCONOMIE ══ */
.market-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-top:8px}
.market-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:4px;align-items:center;text-align:center}
.mc-icon{font-size:1.4rem;min-height:44px;display:flex;align-items:center;justify-content:center}
.mc-name{font-size:.72rem;font-weight:600;line-height:1.3}
.mc-qty{font-size:.68rem;color:var(--text-sec)}
.mc-price{font-size:.78rem;font-weight:700;color:var(--gold)}
.mc-seller{font-size:.65rem;color:var(--text-muted)}
.mc-stats{font-size:.62rem;color:var(--accent)}
.market-btn{padding:4px 8px;border-radius:4px;font-size:.68rem;font-weight:600;cursor:pointer;border:1px solid;transition:all .2s;width:100%}
.market-btn.buy{background:#1a2a1a;border-color:#40a040;color:#60c060}
.market-btn.buy:hover{background:#40a040;color:#fff}
.market-btn.cancel{background:#2a1a1a;border-color:#a04040;color:#c06060}
.market-btn.cancel:hover{background:#a04040;color:#fff}
.shop-category{margin-bottom:16px}
.shop-cat-title{font-size:.7rem;font-weight:700;color:var(--text-sec);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}

.craft-item{display:flex;align-items:center;gap:8px;padding:6px;background:var(--bg-card);border-radius:5px;font-size:.75rem}
.craft-item span:first-child{flex:1;color:var(--text)}
.craft-item span:nth-child(2){color:var(--exp)}
.btn-collect{padding:3px 8px;background:var(--accent-dk);border:1px solid var(--accent);border-radius:4px;color:#fff;font-size:.65rem;cursor:pointer}
.btn-collect:hover{background:var(--accent)}

.item-menu-btn{padding:7px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;color:var(--text);font-size:.78rem;cursor:pointer;transition:all .2s;text-align:left}
.item-menu-btn:hover{border-color:var(--accent);color:var(--accent)}

#item-context-menu .modal-content{background:var(--bg-panel);padding:14px;display:flex;flex-direction:column;gap:6px}

/* ══ INNER TABS ══ */
.inner-tabs{display:flex;gap:6px;margin-bottom:14px;border-bottom:1px solid var(--border);padding-bottom:10px}
.inner-tab{padding:6px 16px;background:transparent;border:1px solid var(--border);border-radius:5px;color:var(--text-sec);cursor:pointer;font-size:.8rem;transition:all .2s}
.inner-tab:hover{border-color:var(--accent);color:var(--accent)}
.inner-tab.active{background:var(--accent-dk);border-color:var(--accent);color:#fff}
.inner-tab-content{display:none}
.inner-tab-content.active{display:block;animation:panel-enter .18s ease both}

/* ══ TALENTS ══ */
.talent-tooltip{position:fixed;top:auto;right:auto;z-index:9999;background:var(--bg-panel);border:1px solid var(--border-glow);border-radius:10px;padding:14px;min-width:200px;max-width:260px;display:flex;flex-direction:column;gap:6px;box-shadow:0 4px 20px rgba(0,0,0,.5)}
.tt-title{font-weight:700;font-size:.95rem;color:var(--text)}
.tt-branch{font-size:.7rem;color:var(--text-sec);letter-spacing:.06em}
.tt-desc{font-size:.8rem;color:var(--accent)}
.tt-cost{font-size:.72rem;color:var(--exp)}
.tt-req{font-size:.68rem;color:var(--text-muted)}
.tt-status.learned{color:var(--pm);font-size:.75rem;font-weight:600}
.tt-status.locked{color:var(--text-muted);font-size:.75rem}
.tt-learn-btn{padding:7px 12px;background:var(--accent-dk);border:1px solid var(--accent);border-radius:6px;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}
.tt-learn-btn:hover{background:var(--accent)}

/* ══ COMPÉTENCES ══ */
.skills-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}
.skill-card{width:220px;flex-shrink:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px;transition:border-color .2s}
.skill-header{display:flex;justify-content:space-between;align-items:center}
.skill-name{font-weight:700;font-size:.85rem;color:var(--text)}
.skill-lvl{font-size:.75rem;font-weight:700}
.skill-bonus{font-size:.7rem;color:var(--exp);font-weight:600}
.skill-xp-bar{height:4px;background:var(--bg-deep);border-radius:2px;overflow:hidden;margin-top:2px}
.skill-xp-fill{height:100%;background:linear-gradient(90deg,var(--accent-dk),var(--accent));border-radius:2px;transition:width .4s}
.skill-xp-text{font-size:.65rem;color:var(--text-muted);text-align:right}

/* ══ ADMIN ══ */
.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:12px}
.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center}
.asc-val{font-size:1.4rem;font-weight:700;color:var(--accent)}
.asc-label{font-size:.68rem;color:var(--text-sec);text-transform:uppercase;letter-spacing:.06em}

.admin-top-list{display:flex;flex-direction:column;gap:4px}
.admin-top-row{display:flex;align-items:center;gap:10px;padding:4px 8px;background:var(--bg-card);border-radius:5px;font-size:.78rem}
.admin-top-row span:nth-child(2){flex:1}

.admin-search-row{display:flex;gap:8px;margin-bottom:10px}
.admin-player-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:10px}
.admin-player-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:6px}
.admin-player-card.banned{border-color:var(--hp);opacity:.7}
.apc-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.apc-name{font-weight:700;font-size:.88rem;color:var(--text);flex:1}
.apc-info{font-size:.72rem;color:var(--text-sec)}
.apc-hp{font-size:.7rem;color:var(--text-muted)}
.apc-actions{display:flex;gap:4px;flex-wrap:wrap}
.admin-btn{padding:3px 8px;border-radius:4px;font-size:.65rem;font-weight:600;cursor:pointer;background:var(--bg-deep);border:1px solid var(--border);color:var(--text-sec);transition:all .2s}
.admin-btn:hover{border-color:var(--accent);color:var(--accent)}
.admin-btn.ban{border-color:var(--hp)40;color:var(--hp)}
.admin-btn.ban:hover{background:var(--hp);color:#fff}
.admin-btn.unban{border-color:var(--pm)40;color:var(--pm)}
.admin-inv-row{display:flex;align-items:center;gap:8px;padding:6px;background:var(--bg-card);border-radius:5px;font-size:.78rem}
.admin-inv-row span:first-child{flex:1}

/* ══ VILLE STYLE ARCHEAGE ══ */
.city-modal-aa{max-width:880px;width:96vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}
.city-aa-header{padding:14px 18px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;flex-shrink:0}
.city-aa-emblem{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-deep);border:2px solid var(--border-glow)}
.city-aa-info h2{font-size:1.1rem;color:var(--accent);margin:0}
.city-aa-info p{font-size:.75rem;color:var(--text-sec);margin:0}
.city-aa-tabs{display:flex;gap:2px;background:var(--bg-deep);padding:6px 8px;flex-shrink:0;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.city-tab{padding:6px 12px;background:transparent;border:none;border-radius:5px;color:var(--text-sec);cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s}
.city-tab:hover{background:var(--bg-hover);color:var(--text)}
.city-tab.active{background:var(--accent-dk);color:#fff}
.city-aa-content{flex:1;overflow-y:auto;padding:16px}
.city-tab-content{display:none}
.city-tab-content.active{display:block}
.city-aa-footer{padding:10px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;flex-shrink:0}

.aa-building-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.aa-bld-icon{font-size:2rem}
.aa-bld-title{font-size:1rem;font-weight:700;color:var(--text)}
.aa-bld-sub{font-size:.72rem;color:var(--text-sec);font-weight:400;margin-top:2px}

.aa-service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.aa-service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:6px}
.aa-svc-title{font-weight:700;font-size:.85rem;color:var(--text)}
.aa-svc-desc{font-size:.72rem;color:var(--text-sec);flex:1}
.aa-svc-cost{font-size:.78rem;font-weight:700;color:var(--gold)}

.forge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}

/* ══ TOOLTIP ITEM FLOTTANT ══ */
.item-float-tip{
  position:fixed;z-index:9999;
  background:rgba(6,10,18,0.96);
  border:1px solid rgba(0,170,255,0.2);
  border-radius:var(--radius-md);
  padding:0;
  min-width:200px;max-width:280px;
  pointer-events:none;display:none;
  box-shadow:0 8px 32px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,0.04);
  font-size:.75rem;
  
  overflow:hidden;
  /* Pas d'animation — évite la superposition au survol rapide */
}
.ift-header{padding:10px 12px 8px;border-bottom:1px solid rgba(255,255,255,0.07)}
.ift-body{padding:8px 12px 10px;display:flex;flex-direction:column;gap:5px}
.ift-name{font-family:var(--mono);font-weight:700;font-size:.88rem;margin-bottom:2px;letter-spacing:.03em}
.ift-rarity{
  display:inline-block;font-size:.6rem;font-weight:700;
  font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;
  padding:1px 7px;border-radius:3px;
  border-width:1px;border-style:solid;
  background:rgba(255,255,255,0.06);
}
.ift-desc{color:var(--text-sec);font-size:.72rem;line-height:1.45}
.ift-stats{
  font-size:.73rem;
  padding:6px 8px;
  background:rgba(64,144,255,0.08);
  border:1px solid rgba(64,144,255,0.15);
  border-radius:5px;
  color:#80c0ff;
  line-height:1.5;
}
.ift-effect{font-size:.7rem;color:var(--pm)}
.ift-req{font-size:.68rem;color:#e08030}
.ift-qty{font-size:.68rem;color:var(--text-muted)}
.ift-price{font-size:.68rem;color:var(--gold)}
.ift-effect{color:var(--pm);font-size:.72rem;margin-bottom:3px}
.ift-req{color:var(--hp);font-size:.7rem;margin-bottom:2px}
.ift-qty{color:var(--text-muted);font-size:.68rem;margin-top:4px}
.ift-price{color:var(--gold);font-size:.7rem}

/* ══ EVENT PANEL ══ */
#event-panel{background:var(--bg-card);border:1px solid var(--border-glow);border-radius:8px;padding:10px;animation:fadeIn .2s ease;flex-shrink:0}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* Stat cards avec tooltip */
.stat-card[title]{transition:border-color .2s}
.stat-card[title]:hover{border-color:var(--accent)!important}

/* ══ STATS DÉRIVÉES ══ */
.stats-title{font-size:.75rem;font-weight:700;color:var(--text-sec);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}

/* ══ CAPITALE OGAME ══ */
.city-ogame-modal{max-width:1400px;width:96vw;max-height:94vh;overflow:hidden;display:flex;flex-direction:column}
.city-ogame-content{flex:1;overflow-y:auto;padding:0}

.ogame-layout{display:flex;flex-direction:column;gap:0}
.ogame-faction-bar{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg-card)}
.ogame-faction-stat{flex:1;padding:8px 14px;display:flex;justify-content:space-between;font-size:.75rem;border-right:1px solid var(--border)}
.ogame-faction-stat span:last-child{font-weight:700;color:var(--accent)}

.ogame-category{border-bottom:1px solid var(--border)}
.ogame-cat-title{padding:6px 14px;background:var(--bg-deep);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid var(--border)}
.ogame-buildings-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0}

.ogame-building{display:flex;gap:14px;padding:16px 18px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;min-height:140px}
.ogame-building:hover{background:var(--bg-hover)}
.ogame-bld-icon{font-size:2.6rem;width:52px;flex-shrink:0;display:flex;align-items:flex-start;padding-top:4px}
.ogame-bld-body{flex:1;display:flex;flex-direction:column;gap:3px}
.ogame-bld-name{font-weight:700;font-size:.95rem;color:var(--text)}
.ogame-bld-level{font-size:.7rem;color:var(--text-sec)}
.ogame-bld-level strong{color:var(--accent)}
.ogame-bld-desc{font-size:.75rem;color:var(--text-sec);line-height:1.5}
.ogame-bld-upgrade-cost{font-size:.68rem;color:var(--gold);margin-top:3px}
.ogame-upgrade-btn{
  padding:5px 10px;
  background:rgba(0,78,122,0.5);
  border:1px solid rgba(0,170,255,0.3);
  border-radius:var(--radius-sm);
  color:var(--accent);
  cursor:pointer;font-size:.72rem;
  font-family:var(--mono);letter-spacing:.04em;
  transition:all .2s;width:auto;text-align:center;
  position:relative;overflow:hidden;white-space:nowrap;
}
.ogame-upgrade-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.04),transparent);transform:translateX(-100%);transition:.4s}
.ogame-upgrade-btn:hover::before{transform:translateX(100%)}
.ogame-upgrade-btn:hover{border-color:rgba(0,170,255,0.6);background:rgba(0,100,160,0.5);box-shadow:var(--glow-sm)}
.ogame-upgrade-btn:hover{background:var(--accent)}
.ogame-bld-progress{margin-top:4px}
.ogame-bld-prog-label{font-size:.7rem;color:var(--exp);margin-bottom:3px}
.ogame-bld-prog-bar{height:4px;background:var(--bg-deep);border-radius:2px;overflow:hidden}
.ogame-bld-prog-fill{height:100%;background:var(--exp);border-radius:2px;transition:width 1s}

/* Sous-panels */
.ogame-sub-panel{padding:14px}
.ogame-sub-title{font-size:.82rem;font-weight:700;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.ogame-back-btn{padding:5px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;color:var(--text-sec);cursor:pointer;font-size:.75rem;margin-bottom:12px;transition:all .2s}
.ogame-back-btn:hover{border-color:var(--accent);color:var(--accent)}

/* Dépôt */
.ogame-depot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px;margin-bottom:12px}
.ogame-depot-item{display:flex;justify-content:space-between;align-items:center;padding:5px 8px;background:var(--bg-card);border-radius:5px;font-size:.75rem}
.ogame-deposit-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* Tiki Bar */
.tikibar-feed{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-bottom:10px;background:var(--bg-deep);border-radius:6px;padding:10px}
.tikibar-msg{background:var(--bg-card);border-radius:6px;padding:8px 12px;border-left:3px solid var(--border-glow)}
.tikibar-author{font-weight:700;font-size:.8rem;color:var(--accent);margin-bottom:3px}
.tikibar-time{font-weight:400;font-size:.65rem;color:var(--text-muted);margin-left:6px}
.tikibar-text{font-size:.8rem;color:var(--text);line-height:1.5}
.tikibar-input-row{display:flex;gap:8px}

/* Votes */
.ogame-votes{display:flex;flex-direction:column;gap:10px}
.ogame-vote-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:6px}
.ogame-vote-title{font-weight:700;font-size:.88rem;color:var(--text)}
.ogame-vote-desc{font-size:.75rem;color:var(--text-sec)}
.ogame-vote-counts{font-size:.75rem;color:var(--text-sec)}
.ogame-vote-btns{display:flex;gap:8px}

/* Craft dans repaire */
.ogame-craft-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;
  background:rgba(0,170,255,0.04);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-sm);
  font-size:.75rem;margin-bottom:4px;
}

/* NX dans header */
.hud-nx{font-size:.78rem;font-weight:700;color:var(--gold);padding:3px 8px;background:rgba(240,192,64,.1);border:1px solid rgba(240,192,64,.3);border-radius:5px}

/* auth screen handled above */

/* Fond semi-transparent derrière le jeu */
#screen-game {
  background: url('/fond_ecran.png') center center / cover no-repeat fixed;
}
#screen-game::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,5,15,0.82);
  pointer-events: none;
  z-index: 0;
}
#screen-game > * { position: relative; z-index: 1; }

/* ══ BADGE ADMIN CHAT ══ */
.chat-badge-vip {
  display: inline-block;
  background: linear-gradient(135deg, #b8860b, #ffd700, #b8860b);
  color: #1a1000;
  font-size: .6rem;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 3px;
  border: 1px solid #ffd700;
  letter-spacing: .04em;
  box-shadow: 0 0 6px #ffd70066;
  vertical-align: middle;
}

.chat-badge-admin {
  display: inline-block;
  padding: 1px 5px;
  background: rgba(220,50,50,0.2);
  border: 1px solid #cc3333;
  border-radius: 3px;
  color: #ff4444;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .05em;
  margin-right: 5px;
  vertical-align: middle;
}

/* ══ SYSTÈME D'ASSETS IMAGES ══ */
.game-asset {
  width: 40px;
  height: 40px;
  object-fit: contain;
  image-rendering: pixelated;
}
.item-display-wrap img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  image-rendering: auto;
  border-radius: 4px;
}
.item-display-wrap {
  border-radius: 4px;
  overflow: hidden;
}
.game-asset-sm { width: 20px; height: 20px; }
.game-asset-lg { width: 48px; height: 48px; }

/* ══ RENCONTRES PvP ══ */
.encounter-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:5px}
.enc-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.enc-name{font-weight:700;font-size:.88rem;color:var(--text);flex:1}
.enc-info{font-size:.72rem;color:var(--text-sec)}
.enc-hp{font-size:.7rem;color:var(--text-muted)}
.enc-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}



/* ══ REPAIRE IDLE ══ */
.repaire-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.repaire-tab{padding:5px 10px;background:var(--bg-deep);border:1px solid var(--border);border-radius:5px;color:var(--text-sec);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}
.repaire-tab:hover{border-color:var(--accent);color:var(--accent)}
.repaire-tab.active{background:var(--accent-dk);border-color:var(--accent);color:#fff}

.mw-indicator{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-card);border:1px solid;border-radius:6px;font-size:.75rem}
.mw-bar{width:80px;height:6px;background:var(--bg-deep);border-radius:3px;overflow:hidden}
.mw-fill{height:100%;border-radius:3px;transition:width .4s}
.mw-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:.75rem;margin-bottom:10px;display:flex;gap:16px;flex-wrap:wrap}

.repaire-prod-bar{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:7px 12px;font-size:.75rem;margin-bottom:8px}
.repaire-prod-bar em{color:var(--gold)}

.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:10px}
.slot-card{background:var(--bg-card);border:2px dashed var(--border);border-radius:8px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;min-height:115px;cursor:pointer;transition:all .2s;text-align:center}
.slot-card:hover{border-color:var(--accent)}
.slot-card.locked{opacity:.4;cursor:not-allowed;border-style:solid}
.slot-card.filled{border-style:solid;border-color:var(--accent);background:var(--bg-hover)}
.slot-card.empty{border-color:var(--border-glow)40}

.blueprints-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.blueprint-card{
  background:rgba(0,170,255,0.03);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-md);
  padding:12px 14px;
  display:flex;flex-direction:column;gap:5px;
  transition:border-color .2s, box-shadow .2s;
}
.blueprint-card:hover{
  border-color:rgba(0,170,255,0.3);
  box-shadow:var(--glow-sm);
}
.bp-title{font-weight:700;font-size:.82rem;color:var(--text);font-family:var(--mono)}
.bp-ingredients{font-size:.68rem;color:var(--text-sec);line-height:1.5}
.bp-time{font-size:.68rem;color:var(--exp)}

.storage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}
.storage-item{background:var(--bg-card);border:1px solid var(--border);border-radius:7px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center}

/* Modale ville plus large */


/* ══ CAPITALE 2 COLONNES ══ */
.cap-summary-bar{display:flex;background:var(--bg-card);border:1px solid;border-radius:8px;margin-bottom:12px;overflow:hidden}
.csb-item{flex:1;padding:8px 14px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border)}
.csb-item:last-child{border:none}
.csb-lbl{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.csb-val{font-size:.82rem;font-weight:700;color:var(--accent)}

.cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cap-building{
  display:flex;gap:14px;padding:16px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--border-subtle);
  border-radius:var(--radius-md);cursor:pointer;
  transition:all .2s;align-items:flex-start;
}
.cap-building:hover{
  background:rgba(0,170,255,0.05);
  border-color:rgba(0,170,255,0.25);
  transform:translateY(-1px);
  box-shadow:var(--glow-sm);
}
.cap-bld-left{display:flex;flex-direction:column;align-items:stretch;flex-shrink:0;width:110px;min-height:100%;position:relative}
.cap-bld-right{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}
.cap-bld-left-img{width:100%;height:100%;min-height:110px;object-fit:cover;border-radius:6px 0 0 6px;display:block}
.cap-bld-left-emoji{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:110px;background:linear-gradient(135deg,var(--bg-deep) 0%,var(--bg-card) 100%);border-radius:6px 0 0 6px;font-size:2.6rem}
.cap-bld-left-label{font-size:.6rem;font-weight:700;letter-spacing:.06em;text-align:center;margin-top:4px}
.cap-bld-header{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
.cap-bld-name{font-weight:700;font-size:.92rem;color:var(--text)}
.cap-bld-lvl{padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:700;border:1px solid;flex-shrink:0}
.cap-bld-desc{font-size:.73rem;color:var(--text-sec);line-height:1.45}
.cap-bld-cost{font-size:.68rem;color:var(--text-muted);margin-top:2px}
.cap-bld-prog{font-size:.72rem;margin-top:4px}
.cap-legend{display:flex;gap:16px;flex-wrap:wrap;padding:8px 4px;font-size:.68rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:10px}

/* Tags inline */
.bld-tag{display:inline-block;padding:2px 7px;border-radius:3px;font-size:.68rem;font-weight:600;margin-top:3px}
.bld-tag.green{background:rgba(64,192,128,.12);color:#40c080}
.bld-tag.gold{background:rgba(232,192,64,.12);color:#e8c040}
.bld-tag.blue{background:rgba(74,144,217,.12);color:#4a90d9}
.bld-tag.red{background:rgba(220,64,64,.12);color:#e04040}
.bld-tag.purple{background:rgba(192,64,224,.12);color:#c040e0}
.bld-tag.teal{background:rgba(64,176,160,.12);color:#40b0a0}
.bld-tag.orange{background:rgba(224,128,48,.12);color:#e08030}

/* Slots visuels */
.bld-slots-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.bld-slot-mini{width:42px;height:42px;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;transition:all .15s;position:relative;flex-shrink:0}
.bld-slot-empty{background:var(--bg-deep);border:2px dashed var(--border);color:var(--text-muted)}
.bld-slot-empty:hover{border-color:var(--accent);color:var(--accent)}
.bld-slot-filled{background:var(--bg-hover);border:2px solid var(--border-glow)}
.bld-slot-filled:hover{border-color:var(--accent);transform:scale(1.05)}
.slot-qty{font-size:.55rem;color:var(--text-sec);line-height:1;margin-top:1px;text-align:center;white-space:nowrap}

/* Tooltip custom */
.custom-tooltip{position:fixed;z-index:9999;background:var(--bg-panel);border:1px solid var(--border-glow);border-radius:7px;padding:8px 12px;font-size:.75rem;color:var(--text);pointer-events:none;max-width:220px;line-height:1.5;box-shadow:0 4px 16px rgba(0,0,0,.6)}

/* Barre MW inline repaire */
.mw-bar-inline{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-card);border:1px solid;border-radius:5px;font-size:.72rem}
.rep-prod-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:5px;font-size:.72rem;color:var(--exp)}

/* ══ IMAGES BÂTIMENTS ══ */
.bld-img-wrap{width:56px;height:56px;display:flex;align-items:center;justify-content:center}
.bld-img-custom{width:56px;height:56px;object-fit:contain;border-radius:6px}
.bld-img-custom.error{display:none}
/* Fallback : l'emoji apparaît si l'image est absente (géré par JS) */

/* ══ TIKI BAR FORUM ══ */
.forum-list{display:flex;flex-direction:column;gap:6px}
.forum-topic-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:background .15s}
.forum-topic-row:hover{background:var(--bg-hover);border-color:var(--border-glow)}
.forum-topic-icon{font-size:1.4rem;flex-shrink:0}
.forum-topic-body{flex:1;min-width:0}
.forum-topic-title{font-weight:600;font-size:.88rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.forum-topic-meta{font-size:.68rem;color:var(--text-muted);margin-top:2px}
.forum-del-btn{padding:3px 8px;background:rgba(200,50,50,.15);border:1px solid var(--hp);border-radius:4px;color:var(--hp);cursor:pointer;font-size:.7rem;flex-shrink:0;transition:all .2s}
.forum-del-btn:hover{background:var(--hp);color:#fff}
.forum-topic-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:12px}

/* ══ ICON IMAGE BUILDING ══ */
.bld-icon-img{width:56px;height:56px;border-radius:6px;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;position:relative}
.bld-icon-img.no-img .bld-icon-fallback{display:flex}
.bld-icon-fallback{font-size:2.6rem;display:none}
/* Si l'image se charge, cacher le fallback */
.bld-icon-img[style*="url"]:not([style*="url()"]) .bld-icon-fallback{display:none}

/* ══ ATELIER SECTIONS ══ */
.atelier-section-title{
  font-family:var(--mono);font-size:.7rem;font-weight:700;
  color:var(--accent);text-transform:uppercase;letter-spacing:.12em;
  padding:8px 0 6px;
  border-bottom:1px solid var(--glass-border);
  margin-bottom:10px;
  text-shadow:0 0 10px rgba(0,170,255,0.2);
}

/* ══ MARCHE NOIR ══ */
.bm-card{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-deep) 100%)}

/* ══ SELL INVENTORY ══ */
.sell-inv-row{display:flex;align-items:center;padding:7px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s}
.sell-inv-row:hover{background:var(--bg-hover);border-color:var(--border-glow)}
.sell-inv-row.selected{border-color:var(--accent);background:var(--bg-hover)}

.skill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:8px;align-items:start;align-content:start;grid-auto-rows:min-content}
.skill-grid > .skill-card{width:220px;flex-shrink:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:10px;transition:border-color .2s}

#global-map-canvas{max-width:100%;height:auto;display:block;}

#talent-tree-container{width:100%;min-height:500px;overflow:visible}
.inner-tab-content.active{display:block;overflow-y:auto;max-height:calc(100vh - 200px)}

/* Scrollbar élégante */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:rgba(0,170,255,0.4)}

/* Sélection de texte */
::selection{background:rgba(0,170,255,0.25);color:#fff}
