/* ── NEBULA SPACE — Front office (espace membres) ── */
:root{
  --bg:#0d1520; --bg-2:#0a1019;
  --panel:rgba(19,31,48,.72); --panel-solid:#131f30; --panel-2:#182636;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.15);
  --ink:#e8eef5; --ink-2:#9fb0c3; --ink-3:#67788d;
  --teal:#2ec4b6; --teal-2:#25a99c; --teal-ink:#06231f;
  --glow:rgba(46,196,182,.35);
  --r:14px; --r-sm:10px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 18px 50px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
.preload *,.preload *::before,.preload *::after{transition:none!important;animation:none!important}
html,body{height:100%;width:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Outfit',system-ui,-apple-system,sans-serif;
  overflow:hidden; -webkit-font-smoothing:antialiased;
}
[hidden]{display:none!important}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--glow);color:#fff}
.mono{font-family:'DM Mono',ui-monospace,monospace}

/* Starfield canvas (login only) */
#stars{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .6s}
#stars.on{opacity:1}

/* ══════════════════════ LOGIN ══════════════════════ */
#login{
  position:fixed;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:24px;
  background:
    radial-gradient(60% 55% at 50% -10%, rgba(46,196,182,.18), transparent 60%),
    radial-gradient(90% 60% at 80% 110%, rgba(56,120,220,.12), transparent 60%);
}
#login::before{ /* aurora */
  content:'';position:absolute;inset:-20% -20% auto -20%;height:70%;z-index:-1;
  background:conic-gradient(from 180deg at 50% 50%, transparent, rgba(46,196,182,.10), transparent 40%, rgba(124,156,255,.10), transparent 70%);
  filter:blur(60px);animation:aurora 22s linear infinite;
}
@keyframes aurora{to{transform:rotate(360deg)}}
.lp-top{position:fixed;top:22px;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 28px;z-index:6}
.lang{display:flex;gap:4px}
.lang button{min-width:34px;padding:6px 9px;border-radius:8px;border:1px solid var(--line-2);font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--ink-3);transition:all .15s}
.lang button.on{background:var(--teal);border-color:var(--teal);color:var(--teal-ink)}
.lang button:hover:not(.on){color:var(--ink);border-color:var(--teal)}

.lp-card{
  position:relative;width:100%;max-width:412px;padding:38px 34px 30px;border-radius:22px;
  background:linear-gradient(180deg, rgba(24,38,54,.82), rgba(15,23,34,.86));
  border:1px solid var(--line-2);box-shadow:var(--shadow);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  animation:cardIn .6s var(--ease) both;
}
@keyframes cardIn{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.brand .mark{width:42px;height:42px;border-radius:12px;flex-shrink:0;box-shadow:0 0 0 1px var(--line-2),0 8px 24px rgba(46,196,182,.25)}
.brand .wordmark{font-size:19px;font-weight:700;letter-spacing:.16em}
.brand .wordmark b{color:var(--teal);font-weight:800}
.brand .tag{display:block;font-size:10.5px;letter-spacing:.22em;color:var(--ink-3);font-weight:600;margin-top:2px}

.lp-h{font-size:22px;font-weight:600;margin-bottom:6px}
.lp-sub{font-size:13.5px;color:var(--ink-2);margin-bottom:24px;line-height:1.5}
.lp-sub b{color:var(--ink);font-weight:600}
.field{position:relative;margin-bottom:14px}
.field i{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--ink-3)}
.field input{
  width:100%;height:50px;padding:0 14px 0 44px;border-radius:12px;font-size:15px;
  background:rgba(255,255,255,.04);border:1.5px solid var(--line-2);color:var(--ink);
  transition:border .18s,background .18s,box-shadow .18s;font-family:inherit;
}
.field input::placeholder{color:var(--ink-3)}
.field input:focus{outline:none;border-color:var(--teal);background:rgba(46,196,182,.06);box-shadow:0 0 0 4px rgba(46,196,182,.12)}
.btn{
  width:100%;height:50px;border-radius:12px;font-size:15px;font-weight:700;letter-spacing:.01em;
  background:linear-gradient(180deg,var(--teal),var(--teal-2));color:var(--teal-ink);
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .12s,box-shadow .2s,opacity .2s;box-shadow:0 10px 26px rgba(46,196,182,.28);
}
.btn:hover{box-shadow:0 14px 34px rgba(46,196,182,.42);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn[disabled]{opacity:.55;cursor:default;box-shadow:none;transform:none}
.btn.ghost{background:none;color:var(--ink-2);box-shadow:none;font-weight:600;height:auto;padding:8px}
.btn.ghost:hover{color:var(--teal);transform:none}

/* OTP */
.otp{display:flex;gap:8px;justify-content:space-between;margin-bottom:20px}
.otp input{
  width:100%;height:56px;text-align:center;font-family:'DM Mono',monospace;font-size:22px;font-weight:500;
  background:rgba(255,255,255,.04);border:1.5px solid var(--line-2);border-radius:11px;color:var(--ink);
  transition:border .15s,box-shadow .15s,background .15s;
}
.otp input:focus{outline:none;border-color:var(--teal);background:rgba(46,196,182,.07);box-shadow:0 0 0 3px rgba(46,196,182,.14)}
.otp input.filled{border-color:rgba(46,196,182,.5)}
.lp-back{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-3);margin-bottom:18px}
.lp-back button{color:var(--ink-2);font-weight:600;display:inline-flex;align-items:center;gap:4px}
.lp-back button:hover{color:var(--teal)}
.lp-note{margin-top:18px;font-size:11.5px;color:var(--ink-3);text-align:center;line-height:1.5}
.lp-note b{color:var(--teal)}
.lp-err{color:#f87171;font-size:12.5px;min-height:16px;margin:-4px 0 12px;text-align:center}

/* ══════════════════════ APP SHELL ══════════════════════ */
#app{position:fixed;inset:0;z-index:4;display:flex;background:
  radial-gradient(70% 50% at 100% 0%, rgba(46,196,182,.06), transparent 60%),
  radial-gradient(60% 50% at 0% 100%, rgba(56,120,220,.05), transparent 55%), var(--bg);}
