@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --ink: #16203A; --ink-soft: #5A6582; --ink-faint: #8A93AB;
  --canvas: #ECEFF6; --surface: #FFFFFF; --line: #DCE2EE; --line-soft: #EAEEF6;
  --brand: #3B38DE; --brand-deep: #2A28B0; --brand-tint: #ECEBFB;
  --teal: #11A39B; --amber: #C98700; --amber-tint: #FBF1DA;
  --blue: #2C6BE5; --blue-tint: #E4EDFD; --green: #18995A; --green-tint: #DFF3E8;
  --rose: #C7405A; --rose-tint: #FBE6EA;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, sans-serif; color: var(--ink);
  background: var(--canvas); min-height: 100vh; line-height: 1.5; font-size: 14px;
}
.mono { font-family: 'JetBrains Mono', monospace; }
button { font-family: inherit; }
a { color: var(--brand); }

/* ───────── Login ───────── */
.login-wrap { min-height: 100vh; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(1200px 600px at 70% -10%, #E5E4FB 0%, var(--canvas) 55%); }
.login-card { background: var(--surface); border: 1px solid var(--line); border-radius: 20px;
  width: 100%; max-width: 400px; padding: 34px 32px; box-shadow: 0 20px 60px rgba(22,32,58,.10); }
.login-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 26px; }
.mark { width: 42px; height: 42px; border-radius: 11px; position: relative;
  background: linear-gradient(150deg, var(--brand), var(--brand-deep));
  display: grid; place-items: center; color: #fff; font-family: 'Space Grotesk', sans-serif;
  font-weight: 700; font-size: 24px; box-shadow: inset 0 1px 0 rgba(255,255,255,.25); }
.mark::after { content: ''; position: absolute; top: -3px; right: -3px; width: 12px; height: 12px;
  border-radius: 50%; background: var(--teal); border: 2px solid var(--surface); }
.login-card .mark::after { border-color: var(--surface); }
.wordmark { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 19px; letter-spacing: -.2px; }
.wordmark span { color: var(--teal); }
.login-card h1 { font-family: 'Space Grotesk', sans-serif; font-size: 19px; font-weight: 600; margin: 0 0 4px; }
.login-card p.sub { font-size: 13px; color: var(--ink-soft); margin: 0 0 22px; }

/* ───────── Topbar ───────── */
.top { display: flex; align-items: center; justify-content: space-between;
  padding: 13px 26px; background: var(--ink); border-bottom: 3px solid var(--brand); position: sticky; top: 0; z-index: 30; }
.top .brand { display: flex; align-items: center; gap: 11px; }
.top .mark { width: 36px; height: 36px; font-size: 21px; }
.top .mark::after { border-color: var(--ink); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(17,163,155,.5); } 70% { box-shadow: 0 0 0 7px rgba(17,163,155,0); } 100% { box-shadow: 0 0 0 0 rgba(17,163,155,0); } }
.top .wordmark { color: #fff; font-size: 17px; }
.top .tagline { font-size: 10.5px; color: #9AA6C4; letter-spacing: .3px; }

.tabs { display: flex; gap: 4px; background: rgba(255,255,255,.07); padding: 4px; border-radius: 10px; }
.tab { border: none; background: transparent; color: #B7C0D9; cursor: pointer; font-size: 13px;
  font-weight: 500; padding: 7px 14px; border-radius: 7px; transition: all .15s; display: inline-flex; align-items: center; gap: 7px; }
.tab:hover { color: #fff; }
.tab.on { background: var(--surface); color: var(--ink); }
.tab .badge { background: var(--brand); color: #fff; font-size: 10.5px; font-weight: 600;
  min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px; display: grid; place-items: center; }
.tab.on .badge { background: var(--brand); }

.usermenu { display: flex; align-items: center; gap: 12px; }
.who { text-align: right; line-height: 1.25; }
.who .nm { color: #fff; font-size: 13px; font-weight: 500; }
.who .rl { color: #9AA6C4; font-size: 11px; }
.avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--brand-tint); color: var(--brand-deep);
  display: grid; place-items: center; font-weight: 600; font-size: 13px; font-family: 'Space Grotesk', sans-serif; }
.logout { border: 1px solid rgba(255,255,255,.18); background: transparent; color: #B7C0D9;
  border-radius: 8px; padding: 7px 12px; font-size: 12.5px; cursor: pointer; transition: all .15s; }
.logout:hover { background: rgba(255,255,255,.08); color: #fff; }

/* ───────── Layout ───────── */
.body { max-width: 1180px; margin: 0 auto; padding: 26px; }
.grid { display: grid; grid-template-columns: 380px 1fr; gap: 24px; align-items: start; }
@media (max-width: 880px) { .grid { grid-template-columns: 1fr; } .top { padding: 12px 16px; } .who { display: none; } }

.card { background: var(--surface); border: 1px solid var(--line); border-radius: 16px; }
.pad { padding: 22px; }
.eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--brand); }
.h2 { font-family: 'Space Grotesk', sans-serif; font-size: 20px; font-weight: 600; letter-spacing: -.3px; margin: 6px 0 2px; }
.sub { font-size: 13px; color: var(--ink-soft); }

/* ───────── Form ───────── */
.label { display: block; font-size: 12px; font-weight: 600; margin: 18px 0 7px; }
.label.first { margin-top: 20px; }
.opt { color: var(--ink-faint); font-weight: 400; }
.req { color: var(--rose); margin-left: 2px; }
.input, .textarea { width: 100%; border: 1px solid var(--line); border-radius: 10px; background: #FBFCFE;
  padding: 11px 13px; font-family: 'Inter', sans-serif; font-size: 13.5px; color: var(--ink);
  transition: border-color .15s, box-shadow .15s; resize: vertical; }
.textarea { min-height: 96px; line-height: 1.55; }
.input:focus, .textarea:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint); background: #fff; }
.input::placeholder, .textarea::placeholder { color: var(--ink-faint); }

.seg { display: flex; gap: 8px; }
.segbtn { flex: 1; border: 1px solid var(--line); background: #FBFCFE; border-radius: 10px; padding: 10px;
  cursor: pointer; font-size: 13px; font-weight: 500; color: var(--ink-soft); transition: all .15s;
  display: flex; flex-direction: column; align-items: center; gap: 2px; }
.segbtn .s { font-size: 11px; font-weight: 400; color: var(--ink-faint); }
.segbtn:hover { border-color: #C4CCDD; }
.segbtn.on { border-color: var(--brand); background: var(--brand-tint); color: var(--brand-deep); }
.segbtn.on .s { color: var(--brand); }

.btn { width: 100%; border: none; border-radius: 11px; cursor: pointer; background: var(--brand); color: #fff;
  font-family: 'Space Grotesk', sans-serif; font-size: 14.5px; font-weight: 600; padding: 13px;
  transition: background .15s, transform .05s; display: flex; align-items: center; justify-content: center; gap: 9px; }
.btn:hover:not(:disabled) { background: var(--brand-deep); }
.btn:active:not(:disabled) { transform: translateY(1px); }
.btn:disabled { opacity: .6; cursor: not-allowed; }
.btn.mt { margin-top: 22px; }
.hint { font-size: 11.5px; color: var(--ink-faint); margin-top: 12px; text-align: center; line-height: 1.5; }

/* ───────── Empty / loading ───────── */
.empty { border: 1px dashed var(--line); border-radius: 16px; padding: 64px 30px; text-align: center; min-height: 460px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: repeating-linear-gradient(135deg, transparent, transparent 10px, rgba(59,56,222,.018) 10px, rgba(59,56,222,.018) 20px); }
.empty .ic { width: 56px; height: 56px; border-radius: 14px; background: var(--brand-tint); display: grid; place-items: center; margin-bottom: 18px; }
.empty h3 { font-family: 'Space Grotesk', sans-serif; font-size: 17px; font-weight: 600; margin: 0 0 6px; }
.empty p { font-size: 13px; color: var(--ink-soft); max-width: 320px; margin: 0; }
.loadcard { padding: 50px 30px; text-align: center; }
.loadbar { height: 4px; background: var(--line-soft); border-radius: 4px; overflow: hidden; max-width: 240px; margin: 18px auto 0; }
.loadbar i { display: block; height: 100%; width: 40%; background: var(--brand); border-radius: 4px; animation: slide 1.2s ease-in-out infinite; }
@keyframes slide { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }
.spin { width: 16px; height: 16px; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: 50%; animation: rot .7s linear infinite; display: inline-block; }
.spin.dark { border-color: var(--line); border-top-color: var(--brand); }
@keyframes rot { to { transform: rotate(360deg); } }

/* ───────── Document ───────── */
.dochead { padding: 22px 26px; border-bottom: 1px solid var(--line-soft); display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.ref { font-size: 11px; letter-spacing: .5px; color: var(--ink-faint); margin-bottom: 8px; }
.doctitle { font-family: 'Space Grotesk', sans-serif; font-size: 23px; font-weight: 600; letter-spacing: -.4px; line-height: 1.2; }
.meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 13px; }
.chip { font-size: 11.5px; font-weight: 500; padding: 4px 10px; border-radius: 20px; background: var(--canvas); color: var(--ink-soft); display: inline-flex; align-items: center; gap: 5px; }
.status { font-size: 11px; font-weight: 600; padding: 5px 11px; border-radius: 20px; letter-spacing: .3px; white-space: nowrap; display: inline-flex; align-items: center; gap: 6px; }
.status .dot { width: 7px; height: 7px; border-radius: 50%; }
.status.brouillon { background: var(--amber-tint); color: var(--amber); } .status.brouillon .dot { background: var(--amber); }
.status.revue { background: var(--blue-tint); color: var(--blue); } .status.revue .dot { background: var(--blue); }
.status.publie { background: var(--green-tint); color: var(--green); } .status.publie .dot { background: var(--green); }

.docbody { padding: 8px 26px 26px; }
.section { margin-top: 26px; }
.sectitle { font-family: 'Space Grotesk', sans-serif; font-size: 12px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-soft); display: flex; align-items: center; gap: 9px; margin-bottom: 14px; }
.sectitle::after { content: ''; flex: 1; height: 1px; background: var(--line-soft); }
.resume { font-size: 14.5px; line-height: 1.6; }

.rejected { border: 1px solid #F2C9D2; background: #FDF1F3; border-left: 3px solid var(--rose); border-radius: 10px; padding: 12px 14px; font-size: 13px; }
.rejected b { color: #9B2C42; }

.check { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.check li { display: flex; gap: 11px; align-items: flex-start; font-size: 13.5px; }
.check .box { flex: none; width: 17px; height: 17px; border-radius: 5px; border: 1.5px solid var(--line); margin-top: 1px; }
.check.done .box { border-color: var(--green); background: var(--green-tint); display: grid; place-items: center; }

.steps { display: flex; flex-direction: column; gap: 2px; }
.step { display: flex; gap: 16px; padding: 4px 0; }
.stepnum { flex: none; }
.stepnum .n { width: 30px; height: 30px; border-radius: 9px; background: var(--ink); color: #fff; font-family: 'JetBrains Mono', monospace; font-size: 13px; font-weight: 500; display: grid; place-items: center; }
.stepline { width: 2px; background: var(--line-soft); margin: 6px auto 0; height: calc(100% - 30px); min-height: 8px; }
.stepbody { padding-bottom: 18px; flex: 1; }
.stept { font-weight: 600; font-size: 14px; margin-bottom: 3px; }
.stepd { font-size: 13.5px; color: var(--ink-soft); line-height: 1.6; }
.stepnote { margin-top: 8px; font-size: 12.5px; color: var(--brand-deep); background: var(--brand-tint); border-radius: 8px; padding: 7px 11px; line-height: 1.5; }

.callout { border: 1px solid var(--amber-tint); background: #FEFBF3; border-left: 3px solid var(--amber); border-radius: 10px; padding: 14px 16px; }
.callout ul { margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 6px; }
.callout li { font-size: 13px; line-height: 1.55; }

.docfoot { display: flex; gap: 10px; padding: 16px 26px; border-top: 1px solid var(--line-soft); flex-wrap: wrap; align-items: center; }
.act { border: 1px solid var(--line); background: var(--surface); border-radius: 10px; padding: 9px 14px; cursor: pointer;
  font-size: 13px; font-weight: 500; color: var(--ink); transition: all .15s; display: inline-flex; align-items: center; gap: 7px; }
.act:hover { border-color: #C4CCDD; background: #FBFCFE; }
.act.ghost { color: var(--ink-soft); }
.act.danger { color: var(--rose); }
.act.danger:hover { background: var(--rose-tint); border-color: #F2C9D2; }
.act.primary { background: var(--brand); border-color: var(--brand); color: #fff; }
.act.primary:hover { background: var(--brand-deep); }
.act.publish { background: var(--green); border-color: var(--green); color: #fff; }
.act.publish:hover { background: #14854E; }
.spacer { margin-left: auto; }

/* edit fields */
.ein { width: 100%; border: 1px solid var(--brand-tint); border-radius: 8px; background: #FBFBFF; padding: 8px 10px;
  font-family: inherit; font-size: inherit; color: var(--ink); }
.ein:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint); }
.ein.etitle { font-family: 'Space Grotesk', sans-serif; font-size: 20px; font-weight: 600; }
textarea.ein { resize: vertical; line-height: 1.55; }
.stepdel { border: none; background: var(--rose-tint); color: var(--rose); border-radius: 7px; width: 26px; height: 26px; cursor: pointer; font-size: 15px; line-height: 1; flex: none; }

/* ───────── Library / lists ───────── */
.listtop { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 18px; gap: 16px; flex-wrap: wrap; }
.filters { display: flex; gap: 7px; margin: 16px 0 18px; flex-wrap: wrap; align-items: center; }
.fchip { border: 1px solid var(--line); background: var(--surface); border-radius: 20px; padding: 6px 13px; font-size: 12.5px;
  font-weight: 500; color: var(--ink-soft); cursor: pointer; transition: all .15s; }
.fchip:hover { border-color: #C4CCDD; }
.fchip.on { background: var(--ink); border-color: var(--ink); color: #fff; }
.search { flex: 1; min-width: 180px; max-width: 280px; margin-left: auto; }
.search input { width: 100%; border: 1px solid var(--line); border-radius: 20px; padding: 8px 14px; font-size: 13px; font-family: inherit; background: var(--surface); }
.search input:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint); }

.lib { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.libcard { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 18px; cursor: pointer; transition: all .15s; text-align: left; }
.libcard:hover { border-color: #C4CCDD; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(22,32,58,.06); }
.libref { font-size: 11px; color: var(--ink-faint); margin-bottom: 9px; display: flex; justify-content: space-between; align-items: center; }
.libtitle { font-family: 'Space Grotesk', sans-serif; font-size: 15.5px; font-weight: 600; line-height: 1.3; margin-bottom: 8px; }
.libsub { font-size: 12.5px; color: var(--ink-soft); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.libfoot { margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--line-soft); display: flex; justify-content: space-between; align-items: center; font-size: 11.5px; color: var(--ink-faint); }
.libempty { grid-column: 1/-1; text-align: center; padding: 70px 20px; color: var(--ink-soft); }

/* ───────── Users / tables ───────── */
.table { width: 100%; border-collapse: collapse; }
.table th { text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--ink-faint); padding: 0 14px 12px; font-weight: 600; }
.table td { padding: 13px 14px; border-top: 1px solid var(--line-soft); font-size: 13.5px; }
.rolepill { font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 14px; }
.rolepill.admin { background: var(--brand-tint); color: var(--brand-deep); }
.rolepill.responsable { background: var(--blue-tint); color: var(--blue); }
.rolepill.redacteur { background: var(--canvas); color: var(--ink-soft); }

/* ───────── Misc ───────── */
.err { background: var(--rose-tint); border: 1px solid #F2C9D2; color: #9B2C42; border-radius: 11px; padding: 12px 14px; font-size: 13px; margin-top: 14px; line-height: 1.5; }
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--ink); color: #fff;
  padding: 12px 20px; border-radius: 11px; font-size: 13.5px; font-weight: 500; box-shadow: 0 10px 30px rgba(22,32,58,.25);
  display: flex; align-items: center; gap: 9px; z-index: 60; animation: up .25s ease; }
.toast .ok { color: #4ADE9B; } .toast .ko { color: #F87171; }
@keyframes up { from { opacity: 0; transform: translate(-50%, 10px); } }
.saved { font-size: 11.5px; color: var(--green); display: inline-flex; align-items: center; gap: 5px; }

.modal-bg { position: fixed; inset: 0; background: rgba(22,32,58,.45); display: grid; place-items: center; z-index: 70; padding: 20px; }
.modal { background: var(--surface); border-radius: 18px; width: 100%; max-width: 440px; padding: 26px; }
.modal h3 { font-family: 'Space Grotesk', sans-serif; font-size: 18px; margin: 0 0 4px; }
.modal .row { display: flex; gap: 10px; margin-top: 20px; }
.modal .row .btn { margin: 0; }
