@import url('https://fonts.googleapis.com/css2?family=Afacad:wght@400;500;600;700&family=Cormorant+Garamond:wght@500;600;700&display=swap');
:root{
  --menthe:#B2EBC9; --mint:#A8D5C4; --teal:#4C9A84; --teal-bright:#5fc0a4; --teal-deep:#3A7565;
  --taupe:#B8A99A; --creme:#F4F1EB; --sable:#D4C5A0; --gold:#C9A96E;
  --bg:#0e1512; --bg-2:#141d19; --panel:#192420; --panel-2:#1e2b26;
  --line:#2a3a33; --line-soft:#223029;
  --txt:#e8efe9; --txt-dim:#9fb0a7; --txt-faint:#6f8278;
  --danger:#cf8d72; --danger-bg:#241a15; --closed:#161d1a;
  --case-valgen:#1f4233; --case-valgen-br:#4a9c5e;
  --case-double:#2e2348; --case-double-br:#7c5cc4;
  --case-valloc:#2a3320; --case-valloc-br:#4a5535;
  --case-pending:#33301c; --case-pending-br:#5c5430;
  --violet:#a78bfa; --violet-soft:#8b6fd4;
  --age-red:#b5654d; --age-red-bg:#2c1c16; --age-orange:#b08a4d; --age-orange-bg:#2a2316;
  --age-green:#4f9e84; --age-green-bg:#16241f;
  --radius:14px; --radius-sm:9px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Afacad',system-ui,sans-serif;background:radial-gradient(1200px 600px at 80% -10%, rgba(76,154,132,.10), transparent 60%),var(--bg);color:var(--txt);min-height:100vh;-webkit-font-smoothing:antialiased}
.wrap{max-width:1500px;margin:0 auto;padding:0 28px 80px}
.topbar{position:sticky;top:0;z-index:50;background:rgba(14,21,18,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft);margin-bottom:28px}
.topbar-inner{max-width:1500px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:13px}
.logo-mark{width:38px;height:38px;border-radius:11px;flex-shrink:0;background:linear-gradient(150deg,var(--menthe),var(--teal));position:relative;overflow:hidden;box-shadow:0 4px 16px rgba(76,154,132,.35)}
.logo-mark::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 32%, rgba(255,255,255,.85) 0 14%, transparent 15%),linear-gradient(180deg, transparent 52%, rgba(14,21,18,.30) 52%)}
.brand-txt h1{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:22px;letter-spacing:.3px;line-height:1;color:var(--creme)}
.brand-txt span{font-size:12.5px;color:var(--txt-faint);letter-spacing:2.4px;text-transform:uppercase}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hist-btn{font-family:inherit;cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--txt-dim);font-size:13px;font-weight:600;padding:9px 14px;border-radius:10px;transition:.15s}
.hist-btn:hover{border-color:var(--teal);color:var(--txt)}
.mainnav{display:flex;gap:4px;flex-wrap:wrap}
.mainnav a{font-size:14px;font-weight:600;color:var(--txt-dim);text-decoration:none;padding:9px 13px;border-radius:9px;transition:.15s;border-bottom:2px solid transparent}
.mainnav a:hover{color:var(--txt);background:var(--panel)}
.mainnav a.active{color:var(--menthe);border-bottom-color:var(--menthe)}
.mainnav a.admin-link{color:var(--sable)}
.mainnav a.admin-link.active{color:var(--sable);border-bottom-color:var(--sable)}
.mainnav a.owner-link{color:var(--teal-bright)}
.mainnav a.owner-link.active{color:var(--teal-bright);border-bottom-color:var(--teal-bright)}
.user-chip{display:flex;align-items:center;gap:11px;background:var(--panel);border:1px solid var(--line);padding:7px 12px;border-radius:30px}
.user-name{font-size:13.5px;font-weight:600;color:var(--txt)}
.logout{font-size:12.5px;color:var(--txt-faint);text-decoration:none}
.logout:hover{color:var(--danger)}

.flashes{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}
.flash{padding:12px 16px;border-radius:10px;font-size:14px;border:1px solid}
.flash-success{background:var(--case-valgen);color:var(--mint);border-color:var(--case-valgen-br)}
.flash-error{background:var(--danger-bg);color:var(--danger);border-color:rgba(207,141,114,.35)}
.flash-warning{background:var(--case-pending);color:var(--gold);border-color:var(--case-pending-br)}

