/* /Components/ThemePicker.razor.rz.scp.css */
/* ============================================================================
   Theme picker - component-scoped styles. Colours read the theme design
   tokens, so the picker itself re-themes with the rest of the site.
   ========================================================================== */

.tp[b-xm2v4qvzgk] { position: relative; display: inline-block; }

.tp-trigger[b-xm2v4qvzgk] {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.42rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: var(--surface);
    color: var(--ink);
    font-family: inherit;
    font-size: 0.82rem;
    font-weight: 600;
}
.tp-trigger:hover[b-xm2v4qvzgk] { border-color: var(--accent); }

/* On the dark brand header. */
.tp-dark .tp-trigger[b-xm2v4qvzgk] {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.32);
    color: var(--on-brand);
}
.tp-dark .tp-trigger:hover[b-xm2v4qvzgk] { background: rgba(255, 255, 255, 0.18); }

.tp-dot[b-xm2v4qvzgk] {
    width: 0.7rem; height: 0.7rem;
    border-radius: 50%;
    flex: none;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.18);
}
.tp-label[b-xm2v4qvzgk] { white-space: nowrap; }
.tp-caret[b-xm2v4qvzgk] { font-size: 0.62rem; opacity: 0.75; }

.tp-backdrop[b-xm2v4qvzgk] {
    position: fixed;
    inset: 0;
    z-index: 1300;
}
.tp-menu[b-xm2v4qvzgk] {
    position: absolute;
    right: 0;
    top: calc(100% + 0.4rem);
    z-index: 1301;
    width: 256px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow);
    padding: 0.4rem;
}
.tp-menu-head[b-xm2v4qvzgk] {
    font-size: 0.69rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    font-weight: 700;
    padding: 0.4rem 0.55rem 0.35rem;
}

.tp-option[b-xm2v4qvzgk] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    width: 100%;
    text-align: left;
    border: none;
    background: transparent;
    padding: 0.5rem 0.55rem;
    border-radius: 8px;
    color: var(--ink);
    font-family: inherit;
}
.tp-option:hover[b-xm2v4qvzgk] { background: var(--surface-2); }
.tp-option.is-active[b-xm2v4qvzgk] { background: var(--accent-soft); }

.tp-option-text[b-xm2v4qvzgk] { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.tp-option-name[b-xm2v4qvzgk] { font-size: 0.86rem; font-weight: 600; }
.tp-option-desc[b-xm2v4qvzgk] { font-size: 0.74rem; color: var(--muted); }

.tp-check[b-xm2v4qvzgk] { color: var(--accent-strong); font-weight: 700; }
/* /Widget/AuthMessenger.razor.rz.scp.css */
/* ============================================================================
   HSMSO Authorization Assistant - widget styles (component-scoped)

   These rules are isolated to AuthMessenger.razor via Blazor CSS isolation, so
   the widget is a genuinely self-contained bundle: its styles cannot collide
   with a host page's CSS, nor leak out onto it. Every colour is read from the
   theme design tokens in css/themes.css (--brand, --accent, --surface, ...), so
   the widget re-themes together with the rest of the site - including dark mode.
   ========================================================================== */

/* -- Messenger launcher bubble -------------------------------------------- */
.hsmso-bubble[b-mlffrmamoq] {
    position: fixed;
    right: 22px; bottom: 22px;
    width: 60px; height: 60px;
    border-radius: 50%;
    border: none;
    background: var(--accent);
    color: #fff;
    box-shadow: var(--shadow);
    z-index: 1200;
    display: flex; align-items: center; justify-content: center;
    transition: transform 0.12s ease;
}
.hsmso-bubble:hover[b-mlffrmamoq] { transform: scale(1.06); }
.hsmso-bubble-icon[b-mlffrmamoq] { width: 26px; height: 26px; display: block; }
.hsmso-badge[b-mlffrmamoq] {
    position: absolute;
    top: 6px; right: 6px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--error);
    border: 2px solid var(--surface);
}

