@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=Sora:wght@500;600;700;800&display=swap");

:root {
    color-scheme: dark;
}

html,
body {
    min-height: 100%;
}

body {
    margin: 0;
    font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    background: #0b0714;
    color: #f6f1ff;
}

.pb-shell,
.pb-shell * {
    box-sizing: border-box;
}

.pb-shell {
    position: relative;
    min-height: 100vh;
    isolation: isolate;
    color: var(--mud-palette-text-primary);
    font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    background: var(--pb-bg);
    --pb-transition-fast: 160ms cubic-bezier(0.4, 0, 0.2, 1);
    --pb-transition-base: 220ms cubic-bezier(0.4, 0, 0.2, 1);
    --pb-radius-sm: 14px;
    --pb-radius-md: 16px;
    --pb-radius-lg: 20px;
    --pb-shadow-sm: 0 14px 30px rgba(10, 7, 16, 0.18);
    --pb-shadow-md: 0 28px 64px rgba(10, 7, 16, 0.28);
    --pb-shadow-lg: 0 36px 90px rgba(10, 7, 16, 0.36);
}

.pb-shell[data-theme="dark"] {
    color-scheme: dark;
    --pb-bg: #0b0714;
    --pb-bg-soft: #120c1d;
    --pb-surface: #181126;
    --pb-surface-2: #211734;
    --pb-surface-3: #2b1f43;
    --pb-primary: #7450a8;
    --pb-primary-hover: #5f408a;
    --pb-primary-light: #7c59ae;
    --pb-primary-rgb: 116, 80, 168;
    --pb-primary-ink: #ceb8f1;
    --pb-text: #f6f1ff;
    --pb-text-rgb: 246, 241, 255;
    --pb-text-muted: #c9c0dc;
    --pb-text-soft: rgba(246, 241, 255, 0.74);
    --pb-text-disabled: #9388a8;
    --pb-text-contrast: #171120;
    --pb-secondary: #d8cfee;
    --pb-secondary-rgb: 216, 207, 238;
    --pb-line: rgba(194, 168, 234, 0.18);
    --pb-line-strong: rgba(194, 168, 234, 0.32);
    --pb-focus: rgba(176, 145, 219, 0.44);
    --pb-hover: rgba(176, 145, 219, 0.12);
    --pb-success: #31d39c;
    --pb-success-rgb: 49, 211, 156;
    --pb-info: #58b8ff;
    --pb-info-rgb: 88, 184, 255;
    --pb-warning: #ffb84d;
    --pb-warning-rgb: 255, 184, 77;
    --pb-error: #ff6b7d;
    --pb-error-rgb: 255, 107, 125;
}

.pb-shell[data-theme="light"] {
    color-scheme: light;
    --pb-bg: #f6f3fb;
    --pb-bg-soft: #efeaf7;
    --pb-surface: #ffffff;
    --pb-surface-2: #f5f0fb;
    --pb-surface-3: #ede5f8;
    --pb-card-bg: linear-gradient(180deg, #ffffff, #f8f4fc);
    --pb-panel-bg: linear-gradient(180deg, #ffffff, #f7f2fb);
    --pb-empty-bg: #f7f2fb;
    --pb-primary: #4a146d;
    --pb-primary-hover: #61218a;
    --pb-primary-light: #8456af;
    --pb-primary-rgb: 74, 20, 109;
    --pb-primary-ink: #61218a;
    --pb-text: #201533;
    --pb-text-rgb: 32, 21, 51;
    --pb-text-muted: #67587f;
    --pb-text-soft: rgba(32, 21, 51, 0.64);
    --pb-text-disabled: #86769f;
    --pb-text-contrast: #201533;
    --pb-secondary: #8456af;
    --pb-secondary-rgb: 132, 86, 175;
    --pb-line: rgba(74, 20, 109, 0.12);
    --pb-line-strong: rgba(74, 20, 109, 0.2);
    --pb-focus: rgba(97, 33, 138, 0.22);
    --pb-hover: rgba(97, 33, 138, 0.06);
    --pb-success: #158a64;
    --pb-success-rgb: 21, 138, 100;
    --pb-info: #188ecf;
    --pb-info-rgb: 24, 142, 207;
    --pb-warning: #b7791f;
    --pb-warning-rgb: 183, 121, 31;
    --pb-error: #c43b56;
    --pb-error-rgb: 196, 59, 86;
    --pb-shadow-sm: 0 14px 28px rgba(79, 58, 112, 0.1);
    --pb-shadow-md: 0 26px 64px rgba(79, 58, 112, 0.14);
    --pb-shadow-lg: 0 34px 90px rgba(79, 58, 112, 0.18);
}

.pb-shell {
    --mud-palette-background: var(--pb-bg);
    --mud-palette-background-gray: var(--pb-bg-soft);
    --mud-palette-surface: var(--pb-surface);
    --pb-card-bg: linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 92%, transparent));
    --pb-panel-bg: linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 94%, transparent));
    --pb-empty-bg: color-mix(in srgb, var(--pb-surface-2) 92%, transparent);
    --mud-palette-appbar-background: color-mix(in srgb, var(--pb-bg-soft) 84%, transparent);
    --mud-palette-appbar-text: var(--pb-text);
    --mud-palette-drawer-background: color-mix(in srgb, var(--pb-bg-soft) 92%, transparent);
    --mud-palette-drawer-text: var(--pb-text);
    --mud-palette-drawer-icon: var(--pb-text-muted);
    --mud-palette-primary: var(--pb-primary);
    --mud-palette-primary-rgb: var(--pb-primary-rgb);
    --mud-palette-primary-text: var(--pb-text);
    --mud-palette-primary-darken: var(--pb-primary-hover);
    --mud-palette-primary-lighten: var(--pb-primary-light);
    --mud-palette-primary-hover: rgba(var(--pb-primary-rgb), 0.12);
    --mud-palette-secondary: var(--pb-secondary);
    --mud-palette-secondary-rgb: var(--pb-secondary-rgb);
    --mud-palette-secondary-text: var(--pb-text-contrast);
    --mud-palette-secondary-darken: color-mix(in srgb, var(--pb-secondary) 84%, #000000 16%);
    --mud-palette-secondary-lighten: color-mix(in srgb, var(--pb-secondary) 72%, #ffffff 28%);
    --mud-palette-secondary-hover: rgba(var(--pb-secondary-rgb), 0.08);
    --mud-palette-tertiary: var(--pb-surface-3);
    --mud-palette-tertiary-rgb: var(--pb-primary-rgb);
    --mud-palette-tertiary-text: var(--pb-text);
    --mud-palette-tertiary-darken: var(--pb-surface-2);
    --mud-palette-tertiary-lighten: color-mix(in srgb, var(--pb-surface-3) 70%, #ffffff 30%);
    --mud-palette-info: var(--pb-info);
    --mud-palette-info-rgb: var(--pb-info-rgb);
    --mud-palette-info-text: var(--pb-text-contrast);
    --mud-palette-info-darken: color-mix(in srgb, var(--pb-info) 78%, #071420 22%);
    --mud-palette-info-lighten: color-mix(in srgb, var(--pb-info) 76%, #ffffff 24%);
    --mud-palette-info-hover: rgba(var(--pb-info-rgb), 0.12);
    --mud-palette-success: var(--pb-success);
    --mud-palette-success-rgb: var(--pb-success-rgb);
    --mud-palette-success-text: var(--pb-text-contrast);
    --mud-palette-success-darken: color-mix(in srgb, var(--pb-success) 78%, #03160f 22%);
    --mud-palette-success-lighten: color-mix(in srgb, var(--pb-success) 74%, #ffffff 26%);
    --mud-palette-success-hover: rgba(var(--pb-success-rgb), 0.12);
    --mud-palette-warning: var(--pb-warning);
    --mud-palette-warning-rgb: var(--pb-warning-rgb);
    --mud-palette-warning-text: var(--pb-text-contrast);
    --mud-palette-warning-darken: color-mix(in srgb, var(--pb-warning) 82%, #261708 18%);
    --mud-palette-warning-lighten: color-mix(in srgb, var(--pb-warning) 72%, #ffffff 28%);
    --mud-palette-warning-hover: rgba(var(--pb-warning-rgb), 0.12);
    --mud-palette-error: var(--pb-error);
    --mud-palette-error-rgb: var(--pb-error-rgb);
    --mud-palette-error-text: var(--pb-text-contrast);
    --mud-palette-error-darken: color-mix(in srgb, var(--pb-error) 82%, #2e0911 18%);
    --mud-palette-error-lighten: color-mix(in srgb, var(--pb-error) 72%, #ffffff 28%);
    --mud-palette-error-hover: rgba(var(--pb-error-rgb), 0.12);
    --mud-palette-dark: var(--pb-surface-3);
    --mud-palette-dark-rgb: var(--pb-primary-rgb);
    --mud-palette-dark-text: var(--pb-text);
    --mud-palette-dark-darken: var(--pb-surface-2);
    --mud-palette-dark-lighten: color-mix(in srgb, var(--pb-surface-3) 74%, #ffffff 26%);
    --mud-palette-dark-hover: var(--pb-hover);
    --mud-palette-text-primary: var(--pb-text);
    --mud-palette-text-primary-rgb: var(--pb-text-rgb);
    --mud-palette-text-secondary: var(--pb-text-muted);
    --mud-palette-text-disabled: var(--pb-text-disabled);
    --mud-palette-action-default: color-mix(in srgb, var(--pb-text) 24%, var(--pb-text-muted) 76%);
    --mud-palette-action-default-hover: var(--pb-hover);
    --mud-palette-action-disabled: var(--pb-text-disabled);
    --mud-palette-action-disabled-background: color-mix(in srgb, var(--pb-surface-3) 88%, var(--pb-bg) 12%);
    --mud-palette-lines-default: var(--pb-line);
    --mud-palette-lines-inputs: var(--pb-line-strong);
    --mud-palette-table-lines: var(--pb-line);
    --mud-palette-table-striped: color-mix(in srgb, var(--pb-surface-2) 86%, transparent);
    --mud-palette-table-hover: color-mix(in srgb, var(--pb-primary) 14%, transparent);
    --mud-palette-divider: var(--pb-line);
    --mud-palette-divider-light: color-mix(in srgb, var(--pb-line) 54%, transparent);
    --mud-palette-overlay-dark: rgba(7, 4, 13, 0.64);
    --mud-palette-overlay-light: rgba(246, 243, 251, 0.5);
    --mud-default-borderradius: var(--pb-radius-md);
    --mud-elevation-1: var(--pb-shadow-sm);
    --mud-elevation-2: var(--pb-shadow-sm);
    --mud-elevation-6: var(--pb-shadow-md);
    --mud-elevation-12: var(--pb-shadow-lg);
    --mud-typography-default-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    --mud-typography-default-size: 0.95rem;
    --mud-typography-default-lineheight: 1.6;
    --mud-typography-h4-family: "Sora", "IBM Plex Sans", sans-serif;
    --mud-typography-h4-weight: 700;
    --mud-typography-h4-letterspacing: -0.03em;
    --mud-typography-h5-family: "Sora", "IBM Plex Sans", sans-serif;
    --mud-typography-h5-weight: 700;
    --mud-typography-h5-letterspacing: -0.025em;
    --mud-typography-h6-family: "Sora", "IBM Plex Sans", sans-serif;
    --mud-typography-h6-weight: 700;
    --mud-typography-h6-letterspacing: -0.02em;
    --mud-typography-subtitle2-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    --mud-typography-subtitle2-weight: 600;
    --mud-typography-body2-family: "IBM Plex Sans", "Segoe UI", sans-serif;
    --mud-typography-body2-size: 0.88rem;
    --mud-typography-button-family: "Sora", "IBM Plex Sans", sans-serif;
    --mud-typography-button-weight: 600;
    --mud-typography-button-letterspacing: -0.01em;
    --mud-typography-overline-family: "Sora", "IBM Plex Sans", sans-serif;
    --mud-typography-overline-letterspacing: 0.14em;
    --mud-typography-overline-weight: 700;
}

.pb-shell::before,
.pb-shell::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: -2;
}

.pb-shell::before {
    background:
        radial-gradient(circle at top left, rgba(var(--pb-primary-rgb), 0.26), transparent 34%),
        radial-gradient(circle at 86% 14%, rgba(var(--pb-info-rgb), 0.12), transparent 24%),
        linear-gradient(180deg, color-mix(in srgb, var(--pb-bg) 86%, transparent), var(--pb-bg));
}

.pb-shell::after {
    z-index: -1;
    opacity: 0.42;
    background-image:
        linear-gradient(rgba(var(--pb-primary-rgb), 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--pb-primary-rgb), 0.04) 1px, transparent 1px);
    background-size: 96px 96px;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 72%);
}

.pb-shell .mud-layout {
    background: transparent;
}

.pb-shell {
    --mud-appbar-height: 56px;
}

.pb-shell .mud-main-content {
    position: relative;
    background: transparent;
}

.pb-shell [data-testid="main-content"] {
    padding: calc(var(--mud-appbar-height) + 1rem) 1.25rem 2rem;
}

.pb-shell .mud-container {
    max-width: 100%;
}

.pb-shell .mud-typography,
.pb-shell .mud-button,
.pb-shell .mud-nav-link,
.pb-shell .mud-input,
.pb-shell .mud-table,
.pb-shell .mud-chip,
.pb-shell .mud-alert,
.pb-shell .mud-snackbar {
    font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
}

.pb-shell .mud-typography-h4,
.pb-shell .mud-typography-h5,
.pb-shell .mud-typography-h6,
.pb-shell .mud-button,
.pb-shell .mud-typography-overline {
    font-family: "Sora", "IBM Plex Sans", sans-serif;
}

.pb-shell .mud-appbar {
    backdrop-filter: blur(18px);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-bg-soft) 86%, transparent), color-mix(in srgb, var(--pb-bg-soft) 72%, transparent));
    border-bottom: 1px solid var(--pb-line);
    box-shadow: 0 10px 40px rgba(7, 4, 13, 0.12);
}

.pb-shell .mud-toolbar-appbar {
    gap: 0.65rem;
    padding-inline: 1rem;
}

.pb-shell [data-testid="app-brand-text"],
.pb-shell [data-testid="drawer-brand-text"] {
    letter-spacing: -0.03em;
}

.pb-shell [data-testid="drawer-brand-icon"] {
    width: 2.2rem;
    height: 2.2rem;
    padding: 0.05rem;
}

.pb-shell [data-testid="drawer-brand-icon"] .brand-mark {
    width: 1.75rem;
    height: 1.75rem;
    margin: auto;
}

.pb-shell [data-testid="drawer-brand"] .mud-avatar,
.pb-shell .mud-avatar.mud-avatar-filled.mud-theme-primary {
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--pb-primary-light) 88%, var(--pb-primary) 12%), var(--pb-primary));
    color: #fff;
    box-shadow: 0 18px 34px rgba(var(--pb-primary-rgb), 0.22);
}

.pb-shell .mud-drawer {
    border-right: 1px solid var(--pb-line);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-bg-soft) 96%, transparent), color-mix(in srgb, var(--pb-bg) 92%, transparent));
    backdrop-filter: blur(22px);
    box-shadow: 18px 0 44px rgba(7, 4, 13, 0.14);
}

