/* ==========================================================================
   ARCHIVE PDF - DÉPÔT design system (shared foundation)
   Concept: "tamponné, daté, classé." Admin = minimal, no tilt, no seal.
   Palette ink/bone/red. Type: Saira Condensed (display) · Inter (body) · IBM Plex Mono (labels).
   ========================================================================== */
:root{
  /* palette */
  --ink:#1A1A1A; --paper:#F4EFE6; --red:#B23A2E; --red-d:#9c3024; --card:#FFFDF7;
  --line:#E7DECB; --line2:#D8CBB2; --soft:#6E685D; --faint:#A89F8F;
  --sidebar:#16140F; --side-ink:#EDE6D6; --side-faint:#8D8475;
  --ok:#3E7D58;
  /* type */
  --disp:'Saira Condensed','Arial Narrow','Roboto Condensed',sans-serif; --body:'Inter',sans-serif; --mono:'IBM Plex Mono',monospace;
  /* shape */
  --r:6px; --r-lg:10px; --sidebar-w:262px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
/* overflow-x:clip (et non hidden) : clippe le debordement horizontal SANS creer de conteneur de
   defilement, sinon position:sticky du header marketing (.mhead) est casse. CLIP SUR body SEULEMENT
   (PAS html) : iOS Safari peint un filet de 1px au bord d'un element clippe, et le verrou de scroll du
   menu bascule overflow:hidden -> il NE DOIT PAS toucher l'element clippe sinon le filet est re-rendu a
   chaque open/close (filet vertical full-height a droite, vu 2026-06-24). Donc clip=body, verrou=html. */
body{overflow-x:clip}
a{color:inherit;text-decoration:none}

/* tokens / helpers */
.mono{font-family:var(--mono)}
.lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.muted{color:var(--soft)}

/* ---------- shell ---------- */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

/* ---------- sidebar ---------- */
.side{background:var(--sidebar);color:var(--side-ink);padding:24px 16px 22px;display:flex;flex-direction:column}
.brand{padding:2px 8px 18px}
.brand .brandimg{display:block;width:100%}
.brand .mk{display:flex;align-items:center;justify-content:center}
.brand .wm{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:20px;color:#fff}
.brand .wm .dot{display:inline-block;width:.16em;height:.16em;border-radius:50%;background:var(--red);vertical-align:.3em;margin:0 .05em}
.navgrp{margin-bottom:16px}
.navgrp .h{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--side-faint);padding:0 10px;margin-bottom:7px}
.ni{position:relative;display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:var(--r);font-size:14px;color:var(--side-ink);opacity:.8;margin-bottom:1px}
.ni i{width:17px;text-align:center;font-size:13px;opacity:.65}
.ni:hover{opacity:1;background:rgba(255,255,255,.06)}
/* active = quiet highlight + red marker (NOT a red fill - that's the CTA's job) */
.ni.on{opacity:1;background:rgba(255,255,255,.08);color:#fff;font-weight:600}
.ni.on i{opacity:1;color:var(--red)}
.ni.on:before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--red)}
.side-foot{margin-top:auto;padding:10px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--side-faint)}
/* sidebar: primary action, counts, favoris, storage, user */
.side .send{display:flex;align-items:center;justify-content:center;gap:9px;margin:2px 8px 16px;background:var(--red);color:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.09em;text-transform:uppercase;font-weight:600;padding:11px;border-radius:var(--r)}
.side .send:hover{background:#9c3024}
.side .send.on{box-shadow:inset 0 0 0 2px rgba(255,255,255,.25)}
.ni .ct{margin-left:auto;background:var(--red);color:#fff;font-family:var(--mono);font-size:9.5px;font-weight:600;border-radius:999px;padding:1px 7px;min-width:18px;text-align:center}
.ni.on .ct{background:#fff;color:var(--red)}
.ni.fav i{opacity:.55}
.ni .nt{margin-left:auto;font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--side-faint);border:1px solid rgba(255,255,255,.18);border-radius:4px;padding:1px 5px}
.ni.on .nt{color:#fff;border-color:rgba(255,255,255,.32)}
/* sous-menu 2e niveau (natif <details>) */
.nsub{margin-bottom:1px}
.nsub > summary{list-style:none;cursor:pointer}
.nsub > summary::-webkit-details-marker{display:none}
.nsub > summary .car{margin-left:auto;font-size:9px;opacity:.5;transition:transform .18s}
.nsub[open] > summary{opacity:1}
.nsub[open] > summary .car{transform:rotate(90deg);opacity:.85}
.nsub .subwrap{margin:1px 0 5px 26px;padding-left:9px;border-left:1px solid rgba(255,255,255,.09);display:flex;flex-direction:column}
.ni.sub{padding:6px 10px;font-size:12.5px;opacity:.62}
.ni.sub i{font-size:10px;width:13px}
.ni.sub.on{opacity:1}
.ni.sub.on:before{top:5px;bottom:5px}
.side-bottom{margin-top:auto;padding-top:12px;display:flex;flex-direction:column;gap:8px}
.storage{padding:8px 10px;border-radius:var(--r)}
.storage:hover{background:rgba(255,255,255,.05)}
.storage .sl{display:flex;justify-content:space-between;gap:10px;white-space:nowrap;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--side-faint);margin-bottom:6px}
.storage .sl span:last-child{color:var(--side-soft,#b9b1a2)}
.storage .bar{height:5px;border-radius:3px;background:rgba(255,255,255,.12);overflow:hidden}
.storage .bar i{display:block;height:100%;background:var(--red);border-radius:3px}
.side-user{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r);border:1px solid rgba(255,255,255,.08)}
.side-user:hover{background:rgba(255,255,255,.05)}
.side-user .uu{flex:1;min-width:0}
.side-user .uu b{display:block;color:#fff;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-user .uu em{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;color:var(--side-faint)}
.side-user .pro{font-family:var(--mono);font-size:8px;letter-spacing:.08em;color:#fff;background:var(--red);border-radius:4px;padding:2px 6px}

/* ---------- top bar ---------- */
.main{display:flex;flex-direction:column;min-width:0}
.top{display:flex;align-items:center;gap:16px;padding:0 32px;height:62px;border-bottom:1px solid var(--line)}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.crumb b{color:var(--ink)}
.tsearch{margin-left:auto;display:flex;align-items:center;gap:9px;border:1px solid var(--line2);border-radius:999px;padding:8px 15px;width:300px;color:var(--faint);background:var(--card)}
.tsearch input{border:none;background:none;outline:none;font-family:var(--body);font-size:13.5px;color:var(--ink);width:100%}
.av{width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:600;border:0;cursor:pointer}
.avwrap{position:relative}
.avwrap .menu{position:absolute;right:0;top:46px;display:none;z-index:45}
.avwrap.open .menu{display:block}

/* ---------- content + page header ---------- */
.content{padding:32px 36px 56px;max-width:1040px;width:100%}
.page-h{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.012em;font-size:33px;line-height:1;color:var(--ink)}
.page-sub{color:var(--soft);font-size:14.5px;margin:9px 0 22px}
.page-sub b{font-family:var(--mono);font-size:13px;color:var(--ink)}
.section-h{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:18px;margin:28px 0 12px;color:var(--ink)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-size:14px;font-weight:600;padding:10px 16px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;background:none}
.btn--primary{background:var(--red);color:#fff;font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;padding:11px 18px}
.btn--primary:hover{background:var(--red-d)}
.btn--ghost{background:var(--card);border-color:var(--line2);color:var(--ink)}
.btn--block{width:100%;justify-content:center}
.btn--ghost:hover{border-color:var(--red);color:var(--red)}
.btn--icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border:1px solid var(--line);border-radius:var(--r);color:var(--faint);line-height:1}

/* ---------- pills / chips / tags ---------- */
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line2);border-radius:999px;padding:8px 14px;font-size:13px;color:var(--soft);background:var(--card)}
.tag{display:inline-flex;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--red);color:var(--red);border-radius:999px;padding:2px 9px;background:none}
.tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.tab{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line2);background:var(--card);color:var(--ink);border-radius:999px;padding:8px 15px}
.tab.on{background:var(--red);border-color:var(--red);color:#fff}

/* ---------- toolbar ---------- */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.toolbar .right{margin-left:auto;display:flex;gap:10px}

/* ---------- card list (rows) ---------- */
.list{display:flex;flex-direction:column;gap:10px}
.row{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 18px;display:flex;align-items:center;gap:16px}
.row:hover{border-color:var(--line2)}
.row .gl{width:44px;height:44px;border:1.5px solid var(--ink);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--ink);flex:none;align-self:flex-start}
.row .bd{flex:1;min-width:0}
.row .nm{font-weight:600;font-size:17px;color:var(--ink);letter-spacing:-.005em}
.row .meta{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--soft);margin-top:4px}
.row .meta .ref{color:var(--red)}
.row .tags{display:flex;gap:6px;margin-top:9px}
.filed{flex:none;text-align:right;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);line-height:1.55}
.filed b{display:block;color:var(--ink);font-size:12.5px;letter-spacing:.03em;font-weight:500}
.filed.empty{color:var(--faint)}
.acts{display:flex;align-items:center;gap:6px;color:var(--faint);flex:none}
.acts .heart.on{color:var(--red);border-color:var(--red)}

/* ---------- cards / grid ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px}
.cardlink{display:flex;flex-direction:column;text-decoration:none;color:inherit;padding:18px 18px 16px}
.grid-2{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.grid-2>*{flex:0 1 calc((100% - 14px)/2);min-width:260px}
.grid-3{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.grid-3>*{flex:0 1 calc((100% - 28px)/3);min-width:240px}

/* ---------- forms ---------- */
.field{margin-bottom:16px}
.field > label,.field .lbl{display:block;margin-bottom:6px}
.input{width:100%;border:1px solid var(--line2);border-radius:var(--r);background:#fff;padding:11px 13px;font-family:var(--body);font-size:14px;color:var(--ink);outline:none}
.input::placeholder{color:var(--faint)}
.input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(178,58,46,.12)}

/* ---------- empty state ---------- */
.empty{border:1px dashed var(--line2);border-radius:var(--r-lg);background:var(--card);padding:46px 24px;text-align:center;color:var(--soft)}
.empty .ic{font-size:26px;color:var(--faint);margin-bottom:12px}
.empty .t{font-family:var(--disp);text-transform:uppercase;font-weight:600;font-size:20px;color:var(--ink);letter-spacing:.02em}
.empty .d{font-size:14px;margin-top:6px}

/* ---------- info note ---------- */
.note{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--red);border-radius:var(--r);padding:13px 16px;font-size:13.5px;color:var(--soft);margin-bottom:18px}

/* ---------- stamp (RARE - moments only: confirmations / marketing) ---------- */
.stamp{width:74px;height:74px;aspect-ratio:1;flex:none;border-radius:50%;border:2.5px solid var(--red);color:var(--red);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;box-sizing:border-box}
.stamp:before{content:"";position:absolute;inset:5px;border-radius:50%;border:1px solid var(--red);opacity:.45}
.stamp .t{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:14px;letter-spacing:.06em;line-height:1}
.stamp .d{font-family:var(--mono);font-size:9px;letter-spacing:.06em;margin-top:3px}