/* -- Messenger panel ------------------------------------------------------ */
.hsmso-panel[b-mlffrmamoq] {
    position: fixed;
    right: 22px; bottom: 22px;
    width: 380px;
    height: 620px;
    max-height: calc(100vh - 44px);
    background: var(--surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    z-index: 1200;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--line);
}

.hsmso-panel-header[b-mlffrmamoq] {
    background: var(--brand);
    color: var(--on-brand);
    padding: 0.8rem 1rem;
    display: flex; align-items: center; gap: 0.6rem;
}
.hsmso-avatar[b-mlffrmamoq] {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--on-brand); color: var(--brand);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; overflow: hidden;
}
.hsmso-avatar img[b-mlffrmamoq] { width: 78%; height: 78%; object-fit: contain; }
.hsmso-title[b-mlffrmamoq] { font-weight: 700; font-size: 0.98rem; flex: 1; }
.hsmso-close[b-mlffrmamoq] {
    border: none; background: transparent; font-size: 1rem;
    color: var(--on-brand); padding: 4px 8px; border-radius: 6px;
}
.hsmso-close:hover[b-mlffrmamoq] { background: rgba(255, 255, 255, 0.15); }

.hsmso-transcript[b-mlffrmamoq] {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.hsmso-msg[b-mlffrmamoq] {
    max-width: 84%;
    padding: 0.6rem 0.8rem;
    border-radius: 12px;
    font-size: 0.9rem;
    line-height: 1.45;
    white-space: pre-wrap;
}
.hsmso-msg-system[b-mlffrmamoq] { background: var(--bubble-system); border: 1px solid var(--line); color: var(--ink); align-self: flex-start; }
.hsmso-msg-doctor[b-mlffrmamoq] { background: var(--bubble-doctor); color: var(--ink); align-self: flex-end; }
.hsmso-msg-error[b-mlffrmamoq]  { background: var(--error-bg); border: 1px solid var(--error); color: var(--ink); align-self: flex-start; }
.hsmso-typing[b-mlffrmamoq] { font-style: italic; color: var(--muted); }

/* -- Composer (interactive card for the current step) --------------------- */
.hsmso-composer[b-mlffrmamoq] {
    border-top: 1px solid var(--line);
    padding: 0.9rem 1rem;
    background: var(--surface);
    max-height: 56%;
    overflow-y: auto;
}
.hsmso-lead[b-mlffrmamoq] { margin: 0 0 0.7rem; font-size: 0.9rem; }
.hsmso-field[b-mlffrmamoq] { margin-bottom: 0.7rem; }
.hsmso-field label[b-mlffrmamoq] {
    display: block;
    font-size: 0.78rem;
    color: var(--muted);
    margin-bottom: 0.25rem;
    font-weight: 600;
}
.hsmso-input[b-mlffrmamoq], .hsmso-select[b-mlffrmamoq] {
    width: 100%;
    padding: 0.55rem 0.65rem;
    border: 1px solid var(--line);
    border-radius: 9px;
    font-size: 0.95rem;
    font-family: inherit;
    background: var(--surface);
    color: var(--ink);
}
.hsmso-input:focus[b-mlffrmamoq], .hsmso-select:focus[b-mlffrmamoq] {
    outline: 2px solid var(--accent);
    outline-offset: 0;
}
.hsmso-input.code[b-mlffrmamoq] { letter-spacing: 0.45em; text-align: center; font-size: 1.1rem; }

.hsmso-btn-row[b-mlffrmamoq] { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.hsmso-btn-primary[b-mlffrmamoq], .hsmso-btn-secondary[b-mlffrmamoq], .hsmso-btn-ghost[b-mlffrmamoq] {
    border-radius: 9px;
    padding: 0.62rem 0.9rem;
    font-size: 0.9rem;
    font-weight: 600;
    border: 1px solid transparent;
    flex: 1;
    min-width: 120px;
}
.hsmso-btn-primary[b-mlffrmamoq] { background: var(--accent); color: #fff; }
.hsmso-btn-primary:hover[b-mlffrmamoq] { background: var(--accent-strong); }
.hsmso-btn-primary:disabled[b-mlffrmamoq] { background: var(--accent); opacity: 0.5; cursor: not-allowed; }
.hsmso-btn-secondary[b-mlffrmamoq] { background: var(--surface); color: var(--ink); border-color: var(--line); }
.hsmso-btn-secondary:hover[b-mlffrmamoq] { background: var(--surface-2); }
.hsmso-btn-ghost[b-mlffrmamoq] { background: transparent; color: var(--accent-strong); border: 1px dashed var(--line); }
.hsmso-btn-block[b-mlffrmamoq] { width: 100%; flex: none; }

.hsmso-inline-error[b-mlffrmamoq] {
    color: var(--error);
    font-size: 0.82rem;
    margin: 0.3rem 0 0;
}
.hsmso-meta[b-mlffrmamoq] { font-size: 0.78rem; color: var(--muted); margin-top: 0.4rem; }

/* -- Identity / detail cards inside the composer -------------------------- */
.hsmso-id-card[b-mlffrmamoq], .hsmso-pick[b-mlffrmamoq] {
    border: 1px solid var(--line);
    border-radius: 11px;
    padding: 0.75rem 0.85rem;
    margin-bottom: 0.7rem;
    background: var(--surface);
    color: var(--ink);
    width: 100%;
    text-align: left;
}
.hsmso-pick:hover[b-mlffrmamoq] { border-color: var(--accent); background: var(--accent-soft); }
.hsmso-pick.selected[b-mlffrmamoq] { border-color: var(--accent); background: var(--accent-soft); }
.hsmso-id-card .name[b-mlffrmamoq], .hsmso-pick .name[b-mlffrmamoq] { font-weight: 700; font-size: 0.95rem; }
.hsmso-id-card .sub[b-mlffrmamoq], .hsmso-pick .sub[b-mlffrmamoq] { font-size: 0.8rem; color: var(--muted); margin-top: 0.15rem; }

.hsmso-tags[b-mlffrmamoq] { display: flex; gap: 0.35rem; flex-wrap: wrap; margin-top: 0.4rem; }
.hsmso-tag[b-mlffrmamoq] {
    font-size: 0.72rem;
    padding: 0.18rem 0.5rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: var(--surface-2);
    color: var(--muted);
}

/* status pills */
.pill[b-mlffrmamoq] {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.16rem 0.55rem;
    border-radius: 999px;
}
.pill-approved[b-mlffrmamoq] { background: var(--ok-bg); color: var(--ok); }
.pill-pending[b-mlffrmamoq]  { background: var(--warn-bg); color: var(--warn); }
.pill-denied[b-mlffrmamoq]   { background: var(--deny-bg); color: var(--deny); }

.hsmso-detail dl[b-mlffrmamoq] { margin: 0; }
.hsmso-detail .row[b-mlffrmamoq] { display: flex; justify-content: space-between; gap: 1rem; padding: 0.2rem 0; font-size: 0.85rem; }
.hsmso-detail .row .k[b-mlffrmamoq] { color: var(--muted); }
.hsmso-detail .row .v[b-mlffrmamoq] { font-weight: 600; text-align: right; }

.hsmso-empty[b-mlffrmamoq] { text-align: center; color: var(--muted); padding: 0.6rem 0; }
.hsmso-empty .glyph[b-mlffrmamoq] { font-size: 2rem; }

/* -- Responsive: near-fullscreen messenger on small screens --------------- */
@media (max-width: 480px) {
    .hsmso-panel[b-mlffrmamoq] {
        right: 0; bottom: 0;
        width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        border-radius: 0;
    }
    .hsmso-bubble[b-mlffrmamoq] { right: 16px; bottom: 16px; }
}
