:root{
  --bg:#0b0f14; --panel:#10151d; --text:#eaf1ff; --muted:#9fb3c8;
  --accent1:#00d4ff; --accent2:#6a5cff; --border:rgba(255,255,255,.06);
  --orange:#ee835a; --glow: rgba(0,212,255,.25);
  --love:#ff6b92;
  --topbar-h:64px; /* surchargée par .bc-topbar--xl */
}

/* ===== Reset / fond ===== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 20% -10%,rgba(0,212,255,.06),transparent 60%),
    radial-gradient(800px 400px at 100% 10%,rgba(106,92,255,.06),transparent 60%),
    #0b0f14;
  color:var(--text);
  font:clamp(14px, 1.2vw, 16px)/1.45 Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
}

/* ===== Liens / boutons ===== */
a{color:inherit;text-decoration:none}
.btn-outline{border:1px solid var(--orange);padding:.6rem 1rem;border-radius:16px}
.btn-primary{
  display:inline-block;padding:.8rem 1.15rem;border-radius:12px;
  background:linear-gradient(90deg,var(--accent1),var(--accent2));
  font-weight:800;box-shadow:0 6px 24px rgba(0,0,0,.25);
}

/* ===== Topbar ===== */
.bc-topbar{
  height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1rem;border-bottom:1px solid var(--border);
  background:#0c1117;position:sticky;top:0;z-index:40;
}
.bc-topbar--xl{ /* topbar plus grande */
  --topbar-h:84px;
  padding:0 1.2rem;
}
.bc-left{display:flex;align-items:center;gap:.8rem;min-width:0}
.bc-logo{width:30px;height:30px;border-radius:10px;flex:0 0 auto;box-shadow:0 0 0 2px #0c1117}
.bc-topbar--xl .bc-logo{width:36px;height:36px;border-radius:12px}
.bc-brand{
  font-weight:1000;letter-spacing:1px;font-size:22px;white-space:nowrap;
  background:linear-gradient(90deg,#63e5ff,#9b8bff,#7aa1ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 18px var(--glow);
}
.bc-topbar--xl .bc-brand{font-size:24px;letter-spacing:1.1px}
.bc-nav{display:flex;gap:.7rem;align-items:center;min-width:0}
.bc-nav a{opacity:.95;white-space:nowrap;font-weight:800;letter-spacing:.4px}
.bc-nav a:hover{opacity:1}
.pill-nav{
  padding:.4rem .8rem;border-radius:999px;background:rgba(255,255,255,.03);
  border:1px solid var(--border);transition:transform .12s ease, box-shadow .12s ease;
}
.pill-nav:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.25)}

