@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=IBM+Plex+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--bg:#F7F3EC;--surface:#FFFFFF;--surface-2:#FBF8F2;--border:#E0D8CB;--border-strong:#C5BAA8;--text:#1A1612;--text-muted:#6F665C;--notaire:#1E3A5F;--notaire-bg:#EDF1F7;--dgi:#1F4D3A;--dgi-bg:#ECF3EE;--cadastre:#5A4A2E;--cadastre-bg:#F2EDE0;--ia:#5B3F8C;--ia-bg:#F0EBF7;--public:#4A4540;--ministry:#0D2E4F;--ministry-bg:#E6ECF2;--alert:#8B2635;--alert-bg:#F8E8E8;--warn:#B8893E;--warn-bg:#FAF5EB;--accent:#B8893E;--institution-accent:#B8893E;--hero:#C04A20;--hero-bg:#FCEFE8;--font-display:'Fraunces',Georgia,serif;--font-body:'IBM Plex Sans',system-ui,sans-serif;--font-mono:'JetBrains Mono',ui-monospace,monospace}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;font-size:15px;line-height:1.5}
.app{min-height:100vh;display:flex;flex-direction:column;max-width:1240px;margin:0 auto;background:var(--surface);border-left:1px solid var(--border);border-right:1px solid var(--border);position:relative}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 32px;border-bottom:1px solid var(--border);background:var(--surface);border-top:3px solid var(--institution-accent);transition:border-color .4s}
.brand{display:flex;flex-direction:column;gap:2px}
.brand-institution{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--text);line-height:1.1}
.brand-ministry{font-size:12px;color:var(--text-muted);letter-spacing:.02em;font-weight:500}
.topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lang-toggle{display:flex;border:1px solid var(--border);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em}
.lang-toggle button{background:transparent;border:none;padding:6px 10px;cursor:pointer;color:var(--text-muted);font-family:inherit;font-size:inherit;transition:all .15s}
.lang-toggle button.on{background:var(--text);color:var(--surface)}
.custom-btn{font-size:12px;color:var(--text-muted);background:transparent;border:1px solid var(--border);padding:7px 12px;cursor:pointer;font-family:var(--font-body);transition:all .15s}
.custom-btn:hover{border-color:var(--text);color:var(--text)}
.custom-active{background:var(--text);color:var(--surface);border-color:var(--text)}
.demo-warning{font-size:10px;background:var(--surface-2);border:1px solid var(--border);padding:4px 10px;color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em}
.watermark{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-22deg);font-family:var(--font-display);font-size:56px;color:rgba(184,137,62,.08);pointer-events:none;z-index:1;font-weight:500;letter-spacing:.05em;white-space:nowrap;text-align:center;line-height:1.4}
body.custom-mode .watermark{display:block}
body.custom-mode .topbar{border-top-color:#F77F00}
body.custom-mode{--institution-accent:#F77F00}
.confidential-banner{display:none;padding:10px 32px;background:var(--warn-bg);border-bottom:1px solid var(--warn);font-size:12px;color:#5C4A24;text-align:center}
body.custom-mode .confidential-banner{display:block}
.progress{display:flex;gap:3px;padding:12px 32px;background:var(--surface-2);border-bottom:1px solid var(--border)}
.progress-segment{flex:1;height:3px;background:var(--border);transition:background .3s;position:relative}
.progress-segment.done{background:var(--accent)}
.progress-segment.active{background:var(--text)}
.progress-segment.hero::after{content:'';position:absolute;left:50%;top:-3px;transform:translateX(-50%);width:9px;height:9px;background:var(--hero);border:2px solid var(--surface-2)}
.bandeau{padding:14px 32px;display:flex;align-items:center;gap:16px;font-size:13px;font-weight:500;color:white}
.bandeau-label{text-transform:uppercase;font-size:11px;letter-spacing:.1em;opacity:.7}
.bandeau-persona{font-family:var(--font-display);font-size:18px;font-weight:500}
.bandeau.notaire{background:var(--notaire)}
.bandeau.dgi{background:var(--dgi)}
.bandeau.cadastre{background:var(--cadastre)}
.bandeau.ia{background:var(--ia)}
.bandeau.public{background:var(--public)}
.bandeau.ministry{background:var(--ministry)}
.bandeau.hero{background:linear-gradient(90deg,var(--cadastre) 0%,var(--hero) 100%)}
.bandeau.hero-alert{background:linear-gradient(90deg,var(--notaire) 0%,var(--alert) 100%)}
.bandeau-hero-tag{margin-left:auto;background:rgba(255,255,255,.18);padding:3px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:700;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
.stage{flex:1;padding:40px 48px;background:var(--surface)}
.stage-title{font-family:var(--font-display);font-size:32px;font-weight:500;letter-spacing:-.02em;margin-bottom:8px;line-height:1.15}
.stage-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:15px}
.card{background:var(--surface);border:1px solid var(--border);padding:24px;margin-bottom:16px}
.card-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.card-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:600;margin-bottom:12px}
.card-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:14px;gap:16px}
.card-row:last-child{border-bottom:none}
.card-row-label{color:var(--text-muted)}
.card-row-value{font-weight:500;text-align:right}
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.pill::before{content:'';width:6px;height:6px;border-radius:50%}
.pill.active{background:rgba(31,77,58,.1);color:var(--dgi)}.pill.active::before{background:var(--dgi)}
.pill.suspended{background:var(--warn-bg);color:#8B6914}.pill.suspended::before{background:var(--warn)}
.pill.due{background:var(--alert-bg);color:var(--alert)}.pill.due::before{background:var(--alert)}
.pill.hero{background:var(--hero-bg);color:var(--hero)}.pill.hero::before{background:var(--hero)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}
.field{background:var(--surface-2);border:1px solid var(--border);padding:12px 14px}
.field-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.field-value{font-size:16px;color:var(--text);font-weight:500}
.tax-card{background:var(--surface-2);border:1px dashed var(--border-strong);padding:16px;position:relative}
.tax-card::before{content:attr(data-tag);position:absolute;top:10px;right:12px;font-size:9px;font-family:var(--font-mono);color:var(--accent);letter-spacing:.1em}
.tax-card-title{font-size:12px;color:var(--text-muted);font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}
.tax-card-formula{font-family:var(--font-mono);font-size:13px;color:var(--text-muted);margin-bottom:8px}
.tax-card-amount{font-family:var(--font-display);font-size:22px;font-weight:500}
.verif-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(31,77,58,.08);border-left:4px solid var(--dgi);margin-bottom:24px;font-size:13px;color:var(--dgi)}
.auth-notice{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:var(--warn-bg);border-left:4px solid var(--accent);margin-bottom:24px;font-size:13px;color:#5C4A24}
.auth-notice strong{color:var(--text)}
.ia-recommendation-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--ia-bg);border-left:4px solid var(--ia);margin-bottom:24px}
.ia-rec-icon{width:32px;height:32px;background:var(--ia);color:white;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:600;font-size:14px;flex-shrink:0}
.ia-rec-title{font-size:13px;color:var(--ia);font-weight:600;margin-bottom:2px}
.ia-rec-detail{font-size:12px;color:var(--text-muted)}
.actions{display:flex;justify-content:space-between;align-items:center;padding:20px 48px;border-top:1px solid var(--border);background:var(--surface-2)}
.btn{font-family:var(--font-body);font-size:14px;font-weight:500;padding:12px 24px;border:1px solid var(--text);background:var(--text);color:var(--surface);cursor:pointer;letter-spacing:.01em;transition:all .15s;margin-left:8px}
.btn:hover{background:transparent;color:var(--text)}
.btn-secondary{background:transparent;color:var(--text)}
.btn-secondary:hover{background:var(--text);color:var(--surface)}
.btn-action{background:var(--dgi);border-color:var(--dgi)}.btn-action:hover{background:transparent;color:var(--dgi)}
.btn-ia{background:var(--ia);border-color:var(--ia)}.btn-ia:hover{background:transparent;color:var(--ia)}
.btn-cadastre{background:var(--cadastre);border-color:var(--cadastre)}.btn-cadastre:hover{background:transparent;color:var(--cadastre)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.scene-counter{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);letter-spacing:.05em}
.hash-display{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--surface-2);border:1px solid var(--border);font-family:var(--font-mono);font-size:12px;margin-top:16px;flex-wrap:wrap}
.hash-display-label{color:var(--text-muted);text-transform:uppercase;font-size:10px;letter-spacing:.1em}
.hash-display-value{color:var(--text);flex:1;min-width:0}
.hash-display a{color:var(--accent);text-decoration:none;font-size:11px;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.refus-alert{background:var(--alert-bg);border:2px solid var(--alert);padding:40px;margin:24px 0}
.refus-alert-icon{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--alert);letter-spacing:.2em;margin-bottom:12px}
.refus-alert-title{font-family:var(--font-display);font-size:32px;color:var(--alert);font-weight:500;margin-bottom:16px;line-height:1.1}
.refus-alert-body{font-size:15px;color:var(--text);margin-bottom:16px}
.refus-alert-detail{background:var(--surface);border:1px solid var(--border);padding:16px;margin-top:16px}
.hero-alert{background:var(--hero-bg);border:2px solid var(--hero);padding:32px;margin:24px 0}
.hero-alert-icon{font-family:var(--font-display);font-size:13px;font-weight:600;color:var(--hero);letter-spacing:.2em;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.hero-alert-icon::before{content:'';width:10px;height:10px;background:var(--hero);border-radius:50%;animation:pulse 1.5s infinite}
.hero-alert-title{font-family:var(--font-display);font-size:28px;color:var(--hero);font-weight:500;margin-bottom:16px;line-height:1.15}
.hero-alert-body{font-size:14px;color:var(--text);margin-bottom:12px;line-height:1.6}
.sat-compare{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
@media (max-width:768px){.sat-compare{grid-template-columns:1fr}}
.sat-pane{background:var(--surface-2);border:1px solid var(--border);padding:14px}
.sat-pane-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid}
.sat-pane.before .sat-pane-label{color:var(--text-muted);border-color:var(--border-strong)}
.sat-pane.after .sat-pane-label{color:var(--hero);border-color:var(--hero)}
.sat-svg{width:100%;display:block;background:var(--bg);border:1px solid var(--border);margin-bottom:8px}
.sat-meta{font-size:11px;color:var(--text-muted);line-height:1.5}
.sat-meta strong{color:var(--text)}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}}
.metric{padding:20px;background:var(--surface-2);border:1px solid var(--border)}
.metric-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:8px}
.metric-value{font-family:var(--font-display);font-size:32px;font-weight:500;line-height:1}
.metric-sub{font-size:12px;color:var(--text-muted);margin-top:6px}
.metric.ia-metric .metric-value{color:var(--ia)}
.metric.hero-metric .metric-value{color:var(--hero)}
.timeline{border-left:2px solid var(--border);padding-left:20px;margin-left:8px}
.timeline-event{position:relative;padding-bottom:16px}
.timeline-event::before{content:'';position:absolute;left:-26px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--text);border:2px solid var(--surface);box-shadow:0 0 0 2px var(--border)}
.timeline-event.refus::before{background:var(--alert)}
.timeline-event.success::before{background:var(--dgi)}
.timeline-event.ia::before{background:var(--ia)}
.timeline-event.hero::before{background:var(--hero)}
.timeline-event.sat::before{background:var(--cadastre)}
.timeline-event-title{font-weight:600;font-size:14px;margin-bottom:2px}
.timeline-event-meta{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}
.timeline-event-amount{font-size:13px;color:var(--dgi);font-weight:600;margin-top:4px}
.timeline-event-amount.ia{color:var(--ia)}
.timeline-event-amount.hero{color:var(--hero)}
.params-panel{background:var(--surface-2);border:1px solid var(--border);padding:20px}
.params-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;padding:12px 0;border-bottom:1px solid var(--border);align-items:center;font-size:14px}
.params-row:last-child{border-bottom:none}
.params-value{font-family:var(--font-mono);font-weight:600}
.params-edit{font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;cursor:pointer}
.public-page{background:var(--surface-2);border:1px solid var(--border);padding:32px}
.public-url{font-family:var(--font-mono);font-size:13px;color:var(--text-muted);margin-bottom:24px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);word-break:break-all}
.loading{display:flex;align-items:center;gap:12px;padding:24px;background:var(--surface-2);border:1px dashed var(--border-strong);color:var(--text-muted);font-size:14px;margin-top:20px}
.loading-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulseDot 1.4s infinite}
.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}
@keyframes pulseDot{0%,100%{opacity:.3}50%{opacity:1}}
.ia-checks{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
@media (max-width:768px){.ia-checks{grid-template-columns:1fr}}
.ia-check{padding:18px;background:var(--surface-2);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;opacity:.3;transition:opacity .4s}
.ia-check.checking{opacity:1;border-color:var(--ia)}
.ia-check.done{opacity:1;border-color:var(--dgi)}
.ia-check-header{display:flex;justify-content:space-between;align-items:center}
.ia-check-title{font-weight:600;font-size:14px}
.ia-check-status{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em}
.ia-check.checking .ia-check-status{color:var(--ia)}
.ia-check.done .ia-check-status{color:var(--dgi)}
.ia-check-detail{font-size:12px;color:var(--text-muted)}
.ia-summary{padding:24px;background:linear-gradient(135deg,var(--ia-bg) 0%,var(--surface-2) 100%);border:1px solid var(--ia);display:none}
.ia-summary.visible{display:block}
.ia-summary-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.ia-summary-score{font-family:var(--font-display);font-size:48px;font-weight:500;color:var(--ia);line-height:1}
.ia-summary-rec{background:var(--dgi);color:white;padding:6px 14px;font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;align-self:center}
.ia-summary-rec.hero{background:var(--hero)}
.ia-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(26,22,18,.6);z-index:100;align-items:center;justify-content:center;padding:20px}
.modal-overlay.visible{display:flex}
.modal{background:var(--surface);max-width:420px;width:100%;padding:32px;border-top:4px solid var(--accent)}
.modal-title{font-family:var(--font-display);font-size:22px;margin-bottom:8px}
.modal-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:24px}
.modal-input{display:block;width:100%;padding:12px 14px;border:1px solid var(--border);background:var(--surface-2);font-family:var(--font-body);font-size:14px;margin-bottom:12px}
.modal-input:focus{outline:none;border-color:var(--text)}
.modal-error{color:var(--alert);font-size:12px;margin-bottom:12px;display:none}
.modal-error.visible{display:block}
.modal-hint{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);padding:10px 12px;background:var(--surface-2);border-left:3px solid var(--accent);margin-bottom:16px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end}
.vision-tabs{display:flex;border:1px solid var(--border);margin-bottom:20px;background:var(--surface-2)}
.vision-tab{flex:1;padding:14px 16px;text-align:center;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;border-bottom:3px solid transparent;transition:all .15s}
.vision-tab.on{color:var(--text);border-bottom-color:var(--accent);background:var(--surface)}
.vision-content{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-bottom:20px}
@media (max-width:880px){.vision-content{grid-template-columns:1fr}}
.vision-map-wrap{background:var(--surface-2);border:1px solid var(--border);padding:18px}
.vision-map-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:12px}
.vision-svg{width:100%;display:block;background:var(--bg)}
.vision-kpi-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border)}
.vision-kpi-row{background:var(--surface);padding:14px 18px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.vision-kpi-label{font-size:12px;color:var(--text-muted)}
.vision-kpi-value{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--text);text-align:right}
.vision-kpi-value.accent{color:var(--dgi)}
.vision-kpi-value.alert{color:var(--alert)}
.vision-kpi-value.ia{color:var(--ia)}
.vision-footer{background:var(--surface-2);border:1px solid var(--border);padding:20px;font-size:13px;color:var(--text-muted);line-height:1.6;font-style:italic}
.vision-footer strong{color:var(--text);font-style:normal}
.footer{padding:18px 32px;border-top:1px solid var(--border);background:var(--surface-2);font-size:11px;color:var(--text-muted);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-aksara{font-family:var(--font-mono);letter-spacing:.02em}
.footer-aksara::before{content:'·';margin-right:8px;color:var(--accent)}
@media (max-width:768px){
.stage{padding:24px 20px}
.topbar{padding:14px 20px;flex-wrap:wrap;gap:12px}
.bandeau{padding:12px 20px;flex-wrap:wrap}
.actions{padding:16px 20px;flex-wrap:wrap;gap:12px}
.stage-title{font-size:24px}
.form-row,.card-2col{grid-template-columns:1fr}
.refus-alert,.hero-alert{padding:24px}
.refus-alert-title{font-size:22px}
.hero-alert-title{font-size:20px}
.btn{padding:10px 18px;font-size:13px;margin-left:4px}
.footer{padding:14px 20px;font-size:10px}
.watermark{font-size:28px}
.ia-summary-score{font-size:36px}
.vision-kpi-value{font-size:18px}
}

/* ─── Bande retour vers Aksara Systems ───────────────────────────── */
.back-strip{background:#0D1117;color:#9CA3AF;padding:8px 32px;font-size:11px;font-family:var(--font-mono);letter-spacing:.04em;display:flex;justify-content:space-between;align-items:center;gap:16px;border-bottom:1px solid rgba(255,255,255,.05)}
.back-link{color:#E5E7EB;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:color .15s;font-weight:500}
.back-link:hover{color:#FFFFFF}
.back-arrow{font-size:14px;line-height:1;display:inline-block;transition:transform .15s}
.back-link:hover .back-arrow{transform:translateX(-3px)}
.back-link-text{letter-spacing:.06em;text-transform:uppercase;font-size:10px}
.back-strip-context{color:#6B7280;font-size:10px;letter-spacing:.06em;text-transform:uppercase}

/* ─── Pied de page : lien Aksara cliquable ──────────────────────── */
.footer-aksara a{color:inherit;text-decoration:none;transition:color .15s}
.footer-aksara a:hover{color:var(--text)}

@media (max-width:768px){
  .back-strip{padding:7px 20px;font-size:10px;flex-wrap:wrap;gap:8px}
  .back-strip-context{display:none}
}

/* ════════════════════════════════════════════════════════════════════════
   COUCHE DOCUMENTAIRE — pièces, dossier, ancrage, vérificateur
   ════════════════════════════════════════════════════════════════════════ */

/* ── Bouton Dossier (topbar) ──────────────────────────────────────────── */
.dossier-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);padding:7px 12px;cursor:pointer;letter-spacing:.02em;transition:all .15s}
.dossier-btn:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
.dossier-btn-ico{font-size:13px;opacity:.7}
.dossier-btn:hover .dossier-btn-ico{opacity:1}
.dossier-btn-count{font-family:var(--font-mono);font-size:11px;font-weight:600;background:var(--accent);color:#fff;padding:1px 7px;border-radius:9px;min-width:20px;text-align:center}
.dossier-btn:hover .dossier-btn-count{background:var(--surface);color:var(--text)}

/* ── Bloc "Pièces de cette étape" (injecté dans la scène) ─────────────── */
.pieces-block{margin-top:32px;padding-top:24px;border-top:1px dashed var(--border-strong)}
.pieces-block-title{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin-bottom:14px}
.pieces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.piece-card{background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--border-strong);padding:14px 16px;cursor:pointer;transition:all .15s}
.piece-card:hover{border-left-color:var(--accent);background:var(--surface);transform:translateY(-1px);box-shadow:0 4px 14px rgba(26,22,18,.06)}
.piece-card.deposited{border-left-color:var(--notaire)}
.piece-card.generated{border-left-color:var(--dgi)}
.piece-card.rejected{border-left-color:var(--alert);background:var(--alert-bg)}
.piece-card-mode{display:inline-block;font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.12em;padding:2px 7px;margin-bottom:8px;border:1px solid var(--border-strong);color:var(--text-muted)}
.piece-card-mode.deposited{color:var(--notaire);border-color:var(--notaire)}
.piece-card-mode.generated{color:var(--dgi);border-color:var(--dgi)}
.piece-card-mode.rejected{color:var(--alert);border-color:var(--alert)}
.piece-card-type{font-family:var(--font-display);font-size:15px;font-weight:500;line-height:1.25;margin-bottom:4px}
.piece-card-service{font-size:12px;color:var(--text-muted);line-height:1.4;margin-bottom:12px}
.piece-card-foot{display:flex;justify-content:space-between;align-items:center;gap:8px}
.piece-card-block{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}
.piece-card-block.none{color:var(--alert)}
.piece-card-consult{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}
.piece-note{margin-top:16px;padding:14px 16px;background:var(--ministry-bg);border-left:3px solid var(--ministry);font-size:12.5px;line-height:1.6;color:var(--text)}

/* ── Visionneuse de pièce (modale) ────────────────────────────────────── */
.piece-overlay.visible,.dossier-overlay.visible{display:flex;align-items:flex-start;overflow-y:auto;padding:40px 20px}
.piece-modal-shell,.dossier-modal-shell{position:relative;background:var(--bg);max-width:640px;width:100%;margin:auto;border-top:4px solid var(--accent);box-shadow:0 20px 60px rgba(26,22,18,.3)}
.piece-modal-close{position:absolute;top:12px;right:12px;z-index:5;width:32px;height:32px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;cursor:pointer;line-height:1;transition:all .15s}
.piece-modal-close:hover{background:var(--text);color:var(--surface)}

/* ── La pièce stylée façon document officiel ──────────────────────────── */
.doc-paper{position:relative;background:var(--surface);padding:36px 40px;overflow:hidden}
.doc-paper.rejected{background:#fff}
.doc-watermark{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%) rotate(-24deg);font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:.18em;color:rgba(184,137,62,.10);white-space:nowrap;pointer-events:none;user-select:none}
.doc-paper.rejected .doc-watermark{color:rgba(139,38,53,.10)}
.doc-head{text-align:center;border-bottom:2px solid var(--text);padding-bottom:14px;margin-bottom:18px}
.doc-head-institution{font-family:var(--font-display);font-size:17px;font-weight:600;letter-spacing:.01em}
.doc-head-motto{font-size:11px;color:var(--text-muted);font-style:italic;margin-top:2px}
.doc-head-service{font-size:12px;color:var(--text-muted);margin-top:6px;text-transform:uppercase;letter-spacing:.06em}
.doc-mode-badge{display:inline-flex;flex-direction:column;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;padding:5px 10px;border:1px solid var(--border-strong);color:var(--text-muted);margin-bottom:14px}
.doc-mode-badge.deposited{color:var(--notaire);border-color:var(--notaire)}
.doc-mode-badge.generated{color:var(--dgi);border-color:var(--dgi)}
.doc-mode-badge.rejected{color:var(--alert);border-color:var(--alert)}
.doc-mode-hint{font-family:var(--font-body);font-size:10.5px;text-transform:none;letter-spacing:0;color:var(--text-muted);margin-top:3px}
.doc-title{font-family:var(--font-display);font-size:23px;font-weight:500;line-height:1.2;margin-bottom:4px}
.doc-ref{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-bottom:14px}
.doc-supersede{font-size:12px;color:var(--cadastre);background:var(--cadastre-bg);padding:8px 12px;border-left:3px solid var(--cadastre);margin-bottom:16px}
.doc-body{position:relative;z-index:1}
.doc-field{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--border);font-size:14px}
.doc-field:last-child{border-bottom:none}
.doc-field-label{color:var(--text-muted)}
.doc-field-value{font-weight:500;text-align:right}
.doc-section-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:16px 0 4px}
.doc-signzone{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}
.doc-sign{border:1px dashed var(--border-strong);padding:12px 14px;background:var(--surface-2)}
.doc-sign-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px}
.doc-sign-val{font-size:13px;font-weight:500}
.doc-crypto{margin-top:22px;background:var(--surface-2);border:1px solid var(--border-strong);padding:14px 16px}
.doc-crypto.rejected{background:var(--alert-bg);border-color:var(--alert)}
.doc-crypto-row{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:11px;padding:5px 0;flex-wrap:wrap}
.doc-crypto-label{color:var(--text-muted);text-transform:uppercase;font-size:9px;letter-spacing:.12em;min-width:96px}
.doc-crypto-val{color:var(--text);word-break:break-all;flex:1;min-width:0}
.doc-crypto-val.none{color:var(--alert)}
.doc-copy{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);padding:4px 8px;cursor:pointer;transition:all .15s}
.doc-copy:hover{background:var(--text);color:var(--surface)}
.doc-crypto-note{font-family:var(--font-body);font-size:11px;line-height:1.55;color:var(--text-muted);margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}

