/* PIASPHERE — design system SeeZam : blanc, monochrome + rouge vif, Work Sans 900 + Poppins. Aucune couleur estompée. */
:root{
  --bg:#ffffff; --bg-light:#F5F5F5; --bg-dark:#3C3C3B;
  --line:#E2E2E2; --line-strong:#C9C9C9;
  --text:#212529;          /* titres / primaire — fort */
  --text-2:#212529;        /* contenu secondaire — MÊME noir, jamais grisé (hiérarchie par taille/poids) */
  --accent:#E63312; --accent-hover:#CC2D0F; --accent-ink:#ffffff;
  --brand:#E63312;
  --r-sm:4px; --r-md:8px; --r-lg:10px; --r-pill:999px;
  --sat:env(safe-area-inset-top,0px); --sab:env(safe-area-inset-bottom,0px);
  --font-display:'Work Sans',sans-serif;
  --font:'Poppins',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--text); font-family:var(--font);
  -webkit-font-smoothing:antialiased; line-height:1.6; min-height:100vh;
  padding-left:env(safe-area-inset-left,0); padding-right:env(safe-area-inset-right,0);
}
button,input{font-family:inherit}
[hidden]{display:none!important}

/* ── Marque ── */
.brand{display:flex;align-items:center;gap:11px}
.brand-bar{width:4px;height:26px;background:var(--accent);flex:none;border-radius:2px}
.brand-word{font-family:var(--font-display);font-weight:900;letter-spacing:-.01em;font-size:1.3rem;color:var(--text);line-height:1}
.brand-word b{font-weight:900;color:var(--accent)}

/* ════ LOGIN ════ */
.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:calc(var(--sat) + 28px) 20px calc(var(--sab) + 28px);background:var(--bg)}
.login-card{width:100%;max-width:400px;display:flex;flex-direction:column;gap:14px}
.login-title{font-family:var(--font-display);font-weight:900;font-size:clamp(2rem,8vw,2.6rem);
  line-height:1.05;letter-spacing:-.02em;color:var(--text);margin:14px 0 0}
.login-lead{margin:0 0 6px;color:var(--text-2);font-size:1.0625rem;line-height:1.55}
.field{display:flex;flex-direction:column;gap:6px}
.field span{font-size:.82rem;font-weight:600;color:var(--text-2)}
.field input{height:50px;background:var(--bg);border:1.5px solid var(--line-strong);border-radius:var(--r-md);
  color:var(--text);font-size:16px;padding:0 14px;transition:border-color .15s,box-shadow .15s}