.pb-shell .mud-drawer .mud-drawer-header {
    padding: 0 1.1rem;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .mud-navmenu {
    padding: 0.9rem 0.75rem 1.35rem;
}

.pb-shell .mud-nav-link {
    min-height: 46px;
    margin: 0.24rem 0;
    padding: 0.72rem 0.9rem;
    border: 1px solid transparent;
    border-radius: var(--pb-radius-md);
    align-items: center;
    color: var(--pb-text-soft);
    transition:
        background-color var(--pb-transition-base),
        border-color var(--pb-transition-base),
        color var(--pb-transition-base),
        transform var(--pb-transition-fast);
}

.pb-shell .mud-nav-link:hover:not(.mud-nav-link-disabled),
.pb-shell .mud-nav-link:focus-visible:not(.mud-nav-link-disabled) {
    background: var(--pb-hover);
    border-color: var(--pb-line);
    color: var(--pb-text);
}

.pb-shell .mud-nav-link.active:not(.mud-nav-link-disabled) {
    color: var(--pb-text);
    background:
        linear-gradient(90deg, rgba(var(--pb-primary-rgb), 0.16), rgba(var(--pb-primary-rgb), 0.04));
    border-color: rgba(var(--pb-primary-rgb), 0.22);
    box-shadow: inset 0 0 0 1px rgba(var(--pb-primary-rgb), 0.08);
}

.pb-shell[data-theme="dark"] .mud-nav-link.active:not(.mud-nav-link-disabled),
.pb-shell[data-theme="dark"] .mud-nav-link.active:not(.mud-nav-link-disabled) .mud-nav-link-text {
    color: var(--pb-text) !important;
}

.pb-shell[data-theme="dark"] .mud-button-filled-primary,
.pb-shell[data-theme="dark"] .mud-button-filled-primary .mud-button-label {
    color: var(--pb-text) !important;
}

.pb-shell[data-theme="dark"] .mud-primary-text,
.pb-shell[data-theme="dark"] .mud-link,
.pb-shell[data-theme="dark"] a:not(.mud-button-root) {
    color: var(--pb-primary-ink) !important;
}

.pb-shell[data-theme="dark"] .mud-button-text-primary,
.pb-shell[data-theme="dark"] .mud-button-text-primary .mud-button-label,
.pb-shell[data-theme="dark"] .mud-button-outlined-primary,
.pb-shell[data-theme="dark"] .mud-button-outlined-primary .mud-button-label {
    color: var(--pb-primary-ink) !important;
}

.pb-shell[data-theme="dark"] .mud-button-text-secondary,
.pb-shell[data-theme="dark"] .mud-button-text-secondary .mud-button-label,
.pb-shell[data-theme="dark"] .mud-button-outlined-secondary,
.pb-shell[data-theme="dark"] .mud-button-outlined-secondary .mud-button-label,
.pb-shell[data-theme="dark"] .mud-button-text-default,
.pb-shell[data-theme="dark"] .mud-button-text-default .mud-button-label,
.pb-shell[data-theme="dark"] .mud-button-outlined-default,
.pb-shell[data-theme="dark"] .mud-button-outlined-default .mud-button-label {
    color: var(--pb-text-muted) !important;
}

.pb-shell[data-theme="dark"] .mud-button-outlined-secondary,
.pb-shell[data-theme="dark"] .mud-button-outlined-default {
    border-color: color-mix(in srgb, var(--pb-text-muted) 28%, transparent) !important;
}

.pb-shell[data-theme="dark"] .mud-select,
.pb-shell[data-theme="dark"] .mud-select-input,
.pb-shell[data-theme="dark"] .mud-select-label,
.pb-shell[data-theme="dark"] .mud-menu-item,
.pb-shell[data-theme="dark"] .mud-popover .mud-list-item,
.pb-shell[data-theme="dark"] .mud-menu .mud-list-item,
.pb-shell[data-theme="dark"] .mud-list-item.mud-selected-item {
    color: var(--pb-text) !important;
}

.pb-shell[data-theme="dark"] .mud-link:hover,
.pb-shell[data-theme="dark"] .mud-link:focus-visible,
.pb-shell[data-theme="dark"] a:not(.mud-button-root):hover,
.pb-shell[data-theme="dark"] a:not(.mud-button-root):focus-visible {
    color: var(--pb-text) !important;
}

.pb-shell .mud-nav-link.active:not(.mud-nav-link-disabled)::before {
    content: "";
    width: 4px;
    align-self: stretch;
    margin-right: 0.7rem;
    border-radius: 999px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--pb-primary-light) 86%, var(--pb-primary) 14%), var(--pb-primary));
    box-shadow: 0 0 22px rgba(var(--pb-primary-rgb), 0.34);
}

.pb-shell .mud-nav-link .mud-nav-link-text {
    margin-left: 0.9rem;
    font-size: 0.93rem;
    font-weight: 500;
    letter-spacing: -0.01em;
}

.pb-shell .mud-nav-link .mud-nav-link-icon {
    font-size: 1.3rem;
    transition: transform var(--pb-transition-fast), filter var(--pb-transition-fast);
}

.pb-shell .mud-nav-link:hover .mud-nav-link-icon,
.pb-shell .mud-nav-link.active .mud-nav-link-icon {
    transform: translateY(-1px);
    filter: drop-shadow(0 6px 10px rgba(0, 0, 0, 0.18));
}

