/* ===========================================================
   myadmy — Back-Office  ·  système de design
   Clair · épuré · officiel · très renseigné · graphique
   Display : Fraunces (serif chaleureux)
   Texte   : Public Sans (sans neutre, lisibilité administrative)
   Data    : IBM Plex Mono (leg_id, dates, chiffres)
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --paper:#faf8f3; --surface:#ffffff; --surface-2:#f6f3ec;
  --ink:#1c1b19; --muted:#76726a; --faint:#a8a399;
  --line:#e6e1d6; --line-strong:#d6d0c2;
  --accent:#1b3a6b; --accent-2:#27508f; --accent-soft:#eaeef6;
  --ok:#2e7d32; --ok-soft:#e8f1e9;
  --warn:#b26a00; --warn-soft:#fbf0db;
  --ko:#bb3b2c; --ko-soft:#f8e8e5;
  --gold:#967523;
  --r:10px; --r-lg:16px;
  --shadow:0 1px 2px rgba(28,27,25,.04), 0 8px 24px -12px rgba(28,27,25,.12);
  --shadow-lg:0 2px 4px rgba(28,27,25,.05), 0 24px 48px -20px rgba(28,27,25,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:"Public Sans",-apple-system,system-ui,sans-serif;
  font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased;
}
a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:"Fraunces",Georgia,serif; font-weight:500; letter-spacing:-.01em; margin:0}
h1{font-size:30px; line-height:1.15}
h2{font-size:20px}
h3{font-size:16px}
.mono{font-family:"IBM Plex Mono",ui-monospace,monospace}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.tiny{font-size:12px}
.up{text-transform:uppercase; letter-spacing:.08em; font-size:11px; font-weight:600; color:var(--muted)}

/* ---------- topbar ---------- */
.topbar{
  position:sticky; top:0; z-index:30; background:rgba(250,248,243,.85);
  backdrop-filter:saturate(1.4) blur(8px); border-bottom:1px solid var(--line);
}
.topbar .inner{max-width:1180px; margin:0 auto; display:flex; align-items:center; gap:28px; padding:0 28px; height:60px}
.brand{display:flex; align-items:center; gap:9px; font-family:"Fraunces",serif; font-weight:600; font-size:19px; letter-spacing:-.02em}
.brand .seal{width:24px; height:24px; border-radius:50%; border:1.5px solid var(--accent); display:grid; place-items:center; color:var(--accent); font-size:12px}
.nav{display:flex; gap:4px; margin-left:6px; flex:1}
.nav a{
  color:var(--muted); font-weight:500; font-size:14px; padding:7px 12px; border-radius:8px;
  text-decoration:none; transition:.15s;
}
.nav a:hover{color:var(--ink); background:var(--surface-2); text-decoration:none}
.nav a.active{color:var(--accent); background:var(--accent-soft)}
.who{display:flex; align-items:center; gap:8px; color:var(--muted); font-size:13px}
.who .ava{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}

/* ---------- layout ---------- */
.wrap{max-width:1180px; margin:0 auto; padding:34px 28px 80px}
.crumb{font-size:13px; color:var(--muted); margin:0 0 14px}
.crumb a{color:var(--muted)}
.page-head{display:flex; justify-content:space-between; align-items:flex-end; gap:20px; margin-bottom:6px}
.lede{color:var(--muted); max-width:680px; margin:8px 0 0}
.section{margin-top:40px}
.section > .up{display:block; margin-bottom:14px; padding-bottom:8px; border-bottom:1px solid var(--line)}

/* ---------- cards ---------- */
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow)}
.card.pad{padding:22px}
.grid{display:grid; gap:16px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* ---------- stat tiles ---------- */
.tile{background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; display:flex; flex-direction:column; gap:2px}
.tile .big{font-family:"Fraunces",serif; font-size:34px; line-height:1; font-weight:500}
.tile .lbl{color:var(--muted); font-size:13px; margin-top:6px}
.tile.alert{border-color:var(--warn-soft); background:var(--warn-soft)}
.tile.alert .big{color:var(--warn)}
.tile.click{cursor:pointer; transition:.15s; text-decoration:none; color:inherit}
.tile.click:hover{border-color:var(--line-strong); box-shadow:var(--shadow-lg); transform:translateY(-1px); text-decoration:none}

/* ---------- status pills (typographic, sober) ---------- */
.st{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:3px 10px; border-radius:6px; white-space:nowrap}
.st::before{content:""; width:7px; height:7px; border-radius:50%}
.st.ok{background:var(--ok-soft); color:var(--ok)} .st.ok::before{background:var(--ok)}
.st.warn{background:var(--warn-soft); color:var(--warn)} .st.warn::before{background:var(--warn)}
.st.ko{background:var(--ko-soft); color:var(--ko)} .st.ko::before{background:var(--ko)}
.st.idle{background:var(--surface-2); color:var(--muted)} .st.idle::before{background:var(--faint)}
.st.run{background:var(--accent-soft); color:var(--accent)} .st.run::before{background:var(--accent); animation:pulse 1.1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- progress ---------- */
.bar{height:8px; background:var(--surface-2); border-radius:6px; overflow:hidden}
.bar > i{display:block; height:100%; background:var(--accent); border-radius:6px}
.bar > i.ok{background:var(--ok)} .bar > i.warn{background:var(--warn)}
.ring{--p:0; --c:var(--accent); width:54px;height:54px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%), var(--surface-2) 0);
  display:grid; place-items:center; position:relative}
