*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #fcf8f8;--surface: #ffffff;--border: #eee2e5;--text: #1f1a1c;--text-muted: #62565a;--accent: #b4233a;--accent-hover: #971e31;--accent-bg: #fce9ec;--danger: #dc3545;--danger-bg: #fdf0f0;--radius: 8px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace}html.dark{--bg: #121212;--surface: #1e1e1e;--border: #333333;--text: #e4e4e4;--text-muted: #999999;--accent: #ef6a7d;--accent-hover: #ff8da0;--accent-bg: #46242a;--danger: #f47171;--danger-bg: #3a1a1a}html,body{height:100%;font-family:var(--font-sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}#app{display:flex;flex-direction:column;height:100%}header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:saturate(1.1) blur(4px);backdrop-filter:saturate(1.1) blur(4px)}.header-row{display:flex;align-items:center;gap:1rem}.brand-link{display:flex;align-items:center;gap:.65rem;color:var(--text);text-decoration:none}.brand-link:hover h1{color:var(--accent)}.brand-suite{display:block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.header-meta{flex:1}.header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.mode-switch{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}.mode-switch-btn{border:none;background:transparent;color:var(--text-muted);font-size:.74rem;font-weight:600;padding:.34rem .6rem;cursor:pointer;transition:background .15s,color .15s}.mode-switch-btn+.mode-switch-btn{border-left:1px solid var(--border)}.mode-switch-btn:hover{background:var(--accent-bg);color:var(--accent)}.mode-switch-btn.active{background:var(--accent);color:#fff}header h1{font-size:1.15rem;font-weight:700;letter-spacing:-.02em}.subtitle{font-size:.85rem;color:var(--text-muted);margin-top:.15rem}.btn-dark-mode{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:1.15rem;color:var(--text-muted);transition:background .15s,border-color .15s;flex-shrink:0}.btn-dark-mode:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.btn-home{padding:.35rem .75rem;font-size:.78rem;font-weight:600;white-space:nowrap;color:var(--accent);background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);text-decoration:none;transition:background .15s,color .15s}.btn-home:hover{background:var(--accent);color:#fff}#app.app-no-preview .preview-pane{display:none}#app.app-no-preview main{grid-template-columns:1fr}#app.app-no-preview .form-pane{width:100%;max-width:920px;margin:0 auto}.icon-sun{display:none}.icon-moon,html.dark .icon-sun{display:inline}html.dark .icon-moon{display:none}.restore-banner{display:flex;align-items:center;gap:.75rem;padding:.6rem 1.5rem;background:var(--accent-bg);border-bottom:1px solid var(--accent);font-size:.82rem;color:var(--text)}.btn-restore-action{padding:.3rem .75rem;font-size:.78rem;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:4px;cursor:pointer;transition:background .15s}.btn-restore-action:hover{background:var(--accent-hover)}.btn-dismiss-action{padding:.3rem .75rem;font-size:.78rem;font-weight:500;color:var(--text-muted);background:none;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:color .15s,border-color .15s}.btn-dismiss-action:hover{color:var(--text);border-color:var(--text-muted)}.mobile-tabs{display:none}main{flex:1;display:grid;grid-template-columns:480px 1fr;gap:1px;background:var(--border);min-height:0}.form-pane,.preview-pane{display:flex;flex-direction:column;background:var(--surface);min-height:0}.form-scroll{flex:1;overflow-y:auto;padding:1rem 1.25rem 2rem;display:flex;flex-direction:column;gap:1rem}.hidden{display:none!important}.progress-bar{position:relative;height:22px;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--border)}.progress-fill{height:100%;background:var(--accent);opacity:.2;transition:width .3s ease;width:0}.progress-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:500;color:var(--text-muted);pointer-events:none}fieldset{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem 1rem}fieldset.collapsed>:not(legend){display:none}legend{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 .35rem;display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}legend:before{content:"▾";display:inline-block;transition:transform .2s;font-size:.65em;width:.8em;text-align:center}fieldset.collapsed legend:before{transform:rotate(-90deg)}.field-row{display:flex;gap:.5rem;margin-top:.6rem;align-items:flex-end}.field-row label{margin-top:0;width:7.5rem;flex-shrink:0}.field-row .field-grow{flex:1;width:auto}.doc-reference{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}.doc-reference-link{display:inline-flex;flex-wrap:wrap;align-items:baseline;column-gap:.45rem;row-gap:.1rem;font-size:.8rem;font-weight:500;color:var(--accent);text-decoration:none;line-height:1.35}.doc-reference-link:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:2px}.doc-reference-label{font-weight:600}.doc-reference-host{font-size:.72rem;font-weight:500;color:var(--text-muted)}.doc-reference-link:hover .doc-reference-host{color:var(--accent-hover)}label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;font-weight:500;color:var(--text-muted);margin-top:.6rem}label:first-of-type{margin-top:.35rem}.checkbox-label{flex-direction:row;align-items:center;gap:.5rem}input[type=text],input[type=date],input[type=email],input[type=tel],textarea,select{width:100%;padding:.5rem .6rem;font-size:.875rem;font-family:var(--font-sans);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);outline:none;transition:border-color .15s}input[type=checkbox]{accent-color:var(--accent)}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical;line-height:1.5}select{cursor:pointer}.regime-info{margin-top:.6rem;padding:.75rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:.78rem;line-height:1.5;color:var(--text)}.regime-info dl{display:grid;grid-template-columns:auto 1fr;gap:.2rem .75rem}.regime-info dt{font-weight:600;color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.regime-info dd{margin:0}.regime-note{margin-top:.5rem;padding:.4rem .6rem;background:var(--accent-bg);border-left:3px solid var(--accent);border-radius:0 4px 4px 0;font-size:.75rem;font-style:italic}.deadline-hint{font-size:.75rem;font-weight:500;min-height:1em;line-height:1.4}.deadline-ok{color:#2e7d32}html.dark .deadline-ok{color:#66bb6a}.deadline-urgent{color:#e65100}html.dark .deadline-urgent{color:#ffb74d}.deadline-expired{color:var(--danger)}.moyen-entry{display:flex;gap:.35rem;align-items:flex-start;margin-top:.6rem;transition:opacity .15s}.moyen-entry:first-child{margin-top:.35rem}.moyen-entry textarea{flex:1;min-height:3.6em}.moyen-list[data-rows="1"] .moyen-entry textarea{min-height:auto}.moyen-entry.dragging{opacity:.35}.drag-handle{cursor:grab;padding:.35rem .1rem;color:var(--text-muted);font-size:1.1rem;-webkit-user-select:none;user-select:none;flex-shrink:0;line-height:1}.drag-handle:active{cursor:grabbing}.moyen-btn-group{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.btn-reorder{width:24px;height:22px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.btn-reorder:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.btn-remove-moyen{flex-shrink:0;width:24px;height:22px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:4px;color:var(--danger);font-size:1rem;cursor:pointer;transition:background .15s,border-color .15s}.btn-remove-moyen:hover{background:var(--danger-bg);border-color:var(--danger)}.btn-library{padding:.15rem .5rem;font-size:.7rem;font-weight:600;color:var(--accent);background:var(--surface);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:background .15s,border-color .15s}.btn-library:hover{background:var(--accent-bg);border-color:var(--accent)}.library-panel{margin-top:.6rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);overflow:hidden}.library-search{width:100%;padding:.45rem .65rem;font-size:.8rem;border:none;border-bottom:1px solid var(--border);background:var(--surface);color:var(--text);outline:none}.library-search:focus{border-bottom-color:var(--accent)}.library-items{max-height:240px;overflow-y:auto}.library-item{display:flex;flex-direction:column;gap:.15rem;width:100%;padding:.5rem .75rem;text-align:left;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;font-family:var(--font-sans)}.library-item:last-child{border-bottom:none}.library-item:hover{background:var(--surface)}.library-item--added{box-shadow:inset 3px 0 0 var(--accent);background:var(--accent-bg)}.library-item--added:hover{background:var(--surface)}.library-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.45rem;width:100%}.library-item-label{font-size:.8rem;font-weight:600;color:var(--text);min-width:0;flex:1}.library-item-badge{flex-shrink:0;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:var(--surface);border:1px solid var(--accent);padding:.1rem .35rem;border-radius:4px;line-height:1.2}.library-item--added .library-item-badge{background:var(--surface)}.library-item-preview{font-size:.72rem;color:var(--text-muted);line-height:1.35}.btn-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--accent);font-size:.9rem;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}.btn-icon:hover{background:var(--accent-bg);border-color:var(--accent)}.btn-primary{padding:.6rem 1.25rem;font-size:.875rem;font-weight:600;color:#fff;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;transition:background .15s,border-color .15s}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.6rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--accent);background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);cursor:pointer;transition:background .15s,color .15s}.btn-secondary:hover{background:var(--accent-bg)}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.actions-row{display:flex;gap:.75rem;align-items:center;margin-top:.25rem}.draft-actions{margin-top:.5rem}.btn-ghost{padding:.35rem .75rem;font-size:.78rem;font-weight:500;color:var(--text-muted);background:none;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.btn-ghost:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}.status-row{display:flex;align-items:center;justify-content:space-between;min-height:1.2em}.autosave-indicator{font-size:.7rem;color:var(--text-muted);opacity:0;transition:opacity .3s}.autosave-indicator.visible{opacity:1}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;flex:1;color:var(--text-muted)}.loading p{font-size:.9rem;font-weight:500}.loading .loading-detail{font-size:.75rem;font-weight:400}.status{font-size:.75rem;color:var(--text-muted);min-height:1.2em}.status.error{color:var(--danger)}.pane-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid var(--border)}.pane-header h2{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}#preview{flex:1;overflow:auto;padding:1rem;display:flex;flex-direction:column;align-items:center}#preview svg{max-width:100%;height:auto;background:#fff;box-shadow:0 1px 4px #0000001f;border-radius:2px}.undo-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--text);color:var(--surface);border-radius:var(--radius);font-size:.82rem;box-shadow:0 4px 16px #00000040;z-index:1000;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.btn-undo{padding:.25rem .6rem;font-size:.78rem;font-weight:600;color:var(--accent);background:var(--surface);border:none;border-radius:4px;cursor:pointer;transition:background .15s}html.dark .btn-undo{color:var(--accent);background:var(--bg)}.btn-undo:hover{opacity:.85}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:900;padding:2rem}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:720px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.modal-header h3{font-size:.9rem;font-weight:600;color:var(--text)}.modal-actions{display:flex;align-items:center;gap:.5rem}.btn-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:1.1rem;cursor:pointer;transition:background .15s,border-color .15s}.btn-close:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.typst-source{flex:1;overflow:auto;padding:1rem;margin:0;font-family:var(--font-mono);font-size:.78rem;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word;-moz-tab-size:2;tab-size:2}@media(max-width:860px){.header-row{flex-wrap:wrap;align-items:flex-start}.header-meta{order:3;width:100%}.subtitle{margin-top:.35rem}main{grid-template-columns:1fr;grid-template-rows:1fr}.mobile-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--surface)}.mobile-tab{flex:1;padding:.55rem 0;font-size:.82rem;font-weight:600;text-align:center;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s}.mobile-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.mobile-hidden{display:none!important}.form-pane{min-height:0}.form-scroll{max-height:none}}.quota-banner{padding:.55rem .75rem;margin-bottom:.75rem;font-size:.78rem;line-height:1.45;color:var(--text);background:var(--danger-bg);border:1px solid var(--danger);border-radius:var(--radius)}.pdf-confirm-body{padding:.85rem 1rem 1.1rem}.pdf-confirm-intro,.pdf-confirm-question{font-size:.82rem;color:var(--text);line-height:1.45;margin:0 0 .5rem}.pdf-confirm-list{margin:.35rem 0 .85rem;padding-left:1.15rem;font-size:.8rem;line-height:1.45;color:var(--text)}.pdf-confirm-list li{margin-top:.25rem}.pdf-confirm-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;margin-top:.65rem}.form-toc{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .65rem;padding:.5rem .65rem;font-size:.72rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.form-toc-title{font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-right:.25rem}.form-toc a{color:var(--accent);text-decoration:none;font-weight:500}.form-toc a:hover{text-decoration:underline}.form-toc-hint{font-size:.7rem;color:var(--text-muted);margin:-.35rem 0 0}.required-hint{font-size:.72rem;color:var(--text-muted);margin:-.25rem 0 0}.form-summary{position:sticky;top:0;z-index:4;display:flex;flex-wrap:wrap;gap:.35rem .65rem;padding:.5rem .65rem;margin-top:-.3rem;font-size:.72rem;color:var(--text-muted);background:color-mix(in srgb,var(--surface) 94%,transparent);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.form-summary span{white-space:nowrap}.required:after{content:" *";color:var(--danger);font-weight:700}label.field-invalid{color:var(--danger)}label.field-invalid input[type=text],label.field-invalid input[type=date],label.field-invalid input[type=email],label.field-invalid input[type=tel],label.field-invalid textarea,label.field-invalid select{border-color:var(--danger);background:var(--danger-bg)}fieldset[id]{scroll-margin-top:.75rem}.profile-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.35rem}.btn-profile{font-size:.72rem!important;padding:.25rem .55rem!important}.pane-header-actions{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;justify-content:flex-end}.preview-zoom-label{display:flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:600;color:var(--text-muted);margin:0;flex-direction:row;text-transform:none;letter-spacing:normal}.preview-zoom-label input[type=range]{width:88px;margin:0;accent-color:var(--accent)}.preview-zoom-value{font-variant-numeric:tabular-nums;min-width:2.5rem}#preview{align-items:stretch}.preview-svg-inner{transform-origin:top center;transition:transform .15s ease;display:flex;flex-direction:column;align-items:center;width:100%}.preview-svg-inner svg{max-width:100%;height:auto;background:#fff;box-shadow:0 1px 4px #0000001f;border-radius:2px}.mobile-action-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:850;padding:.5rem 1rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom));gap:.5rem;justify-content:center;align-items:center;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 16px #00000014}@media(max-width:860px){.mobile-action-bar:not(.hidden){display:flex}.mobile-action-bar .btn-primary,.mobile-action-bar .btn-secondary{flex:1;max-width:160px;justify-content:center}#app{padding-bottom:0}.form-scroll{padding-bottom:4.5rem}}.app-footer{padding:.5rem 1.25rem .65rem;font-size:.72rem;color:var(--text-muted);border-top:1px solid var(--border);background:var(--surface);display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.btn-footer-link{padding:0;font:inherit;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.btn-footer-link:hover{color:var(--accent-hover)}.footer-sep{-webkit-user-select:none;user-select:none}.modal-content--narrow{max-width:420px}.shortcuts-body{padding:.85rem 1rem 1rem;overflow-y:auto}.shortcuts-list{margin:0;font-size:.8rem}.shortcuts-list dt{font-weight:600;color:var(--text);margin-top:.65rem}.shortcuts-list dt:first-child{margin-top:0}.shortcuts-list dd{margin:.15rem 0 0;padding-left:0;color:var(--text-muted)}.shortcuts-list kbd{display:inline-block;padding:.12rem .35rem;font-family:var(--font-mono);font-size:.72rem;background:var(--bg);border:1px solid var(--border);border-radius:4px}.shortcuts-option{margin-top:1rem!important;padding-top:.75rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--text)}.legal-body{padding:.85rem 1rem 1rem;overflow-y:auto;font-size:.8rem;color:var(--text);line-height:1.45}.legal-section+.legal-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.legal-section h4{font-size:.82rem;font-weight:700;margin-bottom:.35rem}.legal-section p+p{margin-top:.35rem}.legal-actions{margin-top:.95rem;padding-top:.8rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media print{body *{visibility:hidden}.preview-pane,.preview-pane *{visibility:visible}.preview-pane{position:absolute;left:0;top:0;width:100%;min-height:auto;background:#fff}.pane-header{display:none}#preview{overflow:visible;padding:0}.preview-svg-inner svg{box-shadow:none;max-width:100%!important}}
