/* ============================================================
   panel.css — side panel (Operatory / Provider / Assistant)
   Priority redesign target, brief §7
   ============================================================ */

.scrim{position:fixed;inset:0;background:rgba(26,26,26,.18);opacity:0;pointer-events:none;transition:opacity .22s;z-index:40}
.scrim.open{opacity:1;pointer-events:auto}

.panel{position:fixed;top:0;right:0;height:100vh;width:480px;max-width:94vw;background:var(--surface);box-shadow:var(--shadow-pop);transform:translateX(100%);transition:transform .26s cubic-bezier(.4,.0,.2,1);z-index:50;display:flex;flex-direction:column}
.panel.open{transform:translateX(0)}

/* header */
.panel .phead{padding:22px 24px 18px;border-bottom:1px solid var(--line)}
.panel .phead .row1{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.panel .phead .eyebrow{display:block;margin-bottom:8px}
.panel .phead h3{font-family:var(--hero);font-weight:400;font-size:23px;margin:0;letter-spacing:-.01em;line-height:1.05}
.panel .phead .when{color:var(--ink-2);font-size:13px;margin-top:5px}
.panel .closex{border:1px solid var(--line);background:var(--surface);width:32px;height:32px;border-radius:8px;cursor:pointer;color:var(--ink-2);font-size:16px;line-height:1;flex:0 0 auto}

/* provider summary chip-line */
.panel .psummary{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.panel .psummary .badge{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:500;border:1px solid var(--line);border-radius:20px;padding:5px 11px;color:var(--ink-2)}
.panel .psummary .badge .chip{width:9px;height:9px;border-radius:3px}
.panel .psummary .badge.alert{color:var(--red);background:var(--red-soft);border-color:#f3c9c9}
.panel .psummary .badge.ok{color:var(--green);background:var(--green-soft);border-color:#bfe6cc}
.panel .psummary .badge.warn{color:var(--amber);background:var(--amber-soft);border-color:#eccfa0}
.panel .outtoggle{margin-left:auto;border:1px solid var(--line);background:var(--surface);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer}
.panel .outtoggle.on{background:var(--red-soft);border-color:#f1c9c9;color:var(--red);font-weight:600}

/* inline doctor-out control (replaces browser prompt) */
.outctl{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line)}
.outctl .outlbl{font-size:12px;color:var(--ink-2);margin-right:2px}
.outctl .outopt{border:1px solid var(--line);background:var(--surface);border-radius:7px;padding:5px 11px;font-size:12px;font-weight:500;color:var(--ink);cursor:pointer}
.outctl .outopt:hover{border-color:var(--red);color:var(--red);background:var(--red-soft)}
.outctl .outnow{font-size:12px;font-weight:600;color:var(--red);background:var(--red-soft);border:1px solid #f1c9c9;border-radius:20px;padding:4px 12px}
.outctl .outback{border:1px solid var(--line);background:var(--surface);border-radius:7px;padding:5px 11px;font-size:12px;font-weight:500;color:var(--ink);cursor:pointer}

/* body */
.panel .pbody{flex:1;overflow-y:auto;padding:20px 24px 24px}
.panel .sectlab{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.panel .sectlab .eyebrow{font-size:10px}
.panel .sectlab .editbtn{border:1px solid var(--line);background:var(--surface);border-radius:7px;padding:5px 11px;font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;display:flex;align-items:center;gap:6px}
.panel .sectlab .editbtn.on{background:var(--nwdc);color:#fff;border-color:var(--nwdc)}
.panel.loc-bcdc .sectlab .editbtn.on{background:var(--bcdc);border-color:var(--bcdc)}

/* ---------- the 3-column operatory table ---------- */
.optable{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.optable thead th{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-weight:500;text-align:left;padding:10px 14px;background:#FCFAF6;border-bottom:1px solid var(--line)}
.optable tbody td{padding:0;border-bottom:1px solid var(--line);vertical-align:middle;height:46px}
.optable tbody tr:last-child td{border-bottom:0}
.optable tbody tr.empty-op td{color:var(--ink-3)}
.optable tbody tr:hover{background:#FCFAF6}

.optable .opcol{width:88px;padding:0 14px;font-weight:600;font-size:12.5px;color:var(--ink-2);border-right:1px solid var(--line)}
.optable .opcol .lab-tag{font-family:var(--mono);font-size:9px;color:var(--ink-3);display:block;font-weight:500;letter-spacing:.06em}

.optable .provcol{padding:0 14px;border-right:1px solid var(--line)}
.optable .provcol .pv{display:flex;align-items:center;gap:8px}
.optable .provcol .pv .chip{width:9px;height:9px;border-radius:3px;flex:0 0 auto}
.optable .provcol .pv .nm{font-size:13px;font-weight:500}
.optable .provcol .muted{color:var(--ink-3);font-size:12.5px}

.optable .asstcol{padding:0 14px;font-size:13px}
.optable .asstcol .name{font-weight:500;margin-right:8px;display:inline-flex;align-items:center;gap:2px}
.optable .asstcol .name.shared{color:var(--amber);font-weight:600}
.optable .asstcol .name .shr{color:var(--amber)}
.optable .asstcol .shared-tag{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;color:var(--amber);background:var(--amber-soft);padding:2px 7px;border-radius:20px}
.optable .asstcol .need-tag{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.04em;color:var(--red);background:var(--red-soft);padding:2px 7px;border-radius:20px}
.optable tbody tr.me{background:var(--nwdc-soft)}
.optable tbody tr.support-row{background:#FBFAF7}
.optable tbody tr.support-row .opcol{color:var(--ink-2)}
.optable tbody tr.support-row td{border-top:1px solid var(--line)}
.panel.loc-bcdc .optable tbody tr.me{background:var(--bcdc-soft)}
.optable tbody tr.me:hover{background:var(--nwdc-soft)}

/* available-this-day strip */
.availbox{margin-top:20px;border-top:1px solid var(--line);padding-top:16px}
.availbox .eyebrow{display:block;margin-bottom:10px}
.availchips{display:flex;flex-wrap:wrap;gap:6px}
.availchips .freechip{font-size:12px;font-weight:500;color:var(--ink);border:1px solid var(--amber);background:var(--amber-soft);border-radius:20px;padding:4px 11px}
.availchips .none{font-size:12.5px;color:var(--ink-3)}

/* edit mode: dropdown */
.optable select{font-family:inherit;font-size:13px;border:1px solid var(--line-strong);border-radius:7px;padding:6px 8px;background:var(--surface);color:var(--ink);width:100%;max-width:170px;cursor:pointer}
.optable select:focus{outline:2px solid var(--nwdc);outline-offset:-1px}

/* footer */
.panel .pfoot{border-top:1px solid var(--line);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:#FCFAF6}
.panel .pfoot .note{font-size:11.5px;color:var(--ink-3)}
.panel .pfoot .btnrow{display:flex;gap:8px}
.panel .pfoot button{border-radius:8px;padding:8px 15px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--line)}
.panel .pfoot .ghost{background:var(--surface);color:var(--ink)}
.panel .pfoot .primary{background:var(--nwdc);color:#fff;border-color:var(--nwdc)}
.panel.loc-bcdc .pfoot .primary{background:var(--bcdc);border-color:var(--bcdc)}