/* ── Dossier cumulatif ────────────────────────────────────────────────── */
.dossier-modal-shell{max-width:720px;padding:32px 36px}
.dossier-head{margin-bottom:20px}
.dossier-title{font-family:var(--font-display);font-size:24px;font-weight:500}
.dossier-sub{font-size:12px;color:var(--text-muted);font-family:var(--font-mono);margin-top:4px}
.dossier-list{display:flex;flex-direction:column;gap:8px}
.dossier-row{display:flex;justify-content:space-between;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border-strong);padding:12px 14px;cursor:pointer;transition:all .15s}
.dossier-row:hover{border-left-color:var(--accent);transform:translateX(2px)}
.dossier-row.deposited{border-left-color:var(--notaire)}
.dossier-row.generated{border-left-color:var(--dgi)}
.dossier-row.rejected{border-left-color:var(--alert);background:var(--alert-bg)}
.dossier-row-main{min-width:0}
.dossier-mode{display:inline-block;font-family:var(--font-mono);font-size:8.5px;text-transform:uppercase;letter-spacing:.1em;padding:1px 6px;border:1px solid var(--border-strong);color:var(--text-muted);margin-bottom:5px}
.dossier-mode.deposited{color:var(--notaire);border-color:var(--notaire)}
.dossier-mode.generated{color:var(--dgi);border-color:var(--dgi)}
.dossier-mode.rejected{color:var(--alert);border-color:var(--alert)}
.dossier-type{display:block;font-family:var(--font-display);font-size:15px;font-weight:500;line-height:1.2}
.dossier-sup{font-family:var(--font-mono);font-size:10px;color:var(--cadastre);letter-spacing:.04em}
.dossier-service{display:block;font-size:11.5px;color:var(--text-muted);margin-top:2px}
.dossier-row-meta{text-align:right;white-space:nowrap}
.dossier-block{font-family:var(--font-mono);font-size:11px;color:var(--text);display:block}
.dossier-block.none{color:var(--alert)}
.dossier-hash{font-family:var(--font-mono);font-size:9.5px;color:var(--text-muted);display:block;margin-top:2px}
.dossier-foot{font-size:11px;line-height:1.55;color:var(--text-muted);margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}

