@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ── VARIABLES ─────────────────────────────── */
:root {
  --bg:       #000;
  --bg1:      #0a0a0a;
  --bg2:      #111;
  --bg3:      #1a1a1a;
  --bg4:      #222;
  --border:   #1f1f1f;
  --border2:  #2a2a2a;
  --border3:  #333;
  --text:     #ededed;
  --text2:    #888;
  --text3:    #444;
  --white:    #fff;
  --green:    #22c55e;
  --red:      #ef4444;
  --blue:     #3b82f6;
  --gold:     #eab308;
  --sw:       220px;
  --th:       52px;
  --r:        8px;
  --r2:       5px;
}

/* ── RESET ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Outfit',system-ui,sans-serif;
  font-size:.9rem;
  line-height:1.55;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit}
input{font-family:inherit}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border3);border-radius:4px}

/* ── LAYOUT ────────────────────────────────── */
.layout{display:flex;min-height:100vh}

/* ── SIDEBAR ───────────────────────────────── */
.sidebar{
  width:var(--sw);
  background:var(--bg1);
  border-right:1px solid var(--border);
  position:fixed;
  top:0;left:0;bottom:0;
  display:flex;flex-direction:column;
  z-index:300;
  overflow-y:auto;
  transition:transform .25s ease;
}

.sidebar-logo{
  display:flex;align-items:center;gap:10px;
  padding:15px 14px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}

.logo-mark{
  width:30px;height:30px;
  background:var(--white);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;
  color:#000;letter-spacing:-.5px;
  flex-shrink:0;
}

.logo-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.logo-name{font-size:.8rem;font-weight:700;color:var(--white);white-space:nowrap}
.logo-server{font-family:'JetBrains Mono',monospace;font-size:.58rem;color:var(--text3);letter-spacing:.8px}

.sidebar-nav{flex:1;padding:8px}

.nav-section{margin-bottom:4px}

.nav-label{
  font-size:.6rem;font-weight:600;
  color:var(--text3);
  letter-spacing:1.2px;text-transform:uppercase;
  padding:8px 8px 4px;
}

.nav-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 9px;
  border-radius:var(--r2);
  color:var(--text2);
  font-size:.83rem;font-weight:500;
  cursor:pointer;
  transition:background .12s,color .12s;
  margin-bottom:1px;
  user-select:none;
  border:1px solid transparent;
}

.nav-item i{width:15px;height:15px;flex-shrink:0;stroke-width:1.75}
.nav-item span{flex:1;min-width:0}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:var(--bg3);color:var(--white);border-color:var(--border2)}

.nbadge{
  font-family:'JetBrains Mono',monospace;
  font-size:.58rem;
  background:var(--bg4);border:1px solid var(--border2);
  border-radius:20px;padding:1px 7px;
  color:var(--text3);flex-shrink:0;
}
.nbadge.green{color:var(--green);border-color:rgba(34,197,94,.2);background:rgba(34,197,94,.06)}

.sidebar-footer{
  padding:12px 14px;
  border-top:1px solid var(--border);
  flex-shrink:0;
}

.sfooter-status{
  display:flex;align-items:center;gap:7px;
  font-size:.73rem;color:var(--text2);margin-bottom:4px;
}

.dot-live{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 6px rgba(34,197,94,.5);
  flex-shrink:0;
  animation:blink 2.5s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.sfooter-count{
  font-family:'JetBrains Mono',monospace;
  font-size:.65rem;color:var(--text3);
  padding-left:13px;
}

.sidebar-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.6);
  z-index:299;
  backdrop-filter:blur(2px);
}

/* ── TOPBAR ────────────────────────────────── */
.main{margin-left:var(--sw);flex:1;display:flex;flex-direction:column;min-width:0}

.topbar{
  height:var(--th);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;
  padding:0 18px;gap:12px;
  position:sticky;top:0;
  background:rgba(0,0,0,.9);
  backdrop-filter:blur(12px);
  z-index:200;flex-shrink:0;
}

.menu-btn{
  display:none;
  background:none;
  border:1px solid var(--border2);
  border-radius:var(--r2);
  color:var(--text2);
  padding:5px 7px;
  transition:all .15s;
  line-height:1;
}
.menu-btn:hover{color:var(--text);border-color:var(--border3)}
.menu-btn i{width:15px;height:15px;display:block}

.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.8rem}
.bc-root{color:var(--text3)}
.bc-sep{color:var(--text3);font-size:.75rem}
.bc-cur{color:var(--text);font-weight:500}

.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.topbar-time{font-family:'JetBrains Mono',monospace;font-size:.63rem;color:var(--text3)}