/* Burger */
.nav-toggle{
  display:none;align-items:center;justify-content:center;
  width:44px;height:44px;border:1px solid var(--border);
  border-radius:12px;background:#0c1117;color:#9fb3c8;cursor:pointer;
}
.nav-toggle:hover{color:#fff}

/* ===== Layout global ===== */
.bc-layout{
  display:grid;grid-template-columns:320px 1fr;
  min-height:calc(100vh - var(--topbar-h));
}

/* ===== Sidebar ===== */
.bc-sidebar{
  border-right:1px solid var(--border);background:#0c1117;
  position:relative;padding:16px;

  /* pour que la liste prenne toute la hauteur */
  display:flex;flex-direction:column;gap:12px;min-height:0;
}

.bc-content{padding:32px}

/* Profil en haut de la sidebar */
.sb-profile{display:flex;align-items:center;gap:14px;margin-bottom:4px}
.avatar-big{
  width:72px;height:72px;border-radius:50%;padding:2px;
  background:conic-gradient(from 0deg,var(--accent1),var(--accent2));
  box-shadow:0 0 0 2px #0c1117;flex:0 0 auto;
}
.avatar-big img,.avatar-fallback.big{
  width:100%;height:100%;border-radius:50%;display:block;object-fit:cover;background:#131a24;
}
.avatar-fallback.big{display:grid;place-items:center;font-weight:900;font-size:28px}
.sb-username{font-weight:800;max-width:200px;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}

/* Raccourcis “Profil / VIP” (affichage large) */
.sb-quick{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.sb-quick-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;
  background:#0b0f15;border:1px solid var(--border);
}
.sb-quick-item:hover{background:#0e1420}
.qi-icon{
  width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:#0e1520;border:1px solid var(--border);color:#cfe7ff;
}
.qi-label{font-weight:800}

/* Titre de section */
.sb-section{margin:6px 0 6px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.7px}
.sb-section.sb-divider{border-top:1px solid var(--border);padding-top:10px}

/* Liste des guildes — occupe tout l’espace restant */
.sb-guilds{
  list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;
  flex:1;min-height:0; /* <- important pour que le scroll se fasse */
  overflow:auto; -webkit-overflow-scrolling:touch;
}

/* Tuile */
.sb-guilds li.guild{
  position:relative;
  display:grid;grid-template-columns:auto 1fr;align-items:center;gap:14px;
  padding:12px;border-radius:14px;background:#0b0f15;border:1px solid var(--border);
}
.sb-guilds li.guild:hover{background:#0e1420}

/* Icône serveur ROND (plein cadre) */
.sb-guilds .gicon{
  width:56px;height:56px;border-radius:50%;overflow:hidden;flex:0 0 auto;
  background:#0e1520;border:1px solid var(--border);box-shadow:inset 0 0 0 1px rgba(255,255,255,.02);
}
.sb-guilds .gicon img{width:100%;height:100%;display:block;object-fit:cover}
.sb-guilds .gicon .noicon{display:grid;place-items:center;height:100%;font-size:12px;color:#9fb3c8}

.sb-guilds .gmeta{display:flex;flex-direction:column;min-width:0}
.sb-guilds .gname{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-guilds .gnick{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-guilds .empty{justify-content:center;color:var(--muted);background:transparent;border:none}

/* Favoris — cœur */
.fav-btn{
  position:absolute;top:8px;right:8px;
  width:24px;height:24px;border-radius:50%;border:1px solid var(--border);
  background:#0c1117;color:#9fb3c8;display:none;align-items:center;justify-content:center;
  font-size:14px;line-height:1;cursor:pointer;transition:transform .08s ease, box-shadow .12s ease, color .12s ease, border-color .12s ease;
}
.fav-btn.press{transform:scale(.95)}
li.guild:hover .fav-btn{display:flex}
li.guild.fav .fav-btn{display:flex;color:var(--love);border-color:rgba(255,107,146,.45);box-shadow:0 0 12px rgba(255,107,146,.35)}

.fav-hint{
  position:absolute;left:12px;bottom:-20px;opacity:0;pointer-events:none;
  background:#0c1117;border:1px solid var(--border);padding:4px 8px;border-radius:8px;
  font-size:12px;color:var(--muted);white-space:nowrap;transition:opacity .15s ease, transform .15s ease; transform:translateY(4px);
}
li.guild:hover .fav-hint{opacity:1;transform:translateY(0)}

/* Bouton repli */
.sb-collapse{
  position:absolute;top:50%;right:-16px;transform:translateY(-50%);
  width:40px;height:40px;display:grid;place-items:center;
  background:#0c1117;color:#9fb3c8;border:1px solid var(--border);
  border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:5;cursor:pointer;
}
.sb-collapse:hover{color:#fff}
.sb-collapse[aria-expanded="false"] svg{transform:rotate(180deg)}
.sb-collapse svg{transition:transform .18s ease}

/* ===== Mode replié (desktop) ===== */
.bc-sidebar.collapsed{width:96px;padding:12px 10px}
.bc-sidebar.collapsed .sb-username,
.bc-sidebar.collapsed .sb-section,
.bc-sidebar.collapsed .sb-guilds .gmeta,
.bc-sidebar.collapsed .sb-guilds .fav-hint,
.bc-sidebar.collapsed .sb-quick{display:none}

/* avatar ajusté (ne devient plus énorme) */
.bc-sidebar.collapsed .avatar-big{
  width:56px;height:56px;margin:4px auto 6px;padding:2px;border-radius:50%;
}

/* liste centrée et pas de “coupe” sur la gauche */
.bc-sidebar.collapsed .sb-guilds{padding:6px; overflow:auto}
.bc-sidebar.collapsed .sb-guilds li.guild{
  background:transparent;border:none;padding:6px;display:grid;place-items:center;overflow:visible;
}
.bc-sidebar.collapsed .sb-guilds .gicon{
  width:56px;height:56px;border-radius:50%;border:1px solid var(--border);background:#0b0f15;overflow:visible;margin:0 auto;
}
/* cache le cœur en replié */
.bc-sidebar.collapsed .fav-btn{display:none!important}

/* Rail d’actions (icônes seules) visible uniquement replié */
.sb-mini-actions{display:none}
.bc-sidebar.collapsed .sb-mini-actions{
  position:relative;display:flex;flex-direction:column;gap:10px;margin:6px auto 2px;
  align-items:center;justify-content:center;
}
.mini-btn{
  width:38px;height:38px;border-radius:12px;border:1px solid var(--border);
  background:#0b0f15;display:grid;place-items:center;color:#d8e7ff;
}
.mini-btn:hover{background:#0e1420}

/* ===== Overlay mobile ===== */
.sb-overlay{
  position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(0,0,0,.45);
  backdrop-filter:blur(2px);display:none;z-index:35;
}
.sb-overlay.show{display:block}

/* ===== User menu (top-right) ===== */
.user-menu{position:relative;display:flex;align-items:center;gap:10px;cursor:pointer;min-width:0}
.avatar-ring{
  position:relative;width:36px;height:36px;border-radius:50%;padding:2px;
  background:conic-gradient(from 0deg,var(--accent1),var(--accent2));
  box-shadow:0 0 0 2px #0c1117;
}
.avatar-ring--big{width:44px;height:44px}
.avatar-ring img,.avatar-fallback{width:100%;height:100%;border-radius:50%;display:block;background:#111;object-fit:cover}
.avatar-fallback{display:grid;place-items:center;font-weight:900}
.presence-dot{position:absolute;right:-2px;bottom:-2px;width:12px;height:12px;border-radius:50%;background:#3ba55c;border:2px solid #0c1117}
.user-name{max-width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:900;letter-spacing:.2px}
.user-name--big{max-width:220px;font-size:16px}
.chev{opacity:.85}
.user-menu .dropdown{
  position:absolute;top:44px;right:0;min-width:220px;background:#141a22;border:1px solid var(--border);
  border-radius:12px;padding:8px;display:none;box-shadow:0 14px 34px rgba(0,0,0,.35)
}
.user-menu:hover .dropdown{display:block}
.user-menu .dropdown a{display:block;padding:10px;border-radius:8px}
.user-menu .dropdown a:hover{background:#0f151d}

/* ===== Cards / contenu ===== */
.page-title{font-size:clamp(22px, 2.5vw, 30px);margin:6px 0 16px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.card{background:#0b0f15;border:1px solid var(--border);border-radius:16px;padding:18px}
.big{font-size:clamp(26px, 3.2vw, 36px);font-weight:1000}
.pill{display:inline-block;padding:6px 10px;border-radius:14px;background:#18222e}
.pill.ok{background:#12361e}
.pill.ko{background:#3a1a1a}
.muted{color:var(--muted)}

/* ===== Login plein écran ===== */
.login-full{
  min-height:calc(100vh - var(--topbar-h));
  display:grid;grid-template-columns:1.15fr 1fr;gap:32px;align-items:center;
  padding:32px;
}
.login-hero{display:grid;gap:16px;align-content:start}
.login-title{font-size:clamp(32px,6vw,56px);line-height:1.05;margin:0}
.login-title span{
  background:linear-gradient(90deg,var(--accent1),var(--accent2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 18px var(--glow);
}
.login-sub{color:var(--muted);font-size:clamp(14px,1.2vw,16px)}
.login-cta{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.login-btn{font-size:16px}
.login-perks{margin:8px 0 0;padding-left:18px;color:var(--muted)}
.login-perks li{margin:.2rem 0}
.login-art{position:relative;display:grid;place-items:center}
.login-logo{
  width:clamp(140px,28vw,260px);height:auto;border-radius:20px;
  box-shadow:0 18px 60px rgba(0,0,0,.35);
}
.login-glow{
  position:absolute;inset:auto;top:50%;left:50%;width:80%;height:60%;
  transform:translate(-50%,-45%);
  background:radial-gradient(closest-side, rgba(0,212,255,.18), transparent 70%),
             radial-gradient(closest-side, rgba(106,92,255,.18), transparent 70%);
  filter:blur(16px);pointer-events:none;z-index:-1;
}

/* ===== Bandeau favoris mobile ===== */
.mobile-fav-strip{display:none}
@media (max-width: 992px){
  .mobile-fav-strip{
    display:flex;gap:10px;position:sticky; top: calc(var(--topbar-h) + 0px);
    z-index: 39;
    padding: 10px 12px;
    background: #0c1117d9;
    border: 1px solid var(--border);
    border-left: none;
    border-right: none;
    overflow-x: auto; -webkit-overflow-scrolling: touch;
  }
  .mobile-fav-strip .gicon{
    width: 60px; height: 60px; border-radius: 50%;
    flex: 0 0 auto; border: 1px solid var(--border);
  }
}

/* ===== Footer ===== */
.bc-footer{
  display:grid;place-items:center;padding:16px;color:var(--muted);
  border-top:1px solid var(--border);background:#0c1117;margin-top:24px;
}
.bc-footer strong{
  background:linear-gradient(90deg,#5df,#79f);
  -webkit-background-clip:text;background-clip:text;color:transparent
}

/* ===== Breakpoints ===== */
@media (max-width: 1400px){
  .bc-layout{grid-template-columns:300px 1fr}
}
@media (max-width: 1200px){
  .bc-layout{grid-template-columns:280px 1fr}
}

/* mobile (off-canvas) */
@media (max-width: 992px){
  .bc-layout{grid-template-columns:1fr}
  .nav-toggle{display:flex}
  .sb-collapse{display:none}
  .bc-sidebar{
    position:fixed;top:var(--topbar-h);left:0;bottom:0;z-index:50;
    width:min(86vw, 380px);
    transform:translateX(-100%);transition:transform .22s ease;
    box-shadow:0 20px 60px rgba(0,0,0,.45);
  }
  .bc-sidebar.open{transform:translateX(0)}
  .bc-content{padding:22px}

  /* Login : pile unique */
  .login-full{grid-template-columns:1fr;padding:24px 18px;gap:20px}
  .login-art{order:-1}
  .login-logo{width:clamp(120px,40vw,200px)}
}

/* tablettes */
@media (max-width: 768px){
  .bc-nav{gap:.5rem;overflow-x:auto;max-width:60vw}
  .cards{grid-template-columns:1fr}
  .user-name{max-width:120px}
}

/* petits téléphones */
@media (max-width: 480px){
  .bc-topbar{padding:0 .7rem}
  .bc-brand{font-size:20px}
  .btn-outline{padding:.5rem .8rem}
  .btn-primary{padding:.75rem 1rem}
  .login-sub{font-size:14px}
}

/* écrans très larges */
@media (min-width: 1800px){
  .bc-layout{grid-template-columns:360px 1fr}
  .sb-guilds .gicon{width:64px;height:64px}
  .bc-sidebar.collapsed .sb-guilds .gicon{width:72px;height:72px}
  .avatar-big{width:84px;height:84px}
  .avatar-ring--big{width:48px;height:48px}
  .user-name--big{max-width:280px;font-size:17px}
}