.pb-shell [data-testid="nav-link-dashboard"] .mud-nav-link-icon,
.pb-shell [data-testid="nav-link-login"] .mud-nav-link-icon {
    color: #8b5cf6;
}

.pb-shell [data-testid="nav-link-clientes"] .mud-nav-link-icon {
    color: #22c55e;
}

.pb-shell [data-testid="nav-link-agendamentos"] .mud-nav-link-icon {
    color: #38bdf8;
}

.pb-shell [data-testid="nav-link-pacotes"] .mud-nav-link-icon {
    color: #f59e0b;
}

.pb-shell [data-testid="nav-link-estoque"] .mud-nav-link-icon {
    color: #ef4444;
}

.pb-shell [data-testid="nav-link-servicos"] .mud-nav-link-icon {
    color: #ec4899;
}

.pb-shell [data-testid="nav-link-conversas"] .mud-nav-link-icon {
    color: #06b6d4;
}

.pb-shell [data-testid="nav-link-calendar"] .mud-nav-link-icon {
    color: #a78bfa;
}

.pb-shell [data-testid="nav-link-petshop-settings"] .mud-nav-link-icon {
    color: #14b8a6;
}

.pb-shell [data-testid="nav-link-subscription"] .mud-nav-link-icon,
.pb-shell [data-testid="nav-link-admin-billing"] .mud-nav-link-icon {
    color: #fbbf24;
}

.pb-shell [data-testid="nav-link-profile"] .mud-nav-link-icon {
    color: #fb7185;
}

.pb-shell [data-testid="nav-link-profissionais"] .mud-nav-link-icon {
    color: #34d399;
}

.pb-shell [data-testid="nav-link-settings"] .mud-nav-link-icon,
.pb-shell [data-testid="nav-link-admin-users"] .mud-nav-link-icon {
    color: #60a5fa;
}

.pb-shell [data-testid="nav-link-admin-dashboard"] .mud-nav-link-icon {
    color: #c084fc;
}

.pb-shell [data-testid="nav-link-admin-attention"] .mud-nav-link-icon {
    color: #f97316;
}

.pb-shell [data-testid="nav-link-admin-tenants"] .mud-nav-link-icon {
    color: #2dd4bf;
}

.pb-shell [data-testid="nav-link-admin-roles"] .mud-nav-link-icon {
    color: #818cf8;
}

.pb-shell [data-testid="nav-link-admin-execucoes"] .mud-nav-link-icon {
    color: #f472b6;
}

.pb-shell [data-testid="nav-link-admin-webhooks"] .mud-nav-link-icon {
    color: #22d3ee;
}

.pb-shell [data-testid="nav-link-admin-data"] .mud-nav-link-icon {
    color: #f87171;
}

.pb-shell .mud-navmenu .mud-typography-overline {
    color: var(--pb-text-muted) !important;
    font-size: 0.68rem;
    opacity: 0.74;
}

.pb-shell [data-testid="nav-section-admin-center"] {
    color: color-mix(in srgb, var(--pb-primary-light) 72%, var(--pb-text-muted) 28%) !important;
}

.pb-shell .mud-navmenu [data-testid^="nav-link-admin-"] .mud-nav-link-icon {
    color: color-mix(in srgb, var(--pb-text-muted) 78%, var(--pb-primary-light) 22%);
}

.pb-shell .mud-navmenu [data-testid="nav-link-admin-attention"] .mud-nav-link-icon {
    color: color-mix(in srgb, var(--pb-warning) 72%, var(--pb-text) 28%);
}

.pb-shell .mud-navmenu [data-testid="nav-link-admin-data"] .mud-nav-link-icon {
    color: color-mix(in srgb, var(--pb-error) 76%, var(--pb-text) 24%);
}

.pb-shell .mud-navmenu [data-testid^="nav-link-admin-"].active .mud-nav-link-icon {
    color: var(--pb-text);
}

.pb-shell .mud-button-root {
    transition:
        transform var(--pb-transition-fast),
        box-shadow var(--pb-transition-base),
        border-color var(--pb-transition-base),
        background-color var(--pb-transition-base);
}

.pb-shell .mud-button-root:focus-visible,
.pb-shell .mud-icon-button:focus-visible,
.pb-shell .mud-nav-link:focus-visible,
.pb-shell .mud-tab:focus-visible,
.pb-shell .mud-input-root:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px var(--pb-focus);
}

.pb-shell .mud-button {
    min-height: 2.8rem;
    padding-inline: 1rem;
    border-radius: var(--pb-radius-sm);
    font-size: 0.88rem;
}

.pb-shell .mud-button-filled {
    box-shadow: 0 16px 30px rgba(7, 4, 13, 0.14);
}

.pb-shell .mud-button-filled-primary {
    border: 1px solid rgba(var(--pb-primary-rgb), 0.42);
    background: linear-gradient(145deg, color-mix(in srgb, var(--pb-primary-light) 72%, var(--pb-primary) 28%), var(--pb-primary));
}

.pb-shell .mud-button-filled-primary:hover,
.pb-shell .mud-button-filled-primary:focus-visible,
.pb-shell .mud-button-filled-primary:active {
    background: linear-gradient(145deg, color-mix(in srgb, var(--pb-primary-light) 62%, var(--pb-primary) 38%), var(--pb-primary-hover));
    transform: translateY(-1px);
    box-shadow: 0 20px 36px rgba(var(--pb-primary-rgb), 0.2);
}

.pb-shell .mud-button-outlined {
    border-width: 1px;
    border-color: var(--pb-line-strong);
    background: color-mix(in srgb, var(--pb-surface) 78%, transparent);
}

.pb-shell .mud-button-outlined:hover,
.pb-shell .mud-button-outlined:focus-visible,
.pb-shell .mud-button-outlined:active {
    border-color: rgba(var(--pb-primary-rgb), 0.3);
    background: rgba(var(--pb-primary-rgb), 0.07);
}

.pb-shell .mud-button-text {
    color: var(--pb-text);
}

.pb-shell .mud-button-text:hover,
.pb-shell .mud-button-text:focus-visible,
.pb-shell .mud-button-text:active {
    background: rgba(var(--pb-primary-rgb), 0.08);
}

.pb-shell .mud-icon-button {
    border-radius: 14px;
    color: var(--pb-text-muted);
}

.pb-shell .mud-icon-button:hover,
.pb-shell .mud-icon-button:focus-within,
.pb-shell .mud-icon-button:active {
    color: var(--pb-text);
    background: rgba(var(--pb-primary-rgb), 0.08);
}