.icon-btn{
  width:30px;height:30px;
  border-radius:var(--r2);
  border:1px solid var(--border2);
  background:none;color:var(--text2);
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.icon-btn i{width:13px;height:13px;stroke-width:2}
.icon-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--border3)}
.icon-btn.spinning i{animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── CONTENT ───────────────────────────────── */
.content{padding:20px;flex:1}

.page{display:none;animation:fadeUp .2s ease}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── PAGE HEAD ─────────────────────────────── */
.page-head{margin-bottom:18px}
.page-title{font-size:1.25rem;font-weight:700;color:var(--white);letter-spacing:-.3px;margin-bottom:3px}
.page-sub{font-size:.78rem;color:var(--text2)}

/* ── GRID ──────────────────────────────────── */
.grid{display:grid;gap:12px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.span2{grid-column:span 2}
.span3{grid-column:span 3}

/* ── KPI ───────────────────────────────────── */
.kpi-card{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:16px;
  transition:border-color .15s;
}
.kpi-card:hover{border-color:var(--border2)}

.kpi-label{
  display:flex;align-items:center;gap:6px;
  font-size:.68rem;font-weight:500;
  color:var(--text2);
  text-transform:uppercase;letter-spacing:.7px;
  margin-bottom:10px;
}
.kpi-label i{width:12px;height:12px;stroke-width:2;flex-shrink:0}

.kpi-val{
  font-family:'JetBrains Mono',monospace;
  font-size:1.9rem;font-weight:700;
  color:var(--white);line-height:1;
  margin-bottom:6px;
}

.kpi-hint{font-size:.68rem;color:var(--text3)}

/* ── CARD ──────────────────────────────────── */
.card{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
}

.card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;
  border-bottom:1px solid var(--border);
}

.card-title{
  display:flex;align-items:center;gap:7px;
  font-size:.78rem;font-weight:600;
  color:var(--text);
}
.card-title i{width:13px;height:13px;stroke-width:2;color:var(--text3)}

.card-body{padding:14px}

.live-pill{
  font-size:.58rem;font-weight:700;
  letter-spacing:1px;color:var(--green);
  background:rgba(34,197,94,.07);
  border:1px solid rgba(34,197,94,.2);
  border-radius:20px;padding:2px 8px;
}

/* ── RANK TABLE ────────────────────────────── */
.rank-table{width:100%;border-collapse:collapse}
.rank-table th{
  font-size:.62rem;font-weight:600;
  color:var(--text3);text-transform:uppercase;letter-spacing:1px;
  padding:8px 14px;
  border-bottom:1px solid var(--border);
  text-align:left;
}
.rank-table td{
  padding:9px 14px;
  border-bottom:1px solid rgba(255,255,255,.03);
  font-size:.83rem;
}
.rank-table tr:last-child td{border-bottom:none}
.rank-table tr:hover td{background:rgba(255,255,255,.02)}

.rk-num{
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;color:var(--text3);
  width:32px;
}
.rk-num.g1{color:var(--gold)}
.rk-num.g2{color:#9ca3af}
.rk-num.g3{color:#92400e}

.rk-name{font-weight:500;color:var(--text)}
.rk-flag{margin-right:7px;font-size:.85rem}
.rk-score{
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;color:var(--text2);
  text-align:right;
}
.rk-score.accent{color:var(--blue)}

/* ── HDV ITEMS ─────────────────────────────── */
.hdv-list{}
.hdv-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;
  border-bottom:1px solid rgba(255,255,255,.03);
  transition:background .12s;
}
.hdv-item:last-child{border-bottom:none}
.hdv-item:hover{background:rgba(255,255,255,.02)}

.hdv-ico{
  width:32px;height:32px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:var(--r2);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.hdv-name{flex:1;font-size:.82rem;font-weight:500;color:var(--text)}
.hdv-seller{font-size:.7rem;color:var(--text3);margin-top:1px}
.hdv-right{text-align:right;flex-shrink:0}
.hdv-price{font-family:'JetBrains Mono',monospace;font-size:.85rem;font-weight:700;color:var(--gold)}
.hdv-qty{font-size:.68rem;color:var(--text3)}

/* ── COUNTRIES GRID ────────────────────────── */
.countries-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:10px;
}

.country-chip{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:12px;
  display:flex;align-items:center;gap:9px;
  cursor:pointer;
  transition:all .15s;
}
.country-chip:hover{background:var(--bg2);border-color:var(--border2);transform:translateY(-1px)}

.country-chip-flag{font-size:1.4rem;flex-shrink:0;line-height:1}
.country-chip-name{font-size:.8rem;font-weight:500;color:var(--text);min-width:0;word-break:break-word}

/* ── COUNTRY DETAIL ────────────────────────── */
.country-header{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:20px 22px;
  margin-bottom:12px;
}

.country-h-top{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.country-flag-big{font-size:2.5rem;line-height:1;flex-shrink:0}
.country-h-info{flex:1}
.country-h-name{font-size:1.4rem;font-weight:700;color:var(--white);margin-bottom:4px}
.country-h-leader{font-size:.78rem;color:var(--text2)}
.country-h-leader strong{color:var(--text)}
.country-tags{display:flex;flex-wrap:wrap;gap:6px}

.tag{
  font-size:.65rem;font-weight:600;
  padding:2px 9px;border-radius:20px;
  border:1px solid;letter-spacing:.3px;
}
.tag-blue{color:var(--blue);border-color:rgba(59,130,246,.3);background:rgba(59,130,246,.07)}
.tag-gold{color:var(--gold);border-color:rgba(234,179,8,.3);background:rgba(234,179,8,.07)}
.tag-green{color:var(--green);border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.07)}
.tag-red{color:var(--red);border-color:rgba(239,68,68,.3);background:rgba(239,68,68,.07)}

.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  margin-bottom:12px;
}

.stat-box{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r2);padding:12px;text-align:center;
}
.stat-box-val{
  font-family:'JetBrains Mono',monospace;
  font-size:1.15rem;font-weight:700;color:var(--white);
  margin-bottom:3px;
}
.stat-box-label{font-size:.62rem;color:var(--text3);text-transform:uppercase;letter-spacing:.8px}