.view-intro{margin-bottom:22px}
.view-intro .eyebrow{font-size:12.5px;letter-spacing:2.6px;text-transform:uppercase;color:var(--teal-bright);margin-bottom:8px}
.view-intro h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:30px;color:var(--creme)}
.view-intro p{color:var(--txt-dim);font-size:15px;margin-top:6px;max-width:640px;line-height:1.45}

.panel{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel + .panel{margin-top:20px}
.panel-head{padding:18px 22px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.panel-head h3{font-size:16.5px;font-weight:600;color:var(--creme)}
.panel-body{padding:22px}
.scope{font-size:11.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:4px 10px;border-radius:7px}
.scope.loc{background:var(--case-valloc);color:var(--sable);border:1px solid var(--case-valloc-br)}

.my-selector{display:flex;align-items:center;gap:6px}
.my-selector button{width:32px;height:36px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);color:var(--txt-dim);cursor:pointer;font-size:16px}
.my-selector button:hover{border-color:var(--teal);color:var(--txt)}
.my-selector select{font-family:inherit;font-size:14px;font-weight:600;color:var(--txt);background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:8px 10px;cursor:pointer}

.dow{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}
.dow span{text-align:center;font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt-faint);font-weight:600}
.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cell{min-height:74px;border-radius:var(--radius-sm);border:1px solid var(--line-soft);background:var(--panel-2);padding:8px 9px;position:relative;display:flex;flex-direction:column;transition:.14s}
.cell.empty{background:transparent;border-color:transparent}
.cell .dnum{font-size:13.5px;font-weight:600;color:var(--txt-dim)}
.cell.today{outline:2px solid rgba(178,235,201,.35);outline-offset:-2px}
.cell.today .dnum{color:var(--menthe)}
.cell.closed{background:var(--closed);border-color:transparent}
.cell.closed .dnum{color:var(--txt-faint);opacity:.5}
.cell.selectable,.cell.clickable{cursor:pointer}
.cell.selectable:hover,.cell.clickable:hover{border-color:var(--teal-bright);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.3)}
.cell.c-valgen{background:var(--case-valgen);border-color:var(--case-valgen-br)}
.cell.c-double{background:var(--case-double);border-color:var(--case-double-br)}
.cell.c-double .badge-mini{background:rgba(167,139,250,.22);color:var(--violet)}
.cell.c-valloc{background:var(--case-valloc);border-color:var(--case-valloc-br)}
.cell.c-pending{background:var(--case-pending);border-color:var(--case-pending-br)}
.cell.selected{outline:2px solid var(--menthe);outline-offset:-2px}
.cell.free-admin .add-hint{margin-top:auto;font-size:11px;color:var(--txt-faint);opacity:0;transition:.15s}
.cell.free-admin:hover .add-hint{opacity:1;color:var(--teal-bright)}
.add-hint{margin-top:auto;font-size:11px;color:var(--txt-faint);opacity:0;transition:.15s}
.cell.selectable:hover .add-hint{opacity:1;color:var(--teal-bright)}
.badge-mini{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:6px;margin-top:auto;width:fit-content;background:rgba(178,235,201,.18);color:var(--menthe)}
.badge-mini.v-loc{background:rgba(212,197,160,.18);color:var(--sable)}
.badge-mini.pend{background:rgba(201,169,110,.2);color:var(--gold)}
.badge-mini.interne{background:rgba(168,213,196,.14);color:var(--mint)}
.badge-mini.to-assign{background:rgba(201,169,110,.18);color:var(--gold);font-style:italic}
.agecount{position:absolute;top:6px;right:7px;font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px}
.agecount.red{background:var(--age-red-bg);color:var(--age-red)} .agecount.orange{background:var(--age-orange-bg);color:var(--age-orange)} .agecount.green{background:var(--age-green-bg);color:var(--age-green)}
.closed-tag{margin-top:auto;font-size:10px;font-weight:600;color:var(--txt-faint)}
.prog-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--mint);margin-right:3px}
.more-badge{font-size:9.5px;font-weight:700;color:var(--txt-faint);margin-top:2px}