.pb-shell .mud-paper,
.pb-shell .mud-card,
.pb-shell .mud-tabs-tabbar,
.pb-shell .mud-popover .mud-paper {
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .mud-paper-outlined,
.pb-shell .mud-table-outlined {
    border-color: var(--pb-line-strong);
}

.pb-shell .page-shell {
    position: relative;
    z-index: 0;
    gap: 1.75rem !important;
}

.pb-shell .conversation-page-shell {
    gap: 1rem !important;
}

.pb-shell .pb-public-shell {
    width: 100%;
    min-height: min(100%, 42rem);
}

.pb-shell .login-page-shell {
    width: 100%;
    padding-inline: 0;
}

.pb-shell .login-page-card {
    width: min(100%, 32rem);
    margin-inline: auto;
    border-color: rgba(255, 255, 255, 0.1);
    background:
        linear-gradient(180deg, rgba(24, 17, 38, 0.98), rgba(18, 13, 29, 0.94));
    box-shadow:
        0 24px 48px rgba(5, 2, 10, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.pb-shell .login-page-card .login-header {
    text-align: center;
}

.pb-shell .login-page-card .login-links {
    padding-top: 0.35rem;
}

.pb-shell [data-testid="login-page"] [data-testid="login-forgot-password"],
.pb-shell [data-testid="login-page"] [data-testid="login-register-tenant"] {
    font-weight: 600;
}

.pb-shell [data-testid="login-page"] [data-testid="login-forgot-password-label"],
.pb-shell [data-testid="login-page"] [data-testid="login-register-tenant-label"] {
    color: #fff !important;
}

.pb-shell [data-testid="login-page"] [data-testid="login-forgot-password"]:hover,
.pb-shell [data-testid="login-page"] [data-testid="login-forgot-password"]:focus-visible,
.pb-shell [data-testid="login-page"] [data-testid="login-forgot-password"]:active,
.pb-shell [data-testid="login-page"] [data-testid="login-register-tenant"]:hover,
.pb-shell [data-testid="login-page"] [data-testid="login-register-tenant"]:focus-visible,
.pb-shell [data-testid="login-page"] [data-testid="login-register-tenant"]:active {
    text-decoration-color: rgba(255, 255, 255, 0.82);
}

.pb-shell .page-header {
    align-items: flex-start !important;
    width: 100%;
    justify-content: space-between;
    row-gap: 0.9rem;
    column-gap: 1.1rem;
}

.pb-shell .page-header-copy {
    gap: 0.25rem !important;
    min-width: 0;
    flex: 1 1 auto;
}

.pb-shell .admin-page-header {
    align-items: flex-start !important;
}

.pb-shell .page-shell.admin-center-shell {
    gap: 1.25rem !important;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell),
.pb-shell .tenant-tabbed-settings-page {
    gap: 1.25rem !important;
    margin-top: -0.35rem;
}

.pb-shell .conversation-page-shell {
    margin-top: -0.35rem;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header,
.pb-shell .tenant-tabbed-settings-page .page-header {
    gap: 0.9rem !important;
    margin-bottom: 0 !important;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header-main,
.pb-shell .tenant-tabbed-settings-page .page-header-main {
    gap: 0.8rem !important;
    flex: 1 1 26rem;
    min-width: 0;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header-copy,
.pb-shell .tenant-tabbed-settings-page .page-header-copy {
    gap: 0.18rem !important;
    max-width: 44rem;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header .mud-typography-h4,
.pb-shell .tenant-tabbed-settings-page .page-header .mud-typography-h4 {
    font-size: clamp(1.75rem, 2vw, 1.9rem);
    line-height: 1.08;
    letter-spacing: -0.035em;
    outline: none;
    border: 0;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-title-icon,
.pb-shell .tenant-tabbed-settings-page .page-title-icon {
    width: 2.5rem;
    height: 2.5rem;
}

.pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header-actions,
.pb-shell .tenant-tabbed-settings-page .page-header-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    margin-left: auto;
    min-width: 0;
}

.pb-shell .admin-page-header .page-header-copy {
    max-width: 46rem;
}

.pb-shell .admin-page-title {
    font-size: clamp(1.75rem, 2vw, 1.9rem);
    line-height: 1.08;
    letter-spacing: -0.035em;
}

.pb-shell .admin-page-subtitle {
    max-width: 44rem;
}

.pb-shell .admin-action-cluster {
    align-items: center;
    justify-content: flex-end;
}

.pb-shell .page-title-icon {
    width: 2.85rem;
    height: 2.85rem;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.2);
    background:
        linear-gradient(160deg, rgba(var(--pb-primary-rgb), 0.18), rgba(var(--pb-primary-rgb), 0.04));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.pb-shell .section-support-text,
.pb-shell .mud-typography.mud-typography-caption,
.pb-shell .mud-text-secondary {
    color: var(--pb-text-muted) !important;
}

.pb-shell .page-panel,
.pb-shell .page-panel-compact,
.pb-shell .page-panel-roomy,
.pb-shell .page-panel-empty,
.pb-shell .calendar-surface,
.pb-shell .calendar-team-column,
.pb-shell .danger-zone-panel {
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-panel-bg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .calendar-content-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.pb-shell .page-panel,
.pb-shell .page-panel-roomy,
.pb-shell .dashboard-panel {
    box-shadow: var(--pb-shadow-md);
}

.pb-shell .tenant-context-panel {
    border: 1px solid color-mix(in srgb, var(--pb-line-strong) 78%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 88%, transparent));
}

.pb-shell .tenant-context-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
    gap: 0.75rem;
    align-items: stretch;
}

.pb-shell .tenant-context-kpi {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-height: 5rem;
    padding: 0.9rem 1rem;
    border: 1px solid color-mix(in srgb, var(--pb-line-strong) 72%, transparent);
    border-radius: calc(var(--pb-radius-lg) - 6px);
    background: color-mix(in srgb, var(--pb-surface) 92%, var(--pb-surface-2) 8%);
}

.pb-shell .tenant-context-kpi-label {
    color: var(--pb-text-muted);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.pb-shell .tenant-context-kpi-value {
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.pb-shell .tenant-touch-target-switch {
    width: 100%;
    min-height: 2.75rem;
}

.pb-shell .tenant-touch-target-switch .mud-switch {
    width: 100%;
}

.pb-shell .tenant-touch-target-switch .mud-button-root,
.pb-shell .tenant-touch-target-switch .mud-switch-button {
    min-width: 2.75rem;
    min-height: 2.75rem;
}

.pb-shell .tenant-checklist {
    margin: 0;
    padding-left: 1rem;
    color: var(--pb-text-muted);
}

.pb-shell .tenant-checklist li + li {
    margin-top: 0.35rem;
}

.pb-shell .tenant-empty-state-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem;
}

.pb-shell .tenant-responsive-list-mobile {
    display: none;
}

.pb-shell .tenant-responsive-list-desktop {
    display: block;
}

.pb-shell .tenant-mobile-list-stack {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.pb-shell .tenant-mobile-list-card {
    border: 1px solid color-mix(in srgb, var(--pb-line-strong) 76%, transparent);
    border-radius: var(--pb-radius-lg);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 88%, transparent));
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .tenant-mobile-list-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.9rem;
}

.pb-shell .tenant-mobile-list-copy {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 0;
}

.pb-shell .tenant-mobile-keyvals {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.pb-shell .tenant-mobile-keyval {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 0;
}

.pb-shell .tenant-mobile-keyval-label {
    color: var(--pb-text-muted);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.pb-shell .tenant-mobile-keyval-value {
    font-size: 0.92rem;
    line-height: 1.35;
    word-break: break-word;
}

.pb-shell .tenant-mobile-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.pb-shell .tenant-mobile-card-actions .mud-button-root {
    flex: 1 1 10rem;
}

.pb-shell .tenant-mobile-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.pb-shell .filter-bar,
.pb-shell .responsive-toolbar,
.pb-shell .section-header-inline {
    gap: 1rem;
}

.pb-shell .tenant-operational-shell .filter-bar,
.pb-shell .tenant-operational-shell .section-header-inline {
    gap: 0.85rem;
}

.pb-shell .search-field,
.pb-shell .toolbar-action {
    min-width: min(100%, 16rem);
}

.pb-shell .kpi-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .kpi-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at top right, rgba(var(--pb-primary-rgb), 0.14), transparent 42%);
}

.pb-shell .kpi-label {
    color: var(--pb-text-muted) !important;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pb-shell .kpi-value {
    margin-top: 0.35rem;
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: clamp(1.9rem, 2.2vw, 2.6rem);
    font-weight: 700;
    letter-spacing: -0.04em;
    line-height: 1;
}

.pb-shell .kpi-icon {
    width: 3rem;
    height: 3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.16);
    border-radius: 18px;
    color: color-mix(in srgb, var(--pb-primary-light) 82%, #ffffff 18%);
    background: rgba(var(--pb-primary-rgb), 0.14);
}

.pb-shell[data-theme="dark"] .page-title-icon,
.pb-shell[data-theme="dark"] .kpi-icon,
.pb-shell[data-theme="dark"] .empty-icon {
    color: var(--pb-text) !important;
}

.pb-shell .empty-state-card {
    min-height: 16rem;
    border: 1px dashed var(--pb-line-strong);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-empty-bg);
}

.pb-shell .empty-icon {
    color: color-mix(in srgb, var(--pb-primary-light) 82%, #ffffff 18%);
}

.pb-shell .tenant-kpi-shell .kpi-card {
    padding: 0.8rem 0.95rem !important;
}

.pb-shell .tenant-balanced-kpi-grid {
    row-gap: 0.75rem;
}

.pb-shell .tenant-balanced-kpi-grid > .mud-grid-item {
    display: flex;
}

.pb-shell .tenant-balanced-kpi-grid > .mud-grid-item > * {
    width: 100%;
    height: 100%;
}

.pb-shell .tenant-stretch-grid > .mud-grid-item {
    display: flex;
}

.pb-shell .tenant-stretch-grid > .mud-grid-item > * {
    width: 100%;
    height: 100%;
}

.pb-shell .tenant-panel-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    min-width: 0;
}

.pb-shell .tenant-panel-stack > * {
    width: 100%;
    margin: 0 !important;
}

.pb-shell .tenant-tab-panel-slim,
.pb-shell .tenant-narrow-panel {
    width: min(100%, 56rem);
    margin-inline: auto;
}

.pb-shell .tenant-tab-panel-slim > *,
.pb-shell .tenant-narrow-panel > * {
    width: 100%;
}

.pb-shell .calendar-team-filters > * {
    flex: 1 1 13rem;
    min-width: min(100%, 13rem);
}

.pb-shell .calendar-filter-select {
    min-width: min(100%, 14rem);
}

.pb-shell .calendar-team-columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: 1rem;
    align-items: stretch;
}

.pb-shell .calendar-team-column {
    width: 100%;
    min-height: 100%;
}

.pb-shell .tenant-dialog-form-grid > .mud-grid-item {
    display: flex;
}

.pb-shell .tenant-dialog-form-grid > .mud-grid-item > * {
    width: 100%;
}

.pb-shell .tenant-dialog-section {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.pb-shell .tenant-dialog-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.pb-shell .tenant-dialog-actions-row .mud-button-root {
    flex: 1 1 12rem;
}

.pb-shell .tenant-dialog-note {
    max-width: 42rem;
}

.pb-shell .tenant-balanced-kpi-grid .kpi-card,
.pb-shell .tenant-balanced-kpi-grid .page-panel-compact {
    min-height: 5.45rem;
}

.pb-shell .tenant-kpi-layout {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    min-height: 100%;
}

.pb-shell .tenant-kpi-summary {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
    flex: 1 1 auto;
}

.pb-shell .tenant-kpi-icon {
    width: 2.55rem;
    height: 2.55rem;
    border-radius: 16px;
    flex: 0 0 auto;
}

.pb-shell .tenant-kpi-label {
    max-width: 7rem;
    text-align: left;
    line-height: 1.12;
    font-size: 0.68rem;
    letter-spacing: 0.07em;
}

.pb-shell .tenant-kpi-number {
    margin-top: 0;
    margin-left: auto;
    text-align: right;
    flex: 0 0 auto;
    min-width: 0;
    font-size: clamp(1.72rem, 2vw, 2.3rem);
}

.pb-shell .tenant-kpi-money {
    font-family: ui-monospace, "SFMono-Regular", "Roboto Mono", Consolas, monospace;
    font-size: clamp(1.28rem, 1.7vw, 1.72rem);
    letter-spacing: -0.03em;
}

.pb-shell .tenant-filter-chip {
    min-height: 2.5rem;
    padding-inline: 0.2rem;
}

.pb-shell .tenant-dashboard-shell .dashboard-panel,
.pb-shell .tenant-operational-shell .page-panel {
    padding: 1rem !important;
}

.pb-shell .tenant-dashboard-shell .section-header-inline,
.pb-shell .tenant-operational-shell .filter-bar {
    margin-bottom: 0.85rem !important;
}

.pb-shell .tenant-dashboard-shell .empty-state-card {
    min-height: 13rem;
}

.pb-shell .tenant-inline-actions {
    align-items: center;
    flex-wrap: nowrap !important;
    gap: 0.125rem !important;
    min-width: 0;
}

.pb-shell .tenant-inline-actions .mud-icon-button {
    width: 2.5rem;
    height: 2.5rem;
}

.pb-shell .tenant-list-panel {
    min-height: clamp(16rem, 36vh, 22rem);
}

.pb-shell .packages-shell .package-status-filters {
    margin-top: -0.15rem;
}

.pb-shell .packages-shell .page-panel-empty {
    min-height: 10.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.4rem !important;
}

.pb-shell .tenant-profile-shell .page-panel {
    min-height: 17rem;
}

.pb-shell .tenant-subscription-card {
    min-height: 13rem;
}

.pb-shell .tenant-subscription-history {
    min-height: 8.5rem;
}

.pb-shell .tenant-team-table {
    min-height: 11rem;
}

.pb-shell .tenant-tabbed-settings-page .mud-tabs-panels {
    padding-top: 0.85rem;
}

.pb-shell .table-actions {
    align-items: center;
}

.pb-shell .table-actions .mud-icon-button {
    width: 2.75rem;
    height: 2.75rem;
}

.pb-shell .admin-users-actions {
    flex-wrap: nowrap;
    gap: 0.125rem !important;
    min-width: 0;
}

.pb-shell .admin-users-actions .mud-icon-button {
    width: 2.5rem;
    height: 2.5rem;
}

.pb-shell .admin-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.pb-shell .admin-responsive-list-mobile {
    display: none;
}

.pb-shell .admin-responsive-list-desktop {
    display: block;
}

.pb-shell .admin-mobile-card {
    border-color: color-mix(in srgb, var(--pb-line-strong) 74%, transparent);
    background: linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 86%, transparent));
}

.pb-shell .admin-mobile-list-stack {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.pb-shell .admin-mobile-list-card {
    border-color: color-mix(in srgb, var(--pb-line-strong) 76%, transparent);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 88%, transparent));
}

.pb-shell .admin-mobile-list-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.9rem;
}

.pb-shell .admin-mobile-list-copy {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    min-width: 0;
}

.pb-shell .admin-mobile-keyvals {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.pb-shell .admin-mobile-keyval {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.pb-shell .admin-mobile-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
}

.pb-shell .admin-mobile-card-actions .mud-button-root {
    flex: 1 1 10rem;
    min-height: 2.85rem;
}

.pb-shell [data-testid="admin-tenants-table-panel"] .admin-mobile-card-actions {
    width: 100%;
}

.pb-shell .admin-mobile-pager {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .admin-mobile-pager-copy {
    color: var(--pb-text-muted) !important;
}

.pb-shell .admin-balanced-grid {
    row-gap: 1rem;
}

.pb-shell .admin-balanced-grid > .mud-grid-item {
    display: flex;
}

.pb-shell .admin-balanced-grid > .mud-grid-item > * {
    width: 100%;
}

.pb-shell .admin-balanced-grid > .mud-grid-item > .mud-paper,
.pb-shell .admin-balanced-grid > .mud-grid-item > .kpi-card,
.pb-shell .admin-balanced-grid > .mud-grid-item > .page-panel,
.pb-shell .admin-balanced-grid > .mud-grid-item > .page-panel-compact,
.pb-shell .admin-balanced-grid > .mud-grid-item > .page-panel-roomy {
    height: 100%;
}

.pb-shell .admin-balanced-kpi-grid .kpi-card {
    min-height: 7.35rem;
}

.pb-shell .admin-data-surface {
    min-height: clamp(24rem, 52vh, 38rem);
}

.pb-shell .admin-dashboard-shell .kpi-card {
    padding: 0.8rem 0.9rem !important;
}

.pb-shell .admin-dashboard-shell .admin-balanced-grid {
    row-gap: 0;
}

.pb-shell .admin-page-header .page-title-icon {
    width: 2.5rem;
    height: 2.5rem;
}

.pb-shell .admin-dashboard-shell .kpi-label {
    font-size: 0.68rem;
    letter-spacing: 0.07em;
}

.pb-shell .admin-dashboard-shell .kpi-value {
    margin-top: 0;
    font-size: clamp(1.72rem, 2vw, 2.3rem);
}

.pb-shell .admin-dashboard-shell .kpi-icon {
    width: 2.55rem;
    height: 2.55rem;
    border-radius: 16px;
}

.pb-shell .admin-dashboard-kpi-layout {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    min-height: 100%;
}

.pb-shell .admin-dashboard-kpi-number {
    flex: 0 0 auto;
    min-width: 0;
    text-align: right;
    margin-left: auto;
}

.pb-shell .admin-dashboard-kpi-summary {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.55rem;
    min-width: 0;
    flex: 1 1 auto;
}

.pb-shell .admin-dashboard-kpi-icon {
    flex: 0 0 auto;
}

.pb-shell .admin-dashboard-kpi-label {
    max-width: 6.25rem;
    text-align: left;
    line-height: 1.12;
}

.pb-shell .admin-dashboard-shell .admin-balanced-kpi-grid .kpi-card {
    min-height: 5.45rem;
}

.pb-shell .admin-mobile-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.pb-shell .admin-meta-label {
    color: var(--pb-text-muted) !important;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.pb-shell .admin-provision-dialog .mud-dialog-content {
    padding-top: 0.75rem;
}

.pb-shell .admin-form-grid {
    row-gap: 0.25rem;
}

.pb-shell .table-avatar,
.pb-shell .table-avatar-sm {
    min-width: 2.05rem;
    min-height: 2.05rem;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.18);
    border-radius: 999px !important;
    background:
        linear-gradient(140deg, rgba(var(--pb-primary-rgb), 0.22), rgba(var(--pb-primary-rgb), 0.08));
    color: var(--pb-text) !important;
    font-weight: 700;
}

.pb-shell .table-avatar-sm {
    min-width: 1.8rem;
    min-height: 1.8rem;
}

.pb-shell .mud-table {
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--pb-line-strong) 72%, transparent);
    border-radius: calc(var(--pb-radius-lg) - 2px);
    background: color-mix(in srgb, var(--pb-surface) 96%, var(--pb-surface-2) 4%);
}

.pb-shell .mud-table-toolbar {
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .mud-table-container {
    border-top: 0;
    background: color-mix(in srgb, var(--pb-surface) 97%, var(--pb-surface-2) 3%);
}

.pb-shell .mud-table-root .mud-table-head .mud-table-cell {
    background: color-mix(in srgb, var(--pb-surface-2) 82%, var(--pb-surface) 18%);
    color: color-mix(in srgb, var(--pb-text) 84%, var(--pb-text-muted) 16%);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--pb-line-strong);
}

.pb-shell .mud-table-root .mud-table-body .mud-table-row {
    transition:
        background-color var(--pb-transition-fast),
        box-shadow var(--pb-transition-fast);
}

.pb-shell .mud-table-root .mud-table-body .mud-table-row .mud-table-cell {
    border-bottom: 1px solid color-mix(in srgb, var(--pb-line) 78%, transparent);
}

.pb-shell .mud-table-root .mud-table-body .mud-table-row:nth-child(even) {
    background: color-mix(in srgb, var(--pb-surface-2) 30%, var(--pb-surface) 70%);
}

.pb-shell .mud-table-root .mud-table-row:hover {
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.12) 62%, var(--pb-surface) 38%);
    box-shadow: inset 0 1px 0 rgba(var(--pb-primary-rgb), 0.1);
}