/* Progress */
.prog{margin-bottom:10px}
.prog-head{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text2);margin-bottom:5px}
.prog-bar{height:3px;background:var(--bg3);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width 1s ease}
.prog-fill.blue{background:var(--blue)}
.prog-fill.green{background:var(--green)}
.prog-fill.gold{background:var(--gold)}

/* Info rows */
.irow{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.irow:last-child{border-bottom:none}
.irow-k{font-size:.7rem;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
.irow-v{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--text);font-weight:500}
.irow-v.blue{color:var(--blue)}
.irow-v.gold{color:var(--gold)}
.irow-v.green{color:var(--green)}

/* Allies */
.ally-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ally-chip{
  font-size:.72rem;padding:3px 10px;border-radius:20px;
  cursor:pointer;transition:opacity .15s;
}
.ally-chip:hover{opacity:.8}
.ac-ally{color:var(--green);background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.2)}
.ac-enemy{color:var(--red);background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.2)}

/* Section label */
.slabel{
  font-size:.6rem;font-weight:600;
  color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;
  margin:14px 0 8px;
  display:flex;align-items:center;gap:8px;
}
.slabel::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── PLAYER CARD ───────────────────────────── */
.player-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:20px;
  display:flex;gap:18px;align-items:flex-start;
  margin-bottom:12px;
}
.player-avatar{
  width:80px;height:80px;
  border-radius:var(--r2);border:1px solid var(--border2);
  overflow:hidden;flex-shrink:0;
  background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  image-rendering:pixelated;
}
.player-avatar img{width:100%;height:100%;image-rendering:pixelated}
.player-avatar i{width:28px;height:28px;color:var(--text3)}
.player-info{flex:1;min-width:0}
.player-name{font-size:1.25rem;font-weight:700;color:var(--white);margin-bottom:3px}
.player-country{font-size:.78rem;color:var(--text2);margin-bottom:12px}
.player-stats{display:flex;flex-wrap:wrap;gap:8px}
.pstat{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r2);padding:8px 12px;text-align:center;
}
.pstat-val{font-family:'JetBrains Mono',monospace;font-size:.88rem;font-weight:700;color:var(--white)}
.pstat-key{font-size:.6rem;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-top:2px}
.player-desc{
  margin-top:10px;padding:10px 12px;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);
  font-size:.78rem;color:var(--text2);font-style:italic;
}

/* ── SEARCH BAR ────────────────────────────── */
.sbar{display:flex;align-items:center;gap:10px}

.sbar-wrap{
  display:flex;align-items:center;
  flex:1;max-width:460px;
  background:var(--bg1);
  border:1px solid var(--border2);
  border-radius:var(--r);
  transition:border-color .15s,box-shadow .15s;
  overflow:hidden;
}

.sbar-wrap:focus-within{
  border-color:var(--border3);
  box-shadow:0 0 0 3px rgba(255,255,255,.04);
}

.sbar-icon{
  width:14px;height:14px;
  color:var(--text3);flex-shrink:0;
  margin:0 12px;stroke-width:2;
}

.sbar-input{
  flex:1;background:none;border:none;outline:none;
  color:var(--text);font-size:.85rem;
  padding:10px 12px 10px 0;
}
.sbar-input::placeholder{color:var(--text3)}