.legend-bar{display:flex;gap:16px;flex-wrap:wrap;padding:13px 22px;border-bottom:1px solid var(--line-soft)}
.legend-bar span{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--txt-dim)}
.legend-bar i{width:13px;height:13px;border-radius:4px;border:1px solid rgba(255,255,255,.08)}
.lg-valgen{background:var(--case-valgen);border-color:var(--case-valgen-br)} .lg-double{background:var(--case-double);border-color:var(--violet)} .lg-valloc{background:var(--case-valloc);border-color:var(--case-valloc-br)} .lg-pend{background:var(--case-pending);border-color:var(--case-pending-br)} .lg-we{background:var(--closed)}

.fused{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}
@media(max-width:1120px){.fused{grid-template-columns:1fr}}
.side-col{display:flex;flex-direction:column;gap:20px;position:sticky;top:90px}

.detail-pane{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.dp-empty{padding:40px 24px;text-align:center;color:var(--txt-faint)}
.dp-head{padding:18px 20px;border-bottom:1px solid var(--line-soft);display:flex;align-items:flex-start;justify-content:space-between}
.dp-date{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600;color:var(--creme)}
.dp-sub{font-size:12.5px;color:var(--txt-faint)}
.dp-body{padding:18px 20px}
.dp-head .x,.drawer-head .x{cursor:pointer;color:var(--txt-faint);font-size:22px;background:none;border:0}
.nature-banner{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;margin-bottom:14px;font-size:13.5px;font-weight:600}
.nb-new{background:rgba(95,192,164,.12);color:var(--teal-bright);border:1px solid rgba(95,192,164,.3)}
.nb-change{background:rgba(212,197,160,.12);color:var(--sable);border:1px solid rgba(212,197,160,.3)}
.nb-cancel{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(207,141,114,.3)}
.nb-special{background:rgba(201,169,110,.12);color:var(--gold);border:1px solid rgba(201,169,110,.3)}
.age-block{display:flex;align-items:center;gap:12px;padding:14px;border-radius:11px;margin-bottom:16px;border:1px solid}
.age-block.red{background:var(--age-red-bg);border-color:rgba(181,101,77,.35)}
.age-block.orange{background:var(--age-orange-bg);border-color:rgba(176,138,77,.35)}
.age-block.green{background:var(--age-green-bg);border-color:rgba(79,158,132,.35)}
.age-num{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;line-height:1}
.age-block.red .age-num{color:var(--age-red)} .age-block.orange .age-num{color:var(--age-orange)} .age-block.green .age-num{color:var(--age-green)}
.age-lbl{font-size:12.5px;color:var(--txt-dim);line-height:1.4}
.dp-line{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--txt-dim);padding:9px 0;border-bottom:1px solid var(--line-soft)}
.dp-line:last-of-type{border-bottom:0}
.dpl-k{color:var(--txt-faint);min-width:90px}
.dpl-v{color:var(--txt);font-weight:600;margin-left:auto;text-align:right}
.dpl-v a{color:var(--teal-bright);text-decoration:none}
.dp-context{margin-top:14px;padding:12px 14px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:10px;font-size:12.5px;color:var(--txt-dim);line-height:1.6}
.dp-actions{display:flex;gap:9px;padding:16px 20px;border-top:1px solid var(--line-soft);flex-wrap:wrap}
.dp-actions .btn{flex:1;justify-content:center;min-width:120px}
.dp-resa{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:10px;padding:12px 14px;margin-bottom:10px}
.dp-resa.to-assign-card{border-color:var(--case-pending-br);background:rgba(51,48,28,.4)}
.dp-resa-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.dp-resa-name{font-size:14px;font-weight:600;color:var(--txt)}
.dp-resa-meta{font-size:12px;color:var(--txt-faint);margin-bottom:10px}
.dp-resa-acts{display:flex;gap:6px;flex-wrap:wrap}
.manual-bar{padding:14px 20px;border-top:1px solid var(--line-soft);background:rgba(0,0,0,.12)}
.manual-bar-title{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--txt-faint);font-weight:700;margin-bottom:10px}
.manual-grid{display:flex;gap:8px;flex-wrap:wrap}
.manual-grid .btn{flex:1;min-width:130px;justify-content:center}