/* ── Vérificateur (scène 11) ──────────────────────────────────────────── */
.verifier{margin-top:32px;padding-top:24px;border-top:1px dashed var(--border-strong)}
.verifier-title{font-family:var(--font-display);font-size:20px;font-weight:500;margin-bottom:8px}
.verifier-intro{font-size:13.5px;line-height:1.6;color:var(--text-muted);max-width:620px;margin-bottom:18px}
.verifier-drop{border:2px dashed var(--border-strong);background:var(--surface-2);padding:34px 20px;text-align:center;cursor:pointer;transition:all .18s}
.verifier-drop:hover,.verifier-drop.over{border-color:var(--accent);background:var(--warn-bg)}
.verifier-drop-icon{font-size:30px;color:var(--accent);line-height:1;margin-bottom:10px}
.verifier-drop-text{font-size:14px;font-weight:500;margin-bottom:6px}
.verifier-drop-hint{font-size:11.5px;color:var(--text-muted)}
.verifier-try{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px}
.verifier-try-label{font-size:12px;color:var(--text-muted)}
.verifier-dl{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;cursor:pointer;transition:all .15s}
.verifier-dl.ok:hover{background:var(--dgi);color:#fff;border-color:var(--dgi)}
.verifier-dl.bad:hover{background:var(--alert);color:#fff;border-color:var(--alert)}
.verifier-result{margin-top:20px}
.verifier-result.computing{padding:16px;text-align:center}
.verifier-computing{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}
.verifier-result.match,.verifier-result.nomatch{padding:22px 24px;border:1px solid}
.verifier-result.match{background:var(--dgi-bg);border-color:var(--dgi);border-left:4px solid var(--dgi)}
.verifier-result.nomatch{background:var(--alert-bg);border-color:var(--alert);border-left:4px solid var(--alert)}
.verifier-result-icon{font-size:30px;line-height:1;margin-bottom:8px}
.verifier-result.match .verifier-result-icon{color:var(--dgi)}
.verifier-result.nomatch .verifier-result-icon{color:var(--alert)}
.verifier-result-title{font-family:var(--font-display);font-size:19px;font-weight:600;margin-bottom:6px}
.verifier-result.match .verifier-result-title{color:var(--dgi)}
.verifier-result.nomatch .verifier-result-title{color:var(--alert)}
.verifier-result-body{font-size:13.5px;line-height:1.6;margin-bottom:14px}
.verifier-result-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);line-height:1.7}
.verifier-result-hash{word-break:break-all;color:var(--text);margin-top:4px}