.field input::placeholder{color:#555555}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,51,18,.18)}
.btn-primary{margin-top:8px;min-height:50px;border:none;border-radius:var(--r-md);cursor:pointer;
  background:var(--accent);color:var(--accent-ink);font-weight:600;font-size:1rem;font-family:var(--font);
  transition:background .15s,transform .1s}
.btn-primary:hover{background:var(--accent-hover)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-primary[disabled]{opacity:.7;cursor:wait}
.login-err{margin:0;color:var(--accent);font-size:.9rem;font-weight:600}
.login-foot{margin-top:24px;color:var(--text-2);font-size:.8rem;text-align:center}

/* ════ HUB ════ */
.hub{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  gap:12px;min-height:60px;padding:8px 16px;padding-top:calc(var(--sat) + 8px);
  background:var(--bg);border-bottom:1px solid var(--line)}
.topbar-right{display:flex;align-items:center;gap:12px}
.tenant{font-size:.84rem;color:var(--text-2);font-weight:600;max-width:42vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.avatar{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--text);background:var(--bg);
  color:var(--text);font-weight:700;font-size:.82rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.avatar:hover{border-color:var(--accent);color:var(--accent)}

/* Switcher de modules — pastilles vives */
.switcher{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:12px 16px;border-bottom:1px solid var(--line)}
.switcher::-webkit-scrollbar{display:none}
.mod{flex:none;display:flex;align-items:center;gap:8px;min-height:40px;padding:0 15px;border-radius:var(--r-pill);
  background:var(--bg);border:1.5px solid var(--line-strong);color:var(--text);font-size:.86rem;font-weight:600;
  cursor:pointer;white-space:nowrap;transition:border-color .15s,background .15s}
.mod .dot{width:10px;height:10px;border-radius:50%;background:var(--mod)}
.mod:hover{border-color:var(--mod)}
.mod.is-active{border-color:var(--mod);background:color-mix(in srgb,var(--mod) 12%,#fff);color:var(--text)}
.mod.is-off{opacity:.45}
.mod.is-off .dot{background:var(--line-strong)}

/* Console copilote */
.console{flex:1;width:100%;max-width:800px;margin:0 auto;display:flex;flex-direction:column;padding:24px 16px 0;min-height:0}
.console-head h1{font-family:var(--font-display);font-weight:900;letter-spacing:-.02em;
  font-size:clamp(2rem,7vw,2.6rem);line-height:1.05;margin:0 0 8px;color:var(--text)}
.console-sub{margin:0 0 16px;color:var(--text-2);font-size:1.0625rem}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.chip{border:1.5px solid var(--line-strong);background:var(--bg);color:var(--text);
  border-radius:var(--r-pill);padding:9px 15px;font-size:.86rem;font-weight:600;cursor:pointer;min-height:40px;font-family:var(--font)}
.chip:hover{border-color:var(--accent);color:var(--accent)}

/* Fil de conversation */
.thread{flex:1;display:flex;flex-direction:column;gap:14px;padding:16px 0;overflow-y:auto}
.msg{max-width:90%;border-radius:var(--r-lg);padding:13px 16px;font-size:1rem;line-height:1.6;animation:rise .22s ease}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.msg.user{align-self:flex-end;background:color-mix(in srgb,var(--accent) 10%,#fff);
  border:1.5px solid color-mix(in srgb,var(--accent) 40%,#fff);color:var(--text)}
.msg.bot{align-self:flex-start;background:var(--bg-light);border:1px solid var(--line);color:var(--text)}
.msg.bot.loading{color:var(--text-2);font-style:italic}
.msg h4{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin:11px 0 5px;color:var(--text)}
.msg h4:first-child{margin-top:0}
.msg p{margin:7px 0;color:var(--text)}.msg p:first-child{margin-top:0}.msg p:last-child{margin-bottom:0}
.msg ul{margin:5px 0;padding-left:19px}.msg li{margin:3px 0}
.msg strong{color:var(--text);font-weight:700}
.cite{font-size:.62rem;color:var(--accent);font-weight:700;vertical-align:super;margin-left:1px}
.srcs{margin-top:11px;padding-top:9px;border-top:1px dotted var(--line-strong);display:flex;flex-wrap:wrap;gap:6px}
.srcs .s{font-size:.74rem;color:var(--text-2);background:var(--bg);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:3px 9px}

/* Barre de saisie */
.ask{position:sticky;bottom:0;display:flex;gap:8px;padding:12px 0 calc(14px + var(--sab));
  background:linear-gradient(to top,var(--bg) 72%,transparent)}
#ask-input{flex:1;height:52px;background:var(--bg);border:1.5px solid var(--line-strong);
  border-radius:var(--r-pill);color:var(--text);font-size:16px;padding:0 20px}
#ask-input::placeholder{color:#555555}
#ask-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,51,18,.16)}
.ask-send{flex:none;height:52px;padding:0 22px;border:none;border-radius:var(--r-pill);background:var(--accent);
  color:var(--accent-ink);font-size:.95rem;font-weight:600;cursor:pointer;font-family:var(--font);transition:background .15s,transform .1s}
.ask-send:hover{background:var(--accent-hover)}.ask-send:active{transform:scale(.97)}
.ask-send:disabled{opacity:.6;cursor:wait}

@media(min-width:720px){
  .topbar{padding-left:24px;padding-right:24px}
  .switcher{padding-left:24px;padding-right:24px;justify-content:center}
  .console{padding-left:24px;padding-right:24px}
  .login-card{max-width:420px}
}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important}}

/* ════ ADMIN ════ */
.admin-tag{font-family:var(--font);font-size:.78rem;font-weight:600;color:var(--accent);border:1px solid var(--accent);border-radius:var(--r-pill);padding:2px 10px;margin-left:10px}
.admin-link{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--line-strong);background:var(--bg);color:var(--text);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;text-decoration:none}
.admin-link:hover{border-color:var(--accent);color:var(--accent)}
.adm-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding:12px 16px;border-bottom:1px solid var(--line)}
.adm-tabs::-webkit-scrollbar{display:none}
.adm-tab{flex:none;min-height:40px;padding:0 16px;border-radius:var(--r-pill);background:var(--bg);border:1.5px solid var(--line-strong);
  color:var(--text);font-family:var(--font);font-size:.86rem;font-weight:600;cursor:pointer;white-space:nowrap}
.adm-tab.is-active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.adm{width:100%;max-width:820px;margin:0 auto;padding:22px 16px 120px}
.adm-panel{display:none}.adm-panel.is-active{display:block;animation:rise .2s ease}
.adm h2{font-family:var(--font-display);font-weight:900;font-size:1.5rem;margin:0 0 4px;color:var(--text)}
.adm-help{margin:0 0 18px;color:var(--text-2);font-size:.95rem}
.adm-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:560px){.adm-grid{grid-template-columns:1fr 1fr}}
.f{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.f span{font-size:.82rem;font-weight:600;color:var(--text)}
.f input[type=text],.f textarea,.f select{background:var(--bg);border:1.5px solid var(--line-strong);border-radius:var(--r-md);
  color:var(--text);font-size:16px;padding:11px 13px;font-family:var(--font);width:100%}
.f input[type=color]{width:100%;height:46px;border:1.5px solid var(--line-strong);border-radius:var(--r-md);background:var(--bg);cursor:pointer;padding:4px}
.f input:focus,.f textarea:focus,.f select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(230,51,18,.15)}
.adm-mods{display:flex;flex-direction:column;gap:10px}
.adm-mod{display:flex;align-items:center;gap:10px}
.adm-mod .m-color{width:50px;height:46px;flex:none;border:1.5px solid var(--line-strong);border-radius:var(--r-md);padding:4px;cursor:pointer;background:var(--bg)}
.adm-mod .m-label{flex:1;background:var(--bg);border:1.5px solid var(--line-strong);border-radius:var(--r-md);color:var(--text);font-size:16px;padding:11px 13px}
.adm-mod .m-key{font-size:.78rem;color:var(--text-2);font-weight:600;min-width:80px}
.adm-log{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}
.log-row{display:grid;grid-template-columns:140px 150px 1fr;gap:10px;background:var(--bg);padding:10px 12px;font-size:.84rem;align-items:center}
.log-when{color:var(--text-2);font-variant-numeric:tabular-nums;font-size:.78rem}
.log-act{font-weight:700;color:var(--text)}
.log-who{color:var(--text)}
.log-detail{color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:600px){.log-row{grid-template-columns:1fr;gap:2px}.log-detail{white-space:normal}}
.adm-usage{display:flex;flex-direction:column;gap:10px}
.usage-row{display:flex;align-items:baseline;gap:14px;border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px}
.usage-n{font-family:var(--font-display);font-weight:900;font-size:1.8rem;color:var(--accent);min-width:60px}
.adm-save{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:flex-end;gap:14px;
  padding:14px 16px calc(14px + var(--sab));background:var(--bg);border-top:1px solid var(--line)}
.save-msg{font-size:.88rem;font-weight:600;color:var(--accent)}
.adm-save .btn-primary{min-width:160px;margin-top:0}