.pb-shell .mud-table-root .mud-table-row:hover .mud-table-cell {
    background: transparent;
}

.pb-shell .mud-table-cell {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
    vertical-align: middle;
}

.pb-shell .mud-table-pagination {
    border-top: 1px solid var(--pb-line);
    background: color-mix(in srgb, var(--pb-surface) 94%, var(--pb-surface-2) 6%);
}

.pb-shell .mud-table-pagination .mud-input-root,
.pb-shell .mud-table-pagination .mud-input-slot,
.pb-shell .mud-table-pagination .mud-select-input {
    color: var(--pb-text);
}

.pb-shell .mud-table-pagination .mud-button-root,
.pb-shell .mud-table-pagination .mud-icon-button,
.pb-shell .mud-table-pagination .mud-select {
    min-width: 2.75rem;
    min-height: 2.75rem;
}

.pb-shell .status-chip,
.pb-shell .mud-chip {
    border-radius: 999px;
    box-shadow: none;
}

.pb-shell .mud-chip-filled {
    border: 1px solid transparent;
}

.pb-shell .mud-input-control {
    margin-top: 0.25rem;
}

.pb-shell .mud-input-outlined {
    border-radius: var(--pb-radius-sm);
    background: color-mix(in srgb, var(--pb-surface-2) 88%, transparent);
}

.pb-shell .mud-input-outlined .mud-input-outlined-border {
    border-radius: var(--pb-radius-sm);
}

.pb-shell .mud-input-outlined:hover .mud-input-outlined-border,
.pb-shell .mud-input-outlined:focus-within .mud-input-outlined-border {
    border-color: rgba(var(--pb-primary-rgb), 0.28);
}

.pb-shell .mud-input-outlined:focus-within .mud-input-outlined-border,
.pb-shell .mud-input-error .mud-input-outlined-border {
    box-shadow: 0 0 0 4px var(--pb-focus);
}

.pb-shell .mud-input-slot,
.pb-shell .mud-input > input.mud-input-root {
    color: var(--pb-text);
}

.pb-shell .mud-input-label {
    color: var(--pb-text-muted);
}

.pb-shell .mud-input-error .mud-input-label,
.pb-shell .validation-message {
    color: var(--mud-palette-error) !important;
}

.pb-shell .mud-select .mud-input-adornment,
.pb-shell .mud-input-adornment {
    color: var(--pb-text-muted);
}

.pb-shell .mud-dialog {
    border: 1px solid var(--pb-line);
    border-radius: calc(var(--pb-radius-lg) + 2px);
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--pb-surface) 98%, transparent), color-mix(in srgb, var(--pb-surface-2) 92%, transparent));
    box-shadow: var(--pb-shadow-lg);
}

.pb-shell .mud-dialog .mud-dialog-title,
.pb-shell .mud-dialog .mud-dialog-actions {
    border-color: var(--pb-line);
}

.pb-shell .mud-dialog .mud-dialog-title {
    font-family: "Sora", "IBM Plex Sans", sans-serif;
}

.pb-shell .mud-alert {
    border: 1px solid transparent;
}

.pb-shell .mud-alert-filled-warning,
.pb-shell .mud-alert-filled-error,
.pb-shell .mud-alert-filled-info,
.pb-shell .mud-alert-filled-success {
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .mud-alert-outlined-warning,
.pb-shell .mud-alert-outlined-error,
.pb-shell .mud-alert-outlined-info,
.pb-shell .mud-alert-outlined-success {
    background: color-mix(in srgb, var(--pb-surface) 88%, transparent);
}

.pb-shell .mud-snackbar {
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: color-mix(in srgb, var(--pb-surface) 94%, transparent);
    box-shadow: var(--pb-shadow-md);
}

.pb-shell .mud-tabs-tabbar {
    background: color-mix(in srgb, var(--pb-surface-2) 92%, transparent);
}

.pb-shell .mud-tab {
    min-height: 3.15rem;
    letter-spacing: 0.03em;
    text-transform: none;
}

.pb-shell .mud-tab.mud-tab-active {
    color: var(--pb-text);
}

.pb-shell .mud-tab-slider {
    height: 3px !important;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--pb-primary), var(--pb-primary-light));
}

