@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

/* Light mode (default) — concierge gold on warm white */
:root{
--bg-primary:#faf9f6;--bg-card:#ffffff;--bg-input:#ffffff;--bg-elevated:#f5f2ec;
--border:rgba(0,0,0,0.08);--border-strong:rgba(0,0,0,0.14);--border-focus:#c49a3a;
--text-primary:#1a1a1a;--text-secondary:#556070;--text-muted:#94a0b0;--text-on-accent:#1a1a1a;--text-on-dark:#ffffff;
--accent:#c49a3a;--accent-hover:#b38a2f;--accent-glow:rgba(196,154,58,0.18);
--accent-surface-soft:rgba(196,154,58,0.06);--accent-surface:rgba(196,154,58,0.12);--accent-surface-strong:rgba(196,154,58,0.20);
--accent-border:rgba(196,154,58,0.28);--accent-border-strong:rgba(196,154,58,0.45);
--success:#059669;--warning:#d97706;--danger:#dc2626;--recording:#dc2626;
--gold:#d4a849;--navy:#1e293b;
--radius:12px;--radius-sm:8px;
--shadow-card:0 1px 3px rgba(0,0,0,0.05),0 4px 16px rgba(0,0,0,0.04);
--shadow-elevated:0 4px 12px rgba(0,0,0,0.08),0 16px 40px rgba(0,0,0,0.08);
--top-bar-bg:rgba(250,249,246,0.92);
--overlay-bg:rgba(30,41,59,0.55);
--surface-soft:rgba(0,0,0,0.04);--surface-mid:rgba(0,0,0,0.06);--surface-hover:rgba(0,0,0,0.08)}

/* Dark mode — neutral near-black + champagne gold (v3.3.66).
   Pivoted from warm-charcoal (v3.3.65) after the warm tint still read as
   brown to Dr. Malka. Surfaces are now truly neutral — no warm tint in
   any background, input, or border. Text is pure off-white instead of
   warm ivory. The champagne gold accent is preserved (it's the brand
   color and reads as luxury against neutral surfaces). The net effect
   is Apple-HIG-style neutrality with a distinctive gold personality —
   clinical enough to look serious, warm enough via the gold to read as
   concierge rather than consumer-tech. */
[data-theme="dark"]{
--bg-primary:#0A0A0A;--bg-card:#141414;--bg-input:#1A1A1A;--bg-elevated:#202020;
--border:rgba(255,255,255,0.06);--border-strong:rgba(255,255,255,0.12);--border-focus:#C9A961;
--text-primary:#F5F5F5;--text-secondary:#A0A0A0;--text-muted:#6B6B6B;--text-on-accent:#0A0A0A;--text-on-dark:#F5F5F5;
--accent:#C9A961;--accent-hover:#D9BC78;--accent-glow:rgba(201,169,97,0.22);
--accent-surface-soft:rgba(201,169,97,0.06);--accent-surface:rgba(201,169,97,0.12);--accent-surface-strong:rgba(201,169,97,0.20);
--accent-border:rgba(201,169,97,0.28);--accent-border-strong:rgba(201,169,97,0.45);
--success:#7A9A6E;--warning:#C89155;--danger:#B85450;--recording:#C85D58;
--gold:#C9A961;--navy:#0A0A0A;
--shadow-card:none;
--shadow-elevated:0 8px 32px rgba(0,0,0,0.5);
--top-bar-bg:rgba(10,10,10,0.92);
--overlay-bg:rgba(0,0,0,0.78);
--surface-soft:rgba(255,255,255,0.03);--surface-mid:rgba(255,255,255,0.06);--surface-hover:rgba(255,255,255,0.10)}

/* Dark-mode label brightness (v3.3.67). Labels previously inherited the
   secondary-text gray (#A0A0A0), which read as "pale" against the near-
   white input content. Boost to primary text brightness so PATIENT NAME,
   DATE OF BIRTH, AGE, SEX etc. all match the filled-value luminance. */
[data-theme="dark"] .form-label,
[data-theme="dark"] .form-group label,
[data-theme="dark"] label{color:var(--text-primary)}

html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom,20px)}
/* Dark mode reads thinner than light mode at the same weight — bump up
   the base weight so the text has the same visual heft in both themes. */
[data-theme="dark"] body{font-weight:500}
[data-theme="dark"] .step-label,[data-theme="dark"] .tab-btn,[data-theme="dark"] label,[data-theme="dark"] .btn-secondary{font-weight:600}

.top-bar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--top-bar-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.top-left{display:flex;align-items:center;gap:10px}
.logo{font-size:1.5rem}
.app-title{font-weight:600;font-size:1rem;color:var(--text-primary)}
.top-right{display:flex;align-items:center;gap:12px}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 6px var(--success)}
.encounter-timer{font-family:'JetBrains Mono',monospace;font-size:0.85rem;color:var(--text-secondary);background:var(--surface-soft);padding:4px 10px;border-radius:6px}
.btn-icon{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color 0.2s}
.btn-icon:hover{color:var(--danger);background:rgba(248,113,113,0.1)}