.app-in #login,.app-in #stars{display:none}

/* Sidebar */
#sidebar{width:264px;min-width:264px;height:100%;display:flex;flex-direction:column;
  background:linear-gradient(180deg, rgba(16,26,40,.92), rgba(11,17,26,.96));
  border-right:1px solid var(--line);position:relative;z-index:6;
  transition:width .28s var(--ease),min-width .28s var(--ease)}
#sidebar.collapsed{width:76px;min-width:76px}
.sb-logo{height:66px;display:flex;align-items:center;gap:11px;padding:0 18px;border-bottom:1px solid var(--line);flex-shrink:0;overflow:hidden}
.sb-logo .mark{width:34px;height:34px;border-radius:10px;flex-shrink:0}
.sb-logo .txt{font-size:15px;font-weight:700;letter-spacing:.15em;white-space:nowrap}
.sb-logo .txt b{color:var(--teal)}
#sidebar.collapsed .sb-logo{padding:0;justify-content:center}
#sidebar.collapsed .sb-logo .txt{opacity:0;width:0}

.sb-toggle{position:absolute;top:52px;right:-13px;width:26px;height:26px;border-radius:50%;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink-2);
  display:flex;align-items:center;justify-content:center;font-size:15px;z-index:20;transition:transform .28s,color .15s}
.sb-toggle:hover{color:var(--teal)}
#sidebar.collapsed .sb-toggle{transform:rotate(180deg)}

.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 12px 10px}
.sb-nav::-webkit-scrollbar{width:4px}.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px}
.sb-sec{font-size:9.5px;font-weight:800;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase;padding:14px 12px 6px;white-space:nowrap;overflow:hidden}
#sidebar.collapsed .sb-sec{opacity:0;height:8px;padding:0}
.nav-item{display:flex;align-items:center;gap:13px;padding:9px 11px;border-radius:11px;cursor:pointer;color:var(--ink-2);
  white-space:nowrap;overflow:hidden;position:relative;transition:background .15s,color .15s,transform .15s}