.pb-shell .mud-divider {
    border-color: var(--pb-line);
}

.pb-shell .mud-menu {
    color: var(--pb-text);
}

.pb-shell [data-testid="impersonation-banner"] {
    border: 1px solid rgba(var(--pb-warning-rgb), 0.2);
    box-shadow: none;
}

.pb-shell::-webkit-scrollbar,
.pb-shell *::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

.pb-shell::-webkit-scrollbar-track,
.pb-shell *::-webkit-scrollbar-track {
    background: transparent;
}

.pb-shell::-webkit-scrollbar-thumb,
.pb-shell *::-webkit-scrollbar-thumb {
    border: 2px solid transparent;
    border-radius: 999px;
    background: color-mix(in srgb, var(--pb-primary-light) 38%, var(--pb-surface-3));
    background-clip: padding-box;
}

.pb-shell::-webkit-scrollbar-thumb:hover,
.pb-shell *::-webkit-scrollbar-thumb:hover {
    background: color-mix(in srgb, var(--pb-primary-light) 54%, var(--pb-surface-3));
    background-clip: padding-box;
}

.blazor-reconnect-modal {
    width: min(28rem, calc(100vw - 2rem));
    border: 0;
    padding: 0;
    border-radius: 20px;
    background: transparent;
    color: inherit;
}

.blazor-reconnect-modal::backdrop {
    background: rgba(7, 4, 13, 0.56);
    backdrop-filter: blur(10px);
}

.blazor-reconnect-card {
    border: 1px solid rgba(194, 168, 234, 0.2);
    border-radius: 20px;
    padding: 1.6rem;
    background: linear-gradient(180deg, rgba(24, 17, 38, 0.98), rgba(33, 23, 52, 0.98));
    color: #f6f1ff;
    box-shadow: 0 30px 80px rgba(7, 4, 13, 0.42);
}

.blazor-reconnect-card h2 {
    margin: 0 0 0.75rem;
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: 1.32rem;
    letter-spacing: -0.03em;
}

.blazor-reconnect-card p {
    margin: 0;
}

.blazor-reconnect-attempts {
    margin-top: 0.8rem !important;
    color: #c9c0dc;
    font-size: 0.94rem;
}

.blazor-reconnect-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 1.25rem;
}

.blazor-reconnect-actions button {
    border: 1px solid rgba(116, 80, 168, 0.38);
    border-radius: 999px;
    padding: 0.8rem 1.05rem;
    cursor: pointer;
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: 0.88rem;
    font-weight: 600;
    color: #f6f1ff;
    background: linear-gradient(145deg, #7c59ae, #7450a8);
    box-shadow: 0 16px 30px rgba(116, 80, 168, 0.24);
    transition: transform 160ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 220ms cubic-bezier(0.4, 0, 0.2, 1);
}

.blazor-reconnect-actions button:hover {
    transform: translateY(-1px);
    background: linear-gradient(145deg, #815eb1, #5f408a);
    box-shadow: 0 20px 36px rgba(116, 80, 168, 0.3);
}

@media (max-width: 959.98px) {
    .pb-shell [data-testid="main-content"] {
        padding: calc(var(--mud-appbar-height) + 0.95rem) 0.85rem 1.35rem;
    }

    .pb-shell .mud-toolbar-appbar {
        padding-inline: 0.7rem;
    }

    .pb-shell .mud-drawer {
        width: min(88vw, 22rem) !important;
    }

    .pb-shell .mud-drawer.mud-drawer-temporary {
        max-width: min(88vw, 22rem);
    }

    .pb-shell .mud-drawer.mud-drawer-temporary.mud-drawer--closed {
        left: calc(-1 * min(88vw, 22rem)) !important;
    }

    .pb-shell .page-shell {
        gap: 1.05rem !important;
    }

    .pb-shell .page-shell.admin-center-shell {
        gap: 1rem !important;
    }

    .pb-shell .kpi-value {
        font-size: 1.85rem;
    }

    .pb-shell .mud-navmenu {
        padding-inline: 0.6rem;
    }

    .pb-shell .admin-responsive-list-desktop {
        display: none;
    }

    .pb-shell .admin-responsive-list-mobile {
        display: block;
    }

    .pb-shell .tenant-responsive-list-desktop {
        display: none;
    }

    .pb-shell .tenant-responsive-list-mobile {
        display: block;
    }

    .pb-shell .admin-data-surface {
        min-height: auto;
    }

    .pb-shell .admin-action-cluster {
        width: 100%;
        justify-content: stretch;
    }

    .pb-shell .admin-action-cluster .mud-button-root {
        flex: 1 1 12rem;
    }

    .pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header-actions,
    .pb-shell .tenant-tabbed-settings-page .page-header-actions {
        width: 100%;
        margin-left: 0;
        justify-content: flex-start;
    }

    .pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header-actions .mud-button-root,
    .pb-shell .tenant-tabbed-settings-page .page-header-actions .mud-button-root {
        flex: 1 1 12rem;
    }
}

@media (max-width: 599.98px) {
    .pb-shell {
        --mud-appbar-height: 52px;
    }

    .pb-shell [data-testid="main-content"] {
        padding: calc(var(--mud-appbar-height) + 1rem) 0.8rem 1.25rem;
    }

    .pb-shell .mud-appbar {
        backdrop-filter: blur(14px);
    }

    .pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell),
    .pb-shell .tenant-tabbed-settings-page {
        gap: 0.85rem !important;
        margin-top: -0.5rem;
    }

    .pb-shell .conversation-page-shell {
        margin-top: -0.5rem;
    }

    .pb-shell .mud-nav-link {
        min-height: 44px;
        padding: 0.68rem 0.82rem;
    }

    .pb-shell .mud-button {
        min-height: 2.75rem;
    }

    .pb-shell .admin-page-title {
        font-size: 1.58rem;
        line-height: 1.1;
    }

    .pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-header .mud-typography-h4,
    .pb-shell .tenant-tabbed-settings-page .page-header .mud-typography-h4 {
        font-size: 1.58rem;
        line-height: 1.1;
    }

    .pb-shell .admin-page-header .page-title-icon {
        width: 2.35rem;
        height: 2.35rem;
    }

    .pb-shell .page-shell:not(.admin-center-shell):not(.conversation-page-shell) .page-title-icon,
    .pb-shell .tenant-tabbed-settings-page .page-title-icon {
        width: 2.35rem;
        height: 2.35rem;
    }

    .pb-shell .admin-mobile-meta-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .admin-mobile-keyvals {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .search-field,
    .pb-shell .toolbar-action,
    .pb-shell .filter-bar > * {
        width: 100%;
        min-width: 0;
    }

    .pb-shell .table-actions .mud-icon-button {
        width: 2.8rem;
        height: 2.8rem;
    }

    .pb-shell .admin-users-actions .mud-icon-button {
        width: 2.8rem;
        height: 2.8rem;
    }

    .pb-shell .tenant-inline-actions .mud-icon-button {
        width: 2.8rem;
        height: 2.8rem;
    }

    .pb-shell .tenant-settings-tabs .mud-tabs-tabbar {
        overflow-x: auto;
        scrollbar-width: none;
    }

    .pb-shell .tenant-settings-tabs .mud-tabs-tabbar::-webkit-scrollbar {
        display: none;
    }

    .pb-shell .tenant-settings-tabs .mud-tab {
        min-height: 2.75rem;
        padding-inline: 0.9rem;
        white-space: nowrap;
    }

    .pb-shell .tenant-context-kpi-grid,
    .pb-shell .tenant-mobile-keyvals {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .tenant-tab-panel-slim,
    .pb-shell .tenant-narrow-panel {
        width: 100%;
    }

    .pb-shell .calendar-team-columns {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .tenant-mobile-list-header,
    .pb-shell .tenant-mobile-inline {
        flex-wrap: wrap;
    }

    .pb-shell .tenant-mobile-card-actions .mud-button-root {
        flex-basis: 100%;
    }

    .pb-shell .admin-dashboard-kpi-label {
        max-width: 6.75rem;
    }

    .pb-shell .tenant-kpi-label {
        max-width: 6.75rem;
    }

    .pb-shell .appointments-kpi-grid .kpi-card {
        padding: 0.8rem !important;
    }

    .pb-shell .appointments-kpi-grid .tenant-kpi-layout {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.55rem;
    }

    .pb-shell .appointments-kpi-grid .tenant-kpi-summary,
    .pb-shell .appointments-kpi-grid .tenant-kpi-number {
        width: 100%;
    }

    .pb-shell .appointments-kpi-grid .tenant-kpi-number {
        margin-left: 0;
        text-align: left;
        line-height: 1.05;
    }

    .pb-shell .appointments-kpi-grid .tenant-kpi-money {
        font-size: 1.14rem;
        line-height: 1.15;
        overflow-wrap: anywhere;
    }

    .pb-shell .tenant-filter-chip {
        min-height: 2.75rem;
    }

    .pb-shell .page-panel,
    .pb-shell .page-panel-compact,
    .pb-shell .page-panel-roomy,
    .pb-shell .kpi-card,
    .pb-shell .empty-state-card {
        border-radius: 18px;
    }

    .pb-shell .admin-mobile-list-header,
    .pb-shell .admin-mobile-pager {
        flex-wrap: wrap;
    }

    .pb-shell .admin-mobile-card-actions .mud-button-root {
        flex-basis: 100%;
    }

    .pb-shell [data-testid="admin-tenants-table-panel"] {
        padding: 1rem !important;
    }

    .pb-shell [data-testid="admin-tenants-table-panel"] .admin-mobile-card {
        margin-inline: -0.15rem;
    }

    .pb-shell .mud-dialog {
        max-width: calc(100% - 1rem);
        margin: 0.5rem;
    }

    .pb-shell .login-page-card {
        width: 100%;
    }

    .pb-shell .mud-table-pagination {
        gap: 0.35rem;
        padding-inline: 0.5rem;
    }

    .pb-shell .mud-table-pagination > * {
        min-width: 0;
    }

    .pb-shell .conversation-page-shell .page-header {
        margin-bottom: 0.2rem !important;
    }

    .pb-shell .conversation-page {
        min-height: calc(100dvh - 10.5rem);
    }
}

.pb-shell .conversation-page {
    --conversation-panel-gap: 0.85rem;
    --conversation-panel-padding: clamp(0.78rem, 1vw, 1rem);
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: calc(100dvh - 9rem);
    height: calc(100dvh - 9rem);
    overflow: hidden;
}

.pb-shell .conversation-grid {
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
    overflow: hidden;
    align-items: stretch;
}

.pb-shell .conversation-grid.mud-grid {
    width: 100%;
    margin: 0;
}

.pb-shell .conversation-grid > .mud-grid-item {
    display: flex;
    min-height: 0;
    padding-top: 0;
}

.pb-shell .conversation-queue-column,
.pb-shell .conversation-chat-column,
.pb-shell .conversation-context-column {
    align-self: stretch;
    min-height: 0;
}

.pb-shell .conversation-queue-shell,
.pb-shell .conversation-thread-surface,
.pb-shell .conversation-context-shell,
.pb-shell .conversation-thread-empty {
    width: 100%;
    height: 100%;
    min-height: 0;
}

.pb-shell .conversation-queue-shell {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-height: 0;
    padding: var(--conversation-panel-padding);
    overflow: hidden;
}

.pb-shell .conversation-section-kicker {
    color: var(--pb-primary-ink) !important;
}

.pb-shell .conversation-queue-header {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.pb-shell .conversation-queue-heading {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.pb-shell .conversation-queue-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem;
}

.pb-shell .conversation-filter-card,
.pb-shell .conversation-queue-item,
.pb-shell .conversation-quick-reply-card {
    border: 1px solid var(--pb-line);
    background: color-mix(in srgb, var(--pb-surface) 94%, var(--pb-surface-2) 6%);
    color: var(--pb-text);
    transition:
        border-color var(--pb-transition-fast),
        background-color var(--pb-transition-fast),
        transform var(--pb-transition-fast),
        box-shadow var(--pb-transition-fast);
}

.pb-shell .conversation-filter-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.02rem;
    width: 100%;
    min-height: 2.9rem;
    padding: 0.48rem 0.68rem;
    border-radius: 12px;
    text-align: left;
    cursor: pointer;
}

.pb-shell .conversation-filter-card.is-active {
    border-color: rgba(var(--pb-primary-rgb), 0.42);
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.16) 82%, var(--pb-surface) 18%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.pb-shell .conversation-filter-card:hover,
.pb-shell .conversation-queue-item:hover,
.pb-shell .conversation-quick-reply-card:hover {
    transform: translateY(-1px);
    border-color: var(--pb-line-strong);
}

.pb-shell .conversation-filter-card:focus-visible,
.pb-shell .conversation-queue-item:focus-visible,
.pb-shell .conversation-quick-reply-card:focus-visible {
    outline: 3px solid var(--pb-focus);
    outline-offset: 2px;
}

.pb-shell .conversation-filter-label {
    color: var(--pb-text-muted);
    font-size: 0.64rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.pb-shell .conversation-filter-value {
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.pb-shell .conversation-queue-search .mud-input-control {
    margin-top: 0;
    margin-bottom: 0;
}

.pb-shell .conversation-queue-search {
    flex: 0 0 auto;
    min-height: auto;
    margin-bottom: 0;
}

.pb-shell .conversation-queue-sections {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    min-height: 0;
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.35rem;
}

.pb-shell .conversation-queue-item {
    display: block;
    width: 100%;
    padding: 0.68rem 0.75rem;
    border-radius: 16px;
    text-align: left;
    cursor: pointer;
}

.pb-shell .conversation-queue-item.is-selected {
    border-color: rgba(var(--pb-primary-rgb), 0.48);
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.14) 74%, var(--pb-surface) 26%);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .conversation-queue-item.is-high-priority {
    border-color: rgba(var(--pb-error-rgb), 0.28);
}

.pb-shell .conversation-queue-item.is-medium-priority {
    border-color: rgba(var(--pb-warning-rgb), 0.28);
}

.pb-shell .conversation-queue-item-top {
    display: flex;
    gap: 0.72rem;
    align-items: flex-start;
}

.pb-shell .conversation-queue-avatar,
.pb-shell .conversation-thread-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.55rem;
    height: 2.55rem;
    flex-shrink: 0;
    border-radius: 16px;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.18);
    background: linear-gradient(135deg, rgba(var(--pb-primary-rgb), 0.2), rgba(var(--pb-primary-rgb), 0.06));
    color: var(--pb-text);
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-weight: 700;
}

.pb-shell .conversation-queue-avatar.is-urgent {
    border-color: rgba(var(--pb-error-rgb), 0.32);
    background: linear-gradient(135deg, rgba(var(--pb-error-rgb), 0.22), rgba(var(--pb-error-rgb), 0.08));
}

.pb-shell .conversation-queue-avatar.is-warm {
    border-color: rgba(var(--pb-warning-rgb), 0.34);
    background: linear-gradient(135deg, rgba(var(--pb-warning-rgb), 0.22), rgba(var(--pb-warning-rgb), 0.08));
}

.pb-shell .conversation-queue-avatar.is-info {
    border-color: rgba(var(--pb-info-rgb), 0.3);
    background: linear-gradient(135deg, rgba(var(--pb-info-rgb), 0.2), rgba(var(--pb-info-rgb), 0.08));
}

.pb-shell .conversation-queue-copy {
    display: flex;
    flex-direction: column;
    gap: 0.24rem;
    min-width: 0;
    flex: 1;
}

.pb-shell .conversation-queue-item-primary,
.pb-shell .conversation-queue-item-secondary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    min-width: 0;
}

.pb-shell .conversation-queue-name {
    display: block;
    flex: 1 1 auto;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .conversation-queue-phone,
.pb-shell .conversation-queue-preview {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .conversation-queue-phone {
    color: var(--pb-text-muted);
    font-size: 0.76rem;
}

.pb-shell .conversation-queue-preview {
    color: var(--pb-text-muted);
    font-size: 0.82rem;
}

.pb-shell .conversation-queue-badge {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    padding: 0.12rem 0.5rem;
    border-radius: 999px;
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.14) 78%, var(--pb-surface) 22%);
    color: var(--pb-primary-ink);
    font-size: 0.71rem;
    font-weight: 700;
    white-space: nowrap;
}

.pb-shell .conversation-queue-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.32rem;
    margin-top: 0.06rem;
}

.pb-shell .conversation-queue-meta-item {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    max-width: 100%;
    padding: 0.12rem 0.45rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--pb-surface-2) 74%, transparent);
    color: var(--pb-text-muted);
    font-size: 0.7rem;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .conversation-queue-meta-item.is-priority {
    background: color-mix(in srgb, rgba(var(--pb-warning-rgb), 0.16) 78%, var(--pb-surface) 22%);
    color: color-mix(in srgb, var(--pb-warning) 76%, var(--pb-text) 24%);
}

