:root{--indigo:#252550;--indigo-d:#1f1b3c;--mauve:#b8a2ce;--rose:#f7cdd4;--rose-l:#f7e6f0;--teal:#82c0c7;--ink:#333;--muted:#666;--bg:#f5f5f5;--line:#e7e7ee}
*{box-sizing:border-box}
body{margin:0;font-family:'Degular',system-ui,'Segoe UI',Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--teal)}
.topbar{background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 26px}
.topbar .brand{font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:9px}
.topbar .brand .dot{width:10px;height:10px;background:linear-gradient(90deg,var(--rose),var(--mauve))}
.topbar nav a{color:#cfd0e6;text-decoration:none;margin-left:18px;font-size:14px}
.topbar nav a:hover,.topbar nav a.active{color:#fff}
.topbar .user{font-size:13px;color:#cfd0e6;display:flex;align-items:center;gap:14px}
.btn{display:inline-block;background:var(--indigo);color:#fff;border:0;text-decoration:none;padding:11px 22px;border-radius:9px;font-weight:600;cursor:pointer;font-size:14px}
.btn:hover{background:var(--indigo-d)}
.btn.sm{padding:7px 14px;font-size:13px}
.btn.ghost{background:transparent;color:var(--indigo);border:1px solid var(--indigo)}
.btn.link{background:none;color:#cfd0e6;padding:0;font-weight:500}
.wrap{max-width:1040px;margin:32px auto;padding:0 22px}
.card{background:#fff;border-radius:16px;box-shadow:0 8px 30px rgba(37,37,80,.08);padding:28px 30px;margin-bottom:22px}
h1{color:var(--indigo);margin:0 0 4px;font-size:26px}
h2{color:var(--indigo);font-size:18px;margin:0 0 14px}
.muted{color:var(--muted)}
label{display:block;font-size:13px;font-weight:600;color:#444;margin:14px 0 5px}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--mauve);box-shadow:0 0 0 3px var(--rose-l)}
.alert{padding:11px 14px;border-radius:9px;margin-bottom:14px;font-size:14px}
.alert.err{background:#fdeaea;color:#a12;border:1px solid #f3c7c7}
.alert.ok{background:#e9f6ef;color:#176c3a;border:1px solid #bfe6cf}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:14px}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600}
.badge.admin{background:var(--indigo);color:#fff}.badge.supervisor{background:var(--mauve);color:#fff}.badge.doctor{background:var(--rose-l);color:var(--indigo)}
.badge.off{background:#eee;color:#888}
.loginpage{min-height:100vh;display:flex;align-items:center;justify-content:center}
.loginbox{background:#fff;max-width:420px;width:92%;border-radius:18px;overflow:hidden;box-shadow:0 14px 50px rgba(37,37,80,.15)}
.loginbox .band{height:9px;background:linear-gradient(90deg,var(--rose),var(--mauve))}
.loginbox .in{padding:38px 36px}
.zbadge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700}
.zone-normale{background:#e6f4ea;color:#1e7e34}
.zone-transition{background:#e7eefb;color:#2a5b9e}
.zone-pathologique{background:#fdeaea;color:#b3261e}
.grid6{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.metric{border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.metric .lab{font-size:12px;color:var(--muted)}
.metric .val{font-size:20px;font-weight:700;color:var(--indigo)}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-regular-webfont.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-regularitalic-webfont.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-light-webfont.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-lightitalic-webfont.woff2') format('woff2');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-bold-webfont.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-regular-webfont.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-regularitalic-webfont.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-light-webfont.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-lightitalic-webfont.woff2') format('woff2');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'Degular';src:url('/fonts/degulardisplay-bold-webfont.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
/* ===== resserrage ===== */
.card{padding:15px 20px;margin-bottom:12px;box-shadow:0 5px 20px rgba(37,37,80,.06)}
h1{font-size:21px}
h2{font-size:15px;margin:0 0 8px}
.wrap{margin:20px auto}
/* ===== pictos (mask -> prend la couleur du texte) ===== */
.ico{display:inline-block;width:18px;height:18px;background:currentColor;-webkit-mask:var(--m) no-repeat center/contain;mask:var(--m) no-repeat center/contain;vertical-align:-3px;flex:none}
.ico-lg{width:25px;height:25px;vertical-align:-5px}
.sec-h{display:flex;align-items:center;gap:9px}
.sec-h h1,.sec-h h2{margin:0}
/* ===== accordeon patientes ===== */
details.pcard{background:#fff;border-radius:12px;box-shadow:0 4px 16px rgba(37,37,80,.06);margin-bottom:8px;overflow:hidden}
details.pcard>summary{list-style:none;cursor:pointer;padding:11px 18px;display:flex;justify-content:space-between;align-items:center;gap:14px}
details.pcard>summary::-webkit-details-marker{display:none}
details.pcard>summary:hover{background:#faf9fc}
.pname{font-weight:700;color:var(--indigo);font-size:15px;display:flex;align-items:center;gap:8px}
.pcount{font-size:13px;color:var(--muted);white-space:nowrap;display:flex;align-items:center;gap:9px}
.pcount .chev{display:inline-block;transition:transform .2s;color:var(--mauve);font-size:18px;line-height:1}
details.pcard[open]>summary .chev{transform:rotate(90deg)}
.pexams{padding:2px 18px 11px;border-top:1px solid var(--line)}
.pexams table{margin-top:6px}
/* ===== mesures sur 3 colonnes ===== */
.mcols{column-count:3;column-gap:30px}
@media(max-width:920px){.mcols{column-count:2}}
@media(max-width:600px){.mcols{column-count:1}}
.mtest{break-inside:avoid;margin:0 0 14px}
.mtest h3{color:var(--indigo);font-size:13px;margin:0 0 3px;font-weight:700}
.mrow{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding:4px 0;font-size:13px}
.mrow .mk{color:#555}.mrow .mu{color:#9a9aa5;font-size:11px}.mrow .mv{font-weight:700;color:var(--indigo);white-space:nowrap}
/* ===== polices : Degular = TITRES uniquement ; donnees medicales/chiffres en sans lisible ===== */
:root{--sans:ui-sans-serif,system-ui,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif}
body{font-family:var(--sans)}
h1,h2,h3,.brand,.pname,.mtest h3{font-family:'Degular',var(--sans)}
.metric .val,.mrow,.mrow .mk,.mrow .mv,td,th,.badge,.zbadge,input,select,textarea{font-family:var(--sans)}
.metric .val,.mrow .mv,td{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
/* ===== chaque Test dans une petite boite ===== */
.mcols{column-count:3;column-gap:18px}
@media(max-width:920px){.mcols{column-count:2}}
@media(max-width:600px){.mcols{column-count:1}}
.mtest{break-inside:avoid;margin:0 0 16px;background:#fbfbfd;border:1px solid var(--line);border-radius:10px;padding:10px 13px 5px}
.mtest h3{color:var(--indigo);font-size:13px;margin:0 0 6px;font-weight:700;border-bottom:2px solid var(--rose-l);padding-bottom:5px}
.mrow{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid #f1f1f6;padding:4px 0;font-size:13px}
.mrow:last-child{border-bottom:0}
.mrow .mk{color:#555}.mrow .mu{color:#9a9aa5;font-size:11px}.mrow .mv{font-weight:700;color:var(--indigo);white-space:nowrap}
