:root{--navy:#0a0f1a;--navy-2:#0f1726;--navy-3:#16203250;--cyan:#4fc3f7;--cyan-strong:#2aa4dd;--nav-text:#e6edf5;--nav-text-dim:#93a4b8;--danger:#e5534b;--danger-bg:#e5534b1a;--ok:#2faf78;--ok-bg:#2faf781a;--warn:#d9a441;--radius:8px;--font:"Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif}[data-theme=light]{--content-bg:#f3f6f9;--surface:#ffffff;--text:#0f1722;--text-muted:#51637a;--border:#d6deea;--field-bg:#ffffff;--field-border:#bfccdb;--row-hover:#eef3f9;--th-bg:#eaf0f7;--th-text:#324155}[data-theme=dark]{--content-bg:#0a0f1a;--surface:#111a2a;--text:#e9eef6;--text-muted:#9db0c6;--border:#233143;--field-bg:#0c1421;--field-border:#2b3a4f;--row-hover:#16202f;--th-bg:#16202f;--th-text:#aebfd2}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font);font-size:15px;line-height:1.5;color:var(--nav-text);background:var(--navy);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}h1,h2,h3{margin:0;font-weight:600}.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:56px 1fr;min-height:100vh}.sidebar{grid-row:1/3;grid-column:1;background:var(--navy);border-right:1px solid #1d2738;display:flex;flex-direction:column;padding:18px 12px}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;flex-wrap:wrap}.brand .brand-logo{max-height:38px;max-width:150px;object-fit:contain}.brand .infini{color:var(--cyan);font-size:26px;line-height:1}.brand .nom{font-weight:700;letter-spacing:.04em;color:var(--nav-text);font-size:14px}.brand .nom b{color:var(--cyan)}.editeur-mark{height:22px;width:22px;object-fit:contain;flex:0 0 auto}.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}.nav-section{font-size:11px;text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 6px}.nav a,.nav-section{color:var(--nav-text-dim)}.nav a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);font-size:14px}.nav a:hover{background:#15203150;color:var(--nav-text)}.nav a.actif{background:#15263a;color:var(--nav-text);box-shadow:inset 2px 0 0 var(--cyan)}.nav a.disabled{opacity:.45;pointer-events:none}.nav a svg{width:18px;height:18px;flex:0 0 auto;opacity:.9}.nav-sep{height:0;margin:10px 8px;border:0;border-top:1px solid #1d2738}.entete{grid-column:2;grid-row:1;display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 22px;background:var(--navy-2);border-bottom:1px solid #1d2738}.entete .titre-zone{color:var(--nav-text-dim);font-size:13px}.entete .droite{display:flex;align-items:center;gap:16px}.entete .identite{text-align:right;line-height:1.2}.entete .identite .qui{color:var(--nav-text);font-size:13px;font-weight:600}.entete .identite .role{color:var(--nav-text-dim);font-size:12px}.cartes-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin-top:8px}.carte-admin{display:flex;flex-direction:column;gap:8px;padding:18px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--text);text-decoration:none;transition:border-color .15s ease,transform .15s ease}.carte-admin:hover{border-color:var(--cyan);transform:translateY(-2px)}.carte-admin-icone{display:inline-flex;color:var(--cyan)}.carte-admin-icone svg{width:24px;height:24px}.carte-admin-titre{font-weight:600;font-size:15px}.carte-admin-desc{color:var(--text-muted);font-size:13px;line-height:1.45}.contenu{grid-column:2;grid-row:2;background:var(--content-bg);color:var(--text);padding:26px 28px 60px;min-height:calc(100vh - 56px)}.fil{color:var(--text-muted);font-size:13px;margin-bottom:6px}.ecran-tete{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.ecran-tete h1{color:var(--text);font-size:22px}.ecran-tete .sous{color:var(--text-muted);font-size:14px;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:14px;font-weight:600;padding:9px 16px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer}.btn-primary{background:var(--cyan);color:#06222f;border-color:var(--cyan)}.btn-primary:hover{background:var(--cyan-strong)}.btn-secondary{background:transparent;color:var(--text);border-color:var(--field-border)}.btn-secondary:hover{background:var(--row-hover)}.btn-discret{background:transparent;color:var(--text-muted);padding:6px 10px}.btn-discret:hover{color:var(--text)}.btn:disabled{opacity:.5;cursor:not-allowed}.champ{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.champ label{font-size:13px;font-weight:600;color:var(--text)}.input{font-family:inherit;font-size:15px;padding:10px 12px;border-radius:var(--radius);background:var(--field-bg);color:var(--text);border:1px solid var(--field-border)}.input:focus{outline:2px solid var(--cyan);outline-offset:0;border-color:var(--cyan)}.input::placeholder{color:var(--text-muted)}.carte{padding:22px}.carte,.tableau{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.tableau{width:100%;overflow:hidden}table{width:100%;border-collapse:collapse;font-size:14px}thead th{text-align:left;font-weight:600;font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--th-text);background:var(--th-bg);padding:11px 16px}tbody td,thead th{border-bottom:1px solid var(--border)}tbody td{padding:12px 16px;color:var(--text)}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--row-hover)}.cellule-sec{color:var(--text-muted)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--border)}.badge.ok{color:var(--ok);background:var(--ok-bg);border-color:transparent}.badge.off{color:var(--text-muted)}.badge.role{color:var(--cyan);border-color:var(--cyan);background:transparent}.etat{padding:36px;text-align:center;color:var(--text-muted)}.alerte{padding:11px 14px;border-radius:var(--radius);font-size:14px;margin-bottom:14px}.alerte.err{color:var(--danger);background:var(--danger-bg)}.alerte.ok{color:var(--ok);background:var(--ok-bg)}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--navy);padding:24px}.login-carte{width:380px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:30px}.login-marque{display:flex;align-items:center;gap:10px;justify-content:center;margin:0 0 10px}.login-marque .infini{color:var(--cyan);font-size:30px}.login-logo{display:block;margin:0 auto;max-height:130px;max-width:100%;object-fit:contain}.login-titre{text-align:center;color:var(--text);font-size:18px;margin-bottom:2px}.login-editeur{text-align:center;color:var(--text-muted);font-size:12px;margin-bottom:4px}.login-editeur a{color:var(--text-muted);text-decoration:underline}.login-sous{text-align:center;margin-bottom:22px}.legende,.login-sous{color:var(--text-muted);font-size:13px}.legende{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.legende .item{display:inline-flex;align-items:center;gap:6px}.matrice-barre{display:flex;justify-content:flex-end;margin-bottom:8px}.matrice-scroll{max-height:calc(100vh - 230px);overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.matrice table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.matrice thead th{position:sticky;top:0;z-index:3;height:40px;padding:0 12px;background:var(--th-bg);color:var(--th-text);border-bottom:2px solid var(--border);text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.matrice thead th.role-col{text-align:center;width:100px}.matrice tbody td{padding:7px 12px;border-bottom:1px solid var(--border);color:var(--text)}.matrice tbody td.role-col{text-align:center}.sect-row td{position:sticky;top:40px;z-index:2;padding:0}.sect-banner{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--th-bg);color:var(--text);border-top:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:inset 4px 0 0 var(--cyan)}.sect-banner:hover{background:var(--row-hover)}.sect-banner .chevron{color:var(--cyan);width:12px;font-size:11px}.sect-banner .titre{font-size:14px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.sect-banner .compte{color:var(--text-muted);font-size:12px;font-weight:400}.perm-code{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:12px}.pastille{display:inline-block;min-width:20px;padding:1px 7px;border-radius:999px;font-size:11px;font-weight:700}.pastille.tous{color:#06222f;background:var(--cyan)}.pastille.ses{color:var(--cyan);border:1px solid var(--cyan)}.pastille.non{color:var(--text-muted)}.verrou{color:var(--warn);font-size:12px;margin-left:6px}tr.verrouille td:first-child{box-shadow:inset 3px 0 0 var(--warn)}.role-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.role-badge.sys{color:var(--text-muted);border:1px solid var(--border)}.role-badge.custom{color:var(--cyan);border:1px solid var(--cyan)}.compo-row{display:flex;align-items:center;gap:12px;padding:7px 14px;border-bottom:1px solid var(--border)}.compo-row:last-child{border-bottom:none}.compo-row.verrouille-row{opacity:.55}.compo-row .nom{flex:1 1;display:flex;align-items:center;gap:9px;cursor:pointer}.compo-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--cyan);cursor:pointer}.compo-row input[type=checkbox]:disabled{cursor:not-allowed}.compo-scope select{padding:3px 8px;font-size:12px;border-radius:6px;background:var(--field-bg);color:var(--text);border:1px solid var(--field-border)}.ligne-cliquable{cursor:pointer}.ligne-cliquable:focus-visible{outline:2px solid var(--cyan);outline-offset:-2px}.statut-badge{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;border:1px solid var(--border)}.statut-badge:before{content:"";width:7px;height:7px;border-radius:50%}.statut-badge.av{color:var(--text-muted)}.statut-badge.av:before{background:var(--text-muted)}.statut-badge.ec{color:var(--ok);border-color:transparent;background:var(--ok-bg)}.statut-badge.ec:before{background:var(--ok)}.statut-badge.cl{color:var(--text-muted)}.statut-badge.cl:before{background:#8a98a8}.barre-recherche{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:14px}.onglets-statut{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.onglet{padding:7px 14px;border-radius:var(--radius);font-size:14px;font-weight:600;border:1px solid var(--field-border);color:var(--text-muted)}.onglet:hover{color:var(--text)}.onglet.actif{background:var(--cyan);color:#06222f;border-color:var(--cyan)}.pagination{display:flex;align-items:center;gap:14px;margin-top:16px;color:var(--text-muted);font-size:14px}.segment{display:inline-flex;border:1px solid var(--field-border);border-radius:var(--radius);overflow:hidden}.segment input{position:absolute;width:1px;height:1px;opacity:0}.segment label{padding:9px 22px;cursor:pointer;font-weight:600;font-size:14px;color:var(--text);background:var(--field-bg)}.segment label+input+label{border-left:1px solid var(--field-border)}.segment input:checked+label{background:var(--cyan);color:#06222f}.segment input:focus-visible+label{outline:2px solid var(--cyan);outline-offset:-2px}.fiche-entete{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.fiche-entete .ligne1{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.fiche-entete .num{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:14px;color:var(--text-muted)}.fiche-entete .ident{font-size:20px;font-weight:700;color:var(--text)}.fiche-entete .ligne2{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:10px;color:var(--text-muted);font-size:14px}.danger-badge{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px;color:#fff;background:var(--danger)}.danger-badge:before{content:"▲";font-size:10px}.onglets{display:flex;gap:2px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin:18px 0 22px}.onglets a{padding:10px 15px;font-size:14px;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px}.onglets a:hover{color:var(--text)}.onglets a.actif{color:var(--cyan);border-bottom-color:var(--cyan)}.fiche-grid{display:grid;grid-template-columns:210px 1fr}.fiche-grid>div{display:contents}.fiche-grid .k{color:var(--text-muted);font-size:13px;padding:9px 16px 9px 0}.fiche-grid .k,.fiche-grid .v{border-bottom:1px solid var(--border)}.fiche-grid .v{color:var(--text);font-size:14px;padding:9px 0}.fiche-section-titre{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:20px 0 8px}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.kpi .val{font-size:28px;font-weight:700;color:var(--text);line-height:1.1}.kpi .lbl{color:var(--text-muted);font-size:13px;margin-top:5px}.reparts{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:18px}.repart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.repart h3{font-size:14px;margin-bottom:14px}.repart-ligne{display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:10px;row-gap:5px;margin-bottom:9px}.repart-ligne .nom{font-size:13px;color:var(--text)}.repart-ligne .nb{text-align:right;font-weight:700;font-size:14px;color:var(--text)}.barre-stat{grid-column:1/-1;height:6px;background:var(--row-hover);border-radius:3px;overflow:hidden}.barre-stat>div{height:100%;background:var(--cyan)}.periode-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:20px}.apercu{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#1d2738;min-height:100vh}.apercu-col{display:flex;flex-direction:column}.apercu-bandeau{background:var(--navy-2);color:var(--nav-text);padding:12px 18px;font-weight:600;font-size:14px;border-bottom:1px solid #1d2738}.apercu-bandeau span{color:var(--nav-text-dim);font-weight:400}.apercu-zone{flex:1 1;background:var(--content-bg);color:var(--text);padding:22px}