.bloc-tag{font-size:11.5px;font-weight:700;color:#06120e;background:var(--menthe);padding:3px 9px;border-radius:7px}
.bloc-tag.loc{background:var(--sable)}

.queue-list{display:flex;flex-direction:column}
.ql-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--line-soft);cursor:pointer}
.ql-item:last-child{border-bottom:0}
.ql-age{width:42px;height:42px;border-radius:10px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700}
.ql-age.red{background:var(--age-red-bg);color:var(--age-red)} .ql-age.orange{background:var(--age-orange-bg);color:var(--age-orange)} .ql-age.green{background:var(--age-green-bg);color:var(--age-green)}
.ql-age .qn{font-size:17px;line-height:1} .ql-age .qj{font-size:8.5px;letter-spacing:.5px;opacity:.8}
.ql-body{flex:1;min-width:0}
.ql-body .qt{font-size:13.5px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ql-body .qs{font-size:11.5px;color:var(--txt-faint)}
.ql-kind{font-size:9.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:1px 6px;border-radius:5px;margin-top:3px;display:inline-block}
.ql-kind.new{background:rgba(95,192,164,.14);color:var(--teal-bright)} .ql-kind.change{background:rgba(212,197,160,.14);color:var(--sable)} .ql-kind.cancel{background:var(--danger-bg);color:var(--danger)} .ql-kind.special{background:rgba(201,169,110,.14);color:var(--gold)}

.btn{font-family:inherit;cursor:pointer;border:1px solid var(--line);background:var(--panel-2);color:var(--txt);font-size:13px;font-weight:600;padding:8px 13px;border-radius:8px;transition:.15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.btn:hover{border-color:var(--teal)}
.btn.primary{background:var(--menthe);color:#06120e;border-color:var(--menthe)}
.btn.primary:hover{background:var(--teal-bright);border-color:var(--teal-bright)}
.btn.ghost-danger{color:var(--danger);border-color:rgba(207,141,114,.3)}
.btn.ghost-danger:hover{background:var(--danger-bg);border-color:var(--danger)}
.btn.sm{padding:6px 11px;font-size:12.5px}
.btn.tiny{padding:4px 9px;font-size:11.5px}
.btn:disabled{opacity:.4;cursor:not-allowed}

.stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:22px;max-width:420px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600;line-height:1;color:var(--creme)}
.stat .l{font-size:12px;color:var(--txt-faint);margin-top:5px}
.stat.warn .n{color:var(--gold)} .stat.ok .n{color:var(--menthe)}

table.data{width:100%;border-collapse:collapse}
table.data th{text-align:left;font-size:11.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--txt-faint);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}
table.data td{padding:13px 12px;border-bottom:1px solid var(--line-soft);font-size:13.5px;color:var(--txt-dim);vertical-align:middle}
.tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.tag.interne{background:rgba(95,192,164,.14);color:var(--teal-bright)}
.tag.externe{background:rgba(212,197,160,.14);color:var(--sable)}
.tag.role-admin{background:rgba(201,169,110,.18);color:var(--gold)}
.tag.role-clinilac{background:rgba(95,192,164,.16);color:var(--teal-bright)}
.tag.role-chirurgien{background:rgba(168,213,196,.14);color:var(--mint)}
.tag.on{background:var(--case-valgen);color:var(--mint)} .tag.off{background:var(--danger-bg);color:var(--danger)}

.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--txt-dim);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:14px;color:var(--txt);background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:11px 13px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}}
.field.full{grid-column:1/-1}

.overlay{position:fixed;inset:0;background:rgba(6,12,9,.72);backdrop-filter:blur(5px);z-index:100;display:none;align-items:center;justify-content:center;padding:24px}
.overlay.show{display:flex}
.modal{width:100%;max-width:480px;background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:18px;overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.modal-head{padding:20px 22px;border-bottom:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:flex-start}
.modal-head h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--creme)}
.modal-body{padding:22px;overflow-y:auto}
.modal-foot{padding:18px 22px;border-top:1px solid var(--line-soft);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}