.ring::after{content:""; position:absolute; inset:6px; border-radius:50%; background:var(--surface)}
.ring span{position:relative; font-family:"IBM Plex Mono",monospace; font-size:13px; font-weight:600}
.ring.lg{width:120px;height:120px} .ring.lg::after{inset:11px} .ring.lg span{font-size:24px; font-family:"Fraunces",serif}

/* ---------- pipeline (production chain) ---------- */
.chain{display:flex; flex-direction:column; gap:0}
.node{display:grid; grid-template-columns:56px 1fr auto; gap:18px; align-items:center; padding:16px 0; position:relative}
.node + .node{border-top:1px solid var(--line)}
.node .icn{width:44px;height:44px;border-radius:12px; display:grid; place-items:center; font-family:"IBM Plex Mono",monospace; font-weight:600; font-size:14px; border:1px solid var(--line); background:var(--surface-2); color:var(--muted)}
.node.done .icn{background:var(--ok-soft); color:var(--ok); border-color:var(--ok-soft)}
.node.run .icn{background:var(--accent-soft); color:var(--accent); border-color:var(--accent-soft)}
.node .role .nm{font-weight:600}
.node .role .desc{color:var(--muted); font-size:13px; margin-top:1px}
.node .right{display:flex; align-items:center; gap:16px; min-width:260px; justify-content:flex-end}
.node .pct{font-family:"IBM Plex Mono",monospace; font-weight:600; min-width:42px; text-align:right}
.connector{margin-left:27px; width:2px; height:14px; background:var(--line)}

/* horizontal stepper (compact) */
.stepper{display:flex; align-items:center; gap:0; overflow-x:auto; padding:4px 0}
.step{display:flex; flex-direction:column; align-items:center; gap:7px; min-width:78px}
.step .dot{width:34px;height:34px;border-radius:50%; display:grid; place-items:center; font-family:"IBM Plex Mono",monospace; font-size:12px; font-weight:600; border:2px solid var(--line); background:var(--surface); color:var(--muted)}
.step.done .dot{background:var(--ok); border-color:var(--ok); color:#fff}
.step.run .dot{background:var(--accent); border-color:var(--accent); color:#fff}
.step .cap{font-size:11px; color:var(--muted); text-align:center}
.link{height:2px; flex:1; min-width:18px; background:var(--line); margin-top:17px}
.link.done{background:var(--ok)}

/* ---------- tables ---------- */
table.t{width:100%; border-collapse:collapse; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden}
table.t th{text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); font-weight:600; padding:12px 16px; background:var(--surface-2); border-bottom:1px solid var(--line)}
table.t td{padding:13px 16px; border-top:1px solid var(--line); vertical-align:middle}
table.t tr:first-child td{border-top:none}
table.t tbody tr{transition:.12s}
table.t tbody tr:hover{background:var(--surface-2)}
table.t .idcc{font-family:"IBM Plex Mono",monospace; font-weight:600}
.preuve{color:var(--muted); font-size:12px; margin-top:3px}

/* ---------- buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:7px; background:var(--accent); color:#fff; border:1px solid var(--accent); border-radius:9px; padding:9px 16px; font-size:14px; font-weight:600; font-family:inherit; cursor:pointer; transition:.15s; text-decoration:none}
.btn:hover{background:var(--accent-2); text-decoration:none}
.btn.ghost{background:var(--surface); color:var(--ink); border-color:var(--line-strong)}
.btn.ghost:hover{background:var(--surface-2)}
.btn.ok{background:var(--ok); border-color:var(--ok)}
.btn.sm{padding:6px 12px; font-size:13px}

/* ---------- key/value list ---------- */
.kv{list-style:none; padding:0; margin:0}
.kv li{display:flex; justify-content:space-between; gap:16px; padding:9px 0; border-top:1px solid var(--line)}
.kv li:first-child{border-top:none}
.kv .k{color:var(--muted)}
.kv .v{font-weight:600; text-align:right}

/* ---------- role banner (component) ---------- */
.role-banner{display:flex; gap:18px; align-items:flex-start; padding:22px; background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--accent); border-radius:var(--r-lg)}
.role-banner .tag{font-family:"IBM Plex Mono",monospace; font-weight:600; font-size:22px; color:var(--accent); background:var(--accent-soft); border-radius:10px; padding:10px 14px}