/* ───── Step Progress Bar ───── */
.step-progress{
    display:flex;gap:0;padding:8px 12px;
    background:var(--bg-primary);border-bottom:1px solid var(--border);
    overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.step-progress::-webkit-scrollbar{display:none}
.step-indicator{
    flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
    padding:8px 4px;cursor:pointer;transition:all 0.2s;position:relative;
    min-width:0}
.step-indicator::after{
    content:'';position:absolute;top:50%;right:0;
    width:100%;height:2px;background:var(--border);z-index:0;
    transform:translateY(-6px)}
.step-indicator:last-child::after{display:none}
.step-num{
    width:28px;height:28px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:0.75rem;font-weight:700;
    background:var(--bg-card);border:2px solid var(--border);
    color:var(--text-muted);z-index:1;transition:all 0.2s}
.step-label{font-size:0.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.3px;white-space:nowrap}
.step-indicator.active .step-num{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.step-indicator.active .step-label{color:var(--gold);font-weight:600}
.step-indicator.completed .step-num{background:var(--navy);border-color:var(--success);color:var(--success)}
.step-indicator.completed .step-label{color:var(--success)}
.step-indicator.disabled{pointer-events:none;opacity:0.4}

/* ───── Tab nav (for dictate toggle) ───── */
.tab-nav{display:flex;gap:2px;padding:8px 12px;background:var(--bg-primary);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab-nav::-webkit-scrollbar{display:none}
.tab-btn{flex-shrink:0;padding:10px 16px;border:none;background:transparent;color:var(--text-muted);font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all 0.2s;white-space:nowrap}
.tab-btn:hover{color:var(--text-primary);background:var(--surface-soft)}
.tab-btn.active{color:var(--text-primary);background:var(--accent-surface-strong);box-shadow:inset 0 -2px 0 var(--accent)}

.tab-content{display:none;padding:16px;max-width:800px;margin:0 auto;animation:fadeIn 0.2s ease}
.tab-content.active{display:block}

/* ───── Step content ───── */
.step-content-wrapper{max-width:800px;margin:0 auto;padding:16px}
.encounter-step{display:none;animation:fadeIn 0.2s ease}
.encounter-step.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.section-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 20px}
.section-card h2{font-size:1.25rem;font-weight:600;margin-bottom:16px}
.hint{color:var(--text-muted);font-size:0.825rem;margin-bottom:20px}

/* ───── Step header with back button ───── */
.step-header-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.step-header-row h2{margin-bottom:0}

/* ───── Back button ───── */
.back-btn{
    display:flex;align-items:center;gap:4px;
    padding:8px 16px;background:var(--surface-soft);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    color:var(--text-secondary);font-family:'DM Sans',sans-serif;
    font-size:0.85rem;font-weight:500;cursor:pointer;transition:all 0.2s}
.back-btn:hover{color:var(--text-primary);border-color:var(--accent-border-strong);background:var(--surface-mid)}

/* ───── Step navigation row ───── */
.step-nav-row{display:flex;align-items:center;justify-content:space-between;margin-top:20px;gap:12px}
.nav-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ───── Lock button ───── */
.btn-lock{
    padding:12px 24px;border:2px solid var(--gold);border-radius:var(--radius-sm);
    background:rgba(245,197,66,0.1);color:var(--gold);
    font-family:'DM Sans',sans-serif;font-size:0.95rem;font-weight:700;
    cursor:pointer;transition:all 0.2s}
.btn-lock:hover{background:rgba(245,197,66,0.2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(245,197,66,0.2)}

/* ───── Encounter setup row ───── */
.encounter-setup{margin-bottom:20px}
.setup-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.fg-name{flex:2.5;min-width:200px}
.fg-ref{flex:1.5;min-width:150px}
.fg-parent{flex:1.5;min-width:150px}
.fg-visit{flex:1.2;min-width:160px}
.fg-dob{flex:1;min-width:150px}
.age-group{min-width:130px}
.age-row{display:flex;gap:4px;align-items:center}
.age-num{width:56px!important;text-align:center;padding:12px 6px!important;font-size:1rem!important;-moz-appearance:textfield}
.age-num::-webkit-outer-spin-button,.age-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.age-unit{width:58px!important;padding:12px 4px!important;text-align:center;font-size:0.95rem!important}
.form-input{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:'DM Sans',sans-serif;font-size:1rem;outline:none;transition:border-color 0.2s}
.form-input:focus{border-color:var(--border-focus)}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a9bc0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.form-label{display:block;font-size:0.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.3px}

/* ───── Record controls ───── */
.record-controls{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.record-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg-input);border:2px solid var(--border);border-radius:50px;color:var(--text-primary);font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:500;cursor:pointer;transition:all 0.2s}
.record-btn:hover{border-color:var(--accent);background:var(--accent-surface)}
.record-btn.recording{border-color:var(--recording);background:rgba(239,68,68,0.1);animation:pulse-border 1.5s infinite}
.encounter-btn{padding:12px 24px;font-size:0.95rem}
@keyframes pulse-border{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,0.3)}50%{box-shadow:0 0 0 8px rgba(239,68,68,0)}}
.rec-icon{font-size:1.1rem}
.record-btn.recording .rec-icon{color:var(--recording)}

.audio-viz{display:flex;align-items:center;gap:3px;height:30px}
.viz-bar{width:4px;height:8px;background:var(--accent);border-radius:2px;animation:vizPulse 0.6s ease-in-out infinite alternate}
.viz-bar:nth-child(2){animation-delay:0.1s}.viz-bar:nth-child(3){animation-delay:0.2s}
.viz-bar:nth-child(4){animation-delay:0.3s}.viz-bar:nth-child(5){animation-delay:0.2s}
.viz-bar:nth-child(6){animation-delay:0.1s}.viz-bar:nth-child(7){animation-delay:0.15s}
.viz-bar:nth-child(8){animation-delay:0.25s}
@keyframes vizPulse{from{height:6px;opacity:0.5}to{height:24px;opacity:1}}

/* ───── Outputs ───── */
.editable-output,.readonly-output{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin:12px 0;font-size:0.925rem;line-height:1.65;min-height:120px;max-height:500px;overflow-y:auto;white-space:pre-wrap;outline:none}
.editable-output:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}
.readonly-output{color:var(--text-secondary);font-size:0.85rem}

/* ───── Buttons ───── */
.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:0.875rem;font-weight:600;cursor:pointer;transition:all 0.15s}
/* Primary gold button — Liquid Glass treatment (v3.3.67).
   Convex gradient (light from above), inset top catch-light, inset
   bottom depth shadow, outer champagne halo, drop shadow for lift.
   The ::before pseudo adds a soft top-half shine for the "domed" feel.
   Everything else (cards, inputs) stays flat — gold is the only
   surface that reads polished-metal. */
