:root{--color-primary: #4338ca;--color-primary-strong: #3730a3;--color-primary-subtle: #eef2ff;--color-primary-muted: #c7d2fe;--color-accent: #d97706;--color-accent-strong: #b45309;--color-accent-subtle: #fffbeb;--color-accent-muted: #fde68a;--color-bg: #fafaf9;--color-surface: #ffffff;--color-surface-muted: #f5f5f4;--color-border: #e7e5e4;--color-border-strong: #d6d3d1;--color-text: #1c1917;--color-text-soft: #57534e;--color-text-muted: #a8a29e;--color-success: #059669;--color-success-subtle: #ecfdf5;--color-warning: #d97706;--color-warning-subtle: #fffbeb;--color-danger: #dc2626;--color-danger-subtle: #fef2f2;--color-info: #0284c7;--color-info-subtle: #f0f9ff;--color-focus: #4338ca;--color-overlay: rgba(28, 25, 23, .45);--color-sidebar-bg: #1e1b4b;--color-sidebar-text: #e8ecff;--color-sidebar-text-muted: #b4bffc;--color-sidebar-hover: #312e81;--color-sidebar-active: #4f46e5;--color-sidebar-border: rgba(165, 180, 252, .15);--sidebar-width: 244px;--sidebar-collapsed-width: 56px;--topbar-height: 56px;--shadow-sm: 0 1px 3px rgba(28, 25, 23, .06);--shadow-md: 0 4px 12px rgba(28, 25, 23, .08);--shadow-lg: 0 10px 25px rgba(28, 25, 23, .12);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;color:var(--color-text);background:var(--color-bg);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--color-text);background:var(--color-bg)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,textarea,select{font:inherit}button,input,textarea,select{border:1px solid var(--color-border-strong);border-radius:var(--radius-sm)}button{cursor:pointer;background:var(--color-primary);border-color:var(--color-primary);color:#fff;padding:.55rem .9rem;font-weight:var(--font-semibold);transition:background-color .12s ease,border-color .12s ease,box-shadow .12s ease}button:hover:not(:disabled){background:var(--color-primary-strong);border-color:var(--color-primary-strong)}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{width:100%;background:var(--color-surface);color:var(--color-text);padding:.55rem .7rem;transition:border-color .12s ease,box-shadow .12s ease}input:focus,textarea:focus,select:focus{border-color:var(--color-primary-muted);box-shadow:0 0 0 3px var(--color-primary-subtle)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}table{width:100%;border-collapse:collapse;background:var(--color-surface)}th,td{border-bottom:1px solid var(--color-border);padding:.65rem .5rem}th{color:var(--color-text-soft);font-size:var(--text-sm);font-weight:var(--font-semibold);text-align:left}td{vertical-align:top}small{color:var(--color-text-soft)}code{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:.25rem;padding:.1rem .3rem;font-size:var(--text-sm)}.app-layout{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg)}.app-layout__body{display:flex;flex:1;padding-top:var(--topbar-height)}.app-layout__content{flex:1;overflow-y:auto;padding:var(--space-6) var(--space-6) var(--space-12);max-width:1240px;margin:0 auto;width:100%}.topbar{position:fixed;top:0;left:0;right:0;z-index:30;height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);display:flex;align-items:center;padding:0 var(--space-4);gap:var(--space-4)}.topbar__brand{display:flex;align-items:center;gap:var(--space-2);width:var(--sidebar-width);flex-shrink:0;padding-left:var(--space-2)}.topbar__brand-name{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-primary);letter-spacing:-.01em}.topbar__center{flex:1;display:flex;align-items:center;gap:var(--space-3)}.topbar__right{display:flex;align-items:center;gap:var(--space-3)}.topbar__menu-toggle{display:none;background:transparent;border:none;color:var(--color-text);padding:var(--space-1);border-radius:var(--radius-sm)}.topbar__menu-toggle:hover{background:var(--color-surface-muted)}.sidebar{position:fixed;top:var(--topbar-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--color-sidebar-bg);color:var(--color-sidebar-text);overflow-y:auto;overflow-x:hidden;z-index:20;display:flex;flex-direction:column;transition:width .2s ease,transform .2s ease}.sidebar+.app-layout__content{margin-left:var(--sidebar-width)}.sidebar__nav{flex:1;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__group{margin-bottom:var(--space-1)}.sidebar__group+.sidebar__group{border-top:1px solid var(--color-sidebar-border);padding-top:var(--space-1)}.sidebar__group-title{font-size:.7rem;font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-sidebar-text-muted);padding:var(--space-3) var(--space-3) var(--space-1);display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:.5rem var(--space-3);border-radius:var(--radius-md);color:var(--color-sidebar-text);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;transition:background-color .12s ease,color .12s ease;position:relative;line-height:1.4}.sidebar__link:hover{background:var(--color-sidebar-hover);color:#fff;text-decoration:none}.sidebar__link--active{background:var(--color-sidebar-active);color:#fff}.sidebar__link-icon{width:18px;height:18px;flex-shrink:0;opacity:.8}.sidebar__link--active .sidebar__link-icon{opacity:1}.sidebar__link-badge{margin-left:auto;font-size:var(--text-xs);font-weight:var(--font-semibold);padding:.1rem .45rem;border-radius:9999px;background:#ffffff26;color:var(--color-sidebar-text)}.sidebar__link-badge--warn{background:#d977064d;color:var(--color-accent-muted)}.sidebar__link-badge--danger{background:#dc26264d;color:#fecaca}.sidebar__footer{padding:var(--space-3) var(--space-2);border-top:1px solid var(--color-sidebar-border)}.sidebar-overlay{display:none;position:fixed;inset:0;z-index:19;background:var(--color-overlay)}.sidebar-overlay--visible{display:block}.user-menu{position:relative}.user-menu__trigger{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer}.user-menu__trigger:hover{background:var(--color-surface-muted);border-color:var(--color-border-strong)}.user-menu__dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:40;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;padding:var(--space-1) 0}.user-menu__item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--color-text);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);cursor:pointer}.user-menu__item:hover{background:var(--color-surface-muted)}.user-menu__item--danger{color:var(--color-danger)}.page-stack{display:grid;gap:var(--space-4)}.page-intro{margin:0;color:var(--color-text-soft)}.surface-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:var(--space-4)}.surface-muted{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-muted);padding:var(--space-4)}.section-title{margin:0}.field-grid{display:grid;gap:var(--space-1)}.form-grid{display:grid;gap:var(--space-3)}.form-grid-2col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.filters-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,320px));gap:var(--space-3)}.actions-row{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.list-reset{list-style:none;padding:0;margin:0}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-soft{color:var(--color-text-soft)}.text-muted{color:var(--color-text-muted)}.link-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-weight:var(--font-semibold);padding:.55rem .9rem;font-size:var(--text-sm);transition:background-color .12s ease}.link-button:hover{background:var(--color-primary-strong);border-color:var(--color-primary-strong);color:#fff;text-decoration:none}.link-button--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.link-button--secondary:hover{background:var(--color-surface-muted);color:var(--color-text);border-color:var(--color-border-strong)}.mono{font-variant-numeric:tabular-nums;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.app-shell{min-height:100vh;background:var(--color-bg)}.app-shell__header{border-bottom:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-sm)}.app-shell__inner{margin:0 auto;max-width:1240px;padding:.95rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.app-shell__brand{display:flex;align-items:center;gap:var(--space-2)}.app-shell__brand strong{font-size:1.2rem}.app-shell__status{display:flex;align-items:center;gap:var(--space-2)}.app-shell__nav-wrap{align-items:flex-start;border-top:1px solid var(--color-border)}.app-shell__nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:var(--space-3);width:100%}.app-shell__nav-group{display:grid;gap:var(--space-1)}.app-shell__nav-title{font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-soft)}.app-shell__nav-links{display:flex;flex-wrap:wrap;gap:.4rem}.app-shell__nav-link{color:var(--color-text-soft);font-size:var(--text-sm);border:1px solid transparent;border-radius:9999px;padding:.25rem .6rem}.app-shell__nav-link:hover{text-decoration:none;color:var(--color-primary);background:var(--color-primary-subtle)}.app-shell__nav-link--active{color:var(--color-primary-strong);background:var(--color-primary-subtle);border-color:var(--color-primary-muted)}.app-shell__sync-chip{min-width:fit-content}.app-shell__main{margin:0 auto;max-width:1240px;padding:1.5rem 1.5rem 4rem}.home-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.sync-status-card{margin-bottom:var(--space-4);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3)}.modal-overlay{position:fixed;inset:0;z-index:50;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal-panel{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:480px;width:100%;padding:var(--space-6)}.modal-panel__title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:var(--font-semibold)}.modal-panel__body{color:var(--color-text-soft);margin-bottom:var(--space-4)}.modal-panel__actions{display:flex;gap:var(--space-2);justify-content:flex-end}.ui-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border)}.ui-tab{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-soft);background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .12s ease,border-color .12s ease}.ui-tab:hover{color:var(--color-text)}.ui-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:9999px;flex-shrink:0}.status-dot--success{background:var(--color-success)}.status-dot--warning{background:var(--color-warning)}.status-dot--danger{background:var(--color-danger)}.status-dot--info{background:var(--color-info)}.status-dot--neutral{background:var(--color-text-muted)}.status-dot--primary{background:var(--color-primary)}.skeleton{background:linear-gradient(90deg,var(--color-surface-muted) 25%,var(--color-border) 50%,var(--color-surface-muted) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm);height:1em}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.breadcrumb{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-soft)}.breadcrumb__separator{color:var(--color-text-muted)}.breadcrumb__current{color:var(--color-text);font-weight:var(--font-medium)}.paginated-list__item{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);transition:border-color .12s ease,box-shadow .12s ease}.paginated-list__item:hover{border-color:var(--color-primary-muted);box-shadow:var(--shadow-sm)}.ecriture-row{display:grid;grid-template-columns:110px 100px 1fr 130px auto;gap:var(--space-3);align-items:center;color:inherit;text-decoration:none;padding:var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-sm)}.ecriture-row:hover{background:var(--color-surface-muted);text-decoration:none}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--topbar-height));padding:var(--space-4);background:linear-gradient(135deg,var(--color-primary-subtle) 0%,var(--color-bg) 60%,var(--color-accent-subtle) 100%)}.login-page__card{width:100%;max-width:420px}.login-page__brand{text-align:center;margin-bottom:var(--space-6)}.login-page__brand-name{display:block;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-primary);letter-spacing:-.02em}.login-page__brand-tagline{display:block;font-size:var(--text-sm);color:var(--color-text-soft);margin-top:var(--space-1)}.dossier-grid{display:grid;gap:var(--space-3)}.dossier-card{width:100%;text-align:left;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);background:var(--color-surface);cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease}.dossier-card:hover{border-color:var(--color-primary-muted);box-shadow:var(--shadow-md)}.dossier-card--selected{border-color:var(--color-primary);background:var(--color-primary-subtle);box-shadow:0 0 0 3px var(--color-primary-subtle)}.dossier-card__name{font-weight:var(--font-semibold);color:var(--color-text)}.dossier-card__meta{font-size:var(--text-sm);color:var(--color-text-soft);margin-top:var(--space-1)}@media(max-width:768px){.topbar__menu-toggle{display:flex}.topbar__brand{width:auto}.sidebar{transform:translate(-100%);width:var(--sidebar-width)}.sidebar--open{transform:translate(0)}.sidebar+.app-layout__content{margin-left:0}.app-layout__content{padding:var(--space-4) var(--space-4) var(--space-10)}.form-grid-2col,.filters-grid-2{grid-template-columns:1fr}}.ui-button.ui-button--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.ui-button.ui-button--secondary:hover:not(:disabled){background:var(--color-surface-muted);border-color:var(--color-border-strong)}.ui-button.ui-button--ghost{background:transparent;color:var(--color-primary);border-color:transparent}.ui-button.ui-button--ghost:hover:not(:disabled){background:var(--color-primary-subtle)}.ui-button.ui-button--danger{background:var(--color-danger);border-color:var(--color-danger)}.ui-button.ui-button--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.ui-button.ui-button--accent{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.ui-button.ui-button--accent:hover:not(:disabled){background:var(--color-accent-strong);border-color:var(--color-accent-strong)}.ui-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);padding:var(--space-4)}.ui-field{display:grid;gap:var(--space-1)}.ui-field__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.ui-field__hint{color:var(--color-text-soft);font-size:var(--text-sm)}.ui-field__error{color:var(--color-danger);font-size:var(--text-sm)}.ui-badge{display:inline-flex;align-items:center;gap:var(--space-1);border-radius:9999px;padding:.15rem .55rem;font-size:var(--text-xs);font-weight:var(--font-semibold)}.ui-badge--neutral{color:var(--color-text-soft);background:var(--color-surface-muted)}.ui-badge--primary{color:var(--color-primary-strong);background:var(--color-primary-subtle)}.ui-badge--success{color:#065f46;background:var(--color-success-subtle)}.ui-badge--warning{color:#92400e;background:var(--color-warning-subtle)}.ui-badge--danger{color:#991b1b;background:var(--color-danger-subtle)}.ui-badge--info{color:#075985;background:var(--color-info-subtle)}.ui-badge--accent{color:var(--color-accent-strong);background:var(--color-accent-subtle)}.ui-alert{border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-3) var(--space-4);display:grid;gap:var(--space-1);font-size:var(--text-sm)}.ui-alert__title{display:block;font-weight:var(--font-semibold)}.ui-alert--neutral{color:var(--color-text);background:var(--color-surface-muted)}.ui-alert--info{color:#075985;background:var(--color-info-subtle);border-color:#bae6fd}.ui-alert--warning{color:#92400e;background:var(--color-warning-subtle);border-color:var(--color-accent-muted)}.ui-alert--danger{color:#991b1b;background:var(--color-danger-subtle);border-color:#fecaca}.ui-alert--success{color:#065f46;background:var(--color-success-subtle);border-color:#a7f3d0}.ui-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap}.ui-page-header h1{margin:0;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.ui-page-header p{margin:.25rem 0 0;color:var(--color-text-soft);font-size:var(--text-sm)}.ui-empty-state{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-4);text-align:center;color:var(--color-text-soft)}.ui-empty-state strong{color:var(--color-text)}.ui-empty-state p{margin:var(--space-2) 0 0}.ui-empty-state__actions{margin-top:var(--space-4)}.ui-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:auto;background:var(--color-surface)}.ui-table-wrap table{margin:0}