/* flow arrow (reads/writes) */
.flow{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.chip{display:inline-flex; align-items:center; gap:6px; background:var(--surface-2); border:1px solid var(--line); border-radius:8px; padding:6px 11px; font-size:13px}
.chip .mono{font-size:12px}
.arrow{color:var(--faint)}

/* barre verticale (accès rapide composants) */
body{padding-left:60px}
.rail{position:fixed; left:0; top:60px; bottom:0; width:60px; background:var(--surface); border-right:1px solid var(--line); display:flex; flex-direction:column; align-items:center; gap:6px; padding:12px 0; overflow-y:auto; z-index:20}
.rail-item{width:40px; height:34px; display:grid; place-items:center; border-radius:8px; font-family:"IBM Plex Mono",monospace; font-size:12px; font-weight:600; color:var(--muted); background:var(--surface-2); border:1px solid var(--line); text-decoration:none; transition:.12s}
.rail-item:hover{color:var(--accent); border-color:var(--accent); text-decoration:none}
.rail-item.moat{color:var(--accent); background:var(--accent-soft); border-color:var(--accent-soft); font-size:16px; margin-bottom:4px}
@media(max-width:760px){body{padding-left:0} .rail{display:none}}

/* lecteur d'article */
.article-text{white-space:pre-wrap; font-family:"Public Sans",sans-serif; line-height:1.7; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:24px; max-width:820px}

/* toggle switch */
.row{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0; border-top:1px solid var(--line)}
.row:first-child{border-top:none}
.row .lab{font-size:14px}
.row .sub{color:var(--muted); font-size:12px; margin-top:2px}
.sw{position:relative; width:42px; height:24px; flex:none; cursor:pointer}
.sw input{opacity:0; width:0; height:0; position:absolute}
.sw .track{position:absolute; inset:0; background:var(--line-strong); border-radius:24px; transition:.18s}
.sw .track::before{content:""; position:absolute; left:3px; top:3px; width:18px; height:18px; background:#fff; border-radius:50%; transition:.18s; box-shadow:0 1px 2px rgba(0,0,0,.2)}
.sw input:checked + .track{background:var(--ok)}
.sw input:checked + .track::before{transform:translateX(18px)}
.inp{padding:9px 12px; border:1px solid var(--line-strong); border-radius:9px; font-family:inherit; font-size:14px; background:var(--paper)}
.inp.mono{font-family:"IBM Plex Mono",monospace}

footer.foot{max-width:1180px; margin:40px auto 0; padding:24px 28px; border-top:1px solid var(--line); color:var(--faint); font-size:12px; display:flex; justify-content:space-between}

/* ── panneau d'action (exécution de composants depuis le BO) ── */
.action-panel{position:fixed; right:24px; bottom:24px; width:540px; max-width:92vw; max-height:64vh; background:var(--surface); border:1px solid var(--accent); border-radius:var(--r-lg); box-shadow:var(--shadow-lg); display:flex; flex-direction:column; z-index:80}
.action-panel.hidden{display:none}
.ap-head{display:flex; justify-content:space-between; align-items:center; padding:12px 16px; border-bottom:1px solid var(--line); font-weight:600}
.ap-head button{background:none; border:none; color:var(--muted); font-size:18px; cursor:pointer}
#apBody{margin:0; padding:14px 16px; overflow:auto; font-family:"IBM Plex Mono",monospace; font-size:12px; white-space:pre-wrap; color:var(--ink)}
.login-wrap{display:grid; place-items:center; min-height:100vh}
.login-card2{width:380px; max-width:92vw; padding:32px}
.login-card2 .brand{justify-content:center; font-size:24px; margin-bottom:6px}
.login-card2 label{display:block; font-size:13px; color:var(--muted); margin:14px 0 5px}
.login-card2 input{width:100%; padding:11px 13px; border:1px solid var(--line-strong); border-radius:9px; font-family:inherit; font-size:15px; background:var(--paper)}
.login-card2 input:focus{outline:none; border-color:var(--accent)}
.login-err{background:var(--ko-soft); color:var(--ko); padding:9px 12px; border-radius:8px; font-size:13px; margin-top:12px}