.drawer-overlay{position:fixed;inset:0;background:rgba(6,12,9,.6);backdrop-filter:blur(3px);z-index:150;opacity:0;pointer-events:none;transition:.25s}
.drawer-overlay.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:430px;max-width:92vw;background:linear-gradient(180deg,var(--panel),var(--bg-2));border-left:1px solid var(--line);z-index:160;transform:translateX(100%);transition:.28s;display:flex;flex-direction:column}
.drawer.show{transform:none}
.drawer-head{padding:20px 22px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between}
.drawer-head h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--creme)}
.drawer-body{padding:8px 22px 22px;overflow-y:auto;flex:1}
.timeline{position:relative;padding-left:24px}
.timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--line-soft)}
.tl-item{position:relative;padding:14px 0}
.tl-dot{position:absolute;left:-24px;top:18px;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg);background:var(--teal)}
.tl-dot.val{background:var(--teal-bright)} .tl-dot.refused{background:var(--danger)} .tl-dot.mod{background:var(--sable)} .tl-dot.create{background:var(--mint)} .tl-dot.prog{background:var(--teal-deep)}
.tl-when{font-size:11.5px;color:var(--txt-faint)}
.tl-title{font-size:13.5px;font-weight:600;color:var(--txt)}
.tl-desc{font-size:12.5px;color:var(--txt-dim);line-height:1.5}

/* auth pages */
.auth-wrap{max-width:420px;margin:60px auto;padding:0 24px}
.auth-card{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:18px;padding:36px}
.auth-card h2{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--creme);margin-bottom:6px;text-align:center}
.auth-card .sub{font-size:13.5px;color:var(--txt-faint);text-align:center;margin-bottom:24px}
.auth-card .btn{width:100%;justify-content:center;padding:12px;font-size:15px;margin-top:6px}

/* programme op */
.prog-card{background:var(--bg-2);border:1px solid var(--line);border-radius:12px;margin-bottom:16px;overflow:hidden}
.prog-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line-soft);background:rgba(0,0,0,.12);flex-wrap:wrap}
.prog-date{font-size:14.5px;font-weight:600;color:var(--txt)}
.prog-row{display:grid;grid-template-columns:28px 1fr auto;gap:12px;align-items:center;padding:11px 18px;border-bottom:1px solid var(--line-soft)}
.prog-row:last-child{border-bottom:0}
.prog-order{width:24px;height:24px;border-radius:6px;background:var(--panel-2);border:1px solid var(--line);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--teal-bright)}
.prog-int{font-size:13.5px;color:var(--txt)}
.prog-int small{display:block;font-size:11.5px;color:var(--txt-faint);margin-top:2px}
.pat-initials{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:600;color:var(--sable);letter-spacing:1px}
.prog-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 18px;background:rgba(0,0,0,.12);border-top:1px solid var(--line-soft);flex-wrap:wrap}
.st-tag{font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;padding:4px 9px;border-radius:20px}
.st-tag.pending{background:var(--case-pending);color:var(--gold)} .st-tag.validated{background:var(--case-valgen);color:var(--mint)} .st-tag.draft{background:rgba(157,176,167,.12);color:var(--txt-dim)}
.info-bar{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;background:linear-gradient(135deg,rgba(95,192,164,.08),rgba(95,192,164,.02));border:1px solid rgba(95,192,164,.2);border-radius:12px;margin-bottom:20px;font-size:13px;color:var(--txt-dim);line-height:1.55}
.empty-state{text-align:center;padding:46px 16px;color:var(--txt-faint)}

/* recap */
.recap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}
.rcell{min-height:78px;border-radius:10px;border:1px solid var(--line-soft);background:var(--panel-2);padding:7px 8px;display:flex;flex-direction:column;position:relative}
.rcell.empty{background:transparent;border:0}
.rcell.closed{background:var(--closed)}
.rcell .rd{font-size:13px;font-weight:700;color:var(--txt-dim)}
.rcell.c-valgen{background:var(--case-valgen);border-color:var(--case-valgen-br)}
.rcell.c-double{background:var(--case-double);border-color:var(--case-double-br)}
.rcell.c-double .rdoc{color:var(--violet)}
.rcell.c-valloc{background:var(--case-valloc);border-color:var(--case-valloc-br)}
.rcell.c-pending{background:var(--case-pending);border-color:var(--case-pending-br)}
.rdoc{font-size:11px;font-weight:600;line-height:1.3;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt)}
.dbl-flag{position:absolute;top:6px;right:7px;font-size:8px;font-weight:700;color:#fff;background:var(--violet-soft);padding:1px 5px;border-radius:4px}
.recap-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;margin-bottom:7px}
.recap-dow span{text-align:center;font-size:11px;text-transform:uppercase;color:var(--txt-faint);font-weight:600}