.nav-item:hover{background:rgba(255,255,255,.05);color:var(--ink)}
.nav-item:hover:not(.active){transform:translateX(3px)}
.nav-item.active{background:rgba(46,196,182,.14);color:var(--teal)}
.nav-item::before{content:'';position:absolute;left:0;top:22%;height:56%;width:3px;border-radius:0 3px 3px 0;background:var(--teal);
  transform:scaleY(0);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.nav-item.active::before{transform:scaleY(1)}
.nav-ico{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;transition:background .15s,transform .18s}
.nav-item:hover .nav-ico{transform:scale(1.08)}
.nav-item.active .nav-ico{background:rgba(46,196,182,.18);animation:pop .34s ease}
@keyframes pop{0%{transform:scale(.82)}55%{transform:scale(1.14)}100%{transform:scale(1)}}
.nav-lbl{font-size:14px;font-weight:600;flex:1}
#sidebar.collapsed .nav-lbl{opacity:0;width:0}
#sidebar.collapsed .nav-item{justify-content:center;padding:8px 0;gap:0}
#sidebar.collapsed .nav-item::before{display:none}
/* nav enter animation on rebuild */
.nav-item.enter{animation:navEnter .34s var(--ease) both}
@keyframes navEnter{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}

.sb-foot{padding:12px;border-top:1px solid var(--line);flex-shrink:0}
.sb-user{display:flex;align-items:center;gap:11px;padding:8px;border-radius:11px;cursor:pointer;transition:background .15s}
.sb-user:hover{background:rgba(255,255,255,.05)}
.av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--teal),#185fa5);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.sb-user-info{flex:1;overflow:hidden}
.sb-user-name{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-sub{font-size:11px;color:var(--ink-3);white-space:nowrap}
.sb-logout{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(248,113,113,.55);font-size:17px;transition:all .15s;flex-shrink:0}
.sb-logout:hover{background:rgba(220,38,38,.14);color:#f87171}
#sidebar.collapsed .sb-user-info,#sidebar.collapsed .sb-logout{opacity:0;width:0;overflow:hidden}
#sidebar.collapsed .sb-user{justify-content:center}

/* Main */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
#topbar{height:66px;flex-shrink:0;display:flex;align-items:center;gap:16px;padding:0 26px;border-bottom:1px solid var(--line)}
.tb-title{min-width:0}
.tb-h{font-size:19px;font-weight:700;line-height:1.15;white-space:nowrap}
.tb-crumb{font-size:11.5px;color:var(--ink-3);margin-top:1px}
.tb-spacer{flex:1}
.cmdk-trigger{display:flex;align-items:center;gap:10px;height:40px;padding:0 12px;border-radius:11px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:var(--ink-3);font-size:13px;transition:all .15s;min-width:210px}
.cmdk-trigger:hover{border-color:var(--teal);color:var(--ink-2)}
.cmdk-trigger i{font-size:17px}
.cmdk-trigger .kbd{margin-left:auto;font-family:'DM Mono',monospace;font-size:11px;padding:2px 6px;border-radius:6px;background:rgba(255,255,255,.06);border:1px solid var(--line-2)}
.tb-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line-2);background:rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;color:var(--ink-2);font-size:19px;transition:all .15s;position:relative}
.tb-btn:hover{border-color:var(--teal);color:var(--teal)}
.tb-btn .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
.tb-roles-btn{width:auto;padding:0 14px;gap:8px;font-size:12.5px;font-weight:700}
.menu-btn{display:none}

#content{flex:1;overflow-y:auto;padding:30px 34px 40px}
#content::-webkit-scrollbar{width:6px}#content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:6px}
.view{animation:viewIn .4s var(--ease) both}
@keyframes viewIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* Home hero */
.hero{margin-bottom:30px}
.hero-h{font-size:30px;font-weight:700;letter-spacing:-.01em}
.hero-h .accent{color:var(--teal)}
.hero-sub{font-size:14.5px;color:var(--ink-2);margin-top:8px;max-width:620px;line-height:1.55}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px 6px 10px;border-radius:20px;font-size:12.5px;font-weight:600;
  background:rgba(255,255,255,.05);border:1px solid var(--line-2)}
.chip i{font-size:15px}
.chip .dot{width:8px;height:8px;border-radius:50%}

.grid-h{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin:6px 0 16px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.card{position:relative;padding:22px;border-radius:var(--r);background:var(--panel);border:1px solid var(--line);
  cursor:pointer;overflow:hidden;transition:transform .2s var(--ease),border-color .2s,box-shadow .2s}
.card::after{content:'';position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0%, rgba(46,196,182,.10), transparent 55%);opacity:0;transition:opacity .25s}
.card:hover{transform:translateY(-4px);border-color:rgba(46,196,182,.4);box-shadow:0 14px 34px rgba(0,0,0,.35)}
.card:hover::after{opacity:1}
.card-ico{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;
  background:rgba(46,196,182,.12);color:var(--teal);margin-bottom:16px}
.card-t{font-size:15.5px;font-weight:700;margin-bottom:5px}
.card-d{font-size:13px;color:var(--ink-2);line-height:1.5}
.card-go{position:absolute;top:20px;right:18px;color:var(--ink-3);font-size:19px;transition:transform .2s,color .2s}
.card:hover .card-go{color:var(--teal);transform:translateX(3px)}

/* Empty state (stub views) */
.empty{max-width:520px;margin:6vh auto 0;text-align:center}
.empty-ico{width:88px;height:88px;border-radius:24px;margin:0 auto 22px;display:flex;align-items:center;justify-content:center;
  font-size:42px;background:rgba(46,196,182,.1);color:var(--teal);box-shadow:0 0 0 1px var(--line-2),0 20px 50px rgba(46,196,182,.14)}
.empty-h{font-size:24px;font-weight:700;margin-bottom:10px}
.empty-d{font-size:14.5px;color:var(--ink-2);line-height:1.6}
.soon{display:inline-flex;align-items:center;gap:7px;margin-top:22px;padding:8px 16px;border-radius:20px;
  font-size:12.5px;font-weight:700;color:var(--teal);background:rgba(46,196,182,.1);border:1px solid rgba(46,196,182,.3)}