@media (max-width:768px){
  .doc-paper{padding:26px 22px}
  .doc-signzone{grid-template-columns:1fr}
  .dossier-row{flex-direction:column;align-items:flex-start;gap:8px}
  .dossier-row-meta{text-align:left}
  .pieces-grid{grid-template-columns:1fr}
}

/* ════════════════════════════════════════════════════════════════════════
   AMÉLIORATIONS PRÉSENTATION — fluidité & impact
   ════════════════════════════════════════════════════════════════════════ */

/* ── Sommaire (sélecteur de scène) ────────────────────────────────────── */
.selector-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);padding:7px 12px;cursor:pointer;letter-spacing:.02em;transition:all .15s}
.selector-btn:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
.selector-btn-ico{font-size:14px;opacity:.7;line-height:1}
.selector-btn:hover .selector-btn-ico{opacity:1}

.selector-overlay.visible{display:flex;align-items:flex-start;overflow-y:auto;padding:40px 20px}
.selector-modal-shell{position:relative;background:var(--bg);max-width:680px;width:100%;margin:auto;border-top:4px solid var(--accent);box-shadow:0 20px 60px rgba(26,22,18,.3);padding:32px 36px}
.selector-head{margin-bottom:18px}
.selector-title{font-family:var(--font-display);font-size:24px;font-weight:500}
.selector-sub{font-size:12px;color:var(--text-muted);font-family:var(--font-mono);margin-top:4px;letter-spacing:.04em}
.selector-list{display:flex;flex-direction:column;gap:6px;max-height:60vh;overflow-y:auto}
.selector-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border-strong);padding:10px 14px;cursor:pointer;transition:all .15s}
.selector-row:hover{border-left-color:var(--accent);transform:translateX(2px);background:var(--surface-2)}
.selector-row.current{border-left-color:var(--text);background:var(--surface-2);box-shadow:inset 4px 0 0 var(--text)}
.selector-row.hero{border-left-color:var(--hero)}
.selector-row.notaire{border-left-color:var(--notaire)}
.selector-row.dgi{border-left-color:var(--dgi)}
.selector-row.cadastre{border-left-color:var(--cadastre)}
.selector-row.ia{border-left-color:var(--ia)}
.selector-row.geometre{border-left-color:var(--cadastre)}
.selector-row.public{border-left-color:var(--public)}
.selector-row.ministry{border-left-color:var(--ministry)}
.selector-row-num{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-muted);min-width:30px}
.selector-row.current .selector-row-num{color:var(--text)}
.selector-row-main{flex:1;min-width:0}
.selector-row-persona{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:2px}
.selector-row-title{font-family:var(--font-display);font-size:15px;font-weight:500;line-height:1.25}
.selector-row-hero{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.14em;color:var(--hero);background:var(--hero-bg);padding:3px 8px;white-space:nowrap}