/* synoptique */
.syn-scroll{overflow-x:auto;padding-bottom:8px}
.syn{border-collapse:separate;border-spacing:2px;min-width:100%}
.syn td.mname{font-size:12px;font-weight:600;color:var(--txt-dim);padding:4px 10px 4px 4px;text-align:right;white-space:nowrap}
.syn-day{width:15px;height:22px;border-radius:3px;background:var(--panel-2)}
.syn-day.we{background:var(--closed)} .syn-day.gen{background:var(--case-valgen-br)} .syn-day.double{background:var(--violet-soft);box-shadow:inset 0 0 0 1px var(--violet)} .syn-day.loc{background:var(--case-valloc-br)} .syn-day.pend{background:var(--case-pending-br)}
.syn-mlabel{font-size:11.5px;color:var(--txt-dim);font-weight:700;padding:10px 4px 4px}

.hint{font-size:11.5px;color:var(--txt-faint);margin-top:5px}
.req{color:var(--sable)}
.hide{display:none!important}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.qr-img{display:block;margin:16px auto;background:#fff;padding:10px;border-radius:10px;max-width:220px}
.secret-code{font-family:monospace;font-size:15px;color:var(--gold);background:var(--bg-2);padding:10px 14px;border-radius:8px;text-align:center;letter-spacing:2px;border:1px solid var(--line)}

/* ===== Encart historique dans le volet latéral (Validation) ===== */
.dp-histo{margin:16px 14px 4px;padding:14px 16px;background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:12px}
.dp-histo-title{font-size:12px;letter-spacing:1.2px;text-transform:uppercase;color:var(--txt-faint);font-weight:600;margin-bottom:12px}
.dp-histo .tl-mini{position:relative;padding-left:24px;border-left:2px solid var(--line);margin-left:6px}
.dp-histo .tl-item{padding:9px 0}
.dp-histo .tl-when{font-size:11px;color:var(--txt-faint);margin-bottom:2px}
.dp-histo .tl-title{font-size:13px;color:var(--txt);font-weight:600}
.dp-histo .tl-desc{font-size:12px;color:var(--txt-dim);margin-top:2px}
.dp-histo .tl-empty{font-size:12.5px;color:var(--txt-faint);font-style:italic}

/* ===== Sélecteur de bloc (réaffectation) ===== */
.bloc-pick{display:flex;flex-direction:column;gap:10px}
.bp-opt{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s}
.bp-opt:hover{border-color:var(--teal)}
.bp-opt input{accent-color:var(--teal)}
.bp-name{font-weight:600;color:var(--txt);flex:1}
.bp-state{font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--txt-faint)}
.bp-dis{opacity:.45;cursor:not-allowed}
.bp-dis:hover{border-color:var(--line)}

/* ===== Indicateurs validation/verrou dans le volet ===== */
.dp-resa-valid{font-size:11.5px;color:var(--teal-bright);margin-top:6px;font-weight:600}
.dp-resa-locked{font-size:12px;color:var(--txt-faint);font-style:italic;margin-top:8px;padding:8px 10px;background:rgba(255,255,255,.02);border:1px dashed var(--line);border-radius:8px}