.pb-shell .conversation-queue-meta-item.is-subtle {
    background: transparent;
    padding-inline: 0;
}

.pb-shell .conversation-queue-time,
.pb-shell .conversation-context-label,
.pb-shell .conversation-context-hint,
.pb-shell .conversation-message-meta {
    color: var(--pb-text-muted);
}

.pb-shell .conversation-thread-statusbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.38rem;
}
.pb-shell .conversation-attention-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 1.75rem;
    padding: 0.25rem 0.6rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 600;
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.15) 76%, var(--pb-surface) 24%);
    color: var(--pb-text);
}

.pb-shell .conversation-attention-tag.is-soft {
    background: color-mix(in srgb, var(--pb-surface-2) 78%, transparent);
    color: var(--pb-text-muted);
}

.pb-shell .conversation-attention-tag.is-warning {
    background: rgba(var(--pb-warning-rgb), 0.14);
    color: color-mix(in srgb, var(--pb-warning) 82%, var(--pb-text) 18%);
}

.pb-shell .conversation-attention-tag.is-urgent {
    background: rgba(var(--pb-error-rgb), 0.14);
    color: color-mix(in srgb, var(--pb-error) 84%, var(--pb-text) 16%);
}

.pb-shell .conversation-thread-subline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem 0.6rem;
    color: var(--pb-text-muted);
    font-size: 0.78rem;
}

.pb-shell .conversation-thread-subline span {
    position: relative;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .conversation-thread-subline span:not(:last-child)::after {
    content: "";
    position: absolute;
    right: -0.42rem;
    top: 50%;
    width: 0.2rem;
    height: 0.2rem;
    border-radius: 999px;
    background: var(--pb-line-strong);
    transform: translateY(-50%);
}

.pb-shell .conversation-thread-surface {
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    gap: 0.42rem;
    min-height: 0;
    padding: var(--conversation-panel-padding);
    overflow: hidden;
}

.pb-shell .conversation-thread-header {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    flex-wrap: wrap;
    padding-bottom: 0.05rem;
}

.pb-shell .conversation-thread-identity,
.pb-shell .conversation-thread-title-block {
    display: flex;
    gap: 0.72rem;
    min-width: 0;
    flex-direction: column;
    gap: 0.22rem;
}

.pb-shell .conversation-thread-title-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pb-shell .conversation-contact-name-button {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--pb-text);
    text-align: left;
    cursor: pointer;
}

.pb-shell .conversation-contact-name-button:hover .conversation-contact-name-label,
.pb-shell .conversation-contact-name-button:focus-visible .conversation-contact-name-label {
    color: var(--pb-primary-ink);
}

.pb-shell .conversation-contact-name-button:focus-visible {
    outline: 3px solid var(--pb-focus);
    outline-offset: 4px;
    border-radius: 12px;
}

.pb-shell .conversation-contact-name-label {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: "Sora", "IBM Plex Sans", sans-serif;
    font-size: 0.98rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: color var(--pb-transition-fast);
}

.pb-shell .conversation-thread-contact-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.32rem 0.55rem;
    color: var(--pb-text-muted);
    font-size: 0.78rem;
}

.pb-shell .conversation-thread-phone {
    font-weight: 600;
}

