/* ==========================================================================
   PraxisSafe Pro · pro.css
   ========================================================================== */
:root{
  --ink:#0f1614; --ink-2:#2a3330; --muted:#5d6b66;
  --paper:#faf7f2; --paper-2:#f1ece2; --line:#e2ddd1; --line-2:#d4cdbd;
  --teal:#0f3b3a; --teal-2:#1a5755; --teal-ink:#07201f;
  --clay:#c45a3b; --clay-2:#a74728; --sand:#e8dcc2;
  --ok:#2f7d52; --ok-bg:#e3f1e8; --warn:#b9791f; --warn-bg:#f7eed9; --danger:#b13a2a; --danger-bg:#f6e2dd;
  --radius:14px; --radius-sm:9px;
  --shadow-soft:0 2px 0 rgba(15,22,20,.03), 0 10px 30px -12px rgba(15,22,20,.14);
  --font-display:"Fraunces", Georgia, serif;
  --font-body:"Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}
#pro-root, #pro-root *, .pro-modal, .pro-modal *, .pro-toast-stack, .pro-toast-stack *{ box-sizing:border-box; }

#pro-root{
  font-family:var(--font-body); color:var(--ink); min-height:100vh;
  background:
    radial-gradient(1100px 600px at 90% -10%, rgba(196,90,59,.07), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(15,59,58,.06), transparent 60%),
    var(--paper);
}
.pro-loading{ padding:60px; text-align:center; color:var(--muted); }

