: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}
/* image du test (crop PDF) */
.tmimg{display:block;width:100%;border:1px solid var(--line);border-radius:8px;margin:4px 0 8px;background:#fff;cursor:zoom-in}
/* lightbox image de test */
#vti-zoom{display:none;position:fixed;inset:0;z-index:1000;background:rgba(20,18,40,.82);align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
#vti-zoom img{max-width:96%;max-height:94%;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5);background:#fff}
/* === formulaire 2 colonnes + boites === */
.fbox{border:1px solid var(--line);border-radius:12px;padding:13px 16px 8px;margin:0 0 14px;background:#fff}
.fbh{display:flex;align-items:center;gap:8px;margin:0 0 8px;color:var(--indigo);font-weight:700;font-size:15px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:2px 16px}
.grid2 .full{grid-column:1 / -1}
.fld{margin:0 0 6px}
.fld label{margin:8px 0 4px}
.fld .hint{font-size:11px;color:#9a9aa5;font-weight:400}
.fld.var label{color:#a15c00}
.fld.var .hint{color:#a15c00}
.fld.var input,.fld.var textarea{border-color:#f0c47a;background:#fffaf0}
.fld.stable .hint{color:#1e7e34}
.pinfo{background:#eef7ef;border:1px solid #cfe8d4;color:#1e7e34;border-radius:9px;padding:8px 11px;font-size:13px;margin:0 0 10px}
@media(max-width:680px){.grid2{grid-template-columns:1fr}}
input[readonly]{background:#eef7ef;border-color:#cfe8d4;color:#1e7e34;cursor:not-allowed}
select:disabled{background:#eef7ef;border-color:#cfe8d4;color:#1e7e34;opacity:1;cursor:not-allowed}
/* ===== plateforme : cartes modules ===== */
.modgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.modcard{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 18px;text-decoration:none;box-shadow:0 5px 20px rgba(37,37,80,.06);transition:transform .12s,box-shadow .12s}
.modcard:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(37,37,80,.12);border-color:var(--mauve)}
.ico-xl{width:38px;height:38px;display:block;margin:0 0 10px;vertical-align:0}
.modname{font-family:'Degular',var(--sans);font-weight:700;color:var(--indigo);font-size:17px;margin-bottom:4px}
.moddesc{color:var(--muted);font-size:13px;line-height:1.4}
/* ===== module électrostimulation ===== */
.egrid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ebox{border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-top:12px}
.eboxh{font-family:'Degular',var(--sans);font-weight:700;color:var(--indigo);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.cmp{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums;margin-top:4px}
.cmp th{text-align:left;font-size:12px;color:var(--muted);font-weight:600;padding:7px 10px;border-bottom:1px solid var(--line)}
.cmp td{padding:8px 10px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
.cmp .mname{font-weight:600;color:var(--indigo)}
.cmp .mu{color:var(--muted);font-size:12px}
.cmp .val{font-weight:700}
.trend-up{color:#2e9e5b;font-weight:600}.trend-down{color:#d05a5a;font-weight:600}.trend-flat{color:#8a8a96}
.sens{font-size:11px;font-weight:700;padding:1px 8px;border-radius:8px;white-space:nowrap}
.sens-fav{background:#e6f4ea;color:#1e7e34}.sens-def{background:#fdeaea;color:#b3261e}.sens-neu{background:#eef0f4;color:#5a5a6a}.sens-info{background:#e7eefb;color:#2a5b9e}
.ecard{padding:12px 14px;border:1px solid var(--line);border-radius:11px;background:#faf9fc}
.ecard-fav{background:#f0f8f3;border-color:#cce8d6}.ecard-def{background:#fdf3f3;border-color:#f3d3d3}.ecard-neu{background:#f6f7f9}
.phasebadge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px;margin-right:6px}
.pb-before{background:#eef0f4;color:#5a5a6a}.pb-after{background:#e7eefb;color:#2a5b9e}
.btn.sm{padding:5px 11px;font-size:12px}
.btn.danger{background:#d05a5a;border-color:#d05a5a;color:#fff}
.btn.danger:hover{background:#b84a4a}
/* ===== modale de confirmation ===== */
.vm-ov{position:fixed;inset:0;background:rgba(37,37,80,.5);z-index:200;align-items:center;justify-content:center}
.vm-modal{background:#fff;border-radius:16px;max-width:430px;width:calc(100% - 40px);padding:22px 24px;box-shadow:0 24px 70px rgba(37,37,80,.4);border-top:4px solid var(--mauve)}
.vm-title{font-family:'Degular',var(--sans);font-weight:700;color:var(--indigo);font-size:18px;margin-bottom:7px}
.vm-msg{color:var(--muted);font-size:14px;line-height:1.5;margin-bottom:18px}
.vm-actions{display:flex;gap:10px;justify-content:flex-end}
/* ===== mes patients ===== */
.psearch{width:100%;max-width:360px;margin-top:12px}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.pcard2{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:0 5px 20px rgba(37,37,80,.05)}
.pcard2-h{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.pavatar{width:40px;height:40px;border-radius:50%;color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 auto}
.pname{font-weight:700;color:var(--indigo);font-size:15px;line-height:1.2}
.pexam{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:9px;text-decoration:none;color:#333;border:1px solid var(--line);margin-top:6px;transition:background .12s,border-color .12s}
.pexam:hover{background:#faf9fc;border-color:var(--mauve)}
.pexam .pdate{font-size:13px}
.pexam .pstatus{margin-left:auto;font-size:11px;color:var(--muted)}
.modtag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:7px;white-space:nowrap}
.modtag-vti{background:#e7e6f2;color:#3a2f6e}
.modtag-electro{background:#e7eefb;color:#2a5b9e}
/* ===== barre utilisateur : nom mis en avant ===== */
.topbar .user .uname{color:#fff;font-weight:700}
.topbar .user .urole{margin-left:8px;background:rgba(247,205,212,.18);color:var(--rose);padding:2px 9px;border-radius:9px;font-size:11.5px;font-weight:700;letter-spacing:.3px}

.topbar nav a.active{font-weight:700}
/* ===== graphiques ECG avant/après ===== */
.ecggrid{display:flex;flex-direction:column;gap:14px}
.ecgrow{border:1px solid var(--line);border-radius:11px;padding:10px 12px;background:#faf9fc}
.ecglabel{font-weight:700;color:var(--indigo);font-size:13px;margin-bottom:8px}
.ecgpair{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
.ecgfig{margin:0;text-align:center}
.ecgfig figcaption{margin-bottom:5px}
.ecgimg{max-width:100%;max-height:190px;width:auto;height:auto;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:zoom-in;display:inline-block}