.pb-shell .conversation-thread-contact-hint {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.pb-shell .conversation-thread-actions {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.pb-shell .conversation-thread-secondary-actions {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    flex-wrap: wrap;
}

.pb-shell .conversation-thread-primary-action.mud-button {
    min-height: 2.35rem;
}

.pb-shell .conversation-thread-secondary-actions .mud-button {
    min-height: 2.2rem;
    padding-inline: 0.7rem;
}

.pb-shell .conversation-processing-banner {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.7rem 0.85rem;
    border: 1px solid rgba(var(--pb-warning-rgb), 0.24);
    border-radius: 16px;
    background: color-mix(in srgb, rgba(var(--pb-warning-rgb), 0.12) 72%, var(--pb-surface) 28%);
}

.pb-shell .conversation-thread-message-list {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.35rem;
    padding-top: 0.15rem;
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.pb-shell .conversation-message-day-group {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}

.pb-shell .conversation-message-day-divider {
    display: flex;
    justify-content: center;
}

.pb-shell .conversation-message-day-divider span {
    padding: 0.28rem 0.75rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--pb-surface-2) 78%, transparent);
    color: var(--pb-text-muted);
    font-size: 0.76rem;
    font-weight: 600;
}

.pb-shell .conversation-message-row {
    display: flex;
}

.pb-shell .conversation-message-row.is-inbound {
    justify-content: flex-start;
}

.pb-shell .conversation-message-row.is-outbound {
    justify-content: flex-end;
}

.pb-shell .conversation-message-bubble {
    display: flex;
    flex-direction: column;
    gap: 0.32rem;
    width: min(100%, 38rem);
    padding: 0.75rem 0.88rem;
    border-radius: 18px;
    border: 1px solid var(--pb-line);
}

.pb-shell .conversation-message-bubble.is-contact {
    background: color-mix(in srgb, var(--pb-surface-2) 82%, var(--pb-surface) 18%);
}

.pb-shell .conversation-message-bubble.is-operator {
    background: color-mix(in srgb, rgba(var(--pb-info-rgb), 0.16) 72%, var(--pb-surface) 28%);
    border-color: rgba(var(--pb-info-rgb), 0.28);
}

.pb-shell .conversation-message-bubble.is-ai {
    background: color-mix(in srgb, rgba(var(--pb-success-rgb), 0.14) 72%, var(--pb-surface) 28%);
    border-color: rgba(var(--pb-success-rgb), 0.24);
}

.pb-shell .conversation-message-bubble.is-system {
    background: color-mix(in srgb, var(--pb-surface-2) 70%, transparent);
    border-style: dashed;
}

.pb-shell .conversation-message-meta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.71rem;
}

.pb-shell .conversation-message-content {
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.pb-shell .conversation-thread-composer {
    border-top: 1px solid var(--pb-line);
    padding-top: 0.5rem;
}

.pb-shell .conversation-composer-shell,
.pb-shell .conversation-context-shell {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.pb-shell .conversation-composer-shell {
    position: relative;
}

.pb-shell .conversation-context-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.pb-shell .conversation-context-header-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.pb-shell .conversation-quick-replies-layer {
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(100% + 0.55rem);
    z-index: 15;
}

.pb-shell .conversation-quick-replies-panel {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 0.8rem;
    border: 1px solid var(--pb-line);
    border-radius: 16px;
    background: color-mix(in srgb, var(--pb-surface-2) 68%, var(--pb-surface) 32%);
    box-shadow: var(--pb-shadow-md);
}

.pb-shell .conversation-quick-replies-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.pb-shell .conversation-quick-replies-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
}

.pb-shell .conversation-quick-reply-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
    padding: 0.75rem;
    border-radius: 14px;
    text-align: left;
    cursor: pointer;
}

.pb-shell .conversation-quick-reply-index {
    color: var(--pb-primary-ink);
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
}

.pb-shell .conversation-quick-reply-title {
    font-weight: 700;
}

.pb-shell .conversation-quick-reply-content,
.pb-shell .conversation-quick-replies-empty {
    color: var(--pb-text-muted);
    font-size: 0.84rem;
}

.pb-shell .conversation-composer-main {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
}

.pb-shell .conversation-composer-main .mud-input-control {
    margin-top: 0;
}

.pb-shell .conversation-composer-input .mud-input-outlined {
    align-items: center;
}

.pb-shell .conversation-composer-input textarea.mud-input-slot {
    min-height: 1.35rem !important;
}

.pb-shell .conversation-composer-actions {
    display: flex;
    align-items: stretch;
    gap: 0.45rem;
    flex-shrink: 0;
}

.pb-shell .conversation-composer-action-button {
    min-height: 3rem;
    border-radius: 12px;
}

.pb-shell .conversation-composer-send-button {
    min-width: 3rem;
    width: 3rem;
    padding: 0;
}

.pb-shell .conversation-composer-quick-button {
    gap: 0.4rem;
    min-width: 0;
    padding-inline: 0.72rem;
}

.pb-shell .conversation-composer-quick-label {
    font-size: 0.8rem;
    font-weight: 600;
}

.pb-shell .conversation-context-card {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    padding: 0.8rem;
    border: 1px solid var(--pb-line);
    border-radius: 16px;
    background: color-mix(in srgb, var(--pb-surface-2) 62%, var(--pb-surface) 38%);
}

.pb-shell .conversation-context-card.is-empty {
    border-style: dashed;
}

.pb-shell .conversation-context-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.pb-shell .conversation-context-field {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.pb-shell .conversation-context-label {
    font-size: 0.76rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.pb-shell .conversation-context-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.pb-shell .conversation-context-list-item {
    display: flex;
    gap: 0.7rem;
    align-items: flex-start;
}

.pb-shell .conversation-queue-empty,
.pb-shell .conversation-thread-empty {
    min-height: 9.75rem;
}

.pb-shell .conversation-context-shell {
    overflow-y: auto;
    overflow-x: hidden;
    padding: var(--conversation-panel-padding);
}

.pb-shell .conversation-chat-stage {
    position: relative;
    display: flex;
    width: 100%;
    height: 100%;
    min-height: 0;
}

.pb-shell .conversation-context-backdrop {
    position: absolute;
    inset: 0;
    z-index: 18;
    border: 0;
    background: rgba(20, 24, 31, 0.16);
    cursor: pointer;
}

.pb-shell .conversation-context-overlay {
    position: absolute;
    top: 0.6rem;
    right: 0.6rem;
    bottom: 0.6rem;
    width: min(22rem, calc(100% - 1.2rem));
    z-index: 19;
    display: flex;
}

.pb-shell .conversation-context-shell.is-overlay {
    box-shadow: var(--pb-shadow-lg);
}

.pb-shell .conversation-queue-sections,
.pb-shell .conversation-thread-message-list,
.pb-shell .conversation-context-shell {
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.32) 70%, transparent) transparent;
}

.pb-shell .conversation-queue-sections::-webkit-scrollbar,
.pb-shell .conversation-thread-message-list::-webkit-scrollbar,
.pb-shell .conversation-context-shell::-webkit-scrollbar {
    width: 10px;
}

.pb-shell .conversation-queue-sections::-webkit-scrollbar-thumb,
.pb-shell .conversation-thread-message-list::-webkit-scrollbar-thumb,
.pb-shell .conversation-context-shell::-webkit-scrollbar-thumb {
    border: 3px solid transparent;
    border-radius: 999px;
    background: color-mix(in srgb, rgba(var(--pb-primary-rgb), 0.34) 72%, transparent);
    background-clip: content-box;
}

.pb-shell .conversation-queue-sections::-webkit-scrollbar-track,
.pb-shell .conversation-thread-message-list::-webkit-scrollbar-track,
.pb-shell .conversation-context-shell::-webkit-scrollbar-track {
    background: transparent;
}

@media (max-width: 1279.98px) {
    .pb-shell .conversation-quick-replies-grid,
    .pb-shell .conversation-context-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (min-width: 1280px) {
    .pb-shell .conversation-grid.mud-grid {
        display: grid;
        grid-template-columns: minmax(20rem, 22rem) minmax(0, 1fr);
        grid-auto-rows: minmax(0, 1fr);
        gap: var(--conversation-panel-gap);
    }

    .pb-shell .conversation-grid.mud-grid > .mud-grid-item {
        width: auto;
        max-width: none;
        padding-left: 0;
        flex: initial;
        height: 100%;
    }

    .pb-shell .conversation-queue-column {
        grid-column: 1;
    }

    .pb-shell .conversation-chat-column {
        grid-column: 2;
    }
    .pb-shell .conversation-queue-shell,
    .pb-shell .conversation-thread-surface,
    .pb-shell .conversation-context-shell,
    .pb-shell .conversation-thread-empty {
        max-height: 100%;
    }
}

@media (max-width: 959.98px) {
    .pb-shell .conversation-page {
        min-height: auto;
        height: auto;
        overflow: visible;
    }

    .pb-shell .conversation-grid {
        flex: initial;
        height: auto;
        overflow: visible;
    }

    .pb-shell .conversation-page.mobile-chat-visible .conversation-queue-column {
        display: none;
    }

    .pb-shell .conversation-page.mobile-list-visible .conversation-chat-column,
    .pb-shell .conversation-page.mobile-list-visible .conversation-context-column {
        display: none;
    }

    .pb-shell .conversation-page.mobile-chat-visible .conversation-context-column {
        display: none;
    }

    .pb-shell .conversation-queue-shell,
    .pb-shell .conversation-thread-surface,
    .pb-shell .conversation-context-shell,
    .pb-shell .conversation-thread-empty {
        min-height: auto;
        height: auto;
    }

    .pb-shell .conversation-thread-message-list,
    .pb-shell .conversation-context-shell,
    .pb-shell .conversation-queue-sections {
        overflow: visible;
        padding-right: 0;
    }

    .pb-shell .conversation-composer-main,
    .pb-shell .conversation-thread-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .pb-shell .conversation-quick-replies-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .conversation-context-backdrop {
        background: rgba(20, 24, 31, 0.24);
    }

    .pb-shell .conversation-context-overlay {
        top: auto;
        right: 0;
        bottom: 0;
        left: 0;
        width: auto;
        max-height: min(78dvh, 42rem);
    }

    .pb-shell .conversation-context-shell.is-overlay {
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
    }

    .pb-shell .conversation-quick-replies-layer {
        left: 0;
        right: 0;
        bottom: calc(100% + 0.45rem);
    }
}

@media (max-width: 639.98px) {
    .pb-shell .conversation-composer-quick-label {
        display: none;
    }

    .pb-shell .conversation-queue-item-secondary {
        gap: 0.35rem;
    }
}