.btn-primary{
    background:linear-gradient(180deg,var(--accent-hover) 0%,var(--accent) 100%);
    color:var(--text-on-accent);
    position:relative;
    overflow:hidden;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.35),
        inset 0 -1px 2px rgba(0,0,0,0.18),
        0 2px 10px var(--accent-glow),
        0 2px 4px rgba(0,0,0,0.35);
    transition:transform 0.25s cubic-bezier(0.2,0.8,0.2,1),box-shadow 0.25s cubic-bezier(0.2,0.8,0.2,1);
}
.btn-primary::before{
    content:'';
    position:absolute;
    top:0;left:0;right:0;
    height:50%;
    background:linear-gradient(180deg,rgba(255,255,255,0.18),transparent);
    pointer-events:none;
    border-radius:inherit;
}
.btn-primary > *{position:relative;z-index:1}
.btn-primary:hover{
    transform:translateY(-1px);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.50),
        inset 0 -1px 2px rgba(0,0,0,0.18),
        0 6px 20px var(--accent-glow),
        0 3px 6px rgba(0,0,0,0.40);
}
.btn-primary:active{
    transform:translateY(0);
    box-shadow:
        inset 0 2px 4px rgba(0,0,0,0.25),
        0 1px 2px rgba(0,0,0,0.35);
}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.btn-secondary{background:var(--surface-mid);color:var(--text-primary);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--surface-hover);border-color:var(--accent-border)}
.btn-secondary:disabled{opacity:0.5;cursor:not-allowed}
.btn-sm{padding:6px 14px;font-size:0.8rem}
.btn-large{width:100%;padding:16px;font-size:1rem;margin:16px 0}
.action-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}

/* ───── Interaction bar (dictate + type + send) ───── */
.interaction-bar{
    display:flex;align-items:center;gap:8px;
    padding:10px 12px;margin:12px 0;
    background:rgba(255,255,255,0.02);border:1px solid var(--border);
    border-radius:var(--radius-sm)}