/* ===== Propositions proactives (turquoise) ===== */
:root{ --turq:#1fb6c9; --turq-soft:rgba(31,182,201,.14); --turq-line:rgba(31,182,201,.45);
       --turq-fill:#155e68; --turq-fill-br:#1fb6c9; }
/* Case proposée : TOUTE la case devient turquoise, visible de loin, des deux
   côtés (Clinilac et chirurgien). Fond plein + bordure marquée. */
.cell.c-prop{background:var(--turq-fill);border-color:var(--turq-fill-br);box-shadow:inset 0 0 0 1px var(--turq-fill-br)}
.cell.c-prop .dnum{color:#d6f5fa}
.cell.c-prop .badge-mini.prop-turq{background:rgba(255,255,255,.16);color:#eafcff;border:1px solid rgba(255,255,255,.3);font-weight:700}
.badge-mini.prop-turq{background:var(--turq-soft);color:var(--turq);border:1px solid var(--turq-line);font-weight:600}
.prop-btn{color:var(--turq);border-color:var(--turq-line)!important}
.prop-btn:hover:not(:disabled){background:var(--turq-soft)}

/* Encart propositions dans le volet */
.prop-encart{margin:14px;padding:14px 16px;background:var(--turq-soft);border:1px solid var(--turq-line);border-radius:12px}
.prop-encart-title{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--turq);font-weight:700;margin-bottom:12px}
.prop-row-turq{padding:10px 0;border-bottom:1px solid var(--turq-line)}
.prop-row-turq:last-child{border-bottom:0;padding-bottom:0}
.prop-row-info{display:flex;align-items:center;gap:10px;margin-bottom:3px}
.prop-row-name{font-weight:600;color:var(--txt)}
.prop-row-bloc{font-size:11px;color:var(--turq);background:rgba(31,182,201,.1);padding:1px 7px;border-radius:6px}
.prop-row-exp{font-size:11.5px;color:var(--txt-faint);margin-bottom:6px}
.prop-row-acts{display:flex;gap:6px}

/* Modale proposer : multi-sélection chirurgiens */
.prop-surgeons{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto;border:1px solid var(--line);border-radius:10px;padding:10px}
.prop-check{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;cursor:pointer;font-size:13.5px}
.prop-check:hover{background:rgba(255,255,255,.03)}
.prop-check input{accent-color:var(--turq)}

/* Page chirurgien : cartes de propositions reçues */
.prop-list{display:flex;flex-direction:column;gap:14px;max-width:640px}
.prop-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;background:var(--turq-soft);border:1px solid var(--turq-line);border-radius:14px;flex-wrap:wrap}
.prop-badge-turq{display:inline-block;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--turq);font-weight:700;margin-bottom:6px}
.prop-date{font-size:18px;font-weight:600;color:var(--txt)}
.prop-meta{font-size:13px;color:var(--txt-dim);margin-top:2px}
.prop-expire{font-size:12px;color:var(--txt-faint);margin-top:6px}
.prop-card-acts{display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   Champ mot de passe avec petit œil afficher/masquer
   ============================================================ */
.pwd-wrap{position:relative}
.pwd-wrap input{padding-right:42px}
.pwd-eye{position:absolute;top:50%;right:6px;transform:translateY(-50%);width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--txt-faint);border-radius:7px;transition:.15s;padding:0}
.pwd-eye:hover{color:var(--txt-dim);background:rgba(255,255,255,.04)}
.pwd-eye svg{width:18px;height:18px;display:block;pointer-events:none}
.pwd-eye .eye-off{display:none}
.pwd-eye.shown .eye-on{display:none}
.pwd-eye.shown .eye-off{display:block}

/* ============================================================
   Discussion par date (v1.13) — fil de messages + saisie
   ============================================================ */
.disc-encart{margin:16px 14px 4px;padding:14px 16px;background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:12px}
.disc-title{font-size:12px;letter-spacing:1.2px;text-transform:uppercase;color:var(--txt-faint);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.disc-thread{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow-y:auto;margin-bottom:12px}
.disc-empty{font-size:12.5px;color:var(--txt-faint);font-style:italic;padding:6px 0}
.msg{max-width:85%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.45}
.msg .msg-meta{font-size:10.5px;color:var(--txt-faint);margin-bottom:3px}
.msg-chir{align-self:flex-start;background:var(--bg-2);border:1px solid var(--line-soft);border-bottom-left-radius:4px}
.msg-clin{align-self:flex-end;background:var(--case-valgen);border:1px solid var(--case-valgen-br);border-bottom-right-radius:4px}
.msg-clin .msg-meta{color:var(--mint)}
.disc-form{display:flex;flex-direction:column;gap:8px}
.disc-form textarea{width:100%;font-family:inherit;font-size:13px;color:var(--txt);background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;resize:vertical;min-height:60px}
.disc-form textarea:focus{outline:none;border-color:var(--teal)}

/* Onglet Discussions — liste des fils */
.thread-list{display:flex;flex-direction:column;gap:12px}
.thread-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:12px;cursor:pointer;transition:.15s;text-decoration:none}
.thread-card:hover{border-color:var(--teal)}
.thread-when{font-size:12px;color:var(--txt-faint)}
.thread-who{font-size:14.5px;font-weight:600;color:var(--txt)}
.thread-last{font-size:12.5px;color:var(--txt-dim);margin-top:3px}
.thread-badge{background:var(--menthe);color:#06120e;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.nav-pastille{display:inline-block;min-width:17px;height:17px;line-height:17px;text-align:center;background:var(--menthe);color:#06120e;font-size:10.5px;font-weight:700;border-radius:9px;padding:0 5px;margin-left:5px}