/* ---------- file grid (documents) ---------- */
.fgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.fcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.fcard:hover{border-color:var(--line2)}
.fthumb{position:relative;height:150px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--line2)}
.fthumb .pg{position:absolute;inset:18px 26px;background:repeating-linear-gradient(#f0ead9 0 2px,transparent 2px 9px) no-repeat;border:1px solid var(--line);border-radius:2px;opacity:.7}
.fthumb .ext{position:absolute;top:9px;left:9px;font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.1em;background:var(--red);color:#fff;padding:2px 6px;border-radius:3px}
.fthumb .np{position:absolute;bottom:9px;right:10px;font-family:var(--mono);font-size:9.5px;color:var(--soft)}
.fcard .fc-b{padding:11px 13px}
.fcard .fc-n{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fcard .fc-m{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--faint);margin-top:3px}

/* ---------- stat cards (dashboard) ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.stat .k{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.stat .v{font-family:var(--disp);font-weight:700;font-size:34px;line-height:1;margin-top:8px;color:var(--ink)}
.stat .v .u{font-family:var(--mono);font-size:13px;color:var(--soft);font-weight:400;letter-spacing:.04em}

/* ---------- dropzone (upload) ---------- */
.dropzone{border:2px dashed var(--line2);border-radius:var(--r-lg);background:var(--card);padding:46px 24px;text-align:center;color:var(--soft)}
.dropzone .ic{font-size:30px;color:var(--red);margin-bottom:12px}
.dropzone .t{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:22px;color:var(--ink);letter-spacing:.02em}
.dropzone .d{font-size:13.5px;margin-top:6px}

/* ---------- detail (single document) ---------- */
.detail{display:grid;grid-template-columns:1fr 360px;gap:22px;align-items:start}
.detail-preview{background:#fff;border:1px solid var(--line);border-radius:var(--r);height:520px;display:flex;align-items:center;justify-content:center;position:relative}
.detail-preview .page{width:62%;height:84%;border:1px solid var(--line);border-radius:2px;background:repeating-linear-gradient(#f3eede 0 3px,transparent 3px 13px) no-repeat;box-shadow:0 20px 40px -26px rgba(0,0,0,.5)}
.detail-meta{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.kv:last-child{border-bottom:none}
.kv .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.kv .v{color:var(--ink);text-align:right}
.kv .v.ref{font-family:var(--mono);color:var(--red)}

/* ---------- greeting (dashboard) ---------- */
.greet{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:30px;letter-spacing:.01em;color:var(--ink)}

/* ---------- avatars / unread ---------- */
.avatar{width:40px;height:40px;border-radius:50%;background:#EFE6D4;color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:13px;font-weight:600;flex:none}
.dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex:none}

/* ---------- pricing tiers ---------- */
.tier{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;display:flex;flex-direction:column;text-align:center}
.tier.feat{border:1.5px solid var(--red)}
.tier .btn{margin-top:auto}
.tier .tn{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.tier .price{font-family:var(--disp);font-weight:700;font-size:42px;color:var(--ink);line-height:1;margin-top:6px}
.tier .price .per{font-family:var(--mono);font-size:12px;color:var(--soft);letter-spacing:.04em;font-weight:400}
.tier ul{list-style:none;margin:16px 0 18px;font-size:13.5px;color:var(--soft);text-align:left}
.tier li{padding:5px 0;display:flex;gap:9px;align-items:flex-start}
.tier li i{color:var(--red);font-size:12px;margin-top:3px}

/* ---------- tool / feature card ---------- */
.tool{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px;color:inherit}
.tool:hover{border-color:var(--red)}
.tool .ic{width:42px;height:42px;border-radius:8px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px}
.tool .tt{font-weight:600;font-size:15px}
.tool .td{font-size:13px;color:var(--soft);margin-top:5px}

/* ---------- note card ---------- */
.note-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;min-height:130px;display:flex;flex-direction:column}
.note-card .nt{font-family:var(--disp);font-weight:600;font-size:18px;text-transform:uppercase;letter-spacing:.01em}
.note-card .nx{font-size:13px;color:var(--soft);margin-top:8px;flex:1}
.note-card .nf{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--faint);text-transform:uppercase;margin-top:10px}

/* ---------- search result group ---------- */
.resgrp{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin:22px 0 10px;display:flex;align-items:center;gap:8px}
.resgrp .c{background:var(--red);color:#fff;border-radius:999px;padding:1px 8px;font-size:9.5px}

/* ---------- footer ---------- */
.foot{margin-top:30px;border-top:1px solid var(--line);padding-top:15px;font-family:var(--mono);font-size:10.5px;letter-spacing:.07em;color:var(--faint)}
.foot b{color:var(--soft)}

/* ==========================================================================
   MARKETING PAGES (landing / tarifs / fonctionnalités / contact)
   ========================================================================== */
.mwrap{max-width:1240px;margin:0 auto;padding:0 28px}
/* Header colle (sticky) + verre depoli : reste visible au scroll, desktop comme mobile. */
.mhead{position:sticky;top:0;z-index:50;background:rgba(244,239,230,.86);-webkit-backdrop-filter:saturate(1.4) blur(10px);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
/* verrou de defilement quand le menu mobile est ouvert : html+body bloques + pas de rebond (iOS) */
/* Verrou de scroll du menu mobile : on lock html SEULEMENT (le scroller iOS), JAMAIS body (= l'element
   qui porte overflow-x:clip), pour ne pas re-rendre le filet de clip a chaque open/close. */
html.mmenuopen{overflow:hidden;overscroll-behavior:none;height:100%}
.mnav{display:flex;align-items:center;gap:22px;height:74px}
.mnav>a{display:inline-flex;align-items:center}
.mnav .logo{height:26px;display:block;margin-left:-3px}/* le lockup SVG a ~3px de blanc a gauche : on aligne le glyphe sur le bord du .mwrap (visible en mobile) */
.mnav .links{display:flex;gap:24px;margin-left:18px}
.mnav .links a{font-size:14px;color:var(--soft);font-weight:500}
.mnav .links a:hover,.mnav .links a.on{color:var(--ink)}
.mnav .links a.on{font-weight:600}
.mnav .act{margin-left:auto;display:flex;align-items:center;gap:12px}
.mnav .act a.sign{font-size:14px;font-weight:600;color:var(--ink)}
.mnav .act .sign,.mnav .act .btn{white-space:nowrap}
/* ===== Nav marketing : menus deroulants (desktop) ===== */
.mnav .links{align-items:center}
.mnav .navlink{font-size:14px;color:var(--soft);font-weight:500}
.mnav .navlink:hover,.mnav .navlink.on{color:var(--ink)}
.mnav .navlink.on{font-weight:600}
.navitem{position:relative;display:flex;align-items:center}
.navtrig{display:inline-flex;align-items:center;gap:6px;background:none;border:0;margin:0;padding:0;height:74px;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;color:var(--soft);white-space:nowrap}
.navtrig .fa-chevron-down{font-size:9px;opacity:.6;transition:transform .18s ease}
.navitem:hover .navtrig,.navitem:focus-within .navtrig,.navitem.open .navtrig,.navitem.on .navtrig{color:var(--ink)}
.navitem.on .navtrig{font-weight:600}
.navitem:hover .navtrig .fa-chevron-down,.navitem.open .navtrig .fa-chevron-down{transform:rotate(180deg)}
.navpanel{position:absolute;top:59px;left:0;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:0 28px 56px -26px rgba(0,0,0,.42),0 6px 16px -10px rgba(0,0,0,.25);padding:10px;min-width:316px;opacity:0;visibility:hidden;transform:translateY(7px);transition:opacity .16s ease,transform .16s ease,visibility .16s;z-index:70}
.navpanel:before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.navitem:hover .navpanel,.navitem:focus-within .navpanel,.navitem.open .navpanel{opacity:1;visibility:visible;transform:none;pointer-events:auto}
.mnav .navpanel a{display:flex;align-items:flex-start;gap:12px;padding:10px;border-radius:10px;color:var(--ink);text-decoration:none;font-weight:500}
.mnav .navpanel a:hover{background:var(--paper)}
.npi{flex:none;width:36px;height:36px;border-radius:9px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:15px}
.npt{min-width:0}
.npt b{display:block;font-size:14px;font-weight:600;color:var(--ink);line-height:1.2}
.npt span{display:block;font-size:12.5px;color:var(--soft);margin-top:2px;line-height:1.4}
.navpanel.grid{min-width:540px}
.npgrid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.mnav .navpanel.grid a{align-items:center;padding:9px 10px}
.navpanel.grid .npi{width:32px;height:32px;font-size:14px}
.nphead{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding:11px 10px 5px;margin-top:6px;border-top:1px solid var(--line)}
.npfoot{margin-top:6px;padding-top:8px;border-top:1px solid var(--line)}
.mnav .npfoot a{display:inline-flex;align-items:center;gap:7px;padding:8px 10px;color:var(--red);font-weight:600;font-size:13.5px;border-radius:8px}
.mnav .npfoot a:hover{background:rgba(178,58,46,.06)}
.mnav .npfoot a .fa-arrow-right{font-size:11px}
/* burger -> croix quand le menu est ouvert */
.mburger .fa-xmark{display:none}
body.mmenuopen .mburger .fa-bars{display:none}
body.mmenuopen .mburger .fa-xmark{display:inline-block}
/* menu mobile plein ecran : sections + lignes a icone (langage des dropdowns desktop) */
.mmenu-in{padding:14px 12px 32px;max-width:560px;margin:0 auto}
.mmenu .mmsec{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);padding:18px 6px 7px}
.mmenu-in>.mmsec:first-child{padding-top:6px}
.mmenu .mmsub{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);opacity:.85;padding:11px 6px 5px}
.mmenu a{display:flex;align-items:center;gap:13px;padding:11px 6px;border-radius:11px;color:var(--ink);font-size:15.5px;font-weight:500;text-decoration:none}
.mmenu a:active{background:var(--card)}
.mmenu .mmi{flex:none;width:34px;height:34px;border-radius:9px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:14px}
.mmenu .mmtop{font-weight:600}
.mmenu .mmall{color:var(--red);font-weight:600}
.mmenu .mml-arrow{font-size:11px;margin-left:auto}
.mmcta{display:flex;flex-direction:column;gap:10px;margin-top:22px;padding:18px 8px 0;border-top:1px solid var(--line)}
.mmcta .btn{width:100%;justify-content:center}
/* `.mmenu a{color:var(--ink)}` (0,1,1) bat `.btn--primary{color:#fff}` (0,1,0) -> texte noir illisible sur le rouge ; idem `.mmenu a:active{background:var(--card)}` ferait flasher le bouton en clair. On reforce couleur ET fond du CTA dans le menu. */
.mmcta .btn--primary,.mmcta .btn--primary:active{background:var(--red);color:#fff}
.btn--lg{padding:14px 22px;font-size:13px}
.btn--ghost-d{display:inline-flex;align-items:center;gap:9px;background:none;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:var(--r);padding:14px 22px;font-weight:600;font-size:14px}
/* hero */
.hero{background:#16140F;color:#EDE6D6}
.hero .in{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;padding:64px 0 72px}
.hero .kick{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#E08571}
.hero h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:62px;line-height:.96;letter-spacing:.005em;margin:14px 0 0;color:#fff}
.hero h1 .r{color:var(--red)}
.hero p{font-size:17px;color:#b9b1a2;max-width:460px;margin:18px 0 26px;line-height:1.55}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
/* Aide / FAQ : en-tete compact mono-colonne, le sceau devient un filigrane d'angle
   (plus de colonne droite vide qui gaspille la moitie de l'ecran sur desktop) */
.hero--faq{position:relative;overflow:hidden}
.hero--faq .in{display:block;padding:52px 0 48px}
.hero--faq h1{margin-top:10px}
.hero--faq p{max-width:640px}
.hero--faq .kick,.hero--faq h1,.hero--faq p,.hero--faq .cta{position:relative;z-index:2}
.hero--faq .hseal{position:absolute;top:50%;right:clamp(30px,8vw,140px);transform:translateY(-50%) rotate(-8deg);width:clamp(190px,19vw,250px);height:clamp(190px,19vw,250px);opacity:.6;z-index:1;pointer-events:none}
.hero--faq .hseal text{text-anchor:middle}
.hero--faq .hseal .hs-ring{fill:none;stroke:#E08571;stroke-width:2}
.hero--faq .hseal .hs-thin{stroke-width:1}
.hero--faq .hseal .hs-arc{fill:#E08571;font-family:var(--mono);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase}
.hero--faq .hseal .hs-seam{fill:#E08571;font-size:10px;dominant-baseline:central}
.hero--faq .hseal .hs-word{fill:#E08571;font-family:var(--disp);font-weight:700;font-size:31px;letter-spacing:.03em;text-transform:uppercase;dominant-baseline:central}
.hero--faq p a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.heroviz{position:relative;display:flex;align-items:center;justify-content:center;min-height:300px}
.docwrap{position:relative;display:inline-block}
.doc{position:relative;display:flex;flex-direction:column;gap:clamp(15px,1.5vw,21px);box-sizing:border-box;width:clamp(300px,30vw,420px);aspect-ratio:210/297;padding:clamp(26px,2.4vw,36px);background:linear-gradient(158deg,#fff 0%,#fbf6ec 100%);border-radius:8px;box-shadow:0 46px 84px -30px rgba(0,0,0,.72),0 12px 28px -16px rgba(0,0,0,.5);transform:rotate(-3deg)}
.doc-hd{display:flex;align-items:center;gap:13px;padding-bottom:clamp(15px,1.5vw,21px);border-bottom:1px solid var(--line)}
.doc-ic{flex:none;width:clamp(40px,3.6vw,50px);height:clamp(40px,3.6vw,50px);border-radius:10px;background:rgba(178,58,46,.1);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:clamp(20px,1.8vw,25px)}
.doc-hl{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.doc-hl b{display:block;height:10px;width:64%;background:#d7cdb7;border-radius:3px}
.doc-hl i{display:block;height:8px;width:42%;background:#e8e0cf;border-radius:3px}
.doc-ttl{display:block;height:clamp(15px,1.4vw,19px);width:80%;background:#16140F;opacity:.84;border-radius:3px}
.doc-body{display:flex;flex-direction:column;gap:clamp(10px,1.05vw,14px);flex:1;justify-content:center}
.doc-body .ln{height:8px;background:#ece3d2;border-radius:3px}
.doc-body .ln.m{width:86%}
.doc-body .ln.s{width:55%}
.doc-body .gap{height:clamp(6px,.6vw,9px)}
.doc-ft{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;padding-top:clamp(15px,1.5vw,21px);border-top:1px solid var(--line)}
.doc-qr{flex:none;width:clamp(44px,4vw,56px);height:clamp(44px,4vw,56px);border-radius:7px;background:#fff;border:1px solid var(--line);padding:5px;box-sizing:border-box;display:flex;align-items:center;justify-content:center}
.doc-qr .qrmock{display:block;width:100%;height:100%;fill:#1b1813}
.doc-fl{display:flex;flex-direction:column;gap:8px;flex:1;align-items:flex-end}
.doc-fl i{display:block;height:8px;border-radius:3px;background:#ece3d2}
.doc-fl i:first-child{width:46%}
.doc-fl i:last-child{width:32%}
/* doccard : mockup-document simple des heros persona (associations / metiers / cas d'usage) */
.doccard{position:relative;width:clamp(220px,22vw,272px);padding:26px 24px;background:linear-gradient(165deg,#fff 0%,#fbf6ec 100%);border-radius:10px;box-shadow:0 44px 80px -34px rgba(0,0,0,.72),0 12px 28px -16px rgba(0,0,0,.5);transform:rotate(-3deg)}
.doccard .pg{height:9px;border-radius:3px;background:#e7dec9;margin-bottom:12px}
.doccard .pg:last-child{margin-bottom:0}
.doccard .pg.s{width:58%}
/* highlight tile : tuile pleine sous le mot-cle d'un titre (note design SS4.3 / device SS2.5) */
.htile{display:inline-block;background:var(--red);color:#fff;padding:.02em .22em .08em;border-radius:6px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.heroviz .stamp{position:absolute;right:clamp(-30px,-2vw,-14px);bottom:clamp(34px,7%,64px);width:clamp(120px,12vw,152px);height:clamp(120px,12vw,152px);border-width:3px;transform:rotate(-11deg);background:#16140F;box-shadow:0 20px 44px -16px rgba(0,0,0,.72)}
.heroviz .stamp:before{inset:8px;opacity:.5}
.heroviz .stamp .t{font-size:clamp(19px,1.7vw,24px);letter-spacing:.05em}
.heroviz .stamp .d{font-size:clamp(11px,1vw,13px);letter-spacing:.08em;margin-top:6px}
/* hero document : A/B variants (tilt direction + stacked sheets) */
.heroviz.alt .doc{transform:none;position:relative;z-index:2}
.heroviz.alt .stamp{z-index:3}
.heroviz.alt .ghost{position:absolute;inset:0;border-radius:8px;background:linear-gradient(158deg,#fdfbf5 0%,#f0e7d6 100%);box-shadow:0 28px 56px -34px rgba(0,0,0,.5)}
.heroviz.t-l .docwrap{transform:rotate(-4deg)}
.heroviz.t-r .docwrap{transform:rotate(4deg)}
.heroviz.t-r .stamp{right:auto;left:clamp(-30px,-2vw,-14px);transform:rotate(9deg)}
.heroviz.stamp-r .stamp{left:auto;right:clamp(-30px,-2vw,-14px);transform:rotate(9deg)}
.heroviz.stamp-c .stamp{left:50%;right:auto;bottom:clamp(82px,17%,124px);transform:translate(calc(-50% + var(--sx,0px)),var(--sy,0px)) rotate(calc(9deg + var(--sr,0deg)))}
.heroviz.stamp-cl .stamp{left:32%;right:auto;bottom:clamp(-34px,-4%,-22px);transform:translateX(-50%) rotate(9deg)}
.heroviz.stk-l .ghost.g1{transform:translate(-15px,-14px) rotate(-3deg)}
.heroviz.stk-l .ghost.g2{transform:translate(-30px,-27px) rotate(-6deg)}
.heroviz.stk-r .ghost.g1{transform:translate(15px,-14px) rotate(3deg)}
.heroviz.stk-r .ghost.g2{transform:translate(30px,-27px) rotate(6deg)}
.heroviz.fan .ghost.g1{transform:rotate(8deg) translate(10px,-2px)}
.heroviz.fan .ghost.g2{transform:rotate(16deg) translate(18px,6px)}
/* trust strip */
.trust{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;padding:22px 0;border-bottom:1px solid var(--line)}
.trust .t{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.trust .t i{color:var(--red)}
.flag{width:18px;height:13px;border-radius:2px;overflow:hidden;display:inline-flex;box-shadow:0 0 0 1px var(--line)}
.flag i{display:block;height:100%}.flag .b{width:6px;background:#1E3A8C}.flag .w{width:6px;background:#fff}.flag .r{width:6px;background:var(--red)}
/* contact line: fixed-width centered icon column so labels align */
.cline{display:flex;align-items:center;gap:13px;font-size:14px;color:var(--soft);line-height:1.7;margin-bottom:9px}
.cline:last-child{margin-bottom:0}
.cline>i{flex:none;width:22px;text-align:center;color:var(--red)}
.cline>.flag{flex:none;margin:0 2px}
a.eml:hover{color:var(--red)}
/* sections */
.sec{padding:64px 0}
.sec .lead-h{text-align:center;max-width:640px;margin:0 auto 40px}
.sec .lead-h .kick{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--red)}
.sec .lead-h h2,.sec .lead-h h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:36px;line-height:1;margin:8px 0 10px}
.sec .lead-h p{color:var(--soft);font-size:15.5px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:24px}
.feat-more{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--red);text-decoration:none;display:inline-block;margin-top:10px}
.feat .ic{width:46px;height:46px;border-radius:10px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:14px}
.feat .ic svg{width:25px;height:25px;display:block}
/* la fonte display (Saira Condensed) cale ses capitales haut dans la boite-ligne :
   align-items:center pose donc le pill PRO trop bas, on le remonte sur l'axe optique */
.feat h3 .badge{transform:translateY(-6px)}
.feat h3{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:18px;letter-spacing:.01em}
.feat p{color:var(--soft);font-size:14px;margin-top:7px;line-height:1.5}
/* PRO pill pose dans un .kick (hero), cale optiquement 2px au-dessus de la ligne */
.kpro{display:inline-block;vertical-align:1px;background:var(--red);color:#fff;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.12em;padding:2px 7px;border-radius:4px;margin-left:7px;line-height:1.4}
/* cartes a mini-terminal (integration-ia "Au-dela de MCP") : shells de meme hauteur, colles en bas */
.feat .term{text-align:left}
/* cartes horizontales (integration-ia "Au-dela de MCP") : texte a gauche, terminal a droite, empilees */
.hcards{display:flex;flex-direction:column;gap:14px}
.hcard{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:20px 24px;display:grid;grid-template-columns:1fr 1.05fr;gap:26px;align-items:center}
.hcard .hc-tx{display:flex;gap:15px;align-items:flex-start}
.hcard .hc-tx .ic{flex:none;width:46px;height:46px;border-radius:10px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:19px}
.hcard .hc-tx h3{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:18px;letter-spacing:.01em}
.hcard .hc-tx p{color:var(--soft);font-size:14px;margin-top:6px;line-height:1.5}
/* extrait de code CLAIR (coherent avec le creme heritage, pas un pave noir) */
.snip{font-family:var(--mono);font-size:12.5px;line-height:1.75;background:#F6F1E7;border:1px solid var(--line);border-radius:8px;padding:12px 15px;color:#5a5346;white-space:pre;overflow-x:auto}
.snip .p{color:var(--red)}
.snip .s{color:#7a7058}
@media(max-width:760px){.hcard{grid-template-columns:1fr;gap:16px;padding:18px 18px}.snip{white-space:pre-wrap;word-break:break-word}}
/* lien CTA editorial (rouge, fleche qui glisse) : remplace le bouton fantome trop pale sur fond creme */
.tcta{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:14px;color:var(--red);border-bottom:1.5px solid transparent;padding-bottom:2px;transition:border-color .15s ease,gap .15s ease}
.tcta:hover{border-color:var(--red);gap:13px}
.tcta i{font-size:12px}
/* terminal du hero : un peu plus grand sur desktop */
@media(min-width:861px){.heroviz .term{font-size:13.5px}}
/* hauteur de hero unifiee sur tout www2 (evite le "shift" entre pages) : plancher commun,
   contenu centre verticalement. Les deux mises en page (.hero 2 col + .hero--faq 1 col) partagent
   la meme hauteur mini en desktop. */
@media(min-width:861px){
  .hero .in,.hero--faq .in{box-sizing:border-box;min-height:492px}
  .hero--faq .in{display:flex;flex-direction:column;justify-content:center;align-items:stretch}
}
/* fledger : sommaire de dossier (registre numerote a 2 colonnes, filets fins) --
   alternative editoriale aux grilles de cartes (.feat/.uc voisines), cf. ledger menu */
.fledger{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.fledger .fl-row{display:grid;grid-template-columns:auto auto 1fr;align-items:start;gap:15px;padding:20px 16px;border-bottom:1px solid var(--line);transition:background .15s ease}
.fledger .fl-row:nth-child(odd){padding-right:34px}
.fledger .fl-row:nth-child(even){padding-left:34px;border-left:1px solid var(--line)}
.fledger .fl-row:hover{background:#F8F4EC}
.fledger .fl-n{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--faint);padding-top:3px}
.fledger .fl-ic{color:var(--red);font-size:17px;width:20px;text-align:center;padding-top:1px}
.fledger .fl-tx h3{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:17px;letter-spacing:.01em;color:var(--ink)}
.fledger .fl-tx p{color:var(--soft);font-size:13.5px;margin-top:5px;line-height:1.5}
@media(max-width:760px){
  .fledger{grid-template-columns:1fr;border-top:0}
  .fledger .fl-row:nth-child(odd){padding:18px 16px}
  .fledger .fl-row:nth-child(even){padding:18px 16px;border-left:0}
  .fledger .fl-row:first-child{border-top:1px solid var(--line)}
}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step{display:flex;gap:14px;align-items:flex-start}
.step .n{flex:none;width:38px;height:38px;border-radius:999px;background:var(--ink);color:#fff;font-family:var(--mono);font-weight:600;display:flex;align-items:center;justify-content:center}
.step h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:16px}
.step p{color:var(--soft);font-size:13.5px;margin-top:4px}
.ptease{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:860px;margin:0 auto}
.ctaband{background:#16140F;color:#fff;border-radius:14px;padding:42px;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.ctaband h2{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:30px;line-height:1.02;flex:1;min-width:280px;overflow-wrap:break-word}
.ctaband .seal{display:flex;align-items:center;gap:14px}
.ctaband .btn--lg i{font-size:16px}/* icone du CTA pied de page : moins riquiqui face au gros bouton */
/* footer */
.mfoot{border-top:1px solid var(--line);padding:42px 0 30px;display:grid;grid-template-columns:1.7fr repeat(5,1fr);gap:24px}
.mfoot .col h4{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.mfoot .col a{display:block;font-size:13.5px;color:var(--soft);margin-bottom:8px}
.mfoot .col a:hover{color:var(--red)}
.mfoot .brandcol p{font-size:13px;color:var(--faint);margin-top:12px;max-width:240px;line-height:1.5}
.mfoot .logo{height:24px}
.mfootbar{border-top:1px solid var(--line);padding:16px 28px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--faint);text-align:center}
/* comparison + faq + feature rows (tarifs / fonctionnalités) */
.cmp{width:100%;max-width:940px;margin:0 auto;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.cmp th,.cmp td{padding:13px 16px;text-align:center;border-bottom:1px solid var(--line);font-size:13.5px}
.cmp th{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.cmp td:first-child,.cmp th:first-child{text-align:left;color:var(--ink)}
.cmp tr:last-child td{border-bottom:none}
.cmp .yes{color:var(--red)}
.cmp .no{color:var(--faint)}.cmp .no i{font-size:12px}
.faq{max-width:760px;margin:0 auto}
.faq .q{border-top:1px solid var(--line);padding:18px 0}
.faq .q h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:17px;letter-spacing:.01em}
.faq .q p{color:var(--soft);font-size:14px;margin-top:6px;line-height:1.55}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;padding:40px 0;border-top:1px solid var(--line)}
.frow.rev{direction:rtl}
.frow .vz{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:12px;min-height:252px;padding:26px;display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:inherit}
.frow .vz>*{position:relative;z-index:1}
.frow h2{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:28px;line-height:1.02}
.frow .kick{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.frow p{color:var(--soft);font-size:15px;line-height:1.55;margin-top:10px}
.frow ul{list-style:none;margin:14px 0 0;font-size:14px;color:var(--soft)}
.frow li{padding:4px 0;display:flex;gap:9px}.frow li i{color:var(--red);margin-top:4px;font-size:12px}
/* pricing: gratuit + un seul Pro, bascule mensuel/annuel */
.pricing2{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:720px;margin:0 auto}
.billwrap{text-align:center;margin-bottom:26px}
.billtoggle{display:inline-flex;background:var(--card);border:1px solid var(--line2);border-radius:999px;padding:4px;gap:2px}
.billtoggle button{border:none;background:none;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);padding:9px 18px;border-radius:999px;cursor:pointer;font-weight:600}
.billtoggle button.on{background:var(--ink);color:#fff}
.billtoggle .pct{color:var(--red);margin-left:6px}
.peryear{font-size:12.5px;color:var(--soft);margin-top:4px;min-height:18px}
.tier .price .per{font-family:var(--mono);font-size:13px;color:var(--soft);letter-spacing:.04em;font-weight:400}
.tier-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border-radius:999px}
.tier{position:relative}
/* tier ledger : specs chiffrees a conduites de points (note design SS2.11) */
.tledger{list-style:none;margin:14px 0 16px;padding:0}
.tledger li{display:flex;align-items:baseline;gap:8px;padding:8px 0;border-top:1px solid var(--line)}
.tledger li:first-child{border-top:0}
.tledger .k{font-size:13px;color:var(--soft);white-space:nowrap}
.tledger .d{flex:1;border-bottom:1px dotted var(--line2);position:relative;top:-4px;min-width:12px}
.tledger .v{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap}
/* sceau centre pose au-dessus d'un en-tete lead-h (pages cream sans bandeau hero) */
.lead-seal{display:flex;justify-content:center;margin-bottom:18px}
/* simple page (legal / text) */
.prose{max-width:760px;margin:0 auto}
.prose h1,.prose h2,.prose h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:22px;margin:28px 0 10px}
.prose h1{font-size:33px;line-height:1.05;margin:0 0 14px}
.prose h3{font-size:18px}
.prose p{color:var(--soft);font-size:14.5px;line-height:1.65;margin-bottom:12px}
.prose ul{color:var(--soft);font-size:14.5px;line-height:1.65;margin:0 0 12px 20px}
/* auth screens */
.authwrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--paper);padding:40px 20px}
.authcard{width:420px;max-width:100%;background:var(--card);border:1px solid var(--line);border-radius:var(--r);border-top:3px solid var(--red);padding:30px 32px 26px}
.authcard .blogo{display:block;height:26px;margin:0 auto 18px}
.authcard h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:24px;text-align:center;margin-bottom:20px}
.authcard .alt{margin-top:16px;text-align:center;font-size:13px;color:var(--soft)}
.authcard .alt a{color:var(--red);font-weight:600}
.authsess{text-align:center;margin-top:18px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--faint);line-height:1.7}
/* error pages */
.errwrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:var(--paper);padding:40px}
.errcode{font-family:var(--disp);font-weight:700;font-size:120px;line-height:1;color:var(--ink)}
.errcode .r{color:var(--red)}
.errwrap h1{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:26px;margin:6px 0 10px}
.errwrap p{color:var(--soft);font-size:15px;margin-bottom:22px;max-width:420px}
/* message thread */
.thread{display:flex;flex-direction:column;gap:12px;max-width:720px;margin-bottom:18px}
.bubble{max-width:78%;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 15px;font-size:14px;color:var(--ink);line-height:1.5}
.bubble .by{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:5px}
.bubble.me{align-self:flex-end;background:var(--ink);color:#fff;border-color:var(--ink)}
.bubble.me .by{color:#8d8475}
.reply{display:flex;gap:10px;max-width:720px;align-items:flex-end}
.reply textarea{flex:1}
/* profile header */
.phead{display:flex;align-items:center;gap:18px;padding:8px 0 20px;border-bottom:1px solid var(--line);margin-bottom:22px}
.phead .av-xl{width:72px;height:72px;border-radius:50%;background:#EFE6D4;color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:24px;flex:none}
.phead .nm{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:26px}
.phead .un{font-family:var(--mono);font-size:12px;color:var(--soft);margin-top:2px}
/* public share page */
.pubtop{display:flex;align-items:center;height:64px;border-bottom:1px solid var(--line)}
.pubtop .act{margin-left:auto}
.pubdoc{max-width:780px;margin:40px auto;display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}
.pubprev{background:#fff;border:1px solid var(--line);border-radius:10px;height:440px;display:flex;align-items:center;justify-content:center}
.pubprev .page{width:62%;height:84%;border:1px solid var(--line);border-radius:2px;background:repeating-linear-gradient(#f3eede 0 3px,transparent 3px 13px) no-repeat;box-shadow:0 18px 36px -24px rgba(0,0,0,.4)}

/* ==========================================================================
   RESPONSIVE (mobile) - portail off-canvas + nav marketing repliable
   ========================================================================== */
.burger,.mburger,.mmenu{display:none}
.scrim{display:none}
@media (max-width:920px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:264px;z-index:60;transform:translateX(-100%);transition:transform .22s ease;overflow-y:auto}
  body.navopen .side{transform:none;box-shadow:0 0 40px rgba(0,0,0,.45)}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:55}
  body.navopen .scrim{display:block}
  .top .burger{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);border-radius:var(--r);background:var(--card);color:var(--ink);font-size:15px;margin-right:2px}
  .tsearch{width:auto;flex:1}
  .content{padding:24px 18px 48px}
  .stats,.fgrid{grid-template-columns:repeat(2,1fr)}
  .detail{grid-template-columns:1fr}
}
/* Nav marketing : les declencheurs tiennent des ~880px, mais le panneau "Outils" (grille 2 col, aligne
   sous son declencheur) a besoin de ~1040px pour ne pas deborder a droite ; on bascule donc au burger
   sous 1040px (coherence : tous les panneaux ouvrent sous leur declencheur). Mobile a retravailler. */
@media (max-width:1040px){
  .mnav .links{display:none}
  .mnav .act .sign,.mnav .act .btn{display:none}
  /* PAS de translateZ(0)/will-change ici : promouvoir le burger (bord droit) en couche composite
     laisse un filet de 1px a droite apres open/close du menu sur iOS Safari. Le hit-test n'en a pas
     besoin (cf. note P28). */
  .mnav .mburger{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--line2);border-radius:var(--r);background:var(--card);color:var(--ink);font-size:16px;margin-left:auto;position:relative;z-index:2;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
  /* P28-adjacent (note UI/UX flotte): menu fixed au-dessus d'un header backdrop-filter -> les transitions opacity/visibility/transform sur la couche composee ne repeignent pas de facon fiable sur iOS Safari (etats fantomes, plusieurs taps). Bascule display: reflow complet, rendu fiable. */
  .mmenu{display:none;position:fixed;left:0;right:0;top:74px;bottom:0;z-index:49;background:var(--paper);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
  body.mmenuopen .mmenu{display:block}
}
@media (max-width:780px){
  .hero .in{grid-template-columns:1fr;padding:46px 0 54px}
  .hero--faq .in{padding:40px 0 40px}
  .hero--faq .hseal{display:none}
  .hero h1{font-size:46px;overflow-wrap:break-word}
  .heroviz{min-height:0;margin-top:26px;min-width:0}
  /* hero : empeche tout debordement du decor (tampons, planche d'outils, terminal) */
  .hero{overflow:hidden}
  .hero .in>div{min-width:0}
  /* sceaux "seuls" (tarifs / securite) : honore l'intention s-position-static,
     defaite par la specificite de .heroviz .stamp -> les remet dans le flux, centres */
  .heroviz .stamp.s-position-static,.heroviz .doccard + .stamp{position:static;width:120px;height:120px;margin:10px auto 0;right:auto;left:auto;bottom:auto;transform:rotate(-7deg)}
  .heroviz .stamp.s-position-static:before,.heroviz .doccard + .stamp:before{inset:6px}
  /* outils : la planche-contact a une vraie hauteur, le sceau reste pose dans son coin */
  .heroviz .toolsheet + .stamp{right:8px}
  .grid-2,.grid-3{flex-direction:column;align-items:stretch}
  /* full-width en colonne meme si .s-align-items-start force align-items:start (contact) */
  .grid-2>*,.grid-3>*{min-width:0;flex:none;width:100%}
  .steps,.pricing2,.ptease,.frow{grid-template-columns:1fr}
  .frow{direction:ltr !important}
  .hero .cta{flex-direction:column;align-items:stretch}
  .hero .cta>a{justify-content:center}
  .mfoot{grid-template-columns:1fr 1fr}
  .pubdoc{grid-template-columns:1fr}
  .ctaband{padding:30px}.ctaband h2{font-size:24px}
  .sec{padding:46px 0}.sec .lead-h h2,.sec .lead-h h1{font-size:28px}
  .cmp th,.cmp td{padding:11px 10px;font-size:12.5px}
}
@media (max-width:480px){
  .fgrid,.mfoot,.stats{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .ctaband{padding:26px 22px}.ctaband h2{font-size:21px;min-width:0}
}

/* ===== marketing extras : chiffres, cas d'usage, FAQ accordéon ===== */
.statband{display:flex;flex-wrap:wrap;gap:40px;justify-content:center;padding:30px 0;border-bottom:1px solid var(--line)}
.statband .s{text-align:center}
.statband .s b{display:block;font-family:var(--disp);font-weight:700;font-size:34px;color:var(--ink);line-height:1}
.statband .s span{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.uc{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:22px}
a.uc{display:block;color:inherit;text-decoration:none}
.uc .ic{color:var(--red);font-size:20px;margin-bottom:10px}
.uc h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:17px}
.uc p{color:var(--soft);font-size:13.5px;margin-top:6px;line-height:1.5}
.acc{max-width:760px;margin:0 auto}
.acc details{border-top:1px solid var(--line)}
.acc details:last-child{border-bottom:1px solid var(--line)}
.acc summary{list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none;padding:17px 0;font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:16px;letter-spacing:.01em;display:flex;justify-content:space-between;align-items:center;gap:16px}
.acc summary::-webkit-details-marker{display:none}
.acc summary:after{content:'+';color:var(--red);font-weight:400;font-size:24px;line-height:1}
.acc details[open] summary:after{content:'\2013'}
.acc details>div{color:var(--soft);font-size:14px;line-height:1.6;padding:0 0 17px;max-width:680px}
.acc details p{color:var(--soft);font-size:14px;line-height:1.6;padding:0 0 17px;max-width:680px}
.acc details>div p:last-child{padding-bottom:0}
.acc details ul,.acc details ol{margin:6px 0 4px 18px;padding:0}
.acc details li{font-size:14px;line-height:1.6;color:var(--soft);padding:2px 0}

/* ===== modal (portail) ===== */
.modal-back{position:fixed;inset:0;background:rgba(22,20,15,.55);z-index:80;display:flex;align-items:center;justify-content:center;padding:24px}
.modal{background:var(--card);border:1px solid var(--line);border-radius:12px;width:460px;max-width:100%;box-shadow:0 40px 90px -30px rgba(0,0,0,.55);overflow:hidden}
.modal .mh{display:flex;align-items:center;gap:10px;padding:17px 20px;border-bottom:1px solid var(--line)}
.modal .mh h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:18px;letter-spacing:.01em;flex:1}
.modal .mh .x{color:var(--faint);cursor:pointer;font-size:16px}
.modal .mb{padding:20px}
.modal .mf{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;background:var(--paper)}
/* timeline (à propos) */
.tl{max-width:680px;margin:0 auto;border-left:2px solid var(--line);padding-left:24px}
.tl .ev{position:relative;padding:0 0 26px}
.tl .ev:before{content:"";position:absolute;left:-31px;top:3px;width:11px;height:11px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px var(--paper)}
.tl .ev .y{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--red)}
.tl .ev h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:17px;margin:3px 0 4px}
.tl .ev p{color:var(--soft);font-size:14px;line-height:1.55}

/* ==========================================================================
   CAS D'USAGE · capture web · IA/MCP - composants additionnels
   ========================================================================== */
/* témoignages / personas */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{background:var(--card);border:1px solid var(--line2);border-radius:10px;padding:22px}
.tcard .q{font-size:15px;line-height:1.6;color:var(--ink)}
.tcard .q:before{content:"« ";color:var(--red)}.tcard .q:after{content:" »";color:var(--red)}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.tcard .ava{width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:15px;flex:none}
.tcard .who b{display:block;font-size:13.5px}
.tcard .who span{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--faint);text-transform:uppercase;margin-top:2px}
/* alternance cas d'usage détaillés */
.ucrow{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;padding:30px 0;border-top:1px solid var(--line)}
.ucrow:nth-child(even) .uctext{order:2}
.ucrow .uctag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.ucrow h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:26px;line-height:1.02;letter-spacing:.01em}
.ucrow p{color:var(--soft);font-size:15px;line-height:1.6;margin-top:10px}
.ucrow .uses{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.ucrow .uses a,.ucrow .uses span{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;background:var(--paper);border:1px solid var(--line2);border-radius:999px;padding:6px 11px;color:var(--soft);text-decoration:none}
.ucrow .uses a:hover{border-color:var(--red);color:var(--red)}
.ucrow .uses a.solid{background:var(--red);border-color:var(--red);color:#fff}
.ucviz{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:12px;min-height:222px;padding:26px;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.ucviz>*{position:relative;z-index:1}
.ucviz .big{font-size:64px;color:var(--line2)}
/* cadence pills (capture web) */
.cadence{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.cadence .c{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line2);border-radius:999px;padding:8px 15px;font-weight:600;font-size:13px;color:var(--soft);background:var(--card)}
.cadence .c.on{background:var(--red);border-color:var(--red);color:#fff}
.cadence .c i{font-size:11px;opacity:.9}
/* terminal / extrait de code */
.term{background:#15140F;border:1px solid #2a2820;border-radius:10px;overflow:hidden;font-family:var(--mono);font-size:12.5px;line-height:1.75;box-shadow:0 24px 48px -30px rgba(0,0,0,.6)}
.term .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#1d1b14;border-bottom:1px solid #2a2820}
.term .bar i{width:11px;height:11px;border-radius:50%;background:#3a382e;display:inline-block}
.term .bar i:first-child{background:#B23A2E}
.term .bar .tt{margin-left:8px;color:#7d7768;font-size:11px;letter-spacing:.04em}
.term .body{padding:16px 18px;color:#d9d2c2;white-space:pre;overflow-x:auto}
.term .body .p{color:#B23A2E}.term .body .k{color:#cdb68a}.term .body .c{color:#6f6a5b}.term .body .s{color:#9fb38a}
/* table de planning / captures programmées */
.schedt{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line2);border-radius:10px;overflow:hidden;font-size:13.5px}
.schedt th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:12px 16px;border-bottom:1px solid var(--line);font-weight:500}
.schedt td{padding:13px 16px;border-bottom:1px solid var(--line)}
.schedt tr:last-child td{border-bottom:0}
.schedt .url{font-family:var(--mono);font-size:12.5px;color:var(--ink)}
.schedt .freq{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--soft)}
.schedt .ok{color:#3c7a4e;font-weight:600}
.schedt .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#3c7a4e;margin-right:6px}
@media (max-width:780px){
  .tgrid{grid-template-columns:1fr}
  .ucrow{grid-template-columns:1fr;gap:18px;padding:24px 0}
  .ucrow:nth-child(even) .uctext{order:0}
  /* schedt : on masque les colonnes secondaires (Prochaine / Historique) plutot que de couper la table */
  .schedt th:nth-child(3),.schedt td:nth-child(3),.schedt th:nth-child(4),.schedt td:nth-child(4){display:none}
  .schedt .url{word-break:break-word}
  /* terminaux : on laisse les longues commandes passer a la ligne au lieu d'etre coupees */
  .term .body{white-space:pre-wrap;word-break:break-word;overflow-x:visible}
}

/* ==========================================================================
   STYLEGUIDE - composants système complémentaires
   (alertes, toasts, progress, formulaires avancés, menus, pagination,
    fil d'ariane, badges, tooltips, tableaux, loaders, copie, QR)
   ========================================================================== */
/* alertes inline */
.alert{display:flex;gap:11px;align-items:flex-start;border:1px solid var(--line);border-left-width:3px;border-radius:var(--r);padding:12px 15px;font-size:13.5px;background:var(--card);color:var(--ink);margin-bottom:10px}
.alert > i{margin-top:1px;flex:none}
.alert b{font-weight:600}
.alert .x{margin-left:auto;color:var(--faint);cursor:pointer;flex:none}
.alert.ok{border-left-color:#3c7a4e}.alert.ok > i{color:#3c7a4e}
.alert.err{border-left-color:var(--red)}.alert.err > i{color:var(--red)}
.alert.warn{border-left-color:#b5862b}.alert.warn > i{color:#b5862b}
.alert.info{border-left-color:#3a6b8a}.alert.info > i{color:#3a6b8a}
/* toast (notification flottante type growl) */
.toast{display:inline-flex;gap:10px;align-items:center;background:var(--ink);color:var(--paper);border-radius:9px;padding:12px 16px;font-size:13.5px;box-shadow:0 16px 40px -20px rgba(0,0,0,.55);max-width:340px}
.toast > i{flex:none}.toast.ok > i{color:#7fcf97}.toast.err > i{color:#e98f84}
.toast .x{margin-left:6px;opacity:.6;cursor:pointer}
/* barres de progression + jauge */
.progress{height:8px;background:var(--line);border-radius:999px;overflow:hidden}
.progress > i{display:block;height:100%;background:var(--red);border-radius:999px}
.progress.dark > i{background:var(--ink)}
/* interrupteur (toggle switch) */
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none;vertical-align:middle}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:var(--line2);border-radius:999px;transition:.2s;cursor:pointer}
.switch .sl:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.3)}
.switch input:checked + .sl{background:var(--red)}
.switch input:checked + .sl:before{transform:translateX(18px)}
/* cases & boutons radio (accent natif) */
.opt{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer;margin-bottom:9px;color:var(--ink);-webkit-user-select:none;user-select:none}
.opt input{accent-color:var(--red);width:17px;height:17px;flex:none;cursor:pointer}
.opt .d{display:block;font-size:12px;color:var(--soft);margin-top:1px}
/* select */
.select{position:relative;display:block}
.select select{width:100%;appearance:none;-webkit-appearance:none;border:1px solid var(--line2);border-radius:var(--r);background:#fff;padding:11px 36px 11px 13px;font-family:var(--body);font-size:14px;color:var(--ink);outline:none;cursor:pointer}
.select select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(178,58,46,.12)}
.select:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--faint);font-size:13px;pointer-events:none}
/* textarea (variante de .input) */
textarea.input{resize:vertical;min-height:92px;line-height:1.55}
/* groupe d'input (préfixe / suffixe) */
.igroup{display:flex;align-items:stretch;max-width:100%}
.igroup .pfx,.igroup .sfx{display:inline-flex;align-items:center;padding:0 13px;background:var(--card);border:1px solid var(--line2);font-family:var(--mono);font-size:12.5px;color:var(--soft);white-space:nowrap}
.igroup .pfx{border-right:0;border-radius:var(--r) 0 0 var(--r)}
.igroup .sfx{border-left:0;border-radius:0 var(--r) var(--r) 0}
.igroup .input{border-radius:0}
.igroup .pfx + .input{border-radius:0 var(--r) var(--r) 0}
.igroup .input:has(+ .sfx),.igroup .input:first-child{border-radius:var(--r) 0 0 var(--r)}
/* saisie code PIN / 2FA */
.pin{display:flex;gap:8px}
.pin input{width:46px;height:54px;text-align:center;font-family:var(--disp);font-weight:600;font-size:24px;border:1.5px solid var(--line2);border-radius:var(--r);background:#fff;color:var(--ink);outline:none}
.pin input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(178,58,46,.12)}
/* curseur (range) */
.range{width:100%;accent-color:var(--red)}
/* menu déroulant (kebab / compte) */
.menu{display:inline-block;background:var(--card);border:1px solid var(--line2);border-radius:10px;padding:6px;min-width:210px;box-shadow:0 18px 44px -22px rgba(0,0,0,.42)}
.menu a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:6px;font-size:13.5px;color:var(--ink);text-decoration:none}
.menu a i{width:16px;text-align:center;color:var(--faint)}
.menu a:hover{background:var(--paper)}
.menu a.danger{color:var(--red)}.menu a.danger i{color:var(--red)}
.menu .sep{height:1px;background:var(--line);margin:6px 4px}
.menu .mh{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);padding:7px 11px 4px}
/* pagination */
.pager{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pager a,.pager span{min-width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line2);border-radius:var(--r);background:var(--card);font-size:13px;color:var(--ink);text-decoration:none;padding:0 9px}
.pager a:hover{border-color:var(--red);color:var(--red)}
.pager .on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.pager .dis{color:var(--faint);opacity:.55;pointer-events:none}
/* fil d'ariane */
.bcrumb{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);flex-wrap:wrap}
.bcrumb a{color:var(--soft);text-decoration:none}.bcrumb a:hover{color:var(--red)}
.bcrumb .sep{color:var(--faint)}
.bcrumb b{color:var(--ink);font-weight:600}
/* badges / pastilles d'état + compteur */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;border-radius:999px;padding:3px 9px;font-weight:500;vertical-align:middle}
.badge.pro{background:var(--ink);color:var(--paper)}
.badge.locked{background:#f4e3e0;color:var(--red)}
.badge.expired{background:#f0ead9;color:#8a6d1f}
.badge.public{background:#e4efe7;color:#3c7a4e}
.badge.private{background:var(--line);color:var(--soft)}
.badge.enc{background:var(--line);color:var(--ink)}
.count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;background:var(--red);color:#fff;border-radius:999px;font-family:var(--mono);font-size:10px;font-weight:600}
/* tooltip (CSS) */
.tip{position:relative;display:inline-flex;border-bottom:1px dotted var(--faint);cursor:help}
.tip:before{content:attr(data-tip);position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%);background:var(--ink);color:var(--paper);font-family:var(--body);font-size:12px;white-space:nowrap;padding:7px 10px;border-radius:6px;opacity:0;pointer-events:none;transition:.15s;z-index:5}
.tip:after{content:"";position:absolute;bottom:calc(100% + 3px);left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ink);opacity:0;transition:.15s}
.tip:hover:before,.tip:hover:after{opacity:1}
/* tableau de données (en-têtes triables) */
.dtable{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line2);border-radius:10px;overflow:hidden;font-size:13.5px}
.dtable th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:11px 15px;border-bottom:1px solid var(--line);font-weight:500;cursor:pointer;user-select:none}
.dtable th .ar{color:var(--red);margin-left:4px}
.dtable td{padding:12px 15px;border-bottom:1px solid var(--line)}
.dtable tbody tr:last-child td{border-bottom:0}
.dtable tbody tr:hover{background:var(--paper)}
/* loader + skeleton */
.spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
.skel{background:linear-gradient(90deg,var(--line) 25%,#efe7d6 37%,var(--line) 63%);background-size:400% 100%;animation:skel 1.4s ease infinite;border-radius:6px;height:14px}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}
/* champ copiable / lien de partage */
.copyf{display:flex;align-items:stretch;border:1px solid var(--line2);border-radius:var(--r);overflow:hidden;background:#fff;max-width:440px}
.copyf input{flex:1;border:0;outline:0;padding:11px 13px;font-family:var(--mono);font-size:12.5px;color:var(--ink);background:none;min-width:0}
.copyf button{border:0;border-left:1px solid var(--line2);background:var(--card);padding:0 15px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.copyf button:hover{background:var(--red);color:#fff;border-color:var(--red)}
/* commande a copier : label + code clair + bouton (ex. install CLI) */
.cmdlbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin:0 0 10px}
.cmdbar{display:flex;align-items:stretch;border:1px solid var(--line2);border-radius:var(--r);overflow:hidden;background:#F6F1E7;max-width:760px;margin:0 auto}
.cmdbar code{flex:1;min-width:0;font-family:var(--mono);font-size:12.5px;color:#5a5346;padding:12px 15px;white-space:nowrap;overflow-x:auto;align-self:center}
.cmdbar code .p{color:var(--red)}
.cmdbar .cbtn{flex:none;border:0;border-left:1px solid var(--line2);background:var(--card);padding:0 16px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:background .15s ease,color .15s ease}
.cmdbar .cbtn:hover{background:var(--red);color:#fff}
.cmdbar .cbtn.ok{background:var(--ok);color:#fff}
@media(max-width:560px){.cmdbar{flex-direction:column}.cmdbar .cbtn{border-left:0;border-top:1px solid var(--line2);padding:10px 16px;justify-content:center}}
/* tuile QR */
.qrtile{display:inline-flex;flex-direction:column;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line2);border-radius:12px;padding:18px}
.qrbox{width:120px;height:120px;background:#fff;border:1px solid var(--line);border-radius:6px;display:grid;place-items:center;color:var(--ink);font-size:64px}
.qrtile .cap{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}

@media(min-width:1500px){.mwrap{max-width:1340px}}

/* centered card content (icons + text), matching the centered page rhythm */
.feat,.uc{text-align:center}
.feat .ic{margin-left:auto;margin-right:auto}

/* feature-catalogue status badges */
.badge.live{background:#e4efe7;color:#3c7a4e}
.badge.soon{background:#f3ead4;color:#8a6d1f}
.badge.beta{background:var(--line);color:var(--soft)}
.feat .badge{margin-top:12px}
.cathead{max-width:640px;margin:0 auto 22px;text-align:center}
.cathead h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:22px;letter-spacing:.01em}
.cathead .kick{display:block;margin-bottom:4px}

/* ==========================================================================
   BOITE A OUTILS PDF : hero planche-contact, en-tetes de groupe, cartes
   ========================================================================== */
/* hero : planche-contact d'outils (remplace le tampon seul, trop vide) */
.toolsheet{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;width:286px;transform:rotate(-3deg)}
.toolsheet .tcell{aspect-ratio:1;border-radius:11px;background:#211E17;border:1px solid #2d2920;display:grid;place-items:center;color:#E08571;font-size:21px}
.heroviz .toolsheet + .stamp{right:8px;bottom:6px;background:#16140F}
/* grille d'outils : 3 colonnes alignees a gauche (pas de centrage ragged) */
.toolgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:stretch}
@media(max-width:920px){.toolgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.toolgrid{grid-template-columns:1fr}}
/* "comment ca marche" : bande sombre + frise 1 -> 2 -> 3.
   Volontairement distincte des cartes outils au-dessus ET de la FAQ "sans fond"
   en dessous : une seule bande continue (pas 3 cartes), fond sombre (pas blend-in). */
.flow{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--ink);border-radius:var(--r-lg);padding:40px 26px 34px}
.flow .fstep{position:relative;background:transparent;border:0;border-radius:0;padding:0 20px;text-align:center}
.flow .fn{position:relative;display:flex;flex-direction:column;align-items:center;gap:0;margin-bottom:15px}
.flow .fic{position:relative;z-index:1;width:56px;height:56px;border-radius:999px;background:var(--red);color:#fff;display:grid;place-items:center;font-size:20px}
.flow .fnum{position:absolute;z-index:2;top:-7px;left:calc(50% + 13px);width:23px;height:23px;border-radius:999px;background:var(--card);color:var(--ink);font-family:var(--mono);font-weight:600;font-size:12px;line-height:1;display:grid;place-items:center;box-shadow:0 2px 7px rgba(0,0,0,.35)}
.flow .fstep h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:17px;letter-spacing:.01em;color:#fff}
.flow .fstep p{color:rgba(255,255,255,.66);font-size:13.5px;line-height:1.5;margin-top:6px}
/* trait pointille reliant les noeuds (derriere les pastilles, masque par leur fond plein) */
.flow:before{content:"";position:absolute;top:68px;left:16.66%;right:16.66%;height:2px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.22) 0 6px,transparent 6px 12px);z-index:0}
.flow .farrow{display:none}
@media(max-width:780px){
  .flow{grid-template-columns:1fr;gap:24px;padding:32px 22px}
  .flow:before{display:none}
}
/* en-tete de groupe : titre + compteur + filet */
.toolgrp-h{display:flex;align-items:center;gap:14px;margin:34px 0 16px}
.toolgrp-h .gh{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:18px;color:var(--ink);white-space:nowrap}
.toolgrp-h .gh .num{font-family:var(--mono);font-size:11px;color:var(--faint);margin-left:9px;letter-spacing:.06em}
.toolgrp-h .gl{flex:1;height:1px;background:var(--line)}
/* cartes outil enrichies (relevement au survol, fleche, statut) */
.tool{position:relative;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}
.tool:hover{transform:translateY(-2px);box-shadow:0 16px 32px -22px rgba(26,26,26,.45)}
.tool .ic{transition:background .16s ease,color .16s ease}
.tool:hover .ic{background:var(--red);color:#fff}
.tool .go{position:absolute;top:16px;right:16px;color:var(--red);font-size:13px;opacity:0;transform:translateX(-5px);transition:.16s}
.tool:hover .go{opacity:1;transform:none}
.tool .st{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ok)}
.tool .st i{font-size:7px}
.tool .st.soon{color:var(--soft)}.tool .st.soon i{font-size:10px}
/* outil pas encore en ligne : ton sourd, pas d'effet de survol */
.tool.soon .ic{background:var(--line);color:var(--faint)}
.tool.soon .tt{color:var(--soft)}
.tool.soon:hover{transform:none;box-shadow:none;border-color:var(--line)}
.tool.soon:hover .ic{background:var(--line);color:var(--faint)}

/* ============================================================
   REPARER UN PDF (outil public interactif)
   ============================================================ */

/* visuel "reparation" : document + cle a molette + etincelles */
.repairviz{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center}
.repairviz .doc{font-size:104px;color:#E08571;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}
.repairviz .wrench{position:absolute;right:14px;bottom:14px;width:52px;height:52px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 18px -6px rgba(178,58,46,.7);transform-origin:50% 50%}
.repairviz .spark{position:absolute;width:7px;height:7px;border-radius:50%;background:#F2C57C;opacity:0}
.repairviz .s1{top:24px;right:30px}
.repairviz .s2{top:54px;right:6px}
.repairviz .s3{top:80px;right:44px}
/* variante compacte (etat traitement, sur fond clair) */
.repairviz.small{width:104px;height:104px;margin:0 auto 4px}
.repairviz.small .doc{font-size:66px;color:var(--red)}
.repairviz.small .wrench{width:38px;height:38px;font-size:16px;right:6px;bottom:6px}
/* animation pendant le traitement */
.repairviz.working .wrench{animation:rz-wiggle 1.1s ease-in-out infinite}
.repairviz.working .doc{animation:rz-pulse 1.6s ease-in-out infinite}
.repairviz.working .s1{animation:rz-twinkle 1.4s ease-in-out infinite}
.repairviz.working .s2{animation:rz-twinkle 1.4s ease-in-out .35s infinite}
.repairviz.working .s3{animation:rz-twinkle 1.4s ease-in-out .7s infinite}
@keyframes rz-wiggle{0%,100%{transform:rotate(-16deg)}50%{transform:rotate(18deg)}}
@keyframes rz-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
@keyframes rz-twinkle{0%,100%{opacity:0;transform:scale(.5)}50%{opacity:1;transform:scale(1)}}

/* widget */
.rtool{max-width:680px;margin:0 auto}
.rtool .rz{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;text-align:center}

/* etat depot */
.rz-drop{border:2px dashed var(--line2);border-radius:var(--r);padding:40px 22px;transition:border-color .15s ease,background .15s ease;cursor:pointer}
.rz-drop.over{border-color:var(--red);background:rgba(178,58,46,.04)}
.rz-drop .ic{font-size:40px;color:var(--red);margin-bottom:14px}
.rz-drop .t{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:21px;color:var(--ink);letter-spacing:.01em}
.rz-drop .d{color:var(--soft);font-size:13px;margin:10px 0}
.rz-drop .hint{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--faint);margin-top:14px;text-transform:uppercase}

/* etat envoi */
.rz-file{display:inline-flex;align-items:center;gap:10px;font-weight:600;color:var(--ink);max-width:100%;margin-bottom:16px}
.rz-file i{color:var(--red);font-size:20px;flex:none}
.rz-file span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rz-bar{height:8px;border-radius:999px;background:var(--paper);border:1px solid var(--line);overflow:hidden;max-width:420px;margin:0 auto}
.rz-bar span{display:block;width:0;height:100%;background:var(--red);border-radius:999px;transition:width .2s ease}
.rz-line{display:flex;justify-content:space-between;max-width:420px;margin:9px auto 18px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--soft)}

/* etat traitement / commun titres */
.rz-h{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:24px;color:var(--ink);margin-top:6px}
.rz-ext{color:var(--soft);font-size:14px;margin-top:7px;min-height:20px}
.rz-shimmer{height:8px;border-radius:999px;background:var(--paper);border:1px solid var(--line);overflow:hidden;max-width:420px;margin:18px auto 16px;position:relative}
.rz-shimmer span{position:absolute;top:0;bottom:0;width:40%;background:linear-gradient(90deg,transparent,var(--red),transparent);opacity:.7;animation:rz-slide 1.3s linear infinite}
@keyframes rz-slide{0%{left:-40%}100%{left:100%}}
.rz .hint{font-size:12.5px;color:var(--faint);margin-top:6px}

/* badge resultat (ok / erreur) */
.rz-badge{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 6px;animation:rz-pop .3s ease}
.rz-badge.ok{background:rgba(62,125,88,.12);color:var(--ok)}
.rz-badge.err{background:rgba(178,58,46,.1);color:var(--red)}
@keyframes rz-pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}

/* etat termine */
.rz-result{margin:14px auto 4px;display:flex;flex-direction:column;align-items:center;gap:3px}
.rz-result .fn{font-weight:600;color:var(--ink)}
.rz-result .fm{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.rz-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:20px}
.rz-cta{display:flex;align-items:flex-start;gap:12px;text-align:left;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);color:var(--soft);font-size:13.5px;line-height:1.5}
.rz-cta i{color:var(--red);font-size:18px;margin-top:2px;flex:none}
.rz-cta b{color:var(--ink)}
.rz-cta a{display:inline-block;margin-top:4px;color:var(--red);font-weight:600}

.btn--sm{padding:8px 13px;font-size:13px}
.rz-foot{text-align:center;color:var(--faint);font-size:12.5px;margin:16px auto 0;max-width:560px}
.rz-foot a{color:var(--soft);text-decoration:underline}

/* bloc "ce que repare l'outil" */
.rz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rz-grid .card h3{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:16px;margin-top:4px}
.rz-grid .card p{color:var(--soft);font-size:13.5px;line-height:1.5;margin-top:5px}
.rz-ci{width:42px;height:42px;border-radius:8px;background:rgba(178,58,46,.08);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
@media(max-width:780px){.rz-grid{grid-template-columns:1fr}}

/* animation d'attente discrete sur le visuel "reparation" du hero (etat non working) */
.heroviz .repairviz .wrench{animation:rz-wiggle-soft 3.2s ease-in-out infinite}
.heroviz .repairviz .spark{animation:rz-twinkle 2.6s ease-in-out infinite}
.heroviz .repairviz .s2{animation-delay:.6s}
.heroviz .repairviz .s3{animation-delay:1.3s}
@keyframes rz-wiggle-soft{0%,100%{transform:rotate(-9deg)}50%{transform:rotate(9deg)}}

/* ===== Outil "empreintes MD5 / SHA-512" (widget partage pubtool, mode sync) ===== */
/* visuel empreinte (etat "work" et hero) */
.hashviz{width:104px;height:104px;margin:0 auto 4px;display:flex;align-items:center;justify-content:center;color:var(--red);font-size:62px}
.hashviz.hero{width:160px;height:160px;font-size:120px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}
.hashviz.working i{animation:rz-pulse 1.4s ease-in-out infinite}
.heroviz .hashviz i{animation:rz-pulse 3.4s ease-in-out infinite}

/* outil Fusionner : liste de fichiers multiples (ajout / reordre / retrait) */
.mg-list{margin:16px 0 0;display:flex;flex-direction:column;gap:8px;text-align:left}
.mg-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r);background:var(--card)}
.mg-item .mg-ix{flex:none;width:22px;height:22px;border-radius:999px;background:var(--ink);color:#fff;font-family:var(--mono);font-size:11px;display:grid;place-items:center}
.mg-item .mg-nm{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;color:var(--ink)}
.mg-item .mg-sz{flex:none;font-size:12px;color:var(--soft);font-family:var(--mono)}
.mg-item .mg-act{flex:none;display:flex;gap:4px}
.mg-item .mg-act button{width:30px;height:30px;border:1px solid var(--line2);border-radius:8px;background:var(--paper);color:var(--soft);cursor:pointer;display:grid;place-items:center;font-size:13px}
.mg-item .mg-act button:hover:not(:disabled){border-color:var(--red);color:var(--red)}
.mg-item .mg-act button:disabled{opacity:.35;cursor:default}
.mg-go{margin-top:16px}
.mg-hint{margin-top:10px;font-size:12.5px;color:var(--soft)}

/* outil Editer les metadonnees : grille du formulaire d'edition */
.rz-meta{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;text-align:left;margin:16px 0 4px}
@media(max-width:560px){.rz-meta{grid-template-columns:1fr}}

/* champ optionnel "verifier une empreinte attendue" dans l'etat idle */
.rz-form{margin-top:16px}
.hexp{display:block;text-align:left;max-width:520px;margin:0 auto}
.hexp>span{display:block;font-size:12.5px;color:var(--soft);margin-bottom:6px}
.hexp>span i{color:var(--red);margin-right:4px}
.hexp input{width:100%;box-sizing:border-box;padding:11px 13px;border:1px solid var(--line2);border-radius:var(--r);background:var(--paper);color:var(--ink);font-family:var(--mono);font-size:12.5px}
.hexp input:focus{outline:none;border-color:var(--red)}

/* resultat : empreintes calculees */
.hres{width:100%;text-align:left;margin-top:8px}
.hfile{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);font-size:14px;margin-bottom:12px}
.hfile i{color:var(--red);flex:none}
.hfile .hfn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hfile .hsize{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);flex:none;margin-left:auto}
.hashrow{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.hashrow .hl{font-family:var(--disp);text-transform:uppercase;font-weight:700;font-size:12px;letter-spacing:.04em;color:var(--soft);width:64px;flex:none}
.hashrow .hv{flex:1;min-width:0;font-family:var(--mono);font-size:12.5px;color:var(--ink);word-break:break-all;line-height:1.45}
.hcopy{flex:none;align-self:flex-start;border:1px solid var(--line2);background:var(--paper);color:var(--soft);border-radius:var(--r);padding:6px 10px;font-size:11.5px;cursor:pointer;white-space:nowrap;transition:border-color .15s ease,color .15s ease}
.hcopy:hover{border-color:var(--red);color:var(--red)}
.hcopy.ok{border-color:var(--ok);color:var(--ok)}

/* verdict de comparaison d'empreinte */
.hverdict{display:flex;align-items:flex-start;gap:8px;border-radius:var(--r);padding:11px 13px;font-size:13.5px;line-height:1.45;margin-bottom:14px}
.hverdict i{margin-top:2px;flex:none}
.hverdict.ok{background:rgba(62,125,88,.1);color:var(--ok)}
.hverdict.err{background:rgba(178,58,46,.1);color:var(--red)}
.hverdict.warn{background:rgba(178,58,46,.06);color:var(--soft)}
@media(max-width:560px){.hashrow{flex-wrap:wrap;gap:6px}.hashrow .hl{width:auto}.hcopy{margin-left:auto}}

/* ===== Outils PDF/A (convertir / verifier) ===== */
.pdfaviz{position:relative;width:104px;height:104px;margin:0 auto 4px;display:flex;align-items:center;justify-content:center;color:var(--red);font-size:62px}
.pdfaviz.hero{width:160px;height:160px;font-size:118px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.35))}
.pdfaviz .tag{position:absolute;right:2px;bottom:18px;background:var(--red);color:#fff;font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.06em;padding:3px 8px;border-radius:6px;box-shadow:0 8px 18px -6px rgba(178,58,46,.7)}
.heroviz .pdfaviz i{animation:rz-pulse 3.4s ease-in-out infinite}
/* selecteur de niveau (formulaire de conversion) */
.pdfa-lvl{display:block;text-align:left;max-width:520px;margin:0 auto}
.pdfa-lvl>span{display:block;font-size:12.5px;color:var(--soft);margin-bottom:6px}
.pdfa-lvl>span i{color:var(--red);margin-right:4px}
.pdfa-lvl select{width:100%;box-sizing:border-box;padding:11px 13px;border:1px solid var(--line2);border-radius:var(--r);background:var(--paper);color:var(--ink);font-size:13.5px;cursor:pointer}
.pdfa-lvl select:focus{outline:none;border-color:var(--red)}
/* resultat : verdict de conformite */
.pdfa-res{width:100%;text-align:left;margin-top:8px}
.pdfa-file{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);font-size:14px;margin-bottom:12px}
.pdfa-file i{color:var(--red);flex:none}
.pdfa-file .pdfa-fn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pdfa-rules{list-style:none;margin:0 0 14px;padding:0;border-top:1px solid var(--line)}
.pdfa-rules li{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);font-size:12.5px;line-height:1.45;color:var(--soft)}
.pdfa-rules .pr-d{flex:1;min-width:0}
.pdfa-rules .pr-c{flex:none;font-family:var(--mono);font-size:11px;color:var(--faint)}
.pdfa-next{font-size:13px;color:var(--soft)}
.pdfa-next a{color:var(--red);text-decoration:underline}

/* classes utilitaires (remplacent des styles inline, cf. regle no-inline-styles) */
.hero p b{color:#EDE6D6}
.hero .trust--hero{border:0;padding:0;justify-content:flex-start}
.hero .trust--hero .t{color:#b9b1a2}
.sec.sec--tool{padding-bottom:26px}
.sec.flush-top{padding-top:0}
.acc.narrow{max-width:760px}

/* ===== Utility layer (generated 2026-06-13, atomic declarations extracted from inline styles) ===== */
.ai-c{align-items:center}
.c-faint{color:var(--faint)}
.c-ink{color:var(--ink)}
.c-red{color:var(--red)}
.c-soft{color:var(--soft)}
.c-white{color:#fff}
.d-block{display:block}
.d-flex{display:flex}
.d-ib{display:inline-block}
.ff-disp{font-family:var(--disp)}
.ff-mono{font-family:var(--mono)}
.fl-1{flex:1}
.fs-10{font-size:10px}
.fs-11{font-size:11px}
.fs-12{font-size:12px}
.fs-13{font-size:13px}
.fs-14{font-size:14px}
.fs-15{font-size:15px}
.fs-16{font-size:16px}
.fs-17{font-size:17px}
.fs-18{font-size:18px}
.fs-22{font-size:22px}
.fs-34{font-size:34px}
.fs-38{font-size:38px}
.fs-44{font-size:44px}
.fs-6{font-size:6px}
.fs-9{font-size:9px}
.fw-6{font-weight:600}
.fw-7{font-weight:700}
.fw-wrap{flex-wrap:wrap}
.gap-8{gap:8px}
.gap-14{gap:14px}
.gap-18{gap:18px}
.gap-20{gap:20px}
.jc-c{justify-content:center}
.lh-1{line-height:1}
.m-0{margin:0}
.maxw-520{max-width:520px}
.maxw-680{max-width:680px}
.maxw-740{max-width:740px}
.maxw-760{max-width:760px}
.maxw-800{max-width:800px}
.maxw-880{max-width:880px}
.maxw-940{max-width:940px}
.mb-10{margin-bottom:10px}
.mb-12{margin-bottom:12px}
.mb-14{margin-bottom:14px}
.mb-22{margin-bottom:22px}
.mb-24{margin-bottom:24px}
.mb-26{margin-bottom:26px}
.mb-30{margin-bottom:30px}
.mb-4{margin-bottom:4px}
.ml-6{margin-left:6px}
.mr-10{margin-right:10px}
.mr-9{margin-right:9px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mt-14{margin-top:14px}
.mt-18{margin-top:18px}
.mt-22{margin-top:22px}
.mt-24{margin-top:24px}
.mt-3{margin-top:3px}
.mt-30{margin-top:30px}
.mt-40{margin-top:40px}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.pt-0{padding-top:0}
.s-align-items-start{align-items:start}
.s-align-self-flex-start{align-self:flex-start}
.s-background-var-line{background:var(--line)}
.s-background-var-red{background:var(--red)}
.s-border-1-5px-solid-var-red{border:1.5px solid var(--red)}
.s-border-1px-solid-var-line{border:1px solid var(--line)}
.s-border-left-3px-solid-3c7a4e{border-left:3px solid #3c7a4e}
.s-border-left-3px-solid-var-red{border-left:3px solid var(--red)}
.s-border-radius-10px{border-radius:10px}
.s-border-radius-4px{border-radius:4px}
.s-border-top-1px-solid-var-line{border-top:1px solid var(--line)}
.s-break-inside-avoid{break-inside:avoid}
.s-color-3c7a4e{color:#3c7a4e}
.s-color-6-6{color:#EDE6D6}
.s-color-b9b1a2{color:#b9b1a2}
.s-color-inherit{color:inherit}
.s-column-gap-40px{column-gap:40px}
.s-columns-2{columns:2}
@media (max-width:780px){.s-columns-2{columns:1}}
.s-direction-ltr{direction:ltr}
.s-font-size-10-5px{font-size:10.5px}
.s-font-size-12-5px{font-size:12.5px}
.s-font-size-13-5px{font-size:13.5px}
.s-font-size-14-5px{font-size:14.5px}
.s-grid-template-columns-1fr{grid-template-columns:1fr}
.s-height-130px{height:130px}
.s-height-60px{height:60px}
.s-letter-spacing-01em{letter-spacing:.01em}
.s-letter-spacing-04em{letter-spacing:.04em}
.s-letter-spacing-06em{letter-spacing:.06em}
.s-letter-spacing-08em{letter-spacing:.08em}
.s-letter-spacing-1em{letter-spacing:.1em}
.s-letter-spacing-22em{letter-spacing:.22em}
.s-line-height-1-02{line-height:1.02}
.s-line-height-1-08{line-height:1.08}
.s-line-height-1-5{line-height:1.5}
.s-line-height-1-55{line-height:1.55}
.s-line-height-1-6{line-height:1.6}
.s-line-height-1-85{line-height:1.85}
.s-line-height-2{line-height:2}
.s-list-style-none{list-style:none}
.s-margin-0-0-8px{margin:0 0 8px}
.s-margin-0-auto{margin:0 auto}
.s-margin-0-auto-26px{margin:0 auto 26px}
.s-margin-14px-0-10px{margin:14px 0 10px}
.s-margin-16px-0-6px{margin:16px 0 6px}
.s-margin-18px-0{margin:18px 0}
.s-margin-22px-0{margin:22px 0}
.s-margin-8px-0-12px{margin:8px 0 12px}
.s-margin-left-auto{margin-left:auto}
.s-margin-top-0{margin-top:0}
.s-max-width-none{max-width:none}
.s-min-width-220px{min-width:220px}
.s-padding-13px-18px{padding:13px 18px}
.s-padding-22px-0{padding:22px 0}
.s-padding-2px-7px{padding:2px 7px}
.s-padding-6px-0{padding:6px 0}
.s-padding-8px-0{padding:8px 0}
.s-padding-bottom-18px{padding-bottom:18px}
.s-padding-bottom-20px{padding-bottom:20px}
.s-padding-bottom-24px{padding-bottom:24px}
.s-padding-bottom-80px{padding-bottom:80px}
.s-padding-top-80px{padding-top:80px}
.s-padding-top-8px{padding-top:8px}
.s-position-static{position:static}
.s-transform-rotate-8deg{transform:rotate(-8deg)}
.s-vertical-align-2px{vertical-align:-2px}
.s-vertical-align-middle{vertical-align:middle}
.s-width-0{width:0%}
.s-width-130px{width:130px}
.s-width-22px{width:22px}
.s-width-60px{width:60px}
.ta-c{text-align:center}
.td-none{text-decoration:none}
.tt-up{text-transform:uppercase}
.w-100{width:100%}
.nowrap{white-space:nowrap}

/* ==========================================================================
   HERITAGE TEXTURE DEVICE (guilloche / papier de securite) + FEATURE MOCKUPS
   One engraved-line device used as brand equity (finding #2). It backs the
   document mockups that replace the empty feature panels (finding #1). Keep it
   to this single device to preserve palette discipline.
   ========================================================================== */
.guilloche{background:linear-gradient(158deg,#fffdf9 0%,#f2ead8 100%)}
.guilloche:before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;opacity:.6;
  background-image:
    repeating-radial-gradient(circle at 24% 20%, transparent 0 7px, rgba(26,26,26,.05) 7px 8px),
    repeating-radial-gradient(circle at 84% 86%, transparent 0 9px, rgba(178,58,46,.05) 9px 10px),
    repeating-linear-gradient(90deg, rgba(26,26,26,.026) 0 1px, transparent 1px 6px)}
/* engraved double filet : section separator in the same line-language */
.engr{height:1px;border:none;background:var(--line2);position:relative;margin:0}
.engr:after{content:"";position:absolute;left:0;right:0;top:2px;height:1px;background:var(--line)}

/* feature-row mockups (fonctionnalites) : real compositions, not a lone icon */
.fviz{width:100%;max-width:330px;display:flex;flex-direction:column;align-items:center}
/* shared mini-document card */
.mdoc{width:100%;background:linear-gradient(158deg,#fff 0%,#fbf6ec 100%);border:1px solid var(--line);border-radius:8px;padding:16px;box-shadow:0 22px 40px -26px rgba(0,0,0,.5);display:flex;flex-direction:column;gap:12px}
.mdoc-hd{display:flex;align-items:center;gap:11px;padding-bottom:11px;border-bottom:1px solid var(--line)}
.mdoc-ic{flex:none;width:34px;height:34px;border-radius:8px;background:rgba(178,58,46,.1);color:var(--red);display:flex;align-items:center;justify-content:center;font-size:15px}
.mdoc-hl{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.mdoc-hl b{display:block;height:9px;width:62%;background:#16140F;opacity:.82;border-radius:3px}
.mdoc-hl i{display:block;height:7px;width:40%;background:#d7cdb7;border-radius:3px}
.mdoc-bd{display:flex;flex-direction:column;gap:8px}
.mdoc-bd .ln{height:7px;background:#ece3d2;border-radius:3px}
.mdoc-bd .ln.m{width:84%}.mdoc-bd .ln.s{width:54%}
.mdoc-ft{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:11px;border-top:1px solid var(--line);font-family:var(--mono);font-size:9.5px;letter-spacing:.03em;color:var(--soft)}
.mdoc-ft .sha{color:var(--red)}
/* seal reuse (brand equity) inside mockups */
.fviz .stamp{width:84px;height:84px;background:var(--card)}
.fv-doc{position:relative}
.fv-doc .stamp{position:absolute;right:-4px;bottom:-12px;transform:rotate(-12deg)}
/* fv-lib : search bar + folder grid */
.msearch{display:flex;align-items:center;gap:9px;width:100%;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-family:var(--mono);font-size:11px;color:var(--faint);box-shadow:0 14px 28px -22px rgba(0,0,0,.4)}
.msearch i{color:var(--red)}
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;margin-top:10px}
.mtile{display:flex;flex-direction:column;align-items:flex-start;gap:8px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 10px}
.mtile i{color:var(--red);font-size:15px}
.mtile b{display:block;height:6px;width:72%;background:#d7cdb7;border-radius:3px}
.mtile.on{border-color:var(--red);box-shadow:inset 0 0 0 1px var(--red)}
/* fv-modal : share modal */
.mmod{width:100%;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 26px 46px -28px rgba(0,0,0,.5);overflow:hidden}
.mmod-hd{display:flex;align-items:center;gap:9px;padding:12px 14px;border-bottom:1px solid var(--line);font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:14px}
.mmod-hd i{color:var(--red)}.mmod-hd .x{margin-left:auto;color:var(--faint);font-family:var(--body)}
.mmod-bd{padding:14px;display:flex;flex-direction:column;gap:11px}
.mfield{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:7px;padding:6px 6px 6px 11px;background:#fbf6ec}
.mfield .lk{font-family:var(--mono);font-size:11px;color:var(--soft);flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.mfield b{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;background:var(--red);color:#fff;border-radius:5px;padding:6px 10px}
.mtog{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--soft)}
.mtog .lab i{color:var(--red);margin-right:7px}
.sw{width:30px;height:17px;border-radius:999px;background:var(--line2);position:relative;flex:none}
.sw:after{content:"";position:absolute;top:2px;left:2px;width:13px;height:13px;border-radius:50%;background:#fff}
.sw.on{background:var(--red)}.sw.on:after{left:15px}
/* fv-shield : emblem + chips */
.memblem{width:80px;height:80px;border-radius:18px;background:#16140F;color:#E08571;display:flex;align-items:center;justify-content:center;font-size:34px;box-shadow:0 20px 38px -22px rgba(0,0,0,.6)}
.mchips{display:flex;flex-direction:column;gap:8px;margin-top:16px;width:100%}
.mchips>span{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--ink)}
.mchips>span>i{color:var(--red);width:18px;text-align:center;flex:none}
.mchips .flag{box-shadow:0 0 0 1px var(--line);transform:scale(.85)}
/* fv-pdfa : doc + green conformance badge */
.mvalid{display:inline-flex;align-items:center;gap:8px;background:#e8f1ea;border:1px solid #bcd6c5;color:var(--ok);border-radius:999px;padding:8px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.03em;margin-top:-13px;box-shadow:0 14px 26px -20px rgba(0,0,0,.4)}
.fv-pdfa .cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:10px}
/* fv-sign : doc + cachet de signature pose au glisser-deposer */
.fv-sign{position:relative}
.fv-sign .msign{position:absolute;right:6px;bottom:18px;display:inline-flex;align-items:center;gap:10px;background:var(--card);border:1.5px dashed var(--red);border-radius:8px;padding:9px 13px;transform:rotate(-4deg);box-shadow:0 16px 30px -20px rgba(0,0,0,.5)}
.fv-sign .msign>i{color:var(--red);font-size:21px}
.fv-sign .ms-tx{display:flex;flex-direction:column;line-height:1.2}
.fv-sign .ms-tx b{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:13px;letter-spacing:.04em;color:var(--ink)}
.fv-sign .ms-tx em{font-family:var(--mono);font-style:normal;font-size:9px;letter-spacing:.04em;color:var(--soft);margin-top:2px}
/* fv-cap : browser -> dated versions */
.mbrowser{width:100%;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:0 16px 30px -24px rgba(0,0,0,.4)}
.mbrowser .br-bar{display:flex;align-items:center;gap:7px;padding:9px 11px;border-bottom:1px solid var(--line)}
.mbrowser .br-bar em{width:8px;height:8px;border-radius:50%;background:#e0d6c2;display:inline-block}
.mbrowser .br-bar em:first-child{background:#B23A2E}
.mbrowser .br-url{margin-left:6px;font-family:var(--mono);font-size:10px;color:var(--soft)}
.mcaparrow{color:var(--red);font-size:15px;margin:9px 0}
.mversions{width:100%;display:flex;flex-direction:column;gap:6px}
.mver{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:7px;padding:8px 11px;font-family:var(--mono);font-size:10.5px;color:var(--soft)}
.mver i{color:var(--red)}.mver .d{margin-left:auto;color:var(--faint)}
/* fv-tools : reuse .toolsheet planche-contact, slightly smaller */
.fv-tools .toolsheet{width:252px}
.fv-tools .toolsheet .tcell{font-size:18px}
/* fv-term : reuse .term, compact */
.fv-term{max-width:360px}
.fv-term .term{width:100%;font-size:11px;line-height:1.7}
.fv-term .term .body{padding:13px 14px}
/* cas d'usage : chips sous un mockup (rappel des fonctions mobilisees) */
.ucchips{display:flex;flex-wrap:wrap;justify-content:center;gap:7px;margin-top:14px;width:100%}
.ucchips.one{margin-top:16px}
.ucchips span{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-family:var(--mono);font-size:10px;letter-spacing:.02em;color:var(--ink)}
.ucchips span i{color:var(--red)}
/* fv-folders : classement par appartement / par locataire (proprietaires) */
.fv-folders{max-width:330px}
.ucfold{display:flex;flex-direction:column;gap:8px;width:100%}
.ucf{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 13px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--ink);box-shadow:0 14px 28px -24px rgba(0,0,0,.4)}
.ucf i{color:var(--red);font-size:15px;flex:none}
.ucf b{font-weight:600}
.ucf em{display:block;font-style:normal;font-weight:400;font-size:9px;letter-spacing:.04em;color:var(--soft);margin-top:3px}

/* =========================================================================
   COUCHE MOTION + POLISH (2026-06-13) : micro-interactions transverses www2.
   Parite avec compte2. Desactivee si prefers-reduced-motion.
   ========================================================================= */
.btn{transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .18s ease,transform .08s ease}
.btn:active{transform:translateY(1px)}
.btn--primary:hover{box-shadow:0 8px 20px -8px rgba(178,58,46,.55)}
.btn--ghost:hover{background:#fff}
.tool{transition:border-color .16s ease,box-shadow .22s ease,transform .18s ease}
.tool:hover{box-shadow:0 12px 28px -20px rgba(26,20,10,.45);transform:translateY(-2px)}
.tool:active{transform:translateY(0);box-shadow:none}
.tool .ic{transition:transform .18s ease}
.tool:hover .ic{transform:scale(1.06)}
a.card{transition:border-color .16s ease,box-shadow .22s ease,transform .18s ease}
a.card:hover{border-color:var(--line2);box-shadow:0 12px 28px -20px rgba(26,20,10,.45);transform:translateY(-2px)}
.input,textarea.input,.select select{transition:border-color .15s ease,box-shadow .15s ease}
.acc summary{transition:color .14s ease}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}

/* Recherche dans l'aide (/aide/) : barre proeminente + filtre client-side */
.faqsearch{position:relative;max-width:560px;margin:0 0 22px}
.faqsearch i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--soft);font-size:15px;pointer-events:none}
.faqsearch input{width:100%;box-sizing:border-box;padding:15px 16px 15px 44px;font-size:16px;font-family:inherit;color:var(--ink);background:var(--card);border:1px solid var(--line2);border-radius:10px;outline:none}
.faqsearch input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(178,58,46,.12)}
.faqsearch input::placeholder{color:var(--faint)}
.faqgrp.is-hidden,.acc details.is-hidden{display:none}
#faqnores{display:none;color:var(--soft);padding:6px 0 18px}
#faqnores.is-on{display:block}
/* hub d'aide : titre de rubrique cliquable + lien "voir toutes les questions" */
.faqcat{display:inline-block;font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:18px;margin:28px 0 12px;color:var(--ink);text-decoration:none;transition:color .15s ease}
.faqcat:hover{color:var(--red)}
.faqmore{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--red);text-decoration:none;margin:2px 0 30px}
.faqmore:hover{gap:11px}
.faqmore i{font-size:10px}
.faq-extra{display:none}
.faqgrp mark{background:rgba(178,58,46,.17);color:var(--ink);border-radius:3px;padding:.02em .14em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.faqgrp.searching .faq-extra:not(.is-hidden){display:block}
.faqgrp.searching .faqmore{display:none}