.dictate-btn{
    width:44px;height:44px;border-radius:50%;
    background:rgba(245,197,66,0.1);border:2px solid var(--gold);
    color:var(--gold);font-size:1.2rem;
    cursor:pointer;transition:all 0.2s;
    display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dictate-btn:hover{background:rgba(245,197,66,0.2)}
.dictate-btn.recording{border-color:var(--recording);color:var(--recording);background:rgba(239,68,68,0.1);animation:pulse-border 1.5s infinite}
.interaction-input{
    flex:1;padding:10px 14px;
    background:var(--bg-input);border:1px solid var(--border);
    border-radius:var(--radius-sm);color:var(--text-primary);
    font-family:'DM Sans',sans-serif;font-size:0.9rem;outline:none}
.interaction-input:focus{border-color:var(--border-focus)}
.interaction-hint{flex:1;color:var(--text-muted);font-size:0.85rem;font-style:italic}
.btn-send{
    padding:10px 18px;background:var(--accent);border:none;
    border-radius:var(--radius-sm);color:var(--text-on-accent);
    font-family:'DM Sans',sans-serif;font-size:0.85rem;font-weight:600;
    cursor:pointer;transition:all 0.15s;flex-shrink:0}
.btn-send:hover{background:var(--accent-hover);transform:translateY(-1px)}

/* ───── Stale warning ───── */
.stale-warning{
    background:rgba(251,191,36,0.08);border:1px solid rgba(251,191,36,0.3);
    border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:12px;
    font-size:0.85rem;color:var(--warning);display:flex;align-items:center;gap:12px}

/* ───── Subsection titles ───── */
.subsection-title{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}

/* ───── Prior plan box ───── */
.prior-plan-box{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}

/* ───── Loading inline ───── */
.loading-inline{color:var(--text-muted);font-style:italic;font-size:0.9rem}

/* ───── Diagnosis cards ───── */
.diagnosis-cards{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.dx-card{
    padding:8px 16px;background:rgba(52,211,153,0.08);
    border:1px solid rgba(52,211,153,0.3);border-radius:20px;
    color:var(--success);font-size:0.85rem;font-weight:500;
    cursor:pointer;transition:all 0.15s}
.dx-card:hover{background:rgba(52,211,153,0.15)}
.dx-card.selected{background:rgba(52,211,153,0.2);border-color:var(--success)}
.dx-card.removed{opacity:0.4;text-decoration:line-through;border-color:var(--border);color:var(--text-muted);background:transparent}

/* ───── QC badges ───── */
.section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.qc-badges{display:flex;gap:6px}
.qc-badge{padding:3px 10px;border-radius:20px;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.qc-badge.complete{background:rgba(52,211,153,0.15);color:var(--success)}
.qc-badge.pending{background:var(--surface-soft);color:var(--text-muted)}

/* ───── Transcript ───── */
.transcript-box{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;min-height:150px;max-height:400px;overflow-y:auto;font-size:0.9rem;line-height:1.6;margin:0 0 12px 0}
.transcript-box .interim{color:var(--text-muted);font-style:italic}
.transcript-box .final{color:var(--text-primary)}
.placeholder-text{color:var(--text-muted);font-style:italic}

/* ───── Nudge line ───── */
/* ───── Safety flags removed — gap detection handles post-dictation ───── */

/* ───── Pause / Stop buttons ───── */
.pause-btn{border-color:var(--warning);color:var(--warning)}
.pause-btn:hover{background:rgba(251,191,36,0.1);border-color:var(--warning)}
.pause-btn.paused{border-color:var(--success);color:var(--success);animation:none}
.pause-btn.paused:hover{background:rgba(52,211,153,0.1)}
.stop-btn{border-color:var(--danger);color:var(--danger)}
.stop-btn:hover{background:rgba(248,113,113,0.1);border-color:var(--danger)}

/* ───── Focus mode (recording) ───── */
.details-toggle-btn{
    display:none;align-items:center;gap:4px;
    padding:4px 12px;
    background:var(--surface-soft);border:1px solid var(--border);
    border-radius:16px;
    color:var(--text-muted);font-family:'DM Sans',sans-serif;font-size:0.75rem;font-weight:500;
    cursor:pointer;transition:all 0.2s;white-space:nowrap;
    margin-left:auto}
.details-toggle-btn:hover{color:var(--text-secondary);border-color:var(--accent-border-strong);background:var(--surface-mid)}

/* ───── Silence prompt ───── */
.silence-prompt{display:flex;align-items:center;gap:12px;background:rgba(251,191,36,0.06);border:1px solid rgba(251,191,36,0.2);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:12px;font-size:0.85rem;color:var(--warning)}

/* ───── Dictate / Form ───── */
.mode-selector{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.mode-btn{padding:8px 16px;background:var(--surface-soft);border:1px solid var(--border);border-radius:20px;color:var(--text-secondary);font-family:'DM Sans',sans-serif;font-size:0.825rem;font-weight:500;cursor:pointer;transition:all 0.2s}
.mode-btn:hover{border-color:var(--accent);color:var(--text-primary)}
.mode-btn.active{background:var(--accent-surface);border-color:var(--accent);color:var(--text-primary)}

.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:0.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.3px}
.form-group textarea, textarea{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:'DM Sans',sans-serif;font-size:0.9rem;line-height:1.5;resize:vertical;outline:none;transition:border-color 0.2s}
.form-group textarea:focus, textarea:focus{border-color:var(--border-focus)}

.collapsible{margin-bottom:16px}
.collapsible-toggle{width:100%;text-align:left;padding:10px 14px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-family:'DM Sans',sans-serif;font-size:0.85rem;cursor:pointer}
.collapsible-toggle:hover{background:var(--surface-soft)}
.collapsible-body{max-height:0;overflow:hidden;transition:max-height 0.3s ease}
.collapsible.open .collapsible-body{max-height:400px;overflow-y:auto}

/* ───── Loading ───── */
.loading-overlay{position:fixed;inset:0;background:var(--overlay-bg);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;margin-bottom:16px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{color:var(--text-secondary);font-size:0.9rem}

/* ───── Food Challenge Dose Ladder ───── */
.fc-dose-ladder{display:flex;flex-wrap:wrap;gap:8px}
.fc-dose-step{
    display:flex;align-items:center;gap:8px;
    padding:8px 14px;background:rgba(255,255,255,0.03);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    font-size:0.85rem;min-width:100px;cursor:default}
.fc-dose-label{font-weight:600;color:var(--text-primary)}
.fc-dose-step.fc-dose-pending{cursor:pointer}
.fc-dose-step.fc-dose-pending:hover{border-color:rgba(255,255,255,0.3);background:var(--surface-mid)}
.fc-dose-step.fc-dose-tolerated{
    background:rgba(52,211,153,0.2);border-color:rgb(52,211,153);cursor:pointer}
.fc-dose-step.fc-dose-tolerated .fc-dose-label{color:#fff}
.fc-dose-step.fc-dose-tolerated::before{content:"\2713 ";color:var(--success);font-weight:700}
.fc-dose-step.fc-dose-reaction{
    background:rgba(248,113,113,0.2);border-color:rgb(248,113,113);cursor:pointer}
.fc-dose-step.fc-dose-reaction .fc-dose-label{color:#fff}
.fc-dose-step.fc-dose-reaction::before{content:"\2717 ";color:var(--danger);font-weight:700}
.fc-cumulative{margin-top:12px;font-size:0.88rem;font-weight:600;color:var(--text-secondary)}
.fc-custom-doses{display:flex;flex-wrap:wrap;gap:8px}

/* ───── Quality Check Accordion ───── */
.quality-check-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 16px;border-radius:var(--radius-sm);
    font-size:0.85rem;font-weight:700;text-transform:uppercase;
    letter-spacing:0.6px;user-select:none;transition:all 0.2s}
.quality-check-red{
    background:rgba(248,113,113,0.12);border:1px solid rgba(248,113,113,0.35);
    color:var(--danger);cursor:pointer}
.quality-check-red:hover{background:rgba(248,113,113,0.18)}
.quality-check-red #qualityCheckArrow{animation:qcPulse 2s ease-in-out infinite}
.quality-check-green{
    background:rgba(52,211,153,0.1);border:1px solid rgba(52,211,153,0.3);
    color:var(--success);cursor:default}
@keyframes qcPulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ───── Gaps panel ───── */
.gaps-panel{background:rgba(251,191,36,0.04);border:1px solid rgba(251,191,36,0.2);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px}
.gaps-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.gaps-title{font-size:0.85rem;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--warning)}
.gaps-list{columns:2;column-gap:24px}
.gaps-condition{break-inside:avoid;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(251,191,36,0.12)}
.gaps-condition:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.gaps-condition-name{font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);margin-bottom:3px}
.gap-item{font-size:0.82rem;color:var(--warning);padding:2px 0;line-height:1.4}
.gap-item::before{content:"? ";color:var(--warning);font-weight:700}
.gaps-loading{font-size:0.8rem;color:var(--text-muted);font-style:italic}
.gaps-clear{font-size:0.8rem;color:var(--success);font-weight:500}

/* ═══════════════════════════════════════════════════════════════
   CLINICAL PILL — Unified interactive option button
   Used everywhere: pre-encounter Qs, gap detection, specialist
   review, post-edit clarifying Qs, A&P discussion, condition
   follow-ups. One class, one behavior, one look.
   ═══════════════════════════════════════════════════════════════ */
.clinical-pill{
    display:inline-block;padding:7px 15px;
    background:var(--surface-hover);
    border:1px solid var(--border-strong);border-radius:20px;
    color:var(--text-primary);font-family:'DM Sans',sans-serif;
    font-size:0.82rem;font-weight:500;line-height:1.3;
    cursor:pointer;transition:all 0.15s;
    -webkit-tap-highlight-color:transparent;
    user-select:none;white-space:nowrap}
.clinical-pill:hover{
    border-color:rgba(255,200,0,0.5);color:#fff;
    background:rgba(255,200,0,0.15)}
.clinical-pill:active{transform:scale(0.97)}
.clinical-pill.selected{
    background:rgba(255,200,0,0.25);border-color:#ffc800;
    color:#fff;font-weight:600}
.clinical-pills{display:flex;flex-wrap:wrap;gap:7px}

/* ───── AI Gap Cards ───── */
.ai-gaps-panel{
    background:var(--accent-surface-soft);border:1px solid var(--accent-surface-strong);
    border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:16px}
.ai-gaps-title{font-size:0.85rem;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--accent)}
.ai-gap-card{
    background:rgba(255,255,255,0.02);border:1px solid var(--border);
    border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:10px}
.ai-gap-card:last-child{margin-bottom:0}
.ai-gap-priority{font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:2px 8px;border-radius:10px;display:inline-block;margin-bottom:6px}
.ai-gap-priority-critical{background:rgba(248,113,113,0.15);color:var(--danger)}
.ai-gap-priority-safety{background:rgba(251,191,36,0.15);color:var(--warning)}
.ai-gap-priority-missing{background:var(--accent-surface);color:var(--accent)}
.ai-gap-question{font-size:0.88rem;color:var(--text-primary);margin-bottom:8px;line-height:1.4}
.ai-gap-options{display:flex;flex-wrap:wrap;gap:6px}
.ai-gaps-actions{display:flex;gap:10px;margin-top:14px;justify-content:flex-end}

/* ───── Follow-up Pills (post-edit clarifying questions) ───── */
.followup-pills{margin-top:4px}
.followup-pill-row{padding:10px 0;border-bottom:1px solid var(--surface-soft)}
.followup-pill-row:last-child{border-bottom:none}
.followup-pill-label{font-size:0.84rem;color:var(--text-secondary);margin-bottom:6px}
.followup-pill-options{display:flex;flex-wrap:wrap;gap:6px}

/* ───── Patient autocomplete dropdown ───── */
/* ───── Inline editing (ingestion modal) ───── */
.editable-field{cursor:pointer;border-bottom:1px dashed rgba(255,255,255,0.15);padding:0 2px;transition:all 0.15s}
.editable-field:hover{border-bottom-color:var(--accent);color:var(--accent)}
.editable-field.edited{border-bottom-color:rgba(255,200,0,0.4);color:#fff}
.inline-edit-input{background:var(--bg-input);border:1px solid var(--accent);border-radius:3px;color:var(--text-primary);font-family:'DM Sans',sans-serif;font-size:inherit;padding:1px 4px;width:auto;min-width:40px;outline:none}
.edited-badge{display:inline-block;font-size:0.6rem;font-weight:600;padding:1px 6px;border-radius:6px;background:rgba(255,200,0,0.15);color:rgb(255,200,0);margin-left:6px;vertical-align:middle}
.inline-edit-warning{display:inline-block;font-size:0.7rem;color:var(--danger);margin-left:6px}

/* ───── Patient bound badge ───── */
.patient-bound-badge{font-size:0.65rem;font-weight:600;padding:2px 8px;border-radius:8px;margin-left:6px;vertical-align:middle}
.patient-bound-badge.bound{background:rgba(52,211,153,0.15);color:var(--success)}
.patient-bound-badge.unbound{background:var(--surface-mid);color:var(--text-muted)}

.autocomplete-dropdown{
    position:absolute;top:100%;left:0;right:0;
    background:var(--bg-card);border:1px solid var(--border-focus);border-top:none;
    border-radius:0 0 var(--radius-sm) var(--radius-sm);
    max-height:240px;overflow-y:auto;z-index:200;
    box-shadow:0 8px 24px rgba(0,0,0,0.4)}
.autocomplete-item{
    display:flex;align-items:center;gap:8px;
    padding:10px 14px;cursor:pointer;
    transition:background 0.15s;border-bottom:1px solid var(--surface-soft)}
.autocomplete-item:hover{background:var(--accent-surface)}
.autocomplete-item:last-child{border-bottom:none}
.ac-name{flex:1;font-weight:500;color:var(--text-primary);font-size:0.9rem}
.ac-badge{
    padding:2px 8px;border-radius:10px;
    font-size:0.7rem;font-weight:600;
    background:rgba(52,211,153,0.15);color:var(--success)}
.ac-date{font-size:0.75rem;color:var(--text-muted)}

/* ───── Question panel ───── */
.question-panel{
    background:var(--accent-surface-soft);border:1px solid var(--accent-surface-strong);
    border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px}
.question-panel-header{
    display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.question-panel-title{
    font-size:0.8rem;font-weight:700;text-transform:uppercase;
    letter-spacing:0.6px;color:var(--accent)}
.question-card{margin-bottom:12px;border-left:3px solid var(--border);border-radius:4px;padding-left:12px}
.question-card:last-child{margin-bottom:0}
.question-text{
    font-size:0.875rem;font-weight:500;color:var(--text-primary);margin-bottom:6px}
.condition-label{display:inline-block;font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;padding:2px 8px;border-radius:8px;margin-bottom:6px}

/* ───── Condition colors ───── */
.condition-amber{border-left-color:rgb(245,158,11)}
.condition-amber .condition-label{color:rgb(245,158,11);background:rgba(245,158,11,0.12)}
.condition-amber .clinical-pill{border-color:rgba(245,158,11,0.4)}
.condition-green{border-left-color:rgb(52,211,153)}
.condition-green .condition-label{color:rgb(52,211,153);background:rgba(52,211,153,0.12)}
.condition-green .clinical-pill{border-color:rgba(52,211,153,0.4)}
.condition-blue{border-left-color:var(--accent)}
.condition-blue .condition-label{color:var(--accent);background:var(--accent-surface)}
.condition-blue .clinical-pill{border-color:rgba(79,125,255,0.4)}
.condition-purple{border-left-color:rgb(168,85,247)}
.condition-purple .condition-label{color:rgb(168,85,247);background:rgba(168,85,247,0.12)}
.condition-purple .clinical-pill{border-color:rgba(168,85,247,0.4)}
.condition-teal{border-left-color:rgb(45,212,191)}
.condition-teal .condition-label{color:rgb(45,212,191);background:rgba(45,212,191,0.12)}
.condition-teal .clinical-pill{border-color:rgba(45,212,191,0.4)}
.condition-coral{border-left-color:rgb(251,146,60)}
.condition-coral .condition-label{color:rgb(251,146,60);background:rgba(251,146,60,0.12)}
.condition-coral .clinical-pill{border-color:rgba(251,146,60,0.4)}
.condition-red{border-left-color:rgb(248,113,113)}
.condition-red .condition-label{color:rgb(248,113,113);background:rgba(248,113,113,0.12)}
.condition-red .clinical-pill{border-color:rgba(248,113,113,0.4)}
.condition-gray{border-left-color:var(--border-strong)}
.condition-gray .condition-label{color:var(--text-muted);background:var(--surface-mid)}
.condition-gray .clinical-pill{border-color:var(--border-strong)}
.question-options{display:flex;flex-wrap:wrap;gap:6px}
.question-loading{font-size:0.8rem;color:var(--text-muted);font-style:italic}

/* ───── Lock confirmation modal ───── */
.lock-modal-overlay{
    position:fixed;inset:0;background:rgba(0,0,0,0.6);
    display:flex;align-items:center;justify-content:center;z-index:1001}
.lock-modal{
    background:var(--bg-card);border:1px solid var(--gold);
    border-radius:var(--radius);padding:24px;max-width:360px;width:90%;text-align:center}
.lock-modal p{margin-bottom:16px;font-size:0.95rem;color:var(--text-primary)}
.lock-modal .modal-actions{display:flex;gap:10px;justify-content:center}

/* ───── Mobile ───── */
@media(max-width:600px){
.section-card{padding:18px 14px}
.step-indicator{padding:6px 2px}
.step-label{font-size:0.55rem}
.step-num{width:24px;height:24px;font-size:0.65rem}
.record-btn{padding:12px 20px;font-size:0.9rem}.encounter-btn{padding:14px 24px;font-size:1rem}
.setup-row .form-group{min-width:100%!important;flex:unset!important}
.record-controls{flex-wrap:wrap}
.step-nav-row{flex-direction:column;gap:10px}
.nav-right{width:100%;justify-content:stretch;flex-wrap:wrap;gap:8px}
.nav-right .btn-lock,.nav-right .btn-primary,.nav-right .btn-secondary{flex:1 1 auto;min-width:80px;white-space:nowrap}
.action-row{flex-direction:column}
.action-row .btn-primary,.action-row .btn-secondary{width:100%}
.silence-prompt{flex-direction:column;gap:8px}
.gaps-list{columns:1}
.question-options{flex-direction:column}
.clinical-pills{flex-direction:column}
.clinical-pill{width:100%;text-align:left}
.interaction-bar{flex-wrap:wrap}
.interaction-input{min-width:0}
}

/* ───── Upload Button ───── */
.upload-doc-btn{position:relative;font-size:1.1rem !important}
.upload-badge{position:absolute;top:-2px;right:-4px;background:var(--accent);color:var(--text-on-accent);font-size:0.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* ───── Modal Overlay ───── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:1500;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.modal-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column}
.modal-panel-lg{max-width:640px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:1rem;font-weight:600}
.modal-body{padding:20px;overflow-y:auto;flex:1}
.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border)}

/* ───── Upload Zone ───── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all 0.2s}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:var(--accent-glow)}
.upload-zone-text{color:var(--text-secondary);font-size:0.95rem}
.upload-type-row{display:flex;align-items:center;gap:12px;margin-top:16px}
.upload-type-row label{color:var(--text-secondary);font-size:0.85rem;white-space:nowrap}

/* ───── Confirmation Panel ───── */
.confirm-section{margin-bottom:20px}
.confirm-section-title{font-size:0.8rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.confirm-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.confirm-table th{text-align:left;padding:6px 10px;color:var(--text-secondary);border-bottom:1px solid var(--border);font-weight:500}
.confirm-table td{padding:6px 10px;border-bottom:1px solid var(--border)}
.confirm-table tr.flagged td{background:rgba(251,191,36,0.08)}
.confirm-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:1px solid var(--border)}
.confirm-item input[type="checkbox"]{margin-top:3px;accent-color:var(--accent)}
.confirm-item-text{flex:1;font-size:0.85rem}
.confirm-item-sub{color:var(--text-muted);font-size:0.78rem}
.confirm-value{color:var(--success);font-family:'JetBrains Mono',monospace;font-size:0.82rem}
.confirm-uncertain{color:var(--warning);font-style:italic}

/* ───── Prior Note Upload (Step 1) ───── */
.prior-note-upload{
    margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.prior-note-header{margin-bottom:8px}
.prior-note-title{
    font-size:0.8rem;font-weight:700;text-transform:uppercase;
    letter-spacing:0.6px;color:var(--text-secondary)}
.upload-zone-step1{
    border:2px dashed var(--border);border-radius:var(--radius);
    padding:28px 20px;text-align:center;cursor:pointer;transition:all 0.2s}
.upload-zone-step1:hover,.upload-zone-step1.dragover{
    border-color:var(--accent);background:var(--accent-glow)}
.upload-zone-sub{
    color:var(--text-muted);font-size:0.78rem;margin-top:4px}

/* ───── Condition Status Cards ───── */
.condition-status-panel{
    background:var(--accent-surface-soft);border:1px solid var(--accent-surface-strong);
    border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px}
.condition-status-card{
    background:var(--bg-input);border:1px solid var(--border);
    border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;
    transition:border-color 0.2s}
.condition-status-card.status-selected{
    border-color:var(--accent)}
.condition-name{
    font-size:0.9rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.condition-detail{
    font-size:0.78rem;color:var(--text-muted);margin-bottom:8px}
.status-buttons{display:flex;flex-wrap:wrap;gap:6px}
.status-btn{
    padding:6px 14px;
    background:var(--surface-soft);border:1px solid var(--border);
    border-radius:20px;
    color:var(--text-secondary);font-family:'DM Sans',sans-serif;
    font-size:0.8rem;font-weight:500;cursor:pointer;
    transition:all 0.15s;white-space:nowrap}
.status-btn:hover{
    border-color:var(--accent);color:var(--text-primary);
    background:var(--accent-surface-soft)}
.status-btn.selected-stable{
    background:rgba(52,211,153,0.15);border-color:var(--success);color:var(--success)}
.status-btn.selected-improved{
    background:var(--accent-surface-strong);border-color:var(--accent);color:var(--accent)}
.status-btn.selected-worsened{
    background:rgba(248,113,113,0.12);border-color:var(--danger);color:var(--danger)}
.status-btn.selected-changed{
    background:rgba(251,191,36,0.12);border-color:var(--warning);color:var(--warning)}
.status-btn.selected-reactions{
    background:rgba(248,113,113,0.12);border-color:var(--danger);color:var(--danger)}
.status-btn.selected-well_controlled{
    background:rgba(52,211,153,0.15);border-color:var(--success);color:var(--success)}
.status-btn.selected-not_well_controlled{
    background:rgba(251,191,36,0.12);border-color:var(--warning);color:var(--warning)}
.status-btn.selected-poorly_controlled{
    background:rgba(248,113,113,0.12);border-color:var(--danger);color:var(--danger)}
.status-btn.selected-very_poorly_controlled{
    background:rgba(248,113,113,0.12);border-color:var(--danger);color:var(--danger)}
.status-btn.selected-other{
    background:rgba(251,191,36,0.12);border-color:var(--warning);color:var(--warning)}

/* ───── Condition Follow-Up Questions ───── */
.condition-followup-section{
    background:rgba(251,191,36,0.04);border:1px solid rgba(251,191,36,0.2);
    border-radius:var(--radius-sm);padding:14px 16px;margin-top:10px}
.followup-condition-header{
    font-size:0.85rem;font-weight:600;color:var(--warning);margin-bottom:8px}
.followup-question-row{
    display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.followup-question-label{
    font-size:0.82rem;color:var(--text-secondary);min-width:140px}
.followup-options{display:flex;flex-wrap:wrap;gap:4px}
.followup-dictate-row{margin-top:8px;display:flex;align-items:center;gap:8px}

/* ───── Generated HPI Preview ───── */
.stable-hpi-preview{
    background:var(--bg-input);border:1px solid rgba(52,211,153,0.2);
    border-radius:var(--radius-sm);padding:14px 16px;margin-top:12px;
    font-size:0.88rem;line-height:1.6;color:var(--text-secondary);
    max-height:300px;overflow-y:auto;white-space:pre-wrap}
.stable-hpi-preview-header{
    font-size:0.78rem;font-weight:600;color:var(--success);
    text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}

@media(max-width:600px){
    .status-buttons{flex-direction:column}
    .status-btn{width:100%;text-align:left}
    .followup-question-row{flex-direction:column;align-items:flex-start}
    .followup-options{width:100%}
}

/* ───── Discussion Panel ───── */
.discuss-panel{
    margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);
    background:rgba(255,255,255,0.015);overflow:hidden}
.discuss-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 16px;background:var(--accent-surface-soft);
    border-bottom:1px solid var(--border);cursor:pointer;user-select:none}
.discuss-header span{font-size:0.9rem;font-weight:600;color:var(--text-secondary)}
.discuss-toggle{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:0 4px}
.discuss-body{display:none;padding:12px 16px 16px}
.discuss-body.open{display:block}
.discuss-thread{
    max-height:350px;overflow-y:auto;
    display:flex;flex-direction:column;gap:10px;
    padding:8px 0;margin-bottom:12px}
.discuss-msg{
    max-width:85%;padding:10px 14px;border-radius:14px;
    font-size:0.88rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.discuss-msg-physician{
    align-self:flex-end;
    background:var(--accent-surface-strong);border:1px solid rgba(79,125,255,0.3);
    color:var(--text-primary);border-bottom-right-radius:4px}
.discuss-msg-ai{
    align-self:flex-start;
    background:var(--bg-card);border:1px solid var(--border);
    color:var(--text-primary);border-bottom-left-radius:4px}
.discuss-msg-ai .ai-label{
    display:block;font-size:0.7rem;font-weight:600;
    color:var(--accent);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.5px}
.discuss-regen-row{margin-top:12px;text-align:center}
.ap-diff-added{font-weight:700;color:var(--success);background:rgba(52,211,153,0.08);padding:0 2px;border-radius:2px}
.ap-diff-removed{text-decoration:line-through;color:var(--text-muted);opacity:0.6}
.discuss-typing{color:var(--text-muted);font-style:italic;font-size:0.82rem;padding:6px 0}

/* ───── Specialist Review ───── */
.review-section { margin-bottom: 1.2rem; }
.review-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); margin-bottom: 0.4rem; }
.review-text { font-size: 0.95rem; line-height: 1.6; color: var(--text-primary); }
.review-question { background: var(--bg-input); border-left: 3px solid var(--accent); padding: 1rem; border-radius: 6px; }
.review-question-text { font-size: 1rem; font-weight: 600; margin-bottom: 0.8rem; color: var(--text-primary); }
.safety-flags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.badge-critical { display:inline-block;padding:4px 12px;border-radius:12px;font-size:0.78rem;font-weight:600;background:rgba(248,113,113,0.15);color:var(--danger);border:1px solid rgba(248,113,113,0.3) }
.pill-options { display:flex;flex-wrap:wrap;gap:8px }
.gap-fill-confirm { font-size: 0.85rem; color: var(--success); margin-top: 0.6rem; }

::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--surface-hover);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}

/* Audit panel — shows what the post-generation auditor caught */
.audit-panel { margin-bottom: 8px; padding: 10px 14px; border-radius: 8px; font-size: 0.82rem; line-height: 1.45; }
.audit-panel.audit-clean { background: rgba(74, 222, 128, 0.08); border: 1px solid rgba(74, 222, 128, 0.25); color: var(--success); }
.audit-panel.audit-corrected { background: rgba(251, 191, 36, 0.08); border: 1px solid rgba(251, 191, 36, 0.3); color: #fbbf24; }
.audit-panel .audit-title { font-weight: 600; display: flex; align-items: center; gap: 6px; }
.audit-panel .audit-title .audit-icon { font-size: 0.95rem; }
.audit-panel ul.audit-corrections { margin: 6px 0 0 0; padding-left: 20px; color: var(--text-primary); font-weight: 400; }
.audit-panel ul.audit-corrections li { margin: 3px 0; }
.audit-panel .audit-hint { font-size: 0.75rem; color: var(--text-secondary); margin-top: 4px; }

/* Preferences modal — editable scribe preferences without SSH */
.prefs-modal { position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 9999; backdrop-filter: blur(4px); align-items: center; justify-content: center; display: flex; }
.prefs-modal-content { background: var(--bg-card); border: 1px solid var(--accent-border); border-radius: 16px; padding: 0; width: min(820px, 94vw); max-height: 90vh; display: flex; flex-direction: column; box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
.prefs-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px 14px; border-bottom: 1px solid var(--border); }
.prefs-header h2 { margin: 0; font-size: 1.05rem; font-weight: 600; color: var(--text-primary); }
.prefs-close { font-size: 1.4rem; background: transparent; border: none; color: var(--text-secondary); cursor: pointer; padding: 2px 8px; }
.prefs-close:hover { color: var(--text-primary); }
.prefs-body { padding: 16px 22px 20px; overflow: auto; }
.prefs-hint { background: var(--accent-surface); border: 1px solid rgba(79,125,255,0.18); border-radius: 8px; padding: 10px 14px; font-size: 0.82rem; color: var(--text-secondary); margin-bottom: 12px; line-height: 1.5; }
.prefs-hint strong { color: var(--text-primary); }
.prefs-hint code { background: var(--surface-mid); padding: 1px 5px; border-radius: 3px; font-size: 0.78rem; }
.prefs-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
#preferencesEditor { width: 100%; min-height: 380px; max-height: 55vh; padding: 12px 14px; background: var(--bg-input); border: 1px solid var(--accent-border); border-radius: 8px; color: var(--text-primary); font-family: 'SF Mono', Menlo, Consolas, monospace; font-size: 0.83rem; line-height: 1.5; resize: vertical; box-sizing: border-box; }
#preferencesEditor:focus { outline: none; border-color: var(--border-focus); }
.prefs-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 14px; }
.prefs-actions button { padding: 9px 18px; border-radius: 8px; font-family: inherit; font-size: 0.88rem; font-weight: 500; cursor: pointer; border: 1px solid transparent; }
.prefs-actions .btn-primary { background: linear-gradient(135deg,var(--accent),var(--accent-hover)); color: var(--text-on-accent); }
.prefs-actions .btn-primary:hover { filter: brightness(1.1); }
.prefs-actions .btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.prefs-actions .btn-secondary { background: transparent; color: var(--text-secondary); border-color: var(--accent-border); }
.prefs-actions .btn-secondary:hover { color: var(--text-primary); border-color: var(--accent-border-strong); }
#prefsSaveStatus.saved { color: var(--success); }
#prefsSaveStatus.dirty { color: #fbbf24; }
#prefsSaveStatus.error { color: var(--danger); }

/* ICD-10 autocomplete dropdown — shared across history.html and patients.html */
.icd10-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;max-height:280px;overflow-y:auto;z-index:50;box-shadow:var(--shadow-elevated)}
.icd10-item{padding:9px 12px;cursor:pointer;display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--border);font-size:0.85rem}
.icd10-item:last-child{border-bottom:none}
.icd10-item:hover,.icd10-item.active{background:var(--accent-surface)}
.icd10-item .icd10-code{font-weight:700;color:var(--accent);min-width:78px;font-family:'JetBrains Mono',monospace;font-size:0.78rem;flex-shrink:0}
.icd10-item .icd10-desc{flex:1;color:var(--text-primary);line-height:1.35}
.icd10-code-badge{display:inline-block;padding:2px 7px;background:var(--accent-surface);color:var(--accent);border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:0.72rem;font-weight:700;margin-right:8px}

