@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Syne:wght@600;700;800&family=DM+Mono:wght@400;500&display=swap";
:root{--g50:#f0faf4;--g100:#d6f0e0;--g200:#a8dcba;--g400:#4caf7d;--g500:#2e9e60;--g600:#1d7a48;--g700:#155c36;--gr50:#f8f9fa;--gr100:#f1f3f5;--gr200:#e9ecef;--gr300:#dee2e6;--gr400:#ced4da;--gr500:#adb5bd;--gr600:#6c757d;--gr700:#495057;--gr800:#343a40;--gr900:#212529;--blanc:#fff;--fond:#f8f9fa;--fond2:#f1f3f5;--bordure:#e9ecef;--rouge:#dc3545;--rouge-alpha:#dc35451a;--ambre:#d97706;--ambre-alpha:#d977061a;--bleu:#3b6fd4;--bleu-alpha:#3b6fd41a;--vert-alpha:#1d7a481a;--texte:#212529;--attenue:#6c757d;--discret:#adb5bd;--ombre-carte:0 1px 4px #0000000f,0 4px 16px #0000000a;--ombre-vert:0 4px 16px #1d7a4833;--sidebar-bg:#fff;--sidebar-bordure:#e9ecef;--sidebar-hover:#f1f3f5;--sidebar-actif-bg:#f0faf4;--sidebar-actif-color:#155c36;--sidebar-actif-bordure:#d6f0e0;--tableau-header:#f8f9fa;--tableau-hover:#f8f9fa;--tableau-ligne:#f1f3f5;--input-bg:#fff;--input-bordure:#dee2e6;--scrollbar-track:#f1f3f5;--scrollbar-thumb:#dee2e6;--font-titre:"Syne",sans-serif;--font-corps:"Inter",sans-serif;--font-mono:"DM Mono",monospace;--couleur-fond:var(--fond);--couleur-fond-surface:var(--blanc);--couleur-fond-carte:var(--blanc);--couleur-fond-survol:var(--gr100);--couleur-bordure:var(--bordure);--couleur-bordure-clair:var(--gr300);--couleur-vert:var(--g500);--couleur-vert-clair:var(--g400);--couleur-vert-sombre:var(--g700);--couleur-vert-alpha:var(--vert-alpha);--couleur-ambre:var(--ambre);--couleur-ambre-alpha:var(--ambre-alpha);--couleur-rouge:var(--rouge);--couleur-rouge-alpha:var(--rouge-alpha);--couleur-bleu:var(--bleu);--couleur-bleu-alpha:var(--bleu-alpha);--couleur-texte:var(--texte);--couleur-texte-attenue:var(--attenue);--couleur-texte-discret:var(--discret);--rayon:8px;--rayon-lg:12px;--rayon-xl:16px;--sidebar-largeur:256px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-corps);background:var(--fond);color:var(--texte);-webkit-font-smoothing:antialiased;line-height:1.6;transition:background .25s,color .25s}h1,h2,h3,h4,h5,h6{font-family:var(--font-titre);color:var(--texte);font-weight:700;line-height:1.15}h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:clamp(1.4rem,2.5vw,2rem)}h3{font-size:1.15rem}h4{font-size:1rem}p{color:var(--attenue)}a{color:var(--g600);text-decoration:none;transition:color .15s}a:hover{color:var(--g500)}.valeur-mono{font-family:var(--font-mono)}.btn{border-radius:var(--rayon);font-family:var(--font-corps);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primaire{background:var(--g600);color:#fff}.btn-primaire:hover{background:var(--g700);box-shadow:var(--ombre-vert);color:#fff;transform:translateY(-1px)}.btn-secondaire{background:var(--blanc);color:var(--g600);border:1.5px solid var(--g200)}.btn-secondaire:hover{background:var(--g50);border-color:var(--g400);color:var(--g600)}.btn-danger{color:var(--rouge);border:1.5px solid var(--rouge);background:0 0}.btn-danger:hover{background:var(--rouge-alpha)}.btn-sm{padding:7px 14px;font-size:.8rem}.btn-lg{padding:13px 28px;font-size:.95rem}.carte{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--rayon-lg);box-shadow:var(--ombre-carte);padding:24px;transition:box-shadow .2s,border-color .2s}.carte:hover{border-color:var(--gr400);box-shadow:0 8px 24px #0000001f}.carte-accent-vert{border-left:3px solid var(--g500)}.carte-accent-ambre{border-left:3px solid var(--ambre)}.carte-accent-bleu{border-left:3px solid var(--bleu)}.carte-accent-rouge{border-left:3px solid var(--rouge)}.metrique{flex-direction:column;gap:4px;display:flex}.metrique-valeur{font-family:var(--font-titre);color:var(--texte);font-size:2rem;font-weight:800;line-height:1}.metrique-label{color:var(--discret);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:600}.metrique-sous{color:var(--attenue);font-size:.83rem}.metrique-vert{color:var(--g500)}.metrique-ambre{color:var(--ambre)}.metrique-rouge{color:var(--rouge)}.champ{flex-direction:column;gap:6px;display:flex}.champ label{color:var(--attenue);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.champ input,.champ select,.champ textarea{background:var(--input-bg);border:1.5px solid var(--input-bordure);border-radius:var(--rayon);color:var(--texte);font-family:var(--font-corps);outline:none;width:100%;padding:10px 14px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.champ input:focus,.champ select:focus,.champ textarea:focus{border-color:var(--g500);box-shadow:0 0 0 3px var(--vert-alpha)}.champ input::placeholder{color:var(--discret)}.champ-erreur{color:var(--rouge);font-size:.8rem}.badge{letter-spacing:.04em;border-radius:100px;align-items:center;gap:5px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-vert{background:var(--g50);color:var(--g600);border:1px solid var(--g100)}.badge-ambre{background:var(--ambre-alpha);color:var(--ambre);border:1px solid #d9770633}.badge-rouge{background:var(--rouge-alpha);color:var(--rouge);border:1px solid #dc354533}.badge-bleu{background:var(--bleu-alpha);color:var(--bleu);border:1px solid #3b6fd433}.badge-gris{background:var(--gr100);color:var(--gr600);border:1px solid var(--gr200)}.barre-prog{background:var(--gr200);border-radius:100px;height:6px;overflow:hidden}.barre-prog-remplissage{background:linear-gradient(90deg,var(--g600),var(--g400));border-radius:100px;height:100%;transition:width .8s cubic-bezier(.2,0,0,1)}.layout-app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-largeur);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-bordure);flex-direction:column;flex-shrink:0;min-height:100vh;transition:background .25s,border-color .25s;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid var(--sidebar-bordure);padding:18px 18px 14px}.sidebar-logo-titre{font-family:var(--font-titre);color:var(--texte);align-items:center;gap:8px;font-size:1.1rem;font-weight:800;display:flex}.sidebar-logo-eclair{color:var(--g500)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:10px;display:flex}.sidebar-lien{border-radius:var(--rayon);color:var(--attenue);cursor:pointer;align-items:center;gap:10px;padding:9px 12px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-lien:hover{background:var(--sidebar-hover);color:var(--texte)}.sidebar-lien.actif{background:var(--sidebar-actif-bg);color:var(--sidebar-actif-color);border:1px solid var(--sidebar-actif-bordure);font-weight:600}.sidebar-lien.actif svg{stroke:var(--sidebar-actif-color)}.sidebar-section-titre{color:var(--discret);text-transform:uppercase;letter-spacing:.1em;padding:10px 12px 4px;font-size:.68rem;font-weight:700}.sidebar-footer{border-top:1px solid var(--sidebar-bordure);padding:10px}.contenu-principal{background:var(--fond);flex:1;overflow-x:hidden}.entete-page{border-bottom:1px solid var(--bordure);background:var(--blanc);justify-content:space-between;align-items:center;gap:16px;padding:22px 32px;transition:background .25s;display:flex}.corps-page{padding:28px 32px}.grille-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:20px;display:grid}.grille-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grille-3{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.tableau-wrapper{border-radius:var(--rayon-lg);border:1px solid var(--bordure);background:var(--blanc);overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--tableau-header);text-align:left;color:var(--discret);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--bordure);white-space:nowrap;padding:11px 16px;font-size:.72rem;font-weight:700}tbody tr{border-bottom:1px solid var(--tableau-ligne);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--tableau-hover)}tbody td{color:var(--texte);padding:13px 16px;font-size:.875rem}.banque-jauge{background:var(--blanc);border:1px solid var(--bordure);border-radius:var(--rayon-xl);box-shadow:var(--ombre-carte);padding:24px}.banque-solde{font-family:var(--font-titre);color:var(--g500);font-size:3rem;font-weight:800;line-height:1}.banque-solde-unite{color:var(--attenue);margin-left:4px;font-size:1.3rem;font-weight:600}@keyframes apparition{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes clignotant{0%,to{opacity:1}50%{opacity:.35}}.animer{animation:.35s cubic-bezier(.2,0,0,1) forwards apparition}.delai-1{opacity:0;animation-delay:50ms}.delai-2{opacity:0;animation-delay:.1s}.delai-3{opacity:0;animation-delay:.15s}.delai-4{opacity:0;animation-delay:.2s}.delai-5{opacity:0;animation-delay:.25s}.indicateur-live{background:var(--g500);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite clignotant;display:inline-block}.squelette{background:linear-gradient(90deg,var(--gr100)25%,var(--gr200)50%,var(--gr100)75%);border-radius:var(--rayon);background-size:200% 100%;animation:1.5s infinite shimmer}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:16px}.gap-2{gap:8px}.mb-6{margin-bottom:24px}.mb-4{margin-bottom:16px}.mt-6{margin-top:24px}.w-full{width:100%}.text-attenue{color:var(--attenue)}.text-sm{font-size:.83rem}.text-vert{color:var(--g500)}.text-ambre{color:var(--ambre)}.text-rouge{color:var(--rouge)}.font-titre{font-family:var(--font-titre)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:100px}::-webkit-scrollbar-thumb:hover{background:var(--gr400)}