.soon .pulse{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ══════════════════════ COMMAND PALETTE ══════════════════════ */
#cmdk{position:fixed;inset:0;z-index:40;display:flex;justify-content:center;align-items:flex-start;padding-top:14vh;
  background:rgba(6,10,16,.6);backdrop-filter:blur(6px);animation:fade .15s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.cmdk-box{width:100%;max-width:560px;border-radius:16px;overflow:hidden;background:var(--panel-solid);
  border:1px solid var(--line-2);box-shadow:var(--shadow);animation:cardIn .22s var(--ease) both}
.cmdk-in{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.cmdk-in i{font-size:20px;color:var(--teal)}
.cmdk-in input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-size:16px;font-family:inherit}
.cmdk-in input::placeholder{color:var(--ink-3)}
.cmdk-list{max-height:52vh;overflow-y:auto;padding:8px}
.cmdk-list::-webkit-scrollbar{width:5px}.cmdk-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:5px}
.cmdk-item{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:10px;cursor:pointer;color:var(--ink-2)}
.cmdk-item .ci{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;background:rgba(255,255,255,.05);flex-shrink:0}
.cmdk-item .cl{flex:1;font-size:14px;font-weight:600;color:var(--ink)}
.cmdk-item .cd{font-size:12px;color:var(--ink-3)}
.cmdk-item.sel{background:rgba(46,196,182,.14);color:var(--teal)}
.cmdk-item.sel .ci{background:rgba(46,196,182,.2);color:var(--teal)}
.cmdk-empty{padding:26px;text-align:center;color:var(--ink-3);font-size:13.5px}
.cmdk-foot{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--line);font-size:11px;color:var(--ink-3)}
.cmdk-foot .kbd{font-family:'DM Mono',monospace;padding:1px 5px;border-radius:5px;background:rgba(255,255,255,.06);border:1px solid var(--line-2);margin-right:5px}

/* ══════════════════════ ROLE SIMULATOR ══════════════════════ */
#rolesim{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:88vw;z-index:30;
  background:linear-gradient(180deg,var(--panel-2),var(--panel-solid));border-left:1px solid var(--line-2);
  box-shadow:-24px 0 60px rgba(0,0,0,.5);transform:translateX(100%);transition:transform .32s var(--ease);
  display:flex;flex-direction:column}
#rolesim.on{transform:none}
.rs-scrim{position:fixed;inset:0;z-index:29;background:rgba(6,10,16,.4);opacity:0;pointer-events:none;transition:opacity .3s}
.rs-scrim.on{opacity:1;pointer-events:auto}
.rs-head{padding:22px 22px 16px;border-bottom:1px solid var(--line)}
.rs-badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--teal);background:rgba(46,196,182,.12);padding:4px 9px;border-radius:6px;margin-bottom:12px}
.rs-h{font-size:18px;font-weight:700}
.rs-sub{font-size:12.5px;color:var(--ink-2);margin-top:6px;line-height:1.5}
.rs-list{flex:1;overflow-y:auto;padding:14px}
.rs-role{display:flex;align-items:center;gap:13px;padding:12px;border-radius:12px;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s;margin-bottom:6px}
.rs-role:hover{background:rgba(255,255,255,.04)}
.rs-role.on{background:rgba(46,196,182,.07);border-color:rgba(46,196,182,.28)}
.rs-role-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.rs-role-info{flex:1}
.rs-role-name{font-size:14px;font-weight:600}
.rs-role-slug{font-size:11px;color:var(--ink-3);font-family:'DM Mono',monospace}
.sw{width:42px;height:24px;border-radius:14px;background:rgba(255,255,255,.12);position:relative;transition:background .2s;flex-shrink:0}
.sw::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .22s var(--ease)}
.rs-role.on .sw{background:var(--teal)}
.rs-role.on .sw::after{transform:translateX(18px)}
.rs-foot{padding:14px 18px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-3);display:flex;justify-content:space-between;align-items:center}
.rs-count b{color:var(--teal)}
.rs-close{position:absolute;top:18px;right:18px;width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--ink-2);font-size:19px;transition:all .15s}
.rs-close:hover{background:rgba(255,255,255,.06);color:var(--ink)}

@media (max-width:820px){
  #sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:transform .28s var(--ease);width:264px;min-width:264px}
  #sidebar.mob-on{transform:none}
  .cmdk-trigger{min-width:0;width:40px;padding:0;justify-content:center}
  .cmdk-trigger .kbd,.cmdk-trigger span{display:none}
  #content{padding:22px 18px 34px}
  .hero-h{font-size:24px}
  .menu-btn{display:flex}
  .tb-roles-btn span{display:none}
  .tb-roles-btn{width:40px;padding:0}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.08s!important}
  #login::before{animation:none}
}