/* ── Pré-générique (intro overlay) ────────────────────────────────────── */
.intro-overlay{display:none;position:fixed;inset:0;z-index:200;background:var(--bg);align-items:center;justify-content:center;padding:40px 20px;opacity:0;transition:opacity .45s}
.intro-overlay.visible{display:flex;opacity:1}
.intro-overlay.leaving{opacity:0}
.intro-shell{max-width:820px;width:100%;text-align:left;animation:introIn .8s cubic-bezier(.2,.7,.2,1) both}
@keyframes introIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.intro-eyebrow{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.22em;color:var(--accent);margin-bottom:36px;padding-bottom:14px;border-bottom:1px solid var(--border-strong)}
.intro-title{font-family:var(--font-display);font-size:64px;font-weight:500;line-height:1.05;letter-spacing:-.02em;color:var(--text);margin-bottom:28px}
.intro-subtitle{font-family:var(--font-display);font-size:32px;font-weight:300;line-height:1.2;color:var(--text-muted);margin-bottom:44px}
.intro-lead{font-size:17px;line-height:1.6;color:var(--text);max-width:600px;margin-bottom:40px;font-style:italic}
.intro-cta{font-family:var(--font-display);font-size:18px;font-weight:500;letter-spacing:.02em;color:var(--surface);background:var(--text);border:none;padding:18px 36px;cursor:pointer;transition:all .2s;display:inline-block;margin-right:12px}
.intro-cta:hover{background:var(--accent);transform:translateX(3px)}
.intro-skip{font-family:var(--font-body);font-size:13px;color:var(--text-muted);background:none;border:none;padding:18px 8px;cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.intro-skip:hover{color:var(--text)}
@media (max-width:768px){
  .intro-title{font-size:40px}
  .intro-subtitle{font-size:22px}
  .intro-lead{font-size:15px}
}

/* ── Pulse du compteur Dossier ────────────────────────────────────────── */
@keyframes dossierPulse{
  0%{transform:scale(1);box-shadow:0 0 0 0 rgba(184,137,62,.5)}
  40%{transform:scale(1.06);box-shadow:0 0 0 8px rgba(184,137,62,0)}
  100%{transform:scale(1);box-shadow:0 0 0 0 rgba(184,137,62,0)}
}
.dossier-btn.pulse{animation:dossierPulse 1.2s ease-out}
.dossier-btn.pulse .dossier-btn-count{animation:badgeFlash 1.2s ease-out}
@keyframes badgeFlash{0%,100%{background:var(--accent)}30%{background:var(--hero);transform:scale(1.15)}}

/* ── Toast d'incrément Dossier ────────────────────────────────────────── */
.dossier-toast{position:fixed;top:80px;right:24px;z-index:90;background:var(--text);color:var(--surface);padding:14px 18px;max-width:340px;font-family:var(--font-body);font-size:13px;line-height:1.5;opacity:0;transform:translateX(20px);transition:opacity .25s,transform .25s;pointer-events:none;box-shadow:0 12px 32px rgba(26,22,18,.25)}
.dossier-toast.visible{opacity:1;transform:translateX(0)}
.dossier-toast-head{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:8px}
.dossier-toast-piece{display:block;font-size:12.5px;color:rgba(255,255,255,.82);padding:3px 0;border-top:1px solid rgba(255,255,255,.08)}
.dossier-toast-piece:first-of-type{border-top:none;padding-top:6px}
@media (max-width:768px){
  .dossier-toast{top:auto;bottom:84px;right:12px;left:12px;max-width:none}
}

/* ── Ligne contrefactuelle HERO (scènes 5 et 8) ──────────────────────── */
.counter-factual{margin-top:18px;background:var(--alert-bg);border-left:4px solid var(--alert);padding:14px 18px;position:relative}
.counter-factual-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--alert);font-weight:600;margin-bottom:6px}
.counter-factual-body{font-size:13.5px;line-height:1.6;color:var(--text)}