/* ── BUTTONS ───────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--white);
  border:none;border-radius:var(--r2);
  color:#000;font-family:inherit;
  font-size:.82rem;font-weight:600;
  padding:9px 16px;
  transition:opacity .15s,transform .1s;
  white-space:nowrap;flex-shrink:0;
}
.btn-primary i{width:13px;height:13px;stroke-width:2.5}
.btn-primary:hover{opacity:.88}
.btn-primary:active{transform:scale(.98)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:7px;
  background:none;border:1px solid var(--border2);
  border-radius:var(--r2);color:var(--text2);
  font-family:inherit;font-size:.8rem;font-weight:500;
  padding:7px 13px;transition:all .15s;
}
.btn-ghost i{width:13px;height:13px;stroke-width:2}
.btn-ghost:hover{color:var(--text);border-color:var(--border3);background:var(--bg3)}

/* ── SERVER HERO ───────────────────────────── */
.server-hero{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:32px;
  display:flex;align-items:center;justify-content:space-between;
}
.sh-label{
  display:flex;align-items:center;gap:7px;
  font-size:.7rem;color:var(--text2);
  text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:10px;
}
.sh-label i{width:13px;height:13px;stroke-width:2}
.sh-count{
  font-family:'JetBrains Mono',monospace;
  font-size:3.5rem;font-weight:700;color:var(--white);
  line-height:1;margin-bottom:8px;
}
.sh-sub{font-size:.78rem;color:var(--text2)}
.sh-sub strong{color:var(--text)}
.sh-status{display:flex;align-items:center;gap:8px}
.sh-status-text{font-size:.85rem;color:var(--green);font-weight:600}

/* ── HISTORIQUE ────────────────────────────── */
.hist-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);margin-bottom:8px;
  cursor:pointer;transition:border-color .15s;
}
.hist-item:hover{border-color:var(--border2)}
.hist-avatar{
  width:36px;height:36px;border-radius:4px;
  background:var(--bg3);border:1px solid var(--border2);
  overflow:hidden;flex-shrink:0;image-rendering:pixelated;
}
.hist-avatar img{width:100%;height:100%;image-rendering:pixelated}
.hist-name{font-weight:600;font-size:.85rem;color:var(--text);flex:1}
.hist-date{font-size:.68rem;color:var(--text3);font-family:'JetBrains Mono',monospace}

/* ── COMPARE ───────────────────────────────── */
.compare-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:start}
.vs-sep{
  display:flex;align-items:center;justify-content:center;
  padding-top:60px;
  font-family:'JetBrains Mono',monospace;
  font-size:.85rem;color:var(--text3);font-weight:700;
}

/* ── PLANNING ──────────────────────────────── */
.plan-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.plan-item:last-child{border-bottom:none}
.plan-dot{width:7px;height:7px;border-radius:50%;background:var(--blue);flex-shrink:0}
.plan-name{flex:1;font-size:.83rem;font-weight:500}
.plan-date{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--text3)}

/* ── LOADER ────────────────────────────────── */
.lrow{display:flex;justify-content:center;padding:28px}
.spin{
  width:20px;height:20px;
  border:2px solid var(--border2);
  border-top-color:var(--text2);
  border-radius:50%;animation:spin .8s linear infinite;
}

/* ── EMPTY ─────────────────────────────────── */
.empty{text-align:center;padding:44px 20px}
.empty-ico{width:36px;height:36px;color:var(--text3);margin:0 auto 12px;display:block}
.empty-t{font-size:.9rem;font-weight:600;color:var(--text2);margin-bottom:5px}
.empty-s{font-size:.78rem;color:var(--text3)}

/* ── TOAST ─────────────────────────────────── */
.toast-stack{position:fixed;bottom:18px;right:18px;z-index:1000;display:flex;flex-direction:column;gap:8px}
.toast{
  padding:10px 16px;border-radius:var(--r2);
  font-size:.8rem;font-weight:500;
  background:var(--bg2);border:1px solid var(--border2);
  color:var(--text);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
  animation:toastIn .25s ease;max-width:300px;
}
.toast.ok{color:var(--green);border-color:rgba(34,197,94,.25)}
.toast.err{color:var(--red);border-color:rgba(239,68,68,.25)}
@keyframes toastIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}

/* ── RESPONSIVE ────────────────────────────── */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay.open{display:block}
  .main{margin-left:0}
  .menu-btn{display:block}
  .g4{grid-template-columns:repeat(2,1fr)}
  .g2,.g3{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .compare-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .vs-sep{padding-top:0}
  .server-hero{flex-direction:column;gap:16px;text-align:center}
}

@media(max-width:540px){
  .g4{grid-template-columns:1fr 1fr}
  .content{padding:14px}
  .player-card{flex-direction:column;align-items:center;text-align:center}
  .countries-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .sh-count{font-size:2.5rem}
  .sbar{flex-direction:column;align-items:stretch}
  .sbar-wrap{max-width:100%}
}