/* Dictate tab — recipient + tone controls for Letter/Email modes */
.dictate-control-row { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; flex-wrap: wrap; }
.dictate-control-row > label { font-size: 0.78rem; font-weight: 500; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.4px; min-width: 75px; margin: 0; }
.tone-selector { display: flex; gap: 6px; }
.tone-btn { padding: 6px 14px; background: var(--surface-soft); border: 1px solid var(--border); border-radius: 20px; color: var(--text-secondary); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; font-weight: 500; cursor: pointer; transition: all 0.2s; }
.tone-btn:hover { border-color: var(--accent); color: var(--text-primary); }
.tone-btn.active { background: var(--accent-surface-strong); border-color: var(--accent); color: var(--text-primary); }
.dictate-control-hint { font-size: 0.75rem; color: var(--text-muted); line-height: 1.4; margin-top: 4px; padding: 8px 12px; background: var(--accent-surface-soft); border-left: 2px solid rgba(79,125,255,0.3); border-radius: 4px; }

/* Transcript line — timestamp + speaker + text, one per line */
.transcript-line { display: block; padding: 3px 0; line-height: 1.5; font-size: 0.85rem; }
.transcript-line .ts { color: var(--accent-hover); font-family: 'SF Mono', Menlo, Consolas, monospace; font-size: 0.78rem; font-weight: 500; }
.transcript-line .spk { color: #a78bfa; font-weight: 600; font-size: 0.78rem; cursor: pointer; border-radius: 3px; padding: 0 2px; transition: background 0.15s; }
.transcript-line .spk:hover { background: rgba(167, 139, 250, 0.15); text-decoration: underline; text-decoration-style: dotted; }
.transcript-line .seg-text { color: var(--text-primary); }
.transcript-line .seg-text .match { background: rgba(251, 191, 36, 0.35); border-radius: 2px; padding: 0 1px; }
.transcript-line .seg-text .match.current { background: #fbbf24; color: var(--bg-input); }

/* Transcript search bar — above the transcript review area */
.transcript-search-bar { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; padding: 6px 10px; background: var(--accent-surface-soft); border: 1px solid var(--accent-surface); border-radius: 8px; }
.transcript-search-input { flex: 1; padding: 5px 10px; background: var(--bg-input); border: 1px solid var(--accent-border); border-radius: 6px; color: var(--text-primary); font-family: inherit; font-size: 0.82rem; outline: none; }
.transcript-search-input:focus { border-color: var(--border-focus); }
.transcript-search-count { font-size: 0.75rem; color: var(--text-secondary); min-width: 70px; text-align: right; }
.transcript-search-btn { padding: 3px 8px; font-size: 0.85rem; background: transparent; border: 1px solid var(--accent-border); color: var(--text-secondary); border-radius: 6px; cursor: pointer; }
.transcript-search-btn:hover { color: var(--text-primary); border-color: var(--accent-border-strong); }

/* v3.3.168.3 — ARIA Library pill links (publisher full-text + PubMed).
   Each card's bottom-row affordance; styled as small pills so they read
   as clickable in clinic. Hover brightens the pill — color-agnostic so
   each journal's per-tint palette (v3.3.168.4) all hover correctly. */
.aria-pub-link:hover { filter: brightness(1.25); }
.aria-pub-link:focus-visible { outline: 2px solid currentColor; outline-offset: 2px; }