/* ── Geste humain de validation IA ───────────────────────────────────── */
.human-valid{margin-top:18px;background:var(--surface);border:1px solid var(--border-strong);border-top:3px solid var(--ia);padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;animation:humanValidIn .4s ease-out both;transition:background .4s,border-color .4s}
@keyframes humanValidIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.human-valid-head{display:flex;flex-direction:column;gap:3px;flex:1;min-width:200px}
.human-valid-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--ia);font-weight:600}
.human-valid-hint{font-size:12.5px;color:var(--text-muted);font-style:italic}
.human-valid-btn{margin-left:0;background:var(--ia);border-color:var(--ia)}
.human-valid-btn:hover{background:transparent;color:var(--ia)}

/* État validé : le bloc complet bascule en couleurs DGI/vert */
.human-valid.validated{
  background:var(--dgi-bg);border-color:var(--dgi);border-top-color:var(--dgi);border-left:4px solid var(--dgi);
  padding:18px 22px;justify-content:flex-start;gap:14px;
  animation:humanValidShift .55s cubic-bezier(.2,.7,.2,1) both
}
@keyframes humanValidShift{
  0%{transform:scale(.985)}
  60%{transform:scale(1.01)}
  100%{transform:scale(1)}
}
.human-valid-icon{
  width:36px;height:36px;border-radius:50%;
  background:var(--dgi);color:#fff;font-size:18px;font-weight:600;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  animation:humanValidIconIn .5s cubic-bezier(.2,.7,.2,1) .1s both
}
@keyframes humanValidIconIn{
  from{opacity:0;transform:scale(.4)}
  60%{transform:scale(1.18)}
  to{opacity:1;transform:scale(1)}
}
.human-valid-okbody{
  font-size:14.5px;font-weight:500;color:var(--dgi);letter-spacing:.01em;
  animation:humanValidIn .35s ease-out .2s both
}

/* ── Panneau de synthèse (scène 12 refondue) ─────────────────────────── */
.synth-eyebrow{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--border-strong)}
.synth-title{font-size:40px;line-height:1.08;margin-bottom:18px}
.synth-lead{font-size:16px;line-height:1.55;color:var(--text-muted);max-width:640px;margin-bottom:36px}
.synth-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border-strong);border:1px solid var(--border-strong);margin-bottom:40px}
.synth-tile{background:var(--surface);padding:28px 22px;display:flex;flex-direction:column;gap:10px;animation:synthTileIn .6s cubic-bezier(.2,.7,.2,1) both}
.synth-tile-0{animation-delay:.05s}
.synth-tile-1{animation-delay:.15s}
.synth-tile-2{animation-delay:.25s}
.synth-tile-3{animation-delay:.35s}
@keyframes synthTileIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.synth-tile-val{font-family:var(--font-display);font-size:64px;font-weight:500;line-height:1;letter-spacing:-.02em;color:var(--text)}
.synth-tile-0 .synth-tile-val{color:var(--dgi)}
.synth-tile-1 .synth-tile-val{color:var(--alert)}
.synth-tile-2 .synth-tile-val{color:var(--cadastre)}
.synth-tile-3 .synth-tile-val{color:var(--accent)}
.synth-tile-label{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text);font-weight:600}
.synth-tile-detail{font-size:12.5px;line-height:1.55;color:var(--text-muted);margin-top:4px}
.synth-close{border-top:1px solid var(--border);padding-top:32px;text-align:center}
.synth-close-title{font-family:var(--font-display);font-size:24px;font-weight:500;margin-bottom:12px}
.synth-close-text{font-size:14.5px;line-height:1.7;color:var(--text-muted);max-width:680px;margin:0 auto 28px}
.synth-close-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
@media (max-width:880px){
  .synth-grid{grid-template-columns:repeat(2,1fr)}
  .synth-title{font-size:30px}
  .synth-tile-val{font-size:48px}
}
@media (max-width:520px){
  .synth-grid{grid-template-columns:1fr}
}

