/* EXIGE — Design system maison (sobre, dense, lisible, WCAG AA). */
:root{
  --c-bg:#f4f6f9; --c-surface:#ffffff; --c-border:#e2e7ee; --c-text:#1f2937;
  --c-muted:#6b7280; --c-primary:#0d5bdd; --c-primary-d:#0a47ad; --c-accent:#0f766e;
  --c-ok:#15803d; --c-ok-bg:#e7f6ec; --c-warn:#b45309; --c-warn-bg:#fdf0dd;
  --c-err:#b91c1c; --c-err-bg:#fdeaea; --radius:10px; --shadow:0 1px 3px rgba(16,24,40,.08);
  --sidebar-w:236px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
  color:var(--c-text);background:var(--c-bg);font-size:14.5px;line-height:1.5}
a{color:var(--c-primary);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:1.5rem;margin:0 0 .25rem}
h2{font-size:1.1rem}
code{background:#eef2f7;padding:.1em .35em;border-radius:4px;font-size:.86em}

/* --- Topbar --- */
.topbar{height:56px;background:var(--c-surface);border-bottom:1px solid var(--c-border);
  display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:20}
.topbar__brand{display:flex;align-items:center;gap:14px}
.brand{font-weight:800;letter-spacing:1px;color:var(--c-primary);font-size:1.2rem}
.brand:hover{text-decoration:none}
.topbar__org{color:var(--c-muted);font-size:.9rem;border-left:1px solid var(--c-border);padding-left:14px}
.topbar__right{display:flex;align-items:center;gap:14px}
.topbar__search{flex:1;max-width:420px;margin:0 18px}
.topbar__search input{width:100%;padding:8px 12px;border-radius:20px;border:1px solid var(--c-border);background:#f7f9fc}
.topbar__search input:focus{background:#fff}

/* --- Menu utilisateur --- */
.menu{position:relative}
.menu__btn{background:none;border:1px solid var(--c-border);border-radius:8px;padding:6px 12px;cursor:pointer;font:inherit}
.menu__list{position:absolute;right:0;top:42px;background:#fff;border:1px solid var(--c-border);
  border-radius:8px;box-shadow:var(--shadow);min-width:180px;display:none;overflow:hidden}
.menu.open .menu__list{display:block}
.menu__list a,.menu__logout{display:block;width:100%;text-align:left;padding:10px 14px;background:none;border:0;font:inherit;cursor:pointer;color:var(--c-text)}
.menu__list a:hover,.menu__logout:hover{background:#f3f6fb;text-decoration:none}

/* --- Layout --- */
.layout{display:flex;min-height:calc(100vh - 56px)}
.sidebar{width:var(--sidebar-w);background:var(--c-surface);border-right:1px solid var(--c-border);
  display:flex;flex-direction:column;justify-content:space-between;padding:12px 0}
.sidebar nav{display:flex;flex-direction:column}
.sidebar nav a{padding:10px 18px;color:var(--c-text);display:flex;gap:8px;align-items:center;border-left:3px solid transparent}
.sidebar nav a:hover{background:#f3f6fb;text-decoration:none}
.sidebar nav a.active{background:#eef4ff;border-left-color:var(--c-primary);font-weight:600;color:var(--c-primary-d)}
.sidebar nav a.disabled{color:#aab2bf;cursor:not-allowed}
.sidebar__group{padding:14px 18px 4px;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--c-muted)}
.sidebar__foot{padding:12px 18px;color:#aab2bf;font-size:.75rem}
.content{flex:1;min-width:0;width:100%;max-width:1280px;margin-inline:auto;padding:24px 28px}
/* Tableau de bord : pleine largeur (s'étire sur grand écran). */
.content--wide{max-width:none}

/* --- Page heads --- */
.page-head{position:relative;overflow:hidden;margin-bottom:18px;padding:15px 20px 15px 22px;
  background:linear-gradient(120deg,#e9f1ff,#f5f9ff 55%,#fff);
  border:1px solid var(--c-border);border-radius:16px;
  box-shadow:0 6px 18px -13px rgba(16,24,40,.22)}
.page-head::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(var(--c-primary),var(--c-primary-d))}
.page-head h1{font-size:1.5rem;margin:0;line-height:1.15}
.page-head.between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.muted{color:var(--c-muted)}
.hint{color:var(--c-muted);font-size:.85rem;margin:.25rem 0 .75rem}

/* --- Cards --- */
.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px}
.card__title{margin:0 0 14px;font-size:1.02rem;border-bottom:1px solid var(--c-border);padding-bottom:10px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
/* (responsivité gérée plus bas, section « Responsive / mobile ») */
.stat{text-align:center}
.stat__num{font-size:2rem;font-weight:800;color:var(--c-primary-d)}
.stat__lbl{color:var(--c-muted);font-size:.85rem}

/* --- Tables --- */
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--c-border)}
.table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--c-muted)}
.table--compact th,.table--compact td{padding:7px 10px}
.table tbody tr:hover{background:#f9fbfe}

/* --- Key/value list --- */
.kv{list-style:none;margin:0;padding:0}
.kv li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--c-border)}
.kv li span{color:var(--c-muted)}

/* --- Badges & alerts --- */
.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.78rem;font-weight:600}
.badge--ok{background:var(--c-ok-bg);color:var(--c-ok)}
.badge--warn{background:var(--c-warn-bg);color:var(--c-warn)}
.badge--err{background:var(--c-err-bg);color:var(--c-err)}
.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid transparent}
.alert--ok{background:var(--c-ok-bg);color:var(--c-ok);border-color:#bfe6c9}
.alert--warn{background:var(--c-warn-bg);color:var(--c-warn);border-color:#f3d9a6}
.alert--error{background:var(--c-err-bg);color:var(--c-err);border-color:#f3c0c0}
.empty{color:var(--c-muted);text-align:center;padding:24px}

/* --- Forms --- */
.form .field{display:block;margin-bottom:14px}
.field>span{display:block;font-size:.85rem;margin-bottom:5px;color:#374151;font-weight:600}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--c-border);border-radius:8px;
  font:inherit;background:#fff;color:var(--c-text)}
input:focus,select:focus,textarea:focus{outline:2px solid #b9d2ff;border-color:var(--c-primary)}
textarea{resize:vertical;font-family:ui-monospace,Consolas,monospace}
.field em.err{color:var(--c-err);font-size:.8rem;display:block;margin-top:4px;font-style:normal}
.input--code{letter-spacing:.4em;text-align:center;font-size:1.3rem;font-family:ui-monospace,monospace}
.form__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}

/* --- Buttons --- */
.btn{display:inline-block;padding:9px 16px;border-radius:8px;border:1px solid var(--c-border);
  background:#fff;color:var(--c-text);font:inherit;cursor:pointer;text-align:center}
.btn:hover{background:#f3f6fb;text-decoration:none}
.btn--primary{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.btn--primary:hover{background:var(--c-primary-d)}
.btn--block{width:100%;margin-top:6px}
.btn--danger-soft{border-color:#f3c0c0;color:var(--c-err);background:#fff}
.btn--danger-soft:hover{background:var(--c-err-bg)}
.link-muted{display:inline-block;margin-top:10px;color:var(--c-muted);font-size:.9rem}
.btn--back{display:inline-block;margin-bottom:14px;padding:5px 12px;font-size:.85rem;
  background:#fff;border-color:var(--c-border);color:var(--c-muted)}
.btn--back:hover{background:#f3f6fb;color:var(--c-text)}

/* --- Auth & install screens --- */
.auth,.install,.blank{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0d5bdd11,#0f766e11),var(--c-bg);padding:24px}
.auth__card{background:#fff;border:1px solid var(--c-border);border-radius:14px;box-shadow:var(--shadow);
  padding:34px;width:100%;max-width:380px}
.auth__brand{font-size:1.8rem;font-weight:800;color:var(--c-primary);letter-spacing:2px;text-align:center}
.auth__sub{text-align:center;color:var(--c-muted);margin:.25rem 0 1.4rem}
.install__wrap{width:100%;max-width:760px}
.install__head{text-align:center;margin-bottom:18px}
.blank__card{background:#fff;border:1px solid var(--c-border);border-radius:14px;box-shadow:var(--shadow);
  padding:40px;text-align:center;max-width:460px}
.err-code{font-size:3.4rem;color:var(--c-primary);margin:0;line-height:1}
.err-emoji{font-size:2.6rem;line-height:1;margin-bottom:6px}
.blank__card h2{margin:.2em 0 .4em}
.err-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:18px}

/* =====================================================================
   Page de connexion — édition « corporate premium » (split-screen)
   ===================================================================== */
.authx{min-height:100vh;background:var(--c-surface)}
.authx__shell{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}

/* ---- Panneau marque (gauche) ---- */
.authx__aside{position:relative;overflow:hidden;color:#eaf1ff;
  background:radial-gradient(120% 120% at 0% 0%, #123a7e 0%, #0b2350 45%, #081a3d 100%);
  display:flex;align-items:stretch}
.authx__aside-inner{position:relative;z-index:2;display:flex;flex-direction:column;
  justify-content:space-between;gap:40px;padding:clamp(36px,5vw,72px);width:100%}
.authx__brand{display:flex;align-items:center;gap:14px}
.authx__logo{max-height:48px;max-width:200px;object-fit:contain}
.authx__brand-name{font-size:1.35rem;font-weight:800;letter-spacing:.3px;color:#fff}
.authx__brand-mark{display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:13px;font-weight:800;font-size:1.3rem;color:#fff;
  background:linear-gradient(140deg, var(--c-primary), #2f7bf6);box-shadow:0 8px 22px rgba(13,91,221,.45)}

.authx__hero{max-width:30rem}
.authx__hero-title{font-size:clamp(1.9rem,3vw,2.7rem);line-height:1.12;font-weight:800;
  color:#fff;margin:0 0 16px;letter-spacing:-.02em}
.authx__hero-lead{font-size:1.05rem;line-height:1.6;color:#b9c9e8;margin:0 0 30px}
.authx__feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.authx__feats li{display:flex;align-items:flex-start;gap:14px}
.authx__feat-ic{flex:none;display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:11px;color:#cfe0ff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14)}
.authx__feat-ic svg{width:20px;height:20px}
.authx__feats b{display:block;color:#fff;font-size:.98rem;font-weight:650}
.authx__feats small{display:block;color:#9fb2d6;font-size:.85rem;line-height:1.45;margin-top:2px}
.authx__aside-foot{font-size:.82rem;color:#8ea3cc;letter-spacing:.02em}
.authx__aside-foot b{color:#dbe6ff}

/* halos décoratifs subtils */
.authx__glow{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:1;pointer-events:none}
.authx__glow--1{width:380px;height:380px;top:-120px;right:-90px;
  background:radial-gradient(circle, var(--c-primary), transparent 70%)}
.authx__glow--2{width:320px;height:320px;bottom:-130px;left:-80px;
  background:radial-gradient(circle, #1e9e8a, transparent 70%);opacity:.35}

/* ===== Animation : documents qui s'archivent (convergent, s'empilent, se scellent) ===== */
.archive-anim{position:absolute;right:6%;bottom:11%;width:170px;height:220px;z-index:1;pointer-events:none}
/* Boîte d'archives */
.archive-box{position:absolute;left:22px;bottom:0;width:120px;height:76px}
.archive-box__front{position:absolute;bottom:0;width:120px;height:58px;border-radius:9px;overflow:hidden;
  background:linear-gradient(180deg,#2360c8,#0f3a86);border:1px solid rgba(255,255,255,.20);
  box-shadow:0 20px 40px -14px rgba(0,0,0,.6)}
.archive-box__front::before{content:"";position:absolute;left:0;right:0;top:0;height:15px;background:rgba(255,255,255,.10);
  border-bottom:1px solid rgba(255,255,255,.14)}
.archive-box__label{position:absolute;inset:13px 0 0 0;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.9);font-size:.6rem;font-weight:800;letter-spacing:3px}
/* Pile qui dépasse de la boîte */
.archive-box__stack{position:absolute;left:50%;transform:translateX(-50%);bottom:50px;width:80px;height:28px}
.archive-box__stack span{position:absolute;left:0;width:80px;height:11px;border-radius:3px;
  background:linear-gradient(180deg,#fff,#e7eef8);box-shadow:0 2px 5px rgba(0,0,0,.3)}
.archive-box__stack span:nth-child(1){bottom:0;transform:rotate(-3deg)}
.archive-box__stack span:nth-child(2){bottom:7px;transform:rotate(2.5deg)}
.archive-box__stack span:nth-child(3){bottom:14px;transform:rotate(-1.5deg)}
/* Sceau */
.archive-box__seal{position:absolute;right:-8px;top:-4px;width:28px;height:28px;border-radius:50%;
  background:#16a34a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;
  box-shadow:0 6px 16px rgba(22,163,74,.55);animation:seal-pulse 4.5s ease-in-out infinite;z-index:3}
@keyframes seal-pulse{0%,78%,100%{transform:scale(1)}86%{transform:scale(1.3)}92%{transform:scale(.95)}}
/* Documents qui arrivent et se rangent dans la boîte */
.archive-doc{position:absolute;left:57px;bottom:44px;width:46px;height:58px;border-radius:6px;background-color:#fff;
  background-repeat:no-repeat;box-shadow:0 12px 26px -8px rgba(0,0,0,.5);opacity:0;
  background-image:linear-gradient(#cfe0ff,#cfe0ff),linear-gradient(#e7eef8,#e7eef8),
    linear-gradient(#e7eef8,#e7eef8),linear-gradient(#e7eef8,#e7eef8);
  background-size:28px 6px,32px 3px,32px 3px,20px 3px;
  background-position:8px 9px,8px 22px,8px 30px,8px 38px;
  animation:doc-archive 6s ease-in infinite}
.archive-doc::after{content:"";position:absolute;top:0;right:0;border-width:0 0 11px 11px;border-style:solid;
  border-color:transparent transparent #dce6f5 transparent;border-radius:0 6px 0 0}
.archive-doc:nth-child(1){--dx:-160px;--dy:-150px;--dr:-22deg;animation-duration:5.5s;animation-delay:0s}
.archive-doc:nth-child(2){--dx:60px;--dy:-185px;--dr:18deg;animation-duration:6.5s;animation-delay:1.6s}
.archive-doc:nth-child(3){--dx:-120px;--dy:-205px;--dr:-12deg;animation-duration:6s;animation-delay:3.2s}
.archive-doc:nth-child(4){--dx:30px;--dy:-140px;--dr:14deg;animation-duration:7s;animation-delay:4.6s}
@keyframes doc-archive{
  0%{transform:translate(var(--dx),var(--dy)) rotate(var(--dr)) scale(1);opacity:0}
  14%{opacity:.97}
  72%{opacity:.97}
  100%{transform:translate(0,0) rotate(0) scale(.46);opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .archive-doc,.archive-box__seal{animation:none}
  .archive-doc{display:none}
}

/* ===== Animation : livre 3D, pages qui se tournent ===== */
.book-scene{perspective:1500px;display:flex;justify-content:center;margin:6px 0 22px}
.book{position:relative;width:264px;height:176px;transform-style:preserve-3d;transform:rotateX(10deg)}
.book__cover{position:absolute;top:0;width:130px;height:176px;
  background:linear-gradient(135deg,#0f3a86,#1f5ec4);border:1px solid rgba(255,255,255,.14);
  box-shadow:0 26px 50px -16px rgba(0,0,0,.6)}
.book__cover--l{left:0;border-radius:8px 3px 3px 8px}
.book__cover--r{right:0;border-radius:3px 8px 8px 3px;
  background:linear-gradient(225deg,#0f3a86,#1f5ec4)}
.book__leaf{position:absolute;left:50%;top:9px;width:124px;height:158px;transform-origin:left center;
  border-radius:0 6px 6px 0;backface-visibility:hidden;background-color:#fff;background-repeat:no-repeat;
  box-shadow:2px 8px 18px -6px rgba(0,0,0,.4);
  background-image:linear-gradient(#cfe0ff,#cfe0ff),linear-gradient(#e7eef8,#e7eef8),
    linear-gradient(#e7eef8,#e7eef8),linear-gradient(#e7eef8,#e7eef8),linear-gradient(#e7eef8,#e7eef8);
  background-size:70px 8px,84px 4px,84px 4px,84px 4px,56px 4px;
  background-position:16px 18px,16px 38px,16px 50px,16px 62px,16px 74px;
  animation:leaf-turn 8s ease-in-out infinite}
.book__leaf:nth-child(3){animation-delay:0s;z-index:4}
.book__leaf:nth-child(4){animation-delay:2s;z-index:3}
.book__leaf:nth-child(5){animation-delay:4s;z-index:2}
.book__leaf:nth-child(6){animation-delay:6s;z-index:1}
@keyframes leaf-turn{
  0%,10%{transform:rotateY(-2deg)}
  45%,52%{transform:rotateY(-172deg)}
  90%,100%{transform:rotateY(-2deg)}
}
/* Étincelles qui montent du livre */
.book__spark{position:absolute;top:60px;left:50%;width:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle,#dbeaff,rgba(219,234,255,0));opacity:0;animation:spark 4s ease-in-out infinite}
.book__spark--1{animation-delay:.4s;margin-left:-30px}
.book__spark--2{animation-delay:1.6s;margin-left:6px}
.book__spark--3{animation-delay:2.8s;margin-left:34px}
@keyframes spark{0%{transform:translateY(0) scale(.6);opacity:0}30%{opacity:1}100%{transform:translateY(-70px) scale(1.3);opacity:0}}

@media (prefers-reduced-motion:reduce){
  .paper{animation:none;opacity:.5}
  .book__leaf,.book__spark{animation:none}
  .book__leaf:nth-child(4),.book__leaf:nth-child(5),.book__leaf:nth-child(6){display:none}
}

/* ---- Panneau formulaire (droite) ---- */
.authx__main{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:18px;padding:clamp(28px,5vw,56px);background:var(--c-surface)}
.authx__form{width:100%;max-width:392px;animation:authx-in .5s ease both}
.authx__form-brand{display:flex;align-items:center;gap:10px;margin-bottom:26px}
.authx__form-logo{max-height:34px;max-width:150px;object-fit:contain}
.authx__brand-mark--sm{width:34px;height:34px;border-radius:10px;font-size:1rem}
.authx__form-org{font-weight:750;color:var(--c-text);letter-spacing:.2px}
.authx__form-title{font-size:1.6rem;font-weight:800;margin:0 0 4px;color:var(--c-text);letter-spacing:-.01em}
.authx__form-sub{color:var(--c-muted);margin:0 0 26px;font-size:.95rem}

/* champs & bouton — finition premium (scopé .authx) */
.authx .field>span{font-size:.83rem;color:#475569}
.authx input{padding:12px 13px;border-radius:11px;border-color:#dde3ec;background:#fbfcfe;
  transition:border-color .15s, box-shadow .15s, background .15s}
.authx input:focus{background:#fff;border-color:var(--c-primary);outline:none;
  box-shadow:0 0 0 4px color-mix(in srgb, var(--c-primary) 18%, transparent)}
.authx .btn--primary{padding:13px 16px;border-radius:11px;font-weight:650;font-size:1rem;
  box-shadow:0 10px 22px -8px color-mix(in srgb, var(--c-primary) 70%, transparent);
  transition:transform .12s ease, box-shadow .2s ease, background .15s}
.authx .btn--primary:hover{transform:translateY(-1px);
  box-shadow:0 14px 26px -8px color-mix(in srgb, var(--c-primary) 75%, transparent)}
.authx .btn--primary:active{transform:translateY(0)}
.authx .auth-links{text-align:center;margin:16px 0 0}
.authx .auth-links a{color:var(--c-muted);font-size:.9rem}
.authx .auth-links a:hover{color:var(--c-primary)}
.authx__legal{color:#9aa6b6;font-size:.8rem;margin:0;display:flex;align-items:center;justify-content:center;gap:6px}
.authx__legal svg{width:14px;height:14px}

@keyframes authx-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---- Responsive ---- */
@media (max-width:920px){
  .authx__shell{grid-template-columns:1fr}
  .authx__aside{display:none}
  .authx__main{min-height:100vh}
}
@media (prefers-reduced-motion:reduce){
  .authx__form{animation:none}
  .authx .btn--primary:hover{transform:none}
}

/* Icône SVG « maison » : taille par défaut (proportionnelle au texte).
   Les contextes spécifiques (menu, login) la surchargent plus bas. */
.ic{width:1.1em;height:1.1em;vertical-align:-.15em;flex:none}
h1 .ic{margin-right:.35rem;color:var(--c-primary)}

/* =====================================================================
   Menu latéral — thème SOMBRE élégant (type Linear/Vercel)
   ===================================================================== */
.sidebar{
  --sb-text:#cdd9ec; --sb-muted:#7f93b5; --sb-hover:rgba(255,255,255,.08);
  background:linear-gradient(180deg,#143a78 0%, #0e2a5c 55%, #0a1f47 100%);
  border-right:1px solid rgba(120,160,255,.12);
  justify-content:flex-start;padding:0;color:var(--sb-text)}

/* En-tête de marque */
.sidebar__brand{display:flex;align-items:center;gap:11px;padding:16px 16px 14px;
  border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:6px}
.sidebar__logo{max-height:34px;max-width:140px;object-fit:contain}
.sidebar__mark{flex:none;display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:10px;font-weight:800;font-size:1.05rem;color:#fff;
  background:linear-gradient(140deg,var(--c-primary),#3b82f6);
  box-shadow:0 6px 16px -4px color-mix(in srgb,var(--c-primary) 70%, transparent)}
.sidebar__brand-txt{display:flex;flex-direction:column;min-width:0}
.sidebar__org{font-weight:700;color:#fff;font-size:.98rem;letter-spacing:.2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar__tag{font-size:.68rem;color:var(--sb-muted);text-transform:uppercase;letter-spacing:.14em}

/* Zone de navigation (défilante) */
.sidebar nav{flex:1;display:flex;flex-direction:column;padding:0 10px 10px;gap:1px;
  overflow-y:auto;overflow-x:hidden}
.sidebar nav::-webkit-scrollbar{width:8px}
.sidebar nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.10);border-radius:8px}

/* Liens */
.sidebar nav a{position:relative;padding:9px 12px;border-radius:10px;border-left:0;margin:1px 0;
  color:var(--sb-text);display:flex;align-items:center;gap:11px;font-size:.92rem;line-height:1.2;
  transition:background .15s ease, color .15s ease}
.sidebar nav a:hover{background:var(--sb-hover);color:#fff;text-decoration:none}
.sidebar nav a.active{background:color-mix(in srgb, var(--c-primary) 24%, transparent);color:#fff;font-weight:600}
/* Indicateur actif animé : barre néon à gauche */
.sidebar nav a::before{content:"";position:absolute;left:3px;top:50%;transform:translateY(-50%);
  width:3px;height:0;border-radius:3px;background:var(--c-primary);
  box-shadow:0 0 8px color-mix(in srgb,var(--c-primary) 80%, transparent);transition:height .22s ease}
.sidebar nav a:hover::before{height:36%}
.sidebar nav a.active::before{height:62%}
.sidebar .nav-ic{flex:none;width:22px;display:inline-flex;align-items:center;justify-content:center}
.sidebar .nav-ic svg{width:18px;height:18px;stroke-width:1.9;color:var(--sb-muted);transition:color .15s ease}
.sidebar nav a:hover .nav-ic svg{color:#cdd6e3}
.sidebar nav a.active .nav-ic svg{color:color-mix(in srgb,var(--c-primary) 50%, #ffffff)}
.sidebar .nav-lbl{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar .nav-badge{flex:none;margin-left:auto;background:var(--c-primary);color:#fff;
  border-radius:999px;padding:1px 7px;font-size:.7rem;font-weight:700}
.sidebar .nav-top{margin-bottom:4px}

/* En-tête de groupe (repliable) */
.nav-group{margin-top:10px}
.nav-group__head{width:100%;display:flex;align-items:center;justify-content:space-between;
  background:none;border:0;cursor:pointer;font:inherit;padding:6px 12px 5px;
  color:var(--sb-muted);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.nav-group__head:hover{color:#aeb9c9}
.nav-group__chev{font-size:.6rem;opacity:.6;transition:transform .2s ease}
.nav-group.collapsed .nav-group__chev{transform:rotate(-90deg)}

/* Animation d'ouverture/fermeture (grid-rows : fluide, sans hauteur fixe) */
.nav-group__wrap{display:grid;grid-template-rows:1fr;transition:grid-template-rows .22s ease}
.nav-group.collapsed .nav-group__wrap{grid-template-rows:0fr}
.nav-group__items{overflow:hidden;min-height:0;display:flex;flex-direction:column;gap:1px}

.sidebar__foot{padding:12px 18px;color:#5c6a82;font-size:.72rem;letter-spacing:.06em;
  border-top:1px solid rgba(255,255,255,.06)}

/* La marque dans la topbar fait doublon sur desktop (elle est dans le menu) */
@media (min-width:921px){ .topbar .brand, .topbar__org{display:none} }

@media (prefers-reduced-motion:reduce){
  .nav-group__wrap,.nav-group__chev,.sidebar nav a::before,.sidebar nav a{transition:none}
}

/* --- Filtres & pagination --- */
.filters__row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.filters .field{margin-bottom:0}
.filters__actions{display:flex;gap:8px;align-items:flex-end}
.pagination{display:flex;align-items:center;gap:14px;justify-content:center;margin-top:16px}
.nowrap{white-space:nowrap}
.small{font-size:.8rem}
td.small{max-width:320px;overflow:hidden;text-overflow:ellipsis}

/* --- GED --- */
.page-head__actions{display:flex;gap:8px}
.breadcrumb{font-size:.85rem;color:var(--c-muted);margin-top:4px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.breadcrumb span{color:#c0c6cf}
.hidden{display:none}
.btn-row{display:flex;gap:8px;margin-top:10px}

/* Bannière GED */
.ged-hero{position:relative;overflow:hidden;display:flex;align-items:center;gap:16px;padding:16px 22px;
  border-radius:16px;margin-bottom:14px;color:#fff;
  background:linear-gradient(120deg,var(--c-primary),var(--c-primary-d));
  box-shadow:0 12px 28px -14px color-mix(in srgb,var(--c-primary) 65%,transparent)}
.ged-hero::after{content:"";position:absolute;right:-50px;top:-60px;width:190px;height:190px;border-radius:50%;background:rgba(255,255,255,.10)}
.ged-hero__icon{flex:none;width:50px;height:50px;border-radius:15px;background:rgba(255,255,255,.18);
  display:inline-flex;align-items:center;justify-content:center;font-size:1.6rem;z-index:1}
.ged-hero__txt{flex:1;min-width:0;z-index:1}
.ged-hero__txt h1{margin:0;font-size:1.5rem;line-height:1.15;color:#fff;letter-spacing:.2px;word-break:break-word}
.ged-hero .breadcrumb{margin-top:5px;color:rgba(255,255,255,.78)}
.ged-hero .breadcrumb a{color:#fff;font-weight:500}
.ged-hero .breadcrumb span{color:rgba(255,255,255,.5)}
.ged-hero__cta{flex:none;z-index:1;background:#fff;color:var(--c-primary-d);font-weight:700;
  border-radius:12px;padding:11px 18px;white-space:nowrap;box-shadow:0 4px 12px -2px rgba(0,0,0,.18);transition:transform .1s}
.ged-hero__cta:hover{transform:translateY(-1px);text-decoration:none;color:var(--c-primary-d)}

/* Barre d'outils GED */
.ged-toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.ged-toolbar__sep{flex:1}

/* Tuiles de dossiers */
.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px}
.folder-tile{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--c-border);
  border-radius:14px;color:var(--c-text);background:#fff;transition:transform .12s,box-shadow .12s,border-color .12s}
.folder-tile:hover{text-decoration:none;border-color:#b9d2ff;transform:translateY(-2px);
  box-shadow:0 8px 18px -10px rgba(16,24,40,.25)}
.folder-tile__icon{flex:none;width:44px;height:44px;border-radius:12px;display:inline-flex;align-items:center;
  justify-content:center;font-size:1.45rem;background:linear-gradient(150deg,#eaf1ff,#dbe8ff);color:var(--c-primary-d)}
.folder-tile__name{font-weight:600;word-break:break-word;line-height:1.25}

/* Pastille de type de document */
.type-chip{display:inline-block;font-size:.78rem;font-weight:600;color:var(--c-primary-d);
  background:#eef4ff;border:1px solid #d7e5ff;border-radius:20px;padding:2px 10px}

/* Bannière fiche document */
.doc-hero{position:relative;overflow:hidden;display:flex;align-items:center;gap:16px;padding:16px 22px;
  border-radius:16px;margin-bottom:16px;color:#fff;
  background:linear-gradient(120deg,var(--c-primary),var(--c-primary-d));
  box-shadow:0 12px 28px -14px color-mix(in srgb,var(--c-primary) 65%,transparent)}
.doc-hero::after{content:"";position:absolute;right:-50px;top:-60px;width:190px;height:190px;border-radius:50%;background:rgba(255,255,255,.10)}
.doc-hero__icon{flex:none;width:54px;height:54px;border-radius:14px;display:inline-flex;align-items:center;
  justify-content:center;font-size:1.7rem;background:rgba(255,255,255,.16);box-shadow:0 3px 8px rgba(0,0,0,.18);z-index:1}
.doc-hero__txt{flex:1;min-width:0;z-index:1}
.doc-hero__txt h1{margin:0;font-size:1.5rem;line-height:1.15;color:#fff;word-break:break-word}
.doc-hero .breadcrumb{margin-top:4px;color:rgba(255,255,255,.78)}
.doc-hero .breadcrumb a{color:#fff;font-weight:500}
.doc-hero .breadcrumb span{color:rgba(255,255,255,.5)}
.doc-hero__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:7px;font-size:.85rem;color:rgba(255,255,255,.9)}
.doc-hero__dot{color:rgba(255,255,255,.5)}
.doc-hero__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;z-index:1}
.doc-hero__dl{background:#fff;color:var(--c-primary-d);font-weight:700;border-radius:10px;padding:10px 16px;white-space:nowrap;
  box-shadow:0 4px 12px -2px rgba(0,0,0,.18);transition:transform .1s}
.doc-hero__dl:hover{transform:translateY(-1px);text-decoration:none;color:var(--c-primary-d)}
.doc-hero__actions .btn{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.40);color:#fff}
.doc-hero__actions .btn:hover{background:rgba(255,255,255,.26)}
.doc-hero__actions .btn--danger-soft{background:rgba(255,255,255,.92);color:var(--c-err);border-color:transparent}
.doc-hero__actions .btn--danger-soft:hover{background:#fff}
@media (max-width:760px){
  .doc-hero{flex-wrap:wrap}
  .doc-hero__actions{width:100%}
}
.upload-card{max-width:680px}
/* Zone de dépôt moderne (toute la zone est cliquable) */
.dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  gap:6px;border:2px dashed #c5d3e8;border-radius:16px;padding:34px 20px;background:linear-gradient(180deg,#fbfdff,#f4f8fe);
  transition:border-color .15s,background .15s}
.dropzone:hover{border-color:var(--c-primary);background:#eef4ff}
.dropzone.drag{border-color:var(--c-primary);background:#e4eeff;box-shadow:inset 0 0 0 3px color-mix(in srgb,var(--c-primary) 18%,transparent)}
.dropzone__input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.dropzone__icon{font-size:2.6rem;line-height:1}
.dropzone__title{font-weight:700;font-size:1.05rem;color:var(--c-text)}
.dropzone__hint{color:var(--c-muted);font-size:.9rem}
.dropzone__hint u{color:var(--c-primary);text-decoration:none;font-weight:600}
.filelist{list-style:none;padding:0;margin:10px 0 0;text-align:left;width:100%;position:relative;z-index:1}
.filelist li{display:flex;align-items:center;gap:6px;padding:7px 10px;margin-top:6px;background:#fff;
  border:1px solid var(--c-border);border-radius:9px;font-size:.86rem;box-shadow:0 1px 2px rgba(16,24,40,.05)}

/* Option « import d'archives » en carte avec interrupteur */
.upload-option{display:flex;align-items:center;gap:14px;padding:14px 16px;margin-top:4px;cursor:pointer;
  border:1px solid var(--c-border);border-radius:14px;background:#fff;transition:border-color .12s,background .12s}
.upload-option:hover{border-color:#b9d2ff;background:#fbfdff}
.upload-option__cb{position:absolute;opacity:0;width:0;height:0}
.upload-option__icon{flex:none;font-size:1.7rem;line-height:1}
.upload-option__txt{flex:1;display:flex;flex-direction:column;gap:2px}
.upload-option__switch{flex:none;width:46px;height:26px;border-radius:20px;background:#cbd5e1;position:relative;transition:background .15s}
.upload-option__switch::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:transform .15s}
.upload-option__cb:checked ~ .upload-option__switch{background:var(--c-primary)}
.upload-option__cb:checked ~ .upload-option__switch::after{transform:translateX(20px)}
.upload-option:has(.upload-option__cb:checked){border-color:var(--c-primary);background:color-mix(in srgb,var(--c-primary) 7%,#fff)}
.upload-option__cb:focus-visible ~ .upload-option__switch{outline:2px solid var(--c-primary);outline-offset:2px}
.preview-frame{width:100%;height:520px;border:1px solid var(--c-border);border-radius:8px}
.preview-img{max-width:100%;border:1px solid var(--c-border);border-radius:8px}
.preview-wrap{overflow:auto;-webkit-overflow-scrolling:touch;border-radius:8px}
.preview-actions{margin-top:8px}
.doc-cell{display:flex;align-items:center;gap:10px}
.doc-thumb{width:42px;height:42px;object-fit:cover;border:1px solid var(--c-border);border-radius:9px;background:#f7faff;
  display:inline-flex;align-items:center;justify-content:center;flex:none;box-shadow:0 1px 2px rgba(16,24,40,.06)}
.doc-thumb--icon{font-size:1.25rem}
.saved-list{list-style:none;margin:0;padding:0}
.saved-list li{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px dashed var(--c-border)}
.linkbtn{background:none;border:0;color:var(--c-muted);cursor:pointer;font-size:.95rem}
.linkbtn:hover{color:var(--c-err)}

/* --- Workflows --- */
.nav-badge{display:inline-block;min-width:18px;padding:0 6px;border-radius:10px;background:var(--c-primary);color:#fff;font-size:.72rem;text-align:center}
.wf-timeline{list-style:none;margin:0;padding:0;counter-reset:wf}
.wf-step{position:relative;padding:12px 12px 12px 38px;border:1px solid var(--c-border);border-radius:10px;margin-bottom:10px;background:#fafcff}
.wf-step::before{counter-increment:wf;content:counter(wf);position:absolute;left:10px;top:12px;width:20px;height:20px;border-radius:50%;
  background:var(--c-border);color:#333;font-size:.75rem;display:flex;align-items:center;justify-content:center}
.wf-step--active::before{background:var(--c-primary);color:#fff}
.wf-step--approved::before{background:#1f9d57;color:#fff}
.wf-step--rejected::before{background:var(--c-err);color:#fff}
.wf-step--skipped{opacity:.6}
.wf-step__head{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.wf-decision{margin-top:6px;font-size:.86rem}
.wf-actions{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}
.wf-decide{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.wf-decide input[type=text]{min-width:160px}
.fieldset{border:1px solid var(--c-border);border-radius:8px;padding:10px 14px;margin:10px 0}
.fieldset legend{font-size:.85rem;color:var(--c-muted);padding:0 6px}
.overdue{color:var(--c-err);font-weight:600}

/* --- Projets & budgets --- */
.budget-bar{height:12px;background:#e9eef5;border-radius:6px;overflow:hidden;margin:2px 0}
.budget-bar--sm{height:8px}
.budget-bar__fill{height:100%;background:var(--c-primary);border-radius:6px;transition:width .3s}
.budget-bar__fill--warn{background:#e0a800}
.budget-bar__fill--over{background:var(--c-err)}
.kpi-row{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:10px}
.kpi{flex:1;min-width:150px;background:#fafcff;border:1px solid var(--c-border);border-radius:10px;padding:12px 14px}
.kpi__label{display:block;font-size:.8rem;color:var(--c-muted)}
.kpi__value{display:block;font-size:1.25rem;font-weight:700;margin-top:4px}
.ms-list{list-style:none;margin:0;padding:0}
.ms-list li{padding:7px 0;border-bottom:1px dashed var(--c-border);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.chk{display:inline-flex;align-items:center;gap:4px;font-size:.82rem;color:var(--c-muted)}
.sub{font-size:.95rem;margin:14px 0 6px;color:var(--c-text)}
.copy-input{width:320px;max-width:42vw;font-size:.8rem;padding:4px 8px;border:1px solid var(--c-border);border-radius:6px;background:#f7f9fc}
.link-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* --- Partage public --- */
.public-body{background:#eef2f7;margin:0;min-height:100vh;display:flex;flex-direction:column}
.public-head{display:flex;align-items:center;gap:12px;padding:14px 22px;background:#fff;border-bottom:1px solid var(--c-border)}
.public-head .brand{font-weight:800;color:var(--c-primary);letter-spacing:.5px}
.public-main{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:30px 16px}
.public-foot{text-align:center;padding:14px}
.share-card{background:#fff;border:1px solid var(--c-border);border-radius:14px;padding:24px;max-width:900px;width:100%}
.share-card--narrow{max-width:420px}
.share-preview{position:relative;margin:16px 0;border:1px solid var(--c-border);border-radius:8px;overflow:hidden}
.share-preview img{max-width:100%;display:block;margin:0 auto}
.share-preview iframe{width:100%;height:600px;border:0}
.share-preview.has-watermark::after{content:attr(data-wm);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:2rem;color:rgba(200,0,0,.18);transform:rotate(-30deg);pointer-events:none;font-weight:800;letter-spacing:3px;
  background:repeating-linear-gradient(-30deg,transparent,transparent 80px,rgba(200,0,0,.04) 80px,rgba(200,0,0,.04) 160px)}
.share-actions{margin-top:14px}

/* --- RH confidentiel --- */
.card--confidential{border:1px solid #e3b6b6;background:#fff7f7}
.card--confidential .card__title{color:#a12626}

/* --- Notifications & branding --- */
.bell{position:relative;text-decoration:none;font-size:1.2rem}
.bell .nav-badge{position:absolute;top:-6px;right:-10px}
.brand-logo{height:30px;vertical-align:middle}
.notif-list{list-style:none;margin:0;padding:0}
.notif-list li{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--c-border)}
.notif-list li.unread{background:#f0f6ff;border-left:3px solid var(--c-primary);padding-left:10px}
.export-links{display:inline-flex;gap:6px}
.barline{display:flex;align-items:center;gap:8px;margin:5px 0;font-size:.85rem}
.barline__lbl{width:130px;color:var(--c-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.barline__bar{flex:1;height:10px;background:#e9eef5;border-radius:5px;overflow:hidden}
.barline__bar span{display:block;height:100%;background:var(--c-primary);border-radius:5px}
.barline__n{width:34px;text-align:right;font-weight:600}
a.stat{text-decoration:none;color:inherit}
a.stat:hover{background:#eef4ff}

/* --- Dashboard pro --- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:18px}
.kpi-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--c-border);border-radius:14px;
  padding:16px 18px;text-decoration:none;color:inherit;transition:box-shadow .15s,transform .15s,border-color .15s}
a.kpi-card:hover{box-shadow:0 6px 20px rgba(20,40,80,.08);transform:translateY(-2px);border-color:#cdd9ec}
.kpi-card__icon{width:46px;height:46px;flex:0 0 46px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  background:linear-gradient(135deg,#eef4ff,#e6eefc);border-radius:12px}
.kpi-card__val{font-size:1.7rem;font-weight:800;line-height:1.1;color:#1b2a44}
.kpi-card__lbl{font-size:.84rem;color:var(--c-muted);margin-top:2px}
.kpi-card__hint{font-size:.78rem;color:#8893a5;margin-top:3px}
.kpi-card__hint .up{color:#1f9d57;font-weight:700}
.kpi-card__hint .down{color:var(--c-err);font-weight:700}
.kpi-card--accent{border-color:#b9d2ff;background:linear-gradient(180deg,#f5f9ff,#fff)}
.kpi-card--accent .kpi-card__icon{background:linear-gradient(135deg,#dceaff,#cfe0ff)}
.kpi-card--warn{border-color:#f0d59a;background:linear-gradient(180deg,#fffaf0,#fff)}
.kpi-card--warn .kpi-card__icon{background:linear-gradient(135deg,#fdeecb,#f9e3ad)}

/* Bandeau d'accueil du tableau de bord (salutation + date + horloge Niamey) */
.dash-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:linear-gradient(135deg, var(--c-primary), #16306b);
  color:#fff;border-radius:16px;padding:20px 24px;margin-bottom:20px;
  box-shadow:0 14px 30px -16px color-mix(in srgb, var(--c-primary) 75%, transparent)}
.dash-hero__hi{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:800;margin:0;color:#fff;letter-spacing:-.01em}
.dash-hero__wave{display:inline-block;transform-origin:70% 70%;animation:hero-wave 2.4s ease-in-out infinite}
.dash-hero__date{margin:5px 0 0;color:rgba(255,255,255,.85);font-size:.95rem;text-transform:capitalize}
.dash-hero__right{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.dash-clock{text-align:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:13px;padding:8px 16px;min-width:130px}
.dash-clock__time{display:block;font-size:1.55rem;font-weight:800;letter-spacing:1.5px;
  font-variant-numeric:tabular-nums;line-height:1.1}
.dash-clock__tz{display:block;font-size:.68rem;color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:.09em;margin-top:2px}
@keyframes hero-wave{0%,60%,100%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}
@media (prefers-reduced-motion:reduce){.dash-hero__wave{animation:none}}
@media (max-width:560px){
  .dash-hero{padding:16px 18px}
  .dash-clock{min-width:0}
  .dash-clock__time{font-size:1.3rem}
}

.chart{width:100%;height:auto;display:block}
.chart__bar{fill:var(--c-primary);opacity:.88}
.chart__bar:hover{opacity:1}
.chart__val{fill:#42506a;font-size:13px;font-weight:700}
.chart__lbl{fill:#8893a5;font-size:12px}

.status-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;border-top:1px solid var(--c-border);padding-top:12px}
.chip{font-size:.8rem;color:var(--c-muted);background:#f3f6fb;border:1px solid var(--c-border);border-radius:14px;padding:3px 10px}
.chip b{color:#1b2a44}

/* --- Œil mot de passe --- */
.pwd-wrap{position:relative;display:block}
.pwd-wrap input{width:100%;padding-right:38px}
.pwd-eye{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:0;
  cursor:pointer;font-size:1rem;line-height:1;padding:4px 6px;color:var(--c-muted);opacity:.75}
.pwd-eye:hover{opacity:1}

/* --- Codes de secours 2FA --- */
.codes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:10px}
.rcode{font-family:Consolas,monospace;font-size:1.05rem;background:#fff;border:1px solid var(--c-border);
  border-radius:8px;padding:8px 10px;text-align:center;letter-spacing:1px}

/* --- Éditeur de permissions --- */
.perm-group{border-top:1px solid var(--c-border);padding-top:8px;margin-top:10px}
.perm-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:6px 16px}
.perm-item{display:flex;align-items:flex-start;gap:8px;font-size:.86rem;color:var(--c-text)}
.perm-item input{margin-top:3px}

/* --- Tags & discussion --- */
.tag-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.tag-chip{display:inline-flex;align-items:center;gap:4px;background:#eef4ff;border:1px solid #cfe0ff;
  color:var(--c-primary-d);border-radius:14px;padding:3px 10px;font-size:.82rem}
.tag-x{background:none;border:0;color:var(--c-muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 2px}
.tag-x:hover{color:var(--c-err)}
.comment-list{list-style:none;margin:0;padding:0}
.comment{border:1px solid var(--c-border);border-radius:10px;padding:10px 12px;margin-bottom:8px;background:#fafcff}
.comment__head{display:flex;align-items:center;gap:8px}
.comment__body{margin-top:6px;font-size:.9rem}
.sched-status{display:flex;flex-wrap:wrap;align-items:center;gap:8px}

/* --- Aide / rendu Markdown --- */
.help-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.help-tab{padding:7px 14px;border:1px solid var(--c-border);border-radius:8px;background:var(--c-surface);
  color:var(--c-text);text-decoration:none;font-size:.9rem}
.help-tab:hover{border-color:var(--c-primary)}
.help-tab.active{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.doc-content{max-width:80ch;line-height:1.65}
.doc-content h1{font-size:1.6rem;margin:.2em 0 .5em}
.doc-content h2{font-size:1.28rem;margin:1.4em 0 .5em;padding-bottom:.25em;border-bottom:1px solid var(--c-border)}
.doc-content h3{font-size:1.08rem;margin:1.1em 0 .4em}
.doc-content p{margin:.6em 0}
.doc-content ul,.doc-content ol{margin:.5em 0 .9em;padding-left:1.5em}
.doc-content li{margin:.25em 0}
.doc-content a{color:var(--c-primary)}
.doc-content code{background:#eef2f7;border:1px solid var(--c-border);border-radius:4px;
  padding:.05em .35em;font-size:.88em}
.doc-content .md-pre{background:#0f172a;color:#e2e8f0;border-radius:8px;padding:12px 14px;overflow:auto;margin:.8em 0}
.doc-content .md-pre code{background:none;border:0;color:inherit;padding:0;font-size:.85rem}
.doc-content blockquote{margin:.8em 0;padding:.5em .9em;border-left:4px solid var(--c-primary);
  background:#f4f8ff;color:#334155;border-radius:0 6px 6px 0}
.doc-content blockquote p{margin:0}
.doc-content hr{border:0;border-top:1px solid var(--c-border);margin:1.6em 0}
.doc-content .md-table{border-collapse:collapse;width:100%;margin:.9em 0;font-size:.9rem}
.doc-content .md-table th,.doc-content .md-table td{border:1px solid var(--c-border);padding:7px 10px;text-align:left;vertical-align:top}
.doc-content .md-table thead th{background:var(--c-bg)}
.doc-content .md-table tbody tr:nth-child(even){background:#fafbfd}

/* Aperçu Office servi en iframe (page autonome) */
.office-preview{margin:0;padding:16px;background:#fff;color:var(--c-text)}
.office-preview .doc-content{max-width:none}
.office-preview .doc-content.xlsx h2{font-size:1.05rem;margin-top:1.2em}

/* ===================== Édition repliable (projets/budgets) ===================== */
.inline-edit{position:relative;display:inline-block;vertical-align:middle}
.inline-edit>summary{list-style:none;cursor:pointer;display:inline-block}
.inline-edit>summary::-webkit-details-marker{display:none}
.inline-edit__pop{position:absolute;right:0;top:calc(100% + 6px);z-index:30;
  background:#fff;border:1px solid var(--c-border);border-radius:12px;box-shadow:var(--shadow);
  padding:14px;min-width:280px;text-align:left}
.inline-edit__pop .field{margin-bottom:8px}
.ms-actions{display:inline-flex;gap:4px;align-items:center;margin-left:6px}
.ms-list li{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* ===================== Messagerie interne ===================== */
.btn--sm{padding:5px 10px;font-size:.85rem}
/* Bannière d'en-tête messagerie */
.msg-hero{position:relative;overflow:hidden;display:flex;align-items:center;gap:16px;padding:16px 22px;
  border-radius:16px;margin-bottom:16px;color:#fff;
  background:linear-gradient(120deg,var(--c-primary),var(--c-primary-d));
  box-shadow:0 12px 28px -14px color-mix(in srgb,var(--c-primary) 65%,transparent)}
.msg-hero::after{content:"";position:absolute;right:-50px;top:-60px;width:190px;height:190px;border-radius:50%;
  background:rgba(255,255,255,.10)}
.msg-hero::before{content:"";position:absolute;right:60px;bottom:-70px;width:130px;height:130px;border-radius:50%;
  background:rgba(255,255,255,.06)}
.msg-hero__icon{flex:none;width:50px;height:50px;border-radius:15px;background:rgba(255,255,255,.18);
  display:inline-flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.msg-hero__icon svg{width:27px;height:27px;color:#fff}
.msg-hero__txt{flex:1;min-width:0;z-index:1}
.msg-hero__txt h1{margin:0;font-size:1.55rem;line-height:1.1;color:#fff;letter-spacing:.2px}
.msg-hero__txt p{margin:3px 0 0;color:rgba(255,255,255,.88);font-size:.9rem}
.msg-hero__badge{flex:none;z-index:1;background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.25);
  border-radius:22px;padding:7px 15px;font-size:.82rem;font-weight:600;white-space:nowrap}
@media (max-width:560px){
  .msg-hero{padding:14px 16px;gap:12px}
  .msg-hero__badge{display:none}
  .msg-hero__txt h1{font-size:1.25rem}
  .msg-hero__txt p{font-size:.82rem}
}
.chk--sm{font-size:.85rem;display:flex;gap:6px;align-items:center}
.chat{display:grid;grid-template-columns:328px 1fr;border:1px solid var(--c-border);
  border-radius:18px;overflow:hidden;height:calc(100vh - 240px);min-height:460px;background:#fff;
  box-shadow:0 10px 30px -12px rgba(16,24,40,.18),0 2px 6px rgba(16,24,40,.06)}
.chat__side{display:flex;flex-direction:column;min-width:0;min-height:0;border-right:1px solid var(--c-border);background:#fff}
.chat__side-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;
  border-bottom:1px solid var(--c-border);font-weight:700;font-size:1.05rem;letter-spacing:.2px;
  background:linear-gradient(180deg,#fbfcfe,#f6f8fc)}
.chat__new{padding:12px 14px;border-bottom:1px solid var(--c-border);background:#fff;
  max-height:calc(100vh - 230px);overflow-y:auto}
/* Dans le panneau « + Nouveau », un seul défilement (celui du panneau) :
   les listes du sélecteur ne défilent pas indépendamment. */
.chat__new .people-picker__list{max-height:none}
.chat__new-form{display:flex;flex-direction:column;gap:8px;margin:0}
.chat__new hr{border:0;border-top:1px solid var(--c-border);margin:12px 0}
.chat__members{max-height:150px;overflow:auto;display:flex;flex-direction:column;gap:5px;
  border:1px solid var(--c-border);border-radius:8px;padding:8px}
.chat__convs{flex:1;min-height:0;overflow-y:auto}

/* Sélecteur de personnes (groupe / diffusion / accès) */
.people-picker{border:1px solid var(--c-border);border-radius:12px;overflow:hidden;background:#fff}
.people-picker__bar{display:flex;gap:8px;align-items:center;padding:8px;border-bottom:1px solid var(--c-border);background:#fafbfd}
.people-picker__search{flex:1;padding:7px 11px;border:1px solid var(--c-border);border-radius:20px;font-size:.88rem;background:#fff}
.people-picker__all{flex:none;background:none;border:0;cursor:pointer;font:inherit;font-size:.8rem;font-weight:600;
  color:var(--c-primary);padding:4px 8px;border-radius:6px}
.people-picker__all:hover{background:#eef4ff}
.people-picker__list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column}
.people-opt{display:flex;align-items:center;gap:10px;padding:8px 11px;cursor:pointer;
  border-bottom:1px solid #f0f3f8;transition:background .1s}
.people-opt:last-child{border-bottom:0}
.people-opt:hover{background:#f5f8fd}
.people-opt input{position:absolute;opacity:0;width:0;height:0}
.people-opt__av{flex:none;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-size:.82rem;font-weight:700;color:#fff;background:linear-gradient(140deg,var(--c-primary),#3b82f6)}
.people-opt__name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem}
.people-opt__check{flex:none;width:22px;height:22px;border-radius:50%;border:2px solid #d4dbe6;
  display:inline-flex;align-items:center;justify-content:center;color:transparent;font-size:.72rem;font-weight:700;transition:.12s}
.people-opt.sel{background:color-mix(in srgb,var(--c-primary) 9%,#fff)}
.people-opt.sel .people-opt__check{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.people-opt.sel .people-opt__name{font-weight:600}
.people-opt.hidden{display:none}
.people-picker__count{padding:8px 11px;font-size:.8rem;color:var(--c-muted);border-top:1px solid var(--c-border);background:#fafbfd}
.people-picker__count b{color:var(--c-primary-d)}
.chat__conv{position:relative;display:flex;gap:12px;align-items:center;padding:11px 14px;margin:2px 8px;
  border-radius:12px;color:var(--c-text);transition:background .12s}
.chat__conv:hover{background:#f3f6fc;text-decoration:none}
.chat__conv.active{background:#eaf1ff}
.chat__conv.active::before{content:"";position:absolute;left:-8px;top:8px;bottom:8px;width:4px;
  border-radius:0 4px 4px 0;background:var(--c-primary)}
.chat__avatar{flex:none;width:42px;height:42px;border-radius:50%;display:inline-flex;align-items:center;
  justify-content:center;font-weight:700;color:#fff;font-size:1rem;
  background:linear-gradient(140deg,var(--c-primary),#3b82f6);box-shadow:0 2px 5px rgba(16,24,40,.14)}
.chat__conv-body{min-width:0;flex:1;display:flex;flex-direction:column;gap:1px}
.chat__conv-top{display:flex;justify-content:space-between;align-items:center;gap:6px}
.chat__conv-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat__conv.active .chat__conv-name{color:var(--c-primary-d)}
.chat__conv-prev{color:var(--c-muted);font-size:.83rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat__conv .nav-badge{background:var(--c-primary);color:#fff;border-radius:11px;min-width:20px;height:20px;
  display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;padding:0 6px;flex:none}
.chat__main{display:flex;flex-direction:column;min-width:0;min-height:0}
.chat__composer{flex:none}
.chat__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--c-muted);gap:8px;text-align:center}
.chat__empty svg{width:46px;height:46px;opacity:.35}
.chat__head{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--c-border);
  background:linear-gradient(180deg,#fff,#fbfcfe);box-shadow:0 1px 0 rgba(16,24,40,.03)}
.chat__messages{flex:1;min-height:0;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:7px;
  background:linear-gradient(180deg,#f3f6fb,#eef2f8)}
/* Séparateur de jour */
.msg-day{align-self:center;margin:8px 0}
.msg-day span{background:rgba(15,23,42,.06);color:var(--c-muted);font-size:.74rem;font-weight:600;
  padding:3px 12px;border-radius:20px}
.msg{display:flex}
.msg--mine{justify-content:flex-end}
.msg__bubble{max-width:74%;background:#fff;border:1px solid var(--c-border);border-radius:16px 16px 16px 5px;
  padding:8px 13px;display:flex;flex-direction:column;gap:2px;box-shadow:0 1px 2px rgba(16,24,40,.06)}
.msg--mine .msg__bubble{background:linear-gradient(160deg,var(--c-primary),var(--c-primary-d));
  border:0;color:#fff;border-radius:16px 16px 5px 16px;box-shadow:0 2px 8px -1px color-mix(in srgb,var(--c-primary) 45%,transparent)}
.msg--mine .msg__bubble a,.msg--mine .msg__time{color:rgba(255,255,255,.9)}
.msg--mine .msg__bubble .mention{background:rgba(255,255,255,.22);color:#fff}
.msg--mine .msg__del-btn{color:rgba(255,255,255,.8)}
.msg--mine .msg__del-btn:hover{color:#fff}
.msg__sender{font-size:.74rem;font-weight:700;color:var(--c-primary-d)}
.msg__body{white-space:pre-wrap;word-break:break-word}
.msg__doc{font-size:.85rem}
.msg__archive{margin-top:2px}
.msg__archive .linkbtn{background:none;border:0;padding:0;cursor:pointer;font:inherit;
  font-size:.74rem;color:var(--c-primary);text-decoration:underline}
.msg__archive .linkbtn:hover{color:var(--c-primary-d)}

/* Modale d'aperçu de pièce jointe */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(10,18,35,.55)}
.modal__box{position:relative;z-index:1;background:#fff;border-radius:14px;box-shadow:0 20px 50px -12px rgba(10,18,35,.5);
  width:100%;max-width:760px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--c-border)}
.modal__x{background:none;border:0;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--c-muted)}
.modal__x:hover{color:var(--c-text)}
.modal__body{flex:1;overflow:auto;padding:16px 18px;min-height:160px;background:#f7f9fc}
.modal__foot{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--c-border)}
.modal__folder{padding:14px 18px;border-top:1px solid var(--c-border);background:#fafbfd}
.modal__status{padding:10px 18px;font-size:.9rem;border-top:1px solid var(--c-border)}
.modal__status[hidden]{display:none}
.modal__status--info{color:var(--c-muted)}
.modal__status--ok{background:var(--c-ok-bg);color:var(--c-ok)}
.modal__status--warn{background:var(--c-warn-bg);color:var(--c-warn)}
.modal__status--error{background:var(--c-err-bg);color:var(--c-err)}
.att-prev-img{max-width:100%;height:auto;display:block;margin:0 auto;border-radius:8px}
.att-prev-frame{width:100%;height:60vh;border:0;background:#fff;border-radius:8px}
.att-prev-text{white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,Consolas,monospace;
  font-size:.85rem;background:#fff;border:1px solid var(--c-border);border-radius:8px;padding:12px;margin:0}

/* Messagerie : mentions, suppression, recherche, autocomplétion */
.mention{background:color-mix(in srgb,var(--c-primary) 16%,#fff);color:var(--c-primary-d);
  border-radius:4px;padding:0 3px;font-weight:600}
.msg__bubble{position:relative}
.msg__deleted{color:var(--c-muted);font-style:italic;font-size:.86rem}
.msg__del{position:absolute;top:2px;right:4px;opacity:0;transition:opacity .12s}
.msg__bubble:hover .msg__del{opacity:.7}
.msg__del:hover{opacity:1}
.msg__del-btn{background:none;border:0;cursor:pointer;color:var(--c-muted);font-size:1rem;line-height:1;padding:0}
.msg__del-btn:hover{color:var(--c-err)}
.chat__search{padding:10px 12px;border-bottom:1px solid var(--c-border)}
.chat__search input{width:100%;padding:7px 10px;border-radius:8px;border:1px solid var(--c-border);background:#fff}
.chat__side-sub{padding:8px 12px;font-size:.78rem;color:var(--c-muted)}
.chat__input-wrap{position:relative;flex:1;display:flex;background:#f1f5fb;border:1px solid var(--c-border);
  border-radius:22px;padding:2px 6px;transition:border-color .12s,background .12s}
.chat__input-wrap:focus-within{background:#fff;border-color:var(--c-primary)}
.chat__input-wrap .chat__input{flex:1;border:0;background:transparent;outline:none;padding:9px 12px}
.mention-pop{position:absolute;bottom:100%;left:0;margin-bottom:4px;min-width:200px;max-height:180px;overflow:auto;
  background:#fff;border:1px solid var(--c-border);border-radius:10px;box-shadow:var(--shadow);z-index:30}
.mention-pop[hidden]{display:none}
.mention-pop__item{padding:8px 12px;cursor:pointer;font-size:.9rem}
.mention-pop__item.active,.mention-pop__item:hover{background:#eef4ff;color:var(--c-primary-d)}

/* Présence « en ligne » */
.chat__avatar{position:relative}
.chat__avatar--online::after{content:"";position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;
  border-radius:50%;background:#22c55e;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.04)}
.chat__presence{color:var(--c-muted)}
.chat__presence.is-online{color:#15803d;font-weight:600}

/* Réactions emoji */
.msg__reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px;align-items:center}
.msg--mine .msg__reactions{justify-content:flex-end}
.reaction{display:inline-flex;align-items:center;gap:3px;font-size:.8rem;line-height:1;
  background:#eef2f7;border:1px solid var(--c-border);border-radius:12px;padding:2px 7px;cursor:pointer;font-family:inherit}
.reaction.mine{background:color-mix(in srgb,var(--c-primary) 16%,#fff);
  border-color:color-mix(in srgb,var(--c-primary) 35%,#fff);color:var(--c-primary-d)}
.reaction:hover{border-color:var(--c-primary)}
.reaction-add{background:none;border:0;cursor:pointer;color:var(--c-muted);font-size:.95rem;line-height:1;
  opacity:.5;transition:opacity .12s;padding:2px 4px}
.msg:hover .reaction-add{opacity:1}
.reaction-add:hover{color:var(--c-primary)}
.react-picker{position:fixed;z-index:1100;display:flex;gap:2px;background:#fff;border:1px solid var(--c-border);
  border-radius:24px;box-shadow:var(--shadow);padding:4px 6px}
.react-picker[hidden]{display:none}
.react-picker__emo{background:none;border:0;cursor:pointer;font-size:1.2rem;line-height:1;padding:4px;border-radius:50%;transition:transform .1s}
.react-picker__emo:hover{background:#f1f5fb;transform:scale(1.2)}
.msg__time{align-self:flex-end;font-size:.68rem;color:var(--c-muted)}
.chat__composer{border-top:1px solid var(--c-border);padding:12px 14px;background:#fff;display:flex;flex-direction:column;gap:9px}
.chat__send{flex:none;width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;color:#fff;
  background:linear-gradient(160deg,var(--c-primary),var(--c-primary-d));
  box-shadow:0 3px 8px -1px color-mix(in srgb,var(--c-primary) 50%,transparent);transition:transform .1s,filter .1s}
.chat__send:hover{filter:brightness(1.06);transform:translateY(-1px)}
.chat__send:active{transform:translateY(0)}
.chat__send svg{margin-left:1px}
.chat__attach{display:flex;align-items:center;gap:8px}
.chat__attach .doc-pick{font-size:.85rem;flex:1;min-width:0}
.chat__file-btn{flex:none;cursor:pointer;border:1px solid var(--c-border);border-radius:8px;
  padding:8px 10px;background:#fff;line-height:1;font-size:1rem}
.chat__file-btn:hover{background:#f1f5fb;border-color:var(--c-primary)}
.chat__file-name{font-size:.8rem;color:var(--c-primary-d);max-width:160px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.chat__send-row{display:flex;gap:8px;align-items:flex-end}
.chat__input{resize:none;font-family:inherit;min-height:40px;max-height:120px}
/* Bouton « retour aux conversations » (mobile uniquement) */
.chat__back{display:none;flex:none;width:34px;height:34px;border-radius:50%;
  align-items:center;justify-content:center;font-size:1.3rem;color:var(--c-text);
  text-decoration:none;background:#f1f5fb}
.chat__back:hover{background:#e4ecf7;text-decoration:none}

@media (max-width:760px){
  .chat{grid-template-columns:1fr;height:calc(100vh - 130px);min-height:420px}
  /* Sur mobile : une seule colonne visible à la fois. */
  .chat__side{max-height:none}
  .chat--active .chat__side{display:none}            /* en conversation -> on masque la liste */
  .chat:not(.chat--active) .chat__main{display:none} /* sur la liste -> on masque la conversation */
  .chat__back{display:inline-flex}
  .att-prev-frame{height:50vh}
  .modal{padding:0}
  .modal__box{max-width:100%;max-height:100vh;border-radius:0;height:100vh}
}

/* --- Responsive / mobile --- */
.nav-toggle{display:none;background:none;border:1px solid var(--c-border);border-radius:8px;
  font-size:1.15rem;line-height:1;padding:6px 10px;cursor:pointer;color:var(--c-text)}
.nav-overlay{display:none}

@media (max-width:900px){
  .nav-toggle{display:inline-flex;align-items:center}
  .topbar__org{display:none}
  .topbar__search{max-width:none;margin:0 10px}
  .layout{display:block}
  .sidebar{display:flex;position:fixed;top:56px;left:0;bottom:0;width:var(--sidebar-w);z-index:50;
    overflow-y:auto;transform:translateX(-100%);transition:transform .22s ease;box-shadow:2px 0 16px rgba(0,0,0,.14)}
  body.nav-open .sidebar{transform:translateX(0)}
  body.nav-open .nav-overlay{display:block;position:fixed;inset:56px 0 0 0;background:rgba(15,23,42,.4);z-index:40}
  .content{padding:16px;max-width:100%}
  .grid-2{grid-template-columns:1fr}
  .page-head.between{flex-wrap:wrap;gap:10px}
  .page-head__actions,.export-links,.filters__row,.form__actions{flex-wrap:wrap}
  .table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .copy-input{max-width:60vw}
  /* Aperçu mobile : iframe plus haute + défilement tactile, et bouton plein écran bien visible
     (les iframes ne défilent pas au toucher sur iOS → le plein écran est la solution fiable). */
  .preview-frame{height:72vh}
  .preview-wrap{max-height:72vh}
  .preview-actions .btn{display:block;width:100%;text-align:center}
}
@media (max-width:560px){
  .topbar{padding:0 10px}
  .topbar__search{display:none}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px}
  .kpi-card{padding:12px;gap:10px}
  .kpi-card__icon{width:38px;height:38px;flex-basis:38px;font-size:1.2rem}
  .kpi-card__val{font-size:1.35rem}
  h1{font-size:1.25rem}
  .content{padding:12px}
  .filters__row .field{flex:1 1 100%}
}
@media (max-width:380px){
  .kpi-grid{grid-template-columns:1fr}
}
.edit-row{display:flex;align-items:flex-end;gap:8px;padding:8px 0;border-bottom:1px dashed var(--c-border)}
.edit-row form:first-child{flex:1}

/* --- 2FA --- */
.qr{display:flex;align-items:center;justify-content:center;min-height:180px;border:1px dashed var(--c-border);
  border-radius:10px;padding:12px;margin:10px 0;background:#fafcff;text-align:center;word-break:break-all}
.secret{display:block;background:#eef2f7;padding:10px;border-radius:8px;font-size:1rem;letter-spacing:.1em}