/* shell */
.pro-shell{ max-width:1080px; margin:0 auto; padding:0 20px 60px; }
.pro-top{ display:flex; align-items:center; justify-content:space-between; padding:18px 0; }
.pro-brand{ display:flex; align-items:center; gap:10px; color:var(--teal); font-family:var(--font-display); font-size:1.3rem; }
.pro-brand svg{ color:var(--clay); }
.pro-brand b{ color:var(--clay); font-weight:600; }
.pro-top-right{ display:flex; align-items:center; gap:12px; font-size:.92rem; }
.pro-role-badge{ background:var(--teal); color:#fff; padding:3px 11px; border-radius:999px; font-size:.78rem; font-weight:600; }
.pro-user{ color:var(--ink-2); font-weight:600; }

.pro-context{ display:flex; justify-content:space-between; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:14px 18px; box-shadow:var(--shadow-soft); }
.pro-ctx-label{ display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-bottom:3px; }
.pro-practice-name{ font-family:var(--font-display); font-size:1.25rem; color:var(--teal-ink); }
.pro-select{ font:inherit; padding:9px 12px; border:1px solid var(--line-2); border-radius:10px; background:var(--paper); min-width:280px; }

.pro-tabs{ display:flex; gap:6px; margin:18px 0; flex-wrap:wrap; }
.pro-tab{ border:1px solid var(--line); background:#fff; color:var(--ink-2); padding:9px 16px; border-radius:999px; cursor:pointer; font:inherit; font-weight:600; font-size:.92rem; }
.pro-tab.active{ background:var(--teal); color:#fff; border-color:var(--teal); }

.pro-content{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 28px; box-shadow:var(--shadow-soft); min-height:300px; }
.pro-card-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:18px; }
.pro-card-head h2{ font-family:var(--font-display); font-weight:600; margin:0; font-size:1.5rem; color:var(--teal-ink); }
.pro-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.pro-muted{ color:var(--muted); }
.pro-note{ margin-top:20px; font-size:.82rem; color:var(--muted); border-top:1px solid var(--line); padding-top:14px; }
.pro-empty{ padding:40px 10px; text-align:center; color:var(--muted); }

/* KPIs */
.pro-kpis{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.pro-kpi{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius-sm); padding:14px 16px; }
.pro-kpi-label{ display:block; font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); }
.pro-kpi-val{ font-family:var(--font-display); font-size:1.7rem; color:var(--teal-ink); }
.pro-panel{ margin-top:22px; }
.pro-panel h3{ font-family:var(--font-display); margin:0 0 8px; }
.pro-list-plain{ list-style:none; padding:0; margin:0; }
.pro-list-plain li{ padding:6px 0; border-bottom:1px solid var(--line); }
.pro-list-plain li:last-child{ border-bottom:0; }

/* buttons */
.pro-btn{ display:inline-block; border:0; cursor:pointer; text-decoration:none; font-family:var(--font-body); font-weight:600; border-radius:999px; padding:10px 18px; font-size:.92rem; transition:transform .1s ease; }
.pro-btn:hover{ transform:translateY(-1px); }
.pro-btn-sm{ padding:7px 14px; font-size:.86rem; }
.pro-btn-xs{ padding:5px 10px; font-size:.8rem; }
.pro-btn-primary{ background:var(--teal); color:#fff; }
.pro-btn-clay{ background:var(--clay); color:#fff; }
.pro-btn-ghost{ background:transparent; color:var(--teal); border:1px solid var(--line-2); }
.pro-btn:disabled{ opacity:.6; cursor:default; transform:none; }

/* tables / lists */
.pro-table{ width:100%; border-collapse:collapse; }
.pro-table th{ text-align:left; font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); padding:8px 10px; border-bottom:2px solid var(--line); }
.pro-table td{ padding:11px 10px; border-bottom:1px solid var(--line); vertical-align:top; }
.pro-sub{ font-size:.82rem; color:var(--muted); margin-top:2px; }
.pro-row-actions{ display:flex; gap:6px; flex-wrap:wrap; }

.pro-badge{ display:inline-block; padding:3px 10px; border-radius:999px; font-size:.76rem; font-weight:600; background:var(--paper-2); color:var(--ink-2); }
.pro-badge.ok{ background:var(--ok-bg); color:var(--ok); }
.pro-badge.warn{ background:var(--warn-bg); color:var(--warn); }
.pro-badge.danger{ background:var(--danger-bg); color:var(--danger); }
.pro-chip{ display:inline-block; padding:2px 9px; border-radius:999px; font-size:.74rem; background:var(--sand); color:var(--clay-2); font-weight:600; }

.pro-feed{ list-style:none; padding:0; margin:0; }
.pro-feed li{ display:flex; justify-content:space-between; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.pro-feed li:last-child{ border-bottom:0; }
.pro-feed-main b{ display:inline-block; margin-left:6px; }
.pro-feed-meta{ text-align:right; font-size:.82rem; color:var(--muted); white-space:nowrap; }
.pro-feed-meta .pro-btn{ margin-top:6px; }

.pro-doclist, .pro-appts{ list-style:none; padding:0; margin:0; }
.pro-doclist li{ display:flex; justify-content:space-between; gap:16px; align-items:center; padding:14px 0; border-bottom:1px solid var(--line); }
.pro-doclist li:last-child{ border-bottom:0; }
.pro-doc-actions{ display:flex; gap:8px; align-items:center; white-space:nowrap; }

.pro-appts li{ display:grid; grid-template-columns:200px 1fr auto; gap:16px; align-items:center; padding:15px 0; border-bottom:1px solid var(--line); }
.pro-appts li:last-child{ border-bottom:0; }
.pro-appts li.pro-dim{ opacity:.55; }
.pro-appt-when{ display:flex; flex-direction:column; gap:4px; align-items:flex-start; }
.pro-appt-side{ text-align:right; display:flex; flex-direction:column; gap:8px; align-items:flex-end; }

/* fatal */
.pro-fatal{ max-width:520px; margin:12vh auto; background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px; text-align:center; box-shadow:var(--shadow-soft); }
.pro-fatal h3{ font-family:var(--font-display); margin:0 0 8px; font-size:1.5rem; }
.pro-fatal p{ color:var(--muted); margin:0 0 16px; }

/* modal */
.pro-modal{ position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; }
.pro-modal[hidden]{ display:none; }
.pro-modal-backdrop{ position:absolute; inset:0; background:rgba(15,22,20,.45); }
.pro-modal-card{ position:relative; background:#fff; width:92%; max-width:520px; border-radius:16px; box-shadow:0 30px 70px -20px rgba(0,0,0,.45); max-height:88vh; overflow:auto; }
.pro-modal-head{ display:flex; justify-content:space-between; align-items:center; padding:18px 22px; border-bottom:1px solid var(--line); }
.pro-modal-head h3{ font-family:var(--font-display); margin:0; font-size:1.25rem; }
.pro-x{ border:0; background:transparent; font-size:1.1rem; cursor:pointer; color:var(--muted); }
.pro-modal-body{ padding:20px 22px; }
.pro-modal-foot{ display:flex; justify-content:flex-end; gap:10px; padding:16px 22px; border-top:1px solid var(--line); }
.pro-field{ display:block; margin-bottom:14px; }
.pro-field > span{ display:block; font-size:.82rem; font-weight:600; color:var(--ink-2); margin-bottom:5px; }
.pro-field input, .pro-field select, .pro-field textarea{ width:100%; padding:10px 12px; border:1px solid var(--line-2); border-radius:10px; font:inherit; background:var(--paper); }
.pro-or{ text-align:center; color:var(--muted); font-size:.82rem; margin:6px 0 12px; }

/* toast */
.pro-toast-stack{ position:fixed; right:18px; bottom:18px; z-index:1100; display:flex; flex-direction:column; gap:8px; }
.pro-toast{ background:var(--teal-ink); color:#fff; padding:11px 16px; border-radius:10px; box-shadow:var(--shadow-soft); font-size:.9rem; transition:opacity .3s ease; max-width:340px; }
.pro-toast.success{ background:var(--ok); }
.pro-toast.error{ background:var(--danger); }

@media (max-width:760px){
  .pro-appts li{ grid-template-columns:1fr; }
  .pro-appt-side{ align-items:flex-start; text-align:left; }
  .pro-select{ min-width:0; width:100%; }
}