/* ════════════════════════════════════════════════════════════════════════
   RAIL DOSSIER PERSISTANT — pièces accumulées en jetons colorés
   ════════════════════════════════════════════════════════════════════════ */
.dossier-rail{background:var(--surface);border-bottom:1px solid var(--border);padding:10px 32px;overflow:hidden}
.rail-inner{display:flex;align-items:center;gap:16px;max-width:100%}
.rail-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);white-space:nowrap}
.rail-label strong{color:var(--text);font-weight:600}
.rail-tokens{display:flex;align-items:center;gap:6px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:thin;padding:2px 0}
.rail-tokens::-webkit-scrollbar{height:3px}
.rail-tokens::-webkit-scrollbar-thumb{background:var(--border-strong)}
.rail-empty{font-family:var(--font-mono);color:var(--text-muted);font-size:11px;padding:0 4px}

.rail-token{
  flex:0 0 auto;width:30px;height:30px;border:none;border-radius:6px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;color:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .15s,box-shadow .15s;letter-spacing:0;
}
.rail-token:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(26,22,18,.18)}
.rail-token.persona-cadastre{background:var(--cadastre)}
.rail-token.persona-notaire{background:var(--notaire)}
.rail-token.persona-dgi{background:var(--dgi)}
.rail-token.persona-ia{background:var(--ia)}
.rail-token.persona-ministry{background:var(--ministry)}
.rail-token.mode-rejected{background:transparent;border:1.5px dashed var(--alert);color:var(--alert);font-size:13px}
.rail-token.is-new{animation:railTokenIn .55s cubic-bezier(.2,.7,.2,1) both}
@keyframes railTokenIn{
  0%{opacity:0;transform:scale(.6) translateY(8px)}
  60%{transform:scale(1.12)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
@media (max-width:768px){
  .dossier-rail{padding:8px 20px}
  .rail-token{width:26px;height:26px;font-size:10px}
}

/* ════════════════════════════════════════════════════════════════════════
   VUE FINALE DU DPS — objet souverain contemplé en bloc (scène 12)
   ════════════════════════════════════════════════════════════════════════ */
.dps-final{background:var(--surface);border:1px solid var(--border-strong);border-top:4px solid var(--accent);padding:36px 40px;margin-bottom:36px;position:relative;animation:dpsFinalIn .7s cubic-bezier(.2,.7,.2,1) both}
@keyframes dpsFinalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.dps-final.loading{opacity:.4;text-align:center;padding:80px 40px;color:var(--text-muted)}

.dps-eyebrow{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--accent);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.dps-title{font-family:var(--font-display);font-size:30px;font-weight:500;line-height:1.15;letter-spacing:-.01em;color:var(--text);margin-bottom:24px}

/* Empreinte unique du dossier */
.dps-fp{background:var(--bg);border:1px solid var(--border);padding:16px 18px;margin-bottom:28px;position:relative;overflow:hidden}
.dps-fp::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.dps-fp-label{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:6px}
.dps-fp-val{font-family:var(--font-mono);font-size:13px;color:var(--text);word-break:break-all;line-height:1.5;font-weight:500;margin-bottom:8px}
.dps-fp-hint{font-family:var(--font-body);font-size:11.5px;line-height:1.5;color:var(--text-muted);font-style:italic}

/* 5 facettes */
.dps-facets{display:flex;flex-direction:column;gap:0;margin-bottom:28px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.dps-facet{display:flex;align-items:flex-start;gap:18px;padding:16px 0;border-bottom:1px solid var(--border)}
.dps-facet:last-child{border-bottom:none}
.dps-facet-num{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--accent);letter-spacing:.08em;min-width:24px;padding-top:1px}
.dps-facet-content{flex:1;min-width:0}
.dps-facet-label{font-family:var(--font-display);font-size:15px;font-weight:500;color:var(--text);margin-bottom:3px}
.dps-facet-value{font-size:13.5px;line-height:1.55;color:var(--text-muted)}

/* Timeline des 11 pièces */
.dps-tl-label{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin-bottom:14px}
.dps-tl{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;margin-bottom:24px}
.dps-tl-token{background:var(--bg);border:1px solid var(--border);border-left:3px solid var(--border-strong);padding:12px 14px;cursor:pointer;text-align:left;transition:all .15s;font-family:inherit;color:inherit;display:flex;flex-direction:column;gap:4px}
.dps-tl-token:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(26,22,18,.08);background:var(--surface)}
.dps-tl-token.persona-cadastre{border-left-color:var(--cadastre)}
.dps-tl-token.persona-notaire{border-left-color:var(--notaire)}
.dps-tl-token.persona-dgi{border-left-color:var(--dgi)}
.dps-tl-token.persona-ia{border-left-color:var(--ia)}
.dps-tl-token.persona-ministry{border-left-color:var(--ministry)}
.dps-tl-block{font-family:var(--font-mono);font-size:9.5px;color:var(--text-muted);letter-spacing:.08em}
.dps-tl-type{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--text);line-height:1.25}
.dps-tl-foot{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-top:auto;padding-top:4px}
.dps-tl-date{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}
.dps-tl-service{font-size:10.5px;color:var(--text-muted);text-align:right;line-height:1.2;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.dps-note{font-size:13.5px;line-height:1.65;color:var(--text);font-style:italic;padding:18px 20px;background:var(--bg);border-left:3px solid var(--accent)}

/* Bloc synth après le DPS — un peu de séparation */
.synth-block{padding-top:8px}

@media (max-width:880px){
  .dps-final{padding:24px 22px}
  .dps-title{font-size:24px}
  .dps-facet{flex-direction:column;gap:6px}
  .dps-tl{grid-template-columns:1fr}
}

/* ════════════════════════════════════════════════════════════════════════
   BARRE D'OUTILS DOCUMENT (Imprimer · Télécharger · Vérifier)
   ════════════════════════════════════════════════════════════════════════ */
.doc-toolbar{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;padding:14px 18px;background:var(--surface-2);border-top:1px solid var(--border)}
.doc-tool-btn{font-family:var(--font-body);font-size:12.5px;font-weight:500;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);padding:9px 14px;cursor:pointer;letter-spacing:.02em;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.doc-tool-btn:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
.doc-tool-btn-verify{background:var(--accent);color:#fff;border-color:var(--accent)}
.doc-tool-btn-verify:hover{background:#8a5c20;border-color:#8a5c20}

/* ════════════════════════════════════════════════════════════════════════
   QR CODE — encart latéral sur le document
   ════════════════════════════════════════════════════════════════════════ */
.doc-main-grid{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:start;margin-top:6px}
.doc-main-body{min-width:0}
.doc-qr{flex:0 0 auto;text-align:center;border:1px solid var(--border);padding:10px;background:var(--surface);position:relative}
.doc-qr-img{width:130px;height:130px;display:block;margin:0 auto;image-rendering:crisp-edges;image-rendering:pixelated}
.doc-qr-offline{display:none;font-family:var(--font-mono);font-size:10px;color:var(--alert);padding:30px 10px;width:130px;background:var(--alert-bg);text-align:center;line-height:1.5}
.doc-qr.qr-offline .doc-qr-offline{display:block}
.doc-qr-cap{font-family:var(--font-mono);font-size:9px;letter-spacing:.06em;color:var(--text-muted);margin-top:8px;line-height:1.4;text-transform:uppercase}
@media (max-width:560px){
  .doc-main-grid{grid-template-columns:1fr}
  .doc-qr{margin:0 auto}
}

/* ════════════════════════════════════════════════════════════════════════
   COPIER : bouton plus visible
   ════════════════════════════════════════════════════════════════════════ */
.doc-crypto-val.mono{font-family:var(--font-mono);font-weight:500}
.doc-copy{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--accent);background:var(--accent);color:#fff;padding:5px 10px;cursor:pointer;transition:all .15s;font-weight:600;flex-shrink:0}
.doc-copy:hover{background:transparent;color:var(--accent)}

/* ════════════════════════════════════════════════════════════════════════
   VÉRIFICATEUR DOUBLE-MODE (fichier + hash)
   ════════════════════════════════════════════════════════════════════════ */
.verifier-modes{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
@media (max-width:760px){ .verifier-modes{grid-template-columns:1fr} }
.verifier-mode{display:flex;flex-direction:column;gap:10px}
.verifier-mode-label{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--text);font-weight:600;padding-bottom:6px;border-bottom:1px solid var(--border)}
.verifier-hash-zone{display:flex;gap:0;border:2px solid var(--border-strong);background:var(--surface);transition:border-color .15s}
.verifier-hash-zone:focus-within{border-color:var(--accent)}
.verifier-hash-input{flex:1;min-width:0;font-family:var(--font-mono);font-size:11.5px;border:none;outline:none;padding:13px 14px;background:transparent;color:var(--text)}
.verifier-hash-input::placeholder{color:var(--text-muted);font-style:italic}
.verifier-hash-btn{font-family:var(--font-body);font-size:12.5px;font-weight:600;background:var(--text);color:var(--surface);border:none;padding:0 22px;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;transition:background .15s}
.verifier-hash-btn:hover{background:var(--accent)}

/* ════════════════════════════════════════════════════════════════════════
   MODE AGENT — bascule + allégé fort
   ════════════════════════════════════════════════════════════════════════ */
.agent-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);padding:7px 12px;cursor:pointer;letter-spacing:.02em;transition:all .15s}
.agent-btn:hover{background:var(--text);color:var(--surface);border-color:var(--text)}
.agent-btn-ico{font-size:13px;opacity:.7;line-height:1}
.agent-btn:hover .agent-btn-ico{opacity:1}
.agent-btn.active{background:var(--text);color:var(--surface);border-color:var(--text)}
.agent-btn.active .agent-btn-ico{opacity:1}

/* === Allégé fort : ce qui disparaît === */
body.agent-mode .bandeau{display:none}
body.agent-mode .progress{display:none}
body.agent-mode .dossier-rail{display:none}
body.agent-mode .stage-subtitle{display:none}
body.agent-mode .auth-notice{display:none}
body.agent-mode .counter-factual{display:none}
body.agent-mode .ia-recommendation-banner{display:none}
body.agent-mode .ia-rec-detail{display:none}
body.agent-mode .ia-check-detail{display:none}
body.agent-mode .verifier-intro{display:none}
body.agent-mode .verifier-mode-label{font-size:11px}
body.agent-mode .human-valid-hint{display:none}
body.agent-mode .ia-summary .ia-summary-title{font-size:14px}
body.agent-mode .piece-note{display:none}
body.agent-mode .pieces-block-title{font-size:9.5px;letter-spacing:.18em}
body.agent-mode .demo-warning{display:none}
body.agent-mode .topbar{padding-top:7px;padding-bottom:7px}
body.agent-mode .topbar-right{gap:6px}
/* le titre de scène devient plus dense */
body.agent-mode .stage-title{font-size:24px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
body.agent-mode .stage{padding-top:18px}
body.agent-mode .ia-summary{padding:10px 14px}
body.agent-mode .ia-summary-text{display:none}
body.agent-mode .verif-banner{padding:8px 12px;font-size:11.5px}
body.agent-mode .hero-alert{padding:14px}
body.agent-mode .hero-alert-body{font-size:13px}
/* la validation humaine reste — c'est l'acte métier */
body.agent-mode .human-valid{padding:12px 16px}

/* ════════════════════════════════════════════════════════════════════════
   IMPRESSION — média print, masque l'UI et garde la pièce
   ════════════════════════════════════════════════════════════════════════ */
@media print {
  /* tout cacher */
  body * { visibility: hidden; }
  /* sauf la pièce dans la modale */
  .piece-overlay, .piece-overlay *,
  .piece-modal-shell, .piece-modal-shell * { visibility: visible; }
  .piece-overlay{display:flex !important;background:#fff !important;position:absolute !important;inset:0 !important;padding:0 !important;overflow:visible !important}
  .piece-modal-shell{position:relative !important;box-shadow:none !important;border:none !important;max-width:none !important;width:100% !important;margin:0 !important;border-top:none !important}
  .piece-modal-close, .no-print, .doc-toolbar { display:none !important; }
  .doc-paper{padding:24px 28px !important;background:#fff !important}
  .doc-watermark{opacity:.06 !important}
  /* le QR doit être net et bien dimensionné */
  .doc-qr-img{width:120px !important;height:120px !important}
  /* couper les page-breaks au milieu des sections importantes */
  .doc-crypto, .doc-qr, .doc-signzone{page-break-inside:avoid}
  @page{margin:14mm}
}

/* ════════════════════════════════════════════════════════════════════════
   AMÉLIORATION RAIL — tooltip hash au survol
   ════════════════════════════════════════════════════════════════════════ */
/* rien : le title attribute natif suffit, mais on s'assure qu'il est défini dans le code */
