:root {
    color-scheme: dark;
}

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

body {
    margin: 0;
    font-family: "DM Sans", system-ui, sans-serif;
    background: #04030a;
    color: #edeaf5;
    -webkit-font-smoothing: antialiased;
}

.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: "DM Sans", system-ui, sans-serif;
    background: var(--pb-bg);

    /* Sephira motion + radii */
    --pb-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
    --pb-transition-fast: 160ms var(--pb-ease);
    --pb-transition-base: 220ms var(--pb-ease);
    --pb-radius-sm: 12px;
    --pb-radius-md: 16px;
    --pb-radius-lg: 24px;
    --pb-shadow-sm: 0 14px 30px rgba(0, 0, 0, 0.40);
    --pb-shadow-md: 0 28px 64px rgba(0, 0, 0, 0.55);
    --pb-shadow-lg: 0 32px 80px rgba(0, 0, 0, 0.70);

    /* Vertical accents (always available, regardless of mode) */
    --pb-peach: #ff9a6c;
    --pb-gold: #e4b040;
    --pb-mint: #3ec99a;
    --pb-coral: #ff5e7a;

    /* Aliases used by the standalone Sephira prototype. */
    --ease: var(--pb-ease);
    --t-fast: var(--pb-transition-fast);
    --t-base: var(--pb-transition-base);
    --r-sm: var(--pb-radius-sm);
    --r-md: var(--pb-radius-md);
    --r-lg: var(--pb-radius-lg);
    --r-xl: 28px;
    --bg: var(--pb-bg);
    --bg-soft: var(--pb-bg-soft);
    --surface: var(--pb-surface);
    --surface-2: var(--pb-surface-2);
    --surface-3: var(--pb-surface-3);
    --line: var(--pb-line);
    --line-strong: var(--pb-line-strong);
    --primary: var(--pb-primary);
    --primary-rgb: var(--pb-primary-rgb);
    --primary-light: var(--pb-primary-light);
    --primary-ink: var(--pb-primary-ink);
    --fg: var(--pb-text);
    --fg-rgb: var(--pb-text-rgb);
    --fg-muted: var(--pb-text-muted);
    --fg-soft: var(--pb-text-soft);
    --fg-disabled: var(--pb-text-disabled);
    --accent: var(--pb-primary);
    --accent-dim: var(--pb-accent-dim);
    --accent-glow: var(--pb-accent-glow);
    --hover: var(--pb-hover);
    --focus: var(--pb-focus);
    --shadow-sm: var(--pb-shadow-sm);
    --shadow-md: var(--pb-shadow-md);
    --shadow-lg: var(--pb-shadow-lg);
    --peach: var(--pb-peach);
    --gold: var(--pb-gold);
    --mint: var(--pb-mint);
    --coral: var(--pb-coral);

    /* Sephira spacing scale */
    --pb-space-xs: 4px;
    --pb-space-sm: 8px;
    --pb-space-md: 16px;
    --pb-space-lg: 24px;
    --pb-space-xl: 32px;
    --pb-space-2xl: 48px;
    --pb-space-3xl: 80px;
}

/* Sephira kicker — uppercase eyebrow with leading violet bar */
.pb-shell .kicker {
    display: inline-flex;
    align-items: center;
    gap: var(--pb-space-sm);
    color: var(--pb-text-muted);
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.pb-shell .kicker::before {
    content: "";
    width: 18px;
    height: 1px;
    background: var(--pb-primary);
}

.pb-shell[data-theme="dark"] {
    color-scheme: dark;
    --pb-bg: #04030a;
    --pb-bg-soft: #080710;
    --pb-surface: #0f0e1a;
    --pb-surface-2: #131225;
    --pb-surface-3: #1c1a30;
    --pb-card-bg: #0f0e1a;
    --pb-panel-bg: #0f0e1a;
    --pb-empty-bg: #131225;
    --pb-primary: #7c5cfc;
    --pb-primary-hover: #6a4ce8;
    --pb-primary-light: #9d83fd;
    --pb-primary-rgb: 124, 92, 252;
    --pb-primary-ink: #c4b5fd;
    --pb-text: #edeaf5;
    --pb-text-rgb: 237, 234, 245;
    --pb-text-muted: #9590c0;
    --pb-text-soft: rgba(237, 234, 245, 0.74);
    --pb-text-disabled: #6b6490;
    --pb-text-contrast: #ffffff;
    --pb-secondary: #c4b5fd;
    --pb-secondary-rgb: 196, 181, 253;
    --pb-line: #1c1a30;
    --pb-line-strong: #2a2740;
    --pb-focus: rgba(124, 92, 252, 0.45);
    --pb-hover: rgba(124, 92, 252, 0.10);
    --pb-accent-dim: rgba(124, 92, 252, 0.12);
    --pb-accent-glow: rgba(124, 92, 252, 0.30);
    --pb-success: #3ec99a;
    --pb-success-rgb: 62, 201, 154;
    --pb-info: #58b8ff;
    --pb-info-rgb: 88, 184, 255;
    --pb-warning: #e4b040;
    --pb-warning-rgb: 228, 176, 64;
    --pb-error: #ff5e7a;
    --pb-error-rgb: 255, 94, 122;
}

.pb-shell[data-theme="light"] {
    color-scheme: light;
    --pb-bg: #faf8ff;
    --pb-bg-soft: #f3eefb;
    --pb-surface: #ffffff;
    --pb-surface-2: #f5f0fc;
    --pb-surface-3: #ebe3f7;
    --pb-card-bg: #ffffff;
    --pb-panel-bg: #ffffff;
    --pb-empty-bg: #f5f0fc;
    --pb-primary: #5a3df0;
    --pb-primary-hover: #4a2ee0;
    --pb-primary-light: #7c5cfc;
    --pb-primary-rgb: 90, 61, 240;
    --pb-primary-ink: #4a2ee0;
    --pb-text: #1c1530;
    --pb-text-rgb: 28, 21, 48;
    --pb-text-muted: #6b6490;
    --pb-text-soft: rgba(28, 21, 48, 0.62);
    --pb-text-disabled: #9590c0;
    --pb-text-contrast: #1c1530;
    --pb-secondary: #5a3df0;
    --pb-secondary-rgb: 90, 61, 240;
    --pb-line: #ebe3f7;
    --pb-line-strong: #d8ccf0;
    --pb-focus: rgba(90, 61, 240, 0.28);
    --pb-hover: rgba(90, 61, 240, 0.06);
    --pb-accent-dim: rgba(90, 61, 240, 0.08);
    --pb-accent-glow: rgba(90, 61, 240, 0.20);
    --pb-success: #1d9b6e;
    --pb-success-rgb: 29, 155, 110;
    --pb-info: #1d80c7;
    --pb-info-rgb: 29, 128, 199;
    --pb-warning: #b88a14;
    --pb-warning-rgb: 184, 138, 20;
    --pb-error: #d23a5a;
    --pb-error-rgb: 210, 58, 90;
    --pb-shadow-sm: 0 14px 28px rgba(79, 58, 112, 0.10);
    --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);
    --mud-palette-appbar-background: color-mix(in srgb, var(--pb-bg) 85%, 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: "DM Sans", system-ui, sans-serif;
    --mud-typography-default-size: 0.95rem;
    --mud-typography-default-lineheight: 1.6;
    --mud-typography-h1-family: "Times New Roman", Times, serif;
    --mud-typography-h1-weight: 600;
    --mud-typography-h1-letterspacing: -0.025em;
    --mud-typography-h2-family: "Times New Roman", Times, serif;
    --mud-typography-h2-weight: 600;
    --mud-typography-h2-letterspacing: -0.025em;
    --mud-typography-h3-family: "Times New Roman", Times, serif;
    --mud-typography-h3-weight: 600;
    --mud-typography-h3-letterspacing: -0.025em;
    --mud-typography-h4-family: "Times New Roman", Times, serif;
    --mud-typography-h4-weight: 600;
    --mud-typography-h4-letterspacing: -0.025em;
    --mud-typography-h5-family: "Times New Roman", Times, serif;
    --mud-typography-h5-weight: 600;
    --mud-typography-h5-letterspacing: -0.02em;
    --mud-typography-h6-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-h6-weight: 600;
    --mud-typography-h6-letterspacing: -0.01em;
    --mud-typography-subtitle1-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-subtitle2-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-subtitle2-weight: 600;
    --mud-typography-body1-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-body2-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-body2-size: 0.88rem;
    --mud-typography-button-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-button-weight: 500;
    --mud-typography-button-letterspacing: -0.01em;
    --mud-typography-overline-family: "DM Sans", system-ui, sans-serif;
    --mud-typography-overline-letterspacing: 0.14em;
    --mud-typography-overline-weight: 600;
}

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

.pb-shell::before {
    background:
        radial-gradient(900px 600px at 8% -10%, rgba(var(--pb-primary-rgb), 0.18), transparent 60%),
        radial-gradient(700px 500px at 100% 0%, rgba(62, 201, 154, 0.08), transparent 65%),
        radial-gradient(800px 600px at 50% 100%, rgba(var(--pb-primary-rgb), 0.10), transparent 65%);
}

.pb-shell::after {
    z-index: -1;
    opacity: 0.30;
    background-image:
        linear-gradient(rgba(var(--pb-primary-rgb), 0.04) 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[data-theme="light"]::before {
    background:
        radial-gradient(900px 600px at 8% -10%, rgba(var(--pb-primary-rgb), 0.10), transparent 60%),
        radial-gradient(700px 500px at 100% 0%, rgba(29, 155, 110, 0.05), transparent 65%);
}

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

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

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

.pb-shell [data-testid="main-content"] {
    padding: 1.5rem 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: "DM Sans", system-ui, sans-serif;
}

.pb-shell .mud-typography-h1,
.pb-shell .mud-typography-h2,
.pb-shell .mud-typography-h3,
.pb-shell .mud-typography-h4,
.pb-shell .mud-typography-h5 {
    font-family: "Times New Roman", Times, serif;
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.05;
    color: var(--pb-text);
}

.pb-shell .mud-typography-h1 em,
.pb-shell .mud-typography-h2 em,
.pb-shell .mud-typography-h3 em,
.pb-shell .mud-typography-h4 em,
.pb-shell .mud-typography-h5 em,
.pb-shell .mud-typography-h6 em,
.pb-shell .mud-typography-subtitle1 em,
.pb-shell .mud-typography-subtitle2 em,
.pb-shell .mud-typography-body1 em,
.pb-shell .mud-typography-body2 em,
.pb-shell .mud-typography-caption em,
.pb-shell h1 em,
.pb-shell h2 em,
.pb-shell h3 em,
.pb-shell h4 em,
.pb-shell h5 em {
    font-style: italic;
    font-weight: 300;
    color: var(--pb-primary);
}

.pb-shell .mud-typography-h6,
.pb-shell .mud-button,
.pb-shell .mud-typography-overline {
    font-family: "DM Sans", system-ui, sans-serif;
}

.pb-shell .mud-appbar {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background: color-mix(in srgb, var(--pb-bg) 85%, transparent);
    border-bottom: 1px solid var(--pb-line);
    box-shadow: none;
    min-height: var(--mud-appbar-height);
}

.pb-shell .mud-toolbar-appbar {
    gap: 0.65rem;
    padding-inline: var(--pb-space-md);
    min-height: var(--mud-appbar-height);
}

.pb-shell [data-testid="app-brand-text"],
.pb-shell [data-testid="drawer-brand-text"] {
    font-family: "Times New Roman", Times, serif;
    font-weight: 600;
    letter-spacing: -0.02em;
    font-size: 1.4rem;
}

.pb-shell [data-testid="drawer-brand-icon"] {
    width: 2.4rem;
    height: 2.4rem;
    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, var(--pb-primary-light), var(--pb-primary));
    color: #fff;
    box-shadow: 0 8px 22px rgba(var(--pb-primary-rgb), 0.30);
}

.pb-shell .mud-drawer {
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--pb-line);
    background: color-mix(in srgb, var(--pb-bg-soft) 96%, transparent);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    box-shadow: none;
    overflow: hidden;
}

.pb-shell .main-drawer--mini {
    overflow: hidden;
}

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

.pb-shell .mud-navmenu {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0.75rem 0.75rem 1.1rem;
}

.pb-shell .mud-nav-link {
    min-height: 38px;
    margin: 0.1rem 0;
    padding: 0.5rem 0.78rem;
    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: var(--pb-accent-dim);
    border-color: rgba(var(--pb-primary-rgb), 0.30);
    box-shadow: none;
}

.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: #fff !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: 3px;
    align-self: stretch;
    margin-right: 0.56rem;
    border-radius: 999px;
    background: var(--pb-primary);
    box-shadow: 0 0 14px var(--pb-accent-glow);
}

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

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

.pb-shell .main-drawer--mini .mud-navmenu {
    padding-inline: 0.5rem;
}

.pb-shell .main-drawer--mini .mud-navmenu .mud-typography-overline,
.pb-shell .main-drawer--mini .mud-nav-link .mud-nav-link-text,
.pb-shell .main-drawer--mini .drawer__footer {
    display: none;
}

.pb-shell .main-drawer--mini .mud-nav-link {
    justify-content: center;
    width: 44px;
    min-width: 44px;
    min-height: 44px;
    padding: 0;
    margin-inline: auto;
}

.pb-shell .main-drawer--mini .mud-nav-link.active:not(.mud-nav-link-disabled)::before {
    display: none;
}

.pb-shell .main-drawer--mini .mud-nav-link .mud-nav-link-icon {
    margin: 0;
    font-size: 1.22rem;
}

.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-equipe"] .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 .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 3px var(--pb-focus);
}

.pb-shell .mud-button {
    min-height: 2.6rem;
    padding-inline: 1.1rem;
    border-radius: 100px;
    font-size: 0.88rem;
    font-weight: 500;
    letter-spacing: -0.01em;
}

.pb-shell .mud-button:active {
    transform: scale(0.97);
}

.pb-shell .mud-button-filled-primary {
    background: var(--pb-primary);
    color: #fff;
    border: none;
    box-shadow: none;
}

.pb-shell .mud-button-filled-primary:hover,
.pb-shell .mud-button-filled-primary:focus-visible {
    background: var(--pb-primary);
    filter: brightness(1.1);
    box-shadow: 0 8px 28px var(--pb-accent-glow);
    transform: none;
}

.pb-shell .mud-button-outlined,
.pb-shell .mud-button-outlined-primary {
    border: 1px solid rgba(var(--pb-primary-rgb), 0.35);
    background: transparent;
    color: var(--pb-text-muted);
}

.pb-shell .mud-button-outlined:hover,
.pb-shell .mud-button-outlined-primary:hover,
.pb-shell .mud-button-outlined:focus-visible,
.pb-shell .mud-button-outlined-primary:focus-visible {
    border-color: var(--pb-primary);
    color: var(--pb-text);
    background: var(--pb-hover);
}

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

.pb-shell .mud-button-text:hover,
.pb-shell .mud-button-text:focus-visible {
    background: var(--pb-hover);
}

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

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

.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 .mud-paper:hover,
.pb-shell .mud-card:hover {
    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: var(--pb-space-md) !important;
}

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

.pb-shell .login-page-shell {
    width: 100%;
    padding-inline: 0;
    min-height: calc(100vh - 4rem);
    display: grid;
    place-items: center;
}

.pb-shell .login-page-card {
    width: min(100%, 32rem);
    margin-inline: auto;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
    box-shadow:
        var(--pb-shadow-md),
        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: var(--pb-space-xs) !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: var(--pb-space-md);
}

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

.pb-shell .tenant-context-panel {
    border: 1px solid var(--pb-line-strong);
    background: var(--pb-card-bg);
}

.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 var(--pb-line-strong);
    border-radius: var(--pb-radius-md);
    background: var(--pb-surface);
}

.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: "Times New Roman", Times, 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 var(--pb-line-strong);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
    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: var(--pb-space-sm);
    align-items: center;
}

.pb-shell .filter-bar,
.pb-shell .responsive-toolbar,
.pb-shell .section-header-inline {
    gap: var(--pb-space-md);
}

.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 .admin-search-field,
.pb-shell .admin-filter-field {
    flex: 0 0 clamp(220px, 30vw, 420px);
    width: clamp(220px, 30vw, 420px);
    min-width: min(100%, 220px);
    max-width: 100%;
}

.pb-shell [data-testid="admin-tenants-table-panel"] .admin-tenants-search-field {
    flex-basis: auto;
}

.pb-shell .admin-users-search-field {
    flex-basis: auto;
}

.pb-shell .billing-tabs .mud-tabs-tabbar {
    padding: 0.35rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: color-mix(in srgb, var(--pb-card-bg) 86%, var(--pb-surface) 14%);
}

.pb-shell .billing-tabs .mud-tab {
    min-height: 2.35rem;
    margin: 0;
    border: 1px solid transparent;
    border-radius: var(--pb-radius-sm);
}

.pb-shell .billing-tabs .mud-tab.mud-tab-active {
    border-color: rgba(var(--pb-primary-rgb), 0.28);
    background: rgba(var(--pb-primary-rgb), 0.14);
    color: var(--pb-text);
}

.pb-shell .billing-tabs .mud-tab-slider {
    display: none;
}

.pb-shell .billing-tabs .mud-tabs-panels {
    padding-top: 1rem;
}

.pb-shell .admin-billing-tab-content {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.pb-shell .admin-billing-filter-bar {
    justify-content: flex-start !important;
    column-gap: 1rem !important;
    row-gap: 0.75rem !important;
    margin-bottom: 1rem !important;
}

.pb-shell .admin-billing-filter-bar > .mud-select {
    flex: 0 0 clamp(220px, 30vw, 420px);
    width: clamp(220px, 30vw, 420px);
    min-width: min(100%, 220px);
    max-width: 100%;
}

.pb-shell .admin-billing-create-action {
    margin-left: auto;
}

.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);
    transition:
        background var(--pb-transition-base),
        border-color var(--pb-transition-base);
}

.pb-shell .kpi-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 0% 0%, var(--pb-accent-dim), transparent 60%);
    opacity: 0;
    transition: opacity 0.3s var(--pb-ease);
}

.pb-shell .kpi-card:hover {
    background: var(--pb-surface-2);
    border-color: var(--pb-line-strong);
}

.pb-shell .kpi-card:hover::after {
    opacity: 1;
}

.pb-shell .kpi-label,
.pb-shell .tenant-kpi-label {
    color: var(--pb-text-muted) !important;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
}

.pb-shell .kpi-value,
.pb-shell .tenant-kpi-number {
    margin-top: 0.35rem;
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    letter-spacing: -0.04em;
    line-height: 1;
}

.pb-shell .kpi-icon,
.pb-shell .tenant-kpi-icon {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.30);
    border-radius: 10px;
    color: var(--pb-primary-ink);
    background: var(--pb-accent-dim);
}

/* Per-vertical accents (apply on .pb-shell with .vertical-pet/barber/clinic/fit) */
.pb-shell.vertical-pet .kpi-icon {
    background: rgba(255, 154, 108, 0.10);
    border-color: rgba(255, 154, 108, 0.30);
    color: var(--pb-peach);
}
.pb-shell.vertical-pet .tenant-kpi-money,
.pb-shell.vertical-pet .kpi-card-graphite .kpi-value {
    color: var(--pb-peach);
}
.pb-shell.vertical-barber .kpi-icon {
    background: rgba(228, 176, 64, 0.10);
    border-color: rgba(228, 176, 64, 0.30);
    color: var(--pb-gold);
}
.pb-shell.vertical-clinic .kpi-icon {
    background: rgba(62, 201, 154, 0.10);
    border-color: rgba(62, 201, 154, 0.30);
    color: var(--pb-mint);
}
.pb-shell.vertical-fit .kpi-icon {
    background: rgba(255, 94, 122, 0.10);
    border-color: rgba(255, 94, 122, 0.30);
    color: var(--pb-coral);
}

/* Per-slot KPI accent variants (used when no vertical class) */
.pb-shell .kpi-card-graphite .kpi-icon {
    background: rgba(124, 92, 252, 0.10);
    border-color: rgba(124, 92, 252, 0.30);
    color: var(--pb-primary-ink);
}
.pb-shell .kpi-card-charcoal .kpi-icon {
    background: rgba(62, 201, 154, 0.10);
    border-color: rgba(62, 201, 154, 0.30);
    color: var(--pb-mint);
}
.pb-shell .kpi-card-silver .kpi-icon {
    background: rgba(255, 154, 108, 0.10);
    border-color: rgba(255, 154, 108, 0.30);
    color: var(--pb-peach);
}
.pb-shell .kpi-card-neutral .kpi-icon {
    background: rgba(228, 176, 64, 0.10);
    border-color: rgba(228, 176, 64, 0.30);
    color: var(--pb-gold);
}

.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: var(--pb-text-disabled);
    font-size: 2.6rem;
}

.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: var(--pb-space-md);
    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: var(--pb-space-md);
    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-shell .tenant-kpi-icon {
    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: var(--pb-space-md) !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-table-panel {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-md);
}

.pb-shell .packages-table-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--pb-space-md);
}

.pb-shell .packages-table-heading {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.pb-shell .packages-table-title {
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(1.45rem, 1.8vw, 1.8rem);
    line-height: 1.1;
    font-weight: 700;
}

.pb-shell .packages-create-button {
    flex: 0 0 auto;
}

.pb-shell .packages-shell .packages-table-status-filters {
    margin-top: 0;
}

.pb-shell .packages-table-status-filters .mud-chipset-chip {
    margin: 0.18rem 0.35rem 0.18rem 0;
}

.pb-shell .packages-table-content {
    min-width: 0;
}

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

@media (max-width: 600px) {
    .pb-shell .packages-table-header {
        flex-direction: column;
        align-items: stretch;
    }

    .pb-shell .packages-create-button {
        width: 100%;
    }
}

.pb-shell .hotel-filter-panel {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-md);
}

.pb-shell .hotel-filter-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--pb-space-md);
}

.pb-shell .hotel-filter-heading {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    min-width: 0;
}

.pb-shell .hotel-filter-title-icon {
    flex: 0 0 auto;
    color: var(--pb-primary);
}

.pb-shell .hotel-filter-title {
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(1.45rem, 1.8vw, 1.8rem);
    line-height: 1.1;
    font-weight: 700;
}

.pb-shell .hotel-create-button {
    flex: 0 0 auto;
}

.pb-shell .hotel-filter-grid {
    align-items: stretch;
}

.pb-shell .hotel-occupancy-section {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-sm);
    padding-top: var(--pb-space-md);
    border-top: 1px solid var(--pb-line);
}

.pb-shell .hotel-occupancy-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--pb-space-md);
}

.pb-shell .hotel-occupancy-day-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(7.25rem, 1fr));
    gap: 0.7rem;
}

.pb-shell .hotel-occupancy-day {
    display: flex;
    min-width: 0;
    min-height: 4.9rem;
    flex-direction: column;
    justify-content: center;
    gap: 0.2rem;
    padding: 0.78rem 0.85rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: var(--pb-surface);
}

.pb-shell .hotel-occupancy-day.is-full {
    border-color: rgba(var(--mud-palette-error-rgb), 0.35);
}

.pb-shell .hotel-occupancy-value {
    line-height: 1.05;
    font-size: clamp(1.2rem, 1.4vw, 1.48rem);
    font-weight: 700;
}

@media (min-width: 1200px) {
    .pb-shell .hotel-occupancy-day-grid {
        grid-template-columns: repeat(7, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    .pb-shell .hotel-filter-header {
        flex-direction: column;
        align-items: stretch;
    }

    .pb-shell .hotel-filter-heading {
        justify-content: flex-start;
    }

    .pb-shell .hotel-create-button {
        width: 100%;
    }

    .pb-shell .hotel-occupancy-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.2rem;
    }

    .pb-shell .inventory-table-header {
        flex-direction: column;
        align-items: stretch;
    }

    .pb-shell .inventory-create-button {
        width: 100%;
    }
}

.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 .inventory-table-panel {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-md);
}

.pb-shell .inventory-table-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--pb-space-md);
}

.pb-shell .inventory-table-title-group {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.pb-shell .inventory-table-title {
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(1.45rem, 1.8vw, 1.8rem);
    line-height: 1.1;
    font-weight: 700;
}

.pb-shell .inventory-create-button {
    flex: 0 0 auto;
}

.pb-shell .inventory-filter-bar {
    margin-bottom: 0 !important;
}

.pb-shell .inventory-products-table {
    margin-top: 0;
}

.pb-shell .inventory-products-table .mud-table-cell {
    padding-left: 0.45rem;
    padding-right: 0.45rem;
}

.pb-shell .inventory-code-column {
    width: 5.25rem;
    max-width: 5.25rem;
}

.pb-shell .inventory-active-column {
    width: 4.25rem;
    max-width: 4.25rem;
}

.pb-shell .inventory-actions-column {
    width: 8.25rem;
    max-width: 8.25rem;
}

.pb-shell .inventory-code {
    font-family: ui-monospace, "SFMono-Regular", "Roboto Mono", Consolas, monospace;
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.25;
}

.pb-shell .inventory-brand {
    display: block;
    margin-top: 0.12rem;
    line-height: 1.25;
}

.pb-shell .inventory-products-table .tenant-inline-actions .mud-icon-button {
    width: 2.35rem;
    height: 2.35rem;
}

.pb-shell .inventory-quantity,
.pb-shell .inventory-price,
.pb-shell .inventory-price-caption {
    white-space: nowrap;
}

.pb-shell .inventory-quantity,
.pb-shell .inventory-price {
    font-family: ui-monospace, "SFMono-Regular", "Roboto Mono", Consolas, monospace;
}

.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: var(--pb-space-sm);
    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: var(--pb-line-strong);
    background: var(--pb-card-bg);
}

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

.pb-shell .admin-mobile-list-card {
    border-color: var(--pb-line-strong);
    background: var(--pb-card-bg);
}

.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: var(--pb-space-md);
}

.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: var(--pb-radius-md);
}

.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: 0;
}

.pb-shell .admin-provision-dialog .mud-dialog-actions {
    padding: 0;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .admin-provision-shell {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-md);
    padding: 1.25rem;
}

.pb-shell .admin-provision-intro {
    display: flex;
    flex-direction: column;
    gap: 0.95rem;
    padding: 1rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-panel-bg);
}

.pb-shell .admin-provision-intro-main {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
}

.pb-shell .admin-provision-icon {
    flex: 0 0 auto;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.2);
    border-radius: var(--pb-radius-md) !important;
    background:
        linear-gradient(150deg, rgba(var(--pb-primary-rgb), 0.22), rgba(var(--pb-primary-rgb), 0.08)) !important;
    color: var(--pb-text) !important;
    box-shadow: none;
}

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

.pb-shell .admin-provision-intro-copy .mud-typography-h6,
.pb-shell .admin-provision-section-header .mud-typography-subtitle2,
.pb-shell .admin-provision-toggle .mud-typography-subtitle2 {
    color: var(--pb-text);
    font-weight: 700;
}

.pb-shell .admin-provision-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.pb-shell .admin-provision-summary-item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-width: 0;
    padding: 0.65rem 0.7rem;
    border: 1px solid var(--pb-line-strong);
    border-radius: var(--pb-radius-sm);
    background: var(--pb-surface);
    color: var(--pb-text-muted);
    font-size: 0.77rem;
    font-weight: 700;
}

.pb-shell .admin-provision-summary-item .mud-icon-root {
    flex: 0 0 auto;
    color: var(--pb-primary);
}

.pb-shell .admin-provision-section {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
}

.pb-shell .admin-provision-section-header {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
}

.pb-shell .admin-provision-section-header .mud-icon-root {
    margin-top: 0.18rem;
}

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

.pb-shell .admin-provision-toggle {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.9rem 1rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-panel-bg);
}

.pb-shell .admin-provision-toggle-copy {
    min-width: 0;
}

.pb-shell .admin-provision-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    width: 100%;
    padding: 1rem 1.25rem 1.2rem;
    background: var(--pb-card-bg);
}

.pb-shell .admin-form-grid {
    row-gap: var(--pb-space-xs);
}

@media (max-width: 599.98px) {
    .pb-shell .admin-provision-shell {
        gap: 0.85rem;
        padding: 0.9rem;
    }

    .pb-shell .admin-provision-intro,
    .pb-shell .admin-provision-section,
    .pb-shell .admin-provision-toggle {
        border-radius: var(--pb-radius-md);
        padding: 0.85rem;
    }

    .pb-shell .admin-provision-intro-main,
    .pb-shell .admin-provision-section-header {
        gap: 0.65rem;
    }

    .pb-shell .admin-provision-summary,
    .pb-shell .admin-provision-field-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .pb-shell .admin-provision-toggle {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .pb-shell .admin-provision-toggle .mud-checkbox {
        grid-column: 1 / -1;
        justify-self: flex-start;
        margin-left: -0.4rem;
    }

    .pb-shell .admin-provision-actions {
        flex-direction: column-reverse;
        gap: 0.55rem;
        padding: 0.85rem;
    }

    .pb-shell .admin-provision-actions .mud-button-root {
        width: 100%;
    }
}

.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 var(--pb-line);
    border-radius: var(--pb-radius-lg);
    background: var(--pb-card-bg);
}

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

.pb-shell .mud-table-container {
    border-top: 0;
    background: transparent;
}

.pb-shell .mud-table-root .mud-table-head .mud-table-cell {
    background: transparent;
    color: var(--pb-text-muted);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    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 var(--pb-line);
}

.pb-shell .mud-table-root .mud-table-body .mud-table-row:nth-child(even) {
    background: var(--mud-palette-table-striped);
}

.pb-shell .mud-table-root .mud-table-row:hover {
    background: var(--pb-hover);
    box-shadow: none;
}

.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: transparent;
}

.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: 100px;
    box-shadow: none;
    font-weight: 500;
    font-size: 12px;
}

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

.pb-shell .mud-chip.mud-chip-color-success {
    background: rgba(var(--pb-success-rgb), 0.15);
    color: var(--pb-success);
    border: 1px solid rgba(var(--pb-success-rgb), 0.25);
}

.pb-shell .mud-chip.mud-chip-color-warning {
    background: rgba(var(--pb-warning-rgb), 0.15);
    color: var(--pb-warning);
    border: 1px solid rgba(var(--pb-warning-rgb), 0.25);
}

.pb-shell .mud-chip.mud-chip-color-error {
    background: rgba(var(--pb-error-rgb), 0.15);
    color: var(--pb-error);
    border: 1px solid rgba(var(--pb-error-rgb), 0.25);
}

.pb-shell .mud-chip.mud-chip-color-info {
    background: rgba(var(--pb-info-rgb), 0.15);
    color: var(--pb-info);
    border: 1px solid rgba(var(--pb-info-rgb), 0.25);
}

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

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

.pb-shell .mud-input-outlined .mud-input-outlined-border {
    border-color: var(--pb-line-strong);
    border-radius: var(--pb-radius-md);
}

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

.pb-shell .mud-input-outlined.mud-focused .mud-input-outlined-border,
.pb-shell .mud-input-outlined:focus-within .mud-input-outlined-border {
    border-color: var(--pb-primary);
    border-width: 1px;
    box-shadow: 0 0 0 3px var(--pb-focus);
}

.pb-shell .mud-input-error .mud-input-outlined-border {
    box-shadow: 0 0 0 3px 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-label.mud-input-label-animated.mud-focused {
    color: var(--pb-primary);
}

.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: var(--pb-radius-lg);
    background: var(--pb-card-bg);
    box-shadow: var(--pb-shadow-md);
}

.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: "DM Sans", system-ui, sans-serif;
    font-weight: 600;
}

.pb-shell .mud-alert {
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: var(--pb-card-bg);
    box-shadow: none;
}

.pb-shell .mud-alert-filled-success,
.pb-shell .mud-alert-outlined-success,
.pb-shell .mud-snackbar.mud-alert-filled-success {
    background: rgba(var(--pb-success-rgb), 0.15);
    color: var(--pb-success);
    border: 1px solid rgba(var(--pb-success-rgb), 0.25);
    box-shadow: none;
}

.pb-shell .mud-alert-filled-warning,
.pb-shell .mud-alert-outlined-warning,
.pb-shell .mud-snackbar.mud-alert-filled-warning {
    background: rgba(var(--pb-warning-rgb), 0.15);
    color: var(--pb-warning);
    border: 1px solid rgba(var(--pb-warning-rgb), 0.25);
    box-shadow: none;
}

.pb-shell .mud-alert-filled-error,
.pb-shell .mud-alert-outlined-error,
.pb-shell .mud-snackbar.mud-alert-filled-error {
    background: rgba(var(--pb-error-rgb), 0.15);
    color: var(--pb-error);
    border: 1px solid rgba(var(--pb-error-rgb), 0.25);
    box-shadow: none;
}

.pb-shell .mud-alert-filled-info,
.pb-shell .mud-alert-outlined-info,
.pb-shell .mud-snackbar.mud-alert-filled-info {
    background: rgba(var(--pb-info-rgb), 0.15);
    color: var(--pb-info);
    border: 1px solid rgba(var(--pb-info-rgb), 0.25);
    box-shadow: none;
}

.pb-shell .mud-snackbar {
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: var(--pb-card-bg);
    box-shadow: var(--pb-shadow-md);
}

.pb-shell .mud-tabs-tabbar {
    background: transparent;
    border-bottom: 1px solid var(--pb-line);
    box-shadow: none;
}

.pb-shell .mud-tab {
    min-height: 44px;
    font-family: "DM Sans", system-ui, sans-serif;
    font-weight: 500;
    letter-spacing: -0.01em;
    text-transform: none;
    color: var(--pb-text-muted);
    transition: color var(--pb-transition-base);
}

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

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

.pb-shell .mud-tab-slider {
    height: 2px !important;
    border-radius: 999px;
    background: var(--pb-primary);
    box-shadow: 0 0 8px var(--pb-accent-glow);
}

.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 #1c1a30;
    border-radius: 24px;
    padding: 1.6rem;
    background: #0f0e1a;
    color: #edeaf5;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.70);
}

.blazor-reconnect-card h2 {
    margin: 0 0 0.75rem;
    font-family: "Times New Roman", Times, serif;
    font-size: 1.32rem;
    letter-spacing: -0.025em;
}

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

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

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

.blazor-reconnect-actions button {
    border: none;
    border-radius: 100px;
    padding: 0.7rem 1.1rem;
    cursor: pointer;
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 0.88rem;
    font-weight: 500;
    color: #ffffff;
    background: #7c5cfc;
    box-shadow: none;
    transition: filter 160ms cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 220ms cubic-bezier(0.2, 0.8, 0.2, 1), transform 160ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.blazor-reconnect-actions button:hover {
    filter: brightness(1.1);
    box-shadow: 0 8px 28px rgba(124, 92, 252, 0.30);
}

.blazor-reconnect-actions button:active {
    transform: scale(0.97);
}

@media (max-width: 959.98px) {
    .pb-shell [data-testid="main-content"] {
        padding: 1.35rem 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: var(--pb-space-md) !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: 2rem 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 .admin-search-field,
    .pb-shell .admin-filter-field,
    .pb-shell .toolbar-action,
    .pb-shell .filter-bar > * {
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }

    .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: var(--pb-space-md) !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: var(--pb-space-sm);
    }

    .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: var(--pb-radius-sm);
    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: "DM Sans", system-ui, sans-serif;
    font-size: 0.92rem;
    font-weight: 600;
    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: var(--pb-radius-md);
    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: var(--pb-radius-md);
    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: "Times New Roman", Times, 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: var(--pb-space-sm);
    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: var(--pb-radius-sm);
}

.pb-shell .conversation-contact-name-label {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 0.98rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    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: var(--pb-radius-md);
    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: var(--pb-space-md);
    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: var(--pb-radius-md);
    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: var(--pb-space-sm);
    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: var(--pb-radius-sm);
}

.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: var(--pb-radius-md);
    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;
    }
}

/* ── Material Symbols utility ────────────────────────────────────── */

.pb-shell .msi {
    font-family: "Material Symbols Outlined";
    font-weight: 400;
    font-style: normal;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    font-size: 1.25rem;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-feature-settings: "liga";
    -webkit-font-smoothing: antialiased;
    font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.pb-shell .msi--filled {
    font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}

.pb-shell .msi--sm { font-size: 18px; }
.pb-shell .msi--xs { font-size: 16px; }
.pb-shell .msi--lg { font-size: 28px; }

/* ────────────────────────────────────────────────────────────────────
   SEPHIRA MOCKUP CLASSES — drop-in das classes do prototype
   (botões pill, KPI delta, login surface, fields, switch, chips,
    avatars, drawer, appbar, page-header, chat layout, calendar grid)
   ──────────────────────────────────────────────────────────────────── */

/* ── Botões prototype (.btn, .btn--*) ─────────────────────────────── */

.pb-shell .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--pb-space-sm);
    padding: 10px 18px;
    border-radius: 100px;
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: -0.01em;
    white-space: nowrap;
    transition: all 0.18s var(--pb-ease);
    cursor: pointer;
    border: 1px solid transparent;
    background: transparent;
    color: var(--pb-text);
}
.pb-shell .btn:active { transform: scale(0.97); }
.pb-shell .btn--lg { padding: 13px 24px; font-size: 14px; }
.pb-shell .btn--sm { padding: 7px 14px; font-size: 12px; }
.pb-shell .btn--primary { background: var(--pb-primary); color: #fff; }
.pb-shell .btn--primary:hover { filter: brightness(1.1); box-shadow: 0 8px 28px var(--pb-accent-glow); }
.pb-shell .btn--ghost { border-color: rgba(var(--pb-primary-rgb), 0.35); color: var(--pb-text-muted); }
.pb-shell .btn--ghost:hover { border-color: var(--pb-primary); color: var(--pb-text); }
.pb-shell .btn--text { color: var(--pb-primary-ink); padding-inline: var(--pb-space-md); }
.pb-shell .btn--text:hover { background: var(--pb-hover); }
.pb-shell .btn--icon {
    width: 38px; height: 38px; padding: 0; border-radius: var(--pb-radius-sm);
    display: inline-grid; place-items: center;
    color: var(--pb-text-muted);
    border: 1px solid var(--pb-line);
    background: var(--pb-surface);
}
.pb-shell .btn--icon:hover { color: var(--pb-text); border-color: var(--pb-line-strong); }

.pb-shell .appbar__btn {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    color: var(--pb-text-muted);
    transition: all var(--pb-transition-fast);
    position: relative;
    background: transparent;
    border: 0;
}

.pb-shell .appbar__btn:hover {
    color: var(--pb-text);
    background: var(--pb-hover);
}

.pb-shell .appbar__search {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 100px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    color: var(--pb-text-muted);
    font-size: 13px;
    min-width: 240px;
    transition: border-color var(--pb-transition-fast);
}

.pb-shell .appbar__search:hover { border-color: var(--pb-line-strong); }

.pb-shell .appbar__search input {
    background: none;
    border: none;
    outline: none;
    color: var(--pb-text);
    font: inherit;
    flex: 1;
    min-width: 0;
}

/* ── Cards prototype ──────────────────────────────────────────────── */

.pb-shell .card {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    padding: 22px;
    box-shadow: var(--pb-shadow-sm);
    transition: border-color var(--pb-transition-base);
}
.pb-shell .card:hover { border-color: var(--pb-line-strong); }
.pb-shell .card--padded { padding: 28px 30px; }
.pb-shell .card--flush { padding: 0; overflow: hidden; }
.pb-shell .card--soft { background: var(--pb-surface-2); border-color: transparent; box-shadow: none; }

.pb-shell .card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--pb-space-md);
    margin-bottom: var(--pb-space-md);
}
.pb-shell .card__title {
    font-family: "Times New Roman", Times, serif;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.02em;
}
.pb-shell .card__title em { font-style: italic; font-weight: 300; color: var(--pb-primary); }
.pb-shell .card__subtitle { font-size: 13px; color: var(--pb-text-muted); margin-top: 2px; }

/* ── KPI prototype: grid + delta + variantes vertical ────────────── */

.pb-shell .kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--pb-space-md);
}
@media (max-width: 1100px) { .pb-shell .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .pb-shell .kpi-grid { grid-template-columns: 1fr; } }

.pb-shell .service-kpi-card {
    min-height: 5.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.pb-shell .service-kpi-card__lead {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.pb-shell .service-kpi-card .kpi-icon {
    flex: 0 0 38px;
}

.pb-shell .service-kpi-card .kpi-label {
    color: var(--pb-text) !important;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
    line-height: 1.2;
}

.pb-shell .service-kpi-card .kpi-value {
    max-width: 52%;
    margin-top: 0;
    flex: 0 0 auto;
    text-align: right;
    overflow-wrap: anywhere;
}

.pb-shell .service-kpi-card__value--name {
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.1;
}

.pb-shell .servicos-page-actions {
    margin-left: auto;
}

.pb-shell .servicos-panel-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .servicos-panel-heading__lead {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.pb-shell .servicos-panel-heading__title {
    font-size: 1.85rem;
    line-height: 1.08;
    letter-spacing: 0;
}

@media (max-width: 600px) {
    .pb-shell .servicos-page-actions {
        justify-content: stretch !important;
    }

    .pb-shell .servicos-page-actions > .mud-button-group-root,
    .pb-shell .servicos-page-actions > .mud-button-root {
        width: 100%;
    }

    .pb-shell .servicos-page-actions .mud-button-root {
        flex: 1 1 auto;
    }

    .pb-shell .service-kpi-card .kpi-value {
        max-width: 48%;
    }
}

.pb-shell .kpi {
    position: relative;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    padding: 22px;
    overflow: hidden;
    transition: background var(--pb-transition-base), border-color var(--pb-transition-base);
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.pb-shell .kpi::after {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(circle at 0% 0%, var(--kpi-tint, var(--pb-accent-dim)), transparent 60%);
    opacity: 0;
    transition: opacity 0.3s var(--pb-ease);
    pointer-events: none;
}
.pb-shell .kpi:hover { background: var(--pb-surface-2); border-color: var(--pb-line-strong); }
.pb-shell .kpi:hover::after { opacity: 1; }

.pb-shell .kpi__top { display: flex; align-items: center; justify-content: space-between; }

.pb-shell .kpi__icon {
    width: 38px; height: 38px;
    border-radius: 10px;
    display: grid; place-items: center;
    background: var(--kpi-bg, var(--pb-accent-dim));
    border: 1px solid var(--kpi-border, rgba(var(--pb-primary-rgb), 0.30));
    color: var(--kpi-color, var(--pb-primary-ink));
}

.pb-shell .kpi__num {
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    letter-spacing: -0.04em;
    line-height: 1;
    color: var(--kpi-color, var(--pb-text));
}
.pb-shell .kpi__num span {
    font-size: 0.55em;
    color: var(--pb-primary);
    font-weight: 600;
    margin-left: 2px;
}

.pb-shell .kpi__label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--pb-text-muted);
}

.pb-shell .kpi__delta {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 12px; font-weight: 600;
    color: var(--pb-mint);
    background: rgba(62, 201, 154, 0.15);
    padding: 3px 10px;
    border-radius: 100px;
    width: fit-content;
    border: 1px solid rgba(62, 201, 154, 0.25);
}
.pb-shell .kpi__delta.is-down {
    color: var(--pb-coral);
    background: rgba(255, 94, 122, 0.15);
    border-color: rgba(255, 94, 122, 0.25);
}

.pb-shell .kpi.kpi--peach { --kpi-bg: rgba(255, 154, 108, 0.10); --kpi-border: rgba(255, 154, 108, 0.30); --kpi-color: var(--pb-peach); --kpi-tint: rgba(255, 154, 108, 0.10); }
.pb-shell .kpi.kpi--gold  { --kpi-bg: rgba(228, 176, 64, 0.10);  --kpi-border: rgba(228, 176, 64, 0.30);  --kpi-color: var(--pb-gold);  --kpi-tint: rgba(228, 176, 64, 0.10); }
.pb-shell .kpi.kpi--mint  { --kpi-bg: rgba(62, 201, 154, 0.10);  --kpi-border: rgba(62, 201, 154, 0.30);  --kpi-color: var(--pb-mint);  --kpi-tint: rgba(62, 201, 154, 0.10); }
.pb-shell .kpi.kpi--coral { --kpi-bg: rgba(255, 94, 122, 0.10);  --kpi-border: rgba(255, 94, 122, 0.30);  --kpi-color: var(--pb-coral); --kpi-tint: rgba(255, 94, 122, 0.10); }

.pb-shell .kpi-grid--inline .kpi {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}
.pb-shell .kpi-grid--inline .kpi__lead {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    flex: 1 1 auto;
}
.pb-shell .kpi-grid--inline .kpi__label {
    color: var(--pb-text);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: -0.01em;
    text-transform: none;
}
.pb-shell .kpi-grid--inline .kpi__num {
    flex: 0 0 auto;
    font-size: clamp(26px, 2.6vw, 36px);
    margin-left: auto;
    text-align: right;
}

.pb-shell .kpi-grid--inline .kpi__num--name {
    max-width: 52%;
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: clamp(16px, 1.55vw, 22px);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.12;
    overflow-wrap: anywhere;
}

.pb-shell .service-kpi-grid .kpi {
    min-height: 5.75rem;
}

.pb-shell .service-kpi-grid .kpi__num {
    max-width: 48%;
    overflow-wrap: anywhere;
}

.pb-shell .service-kpi-grid .kpi__num.service-kpi-card__value--name {
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: clamp(15px, 1.35vw, 18px);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.15;
}

.pb-shell .dashboard-actions-row {
    display: flex;
    justify-content: flex-end;
}

.pb-shell [data-testid="admin-dashboard-attention-panel"] .attention-chip-compact.mud-chip,
.pb-shell [data-testid="admin-dashboard-incidents-panel"] .attention-chip-compact.mud-chip,
.pb-shell [data-testid="admin-tenant-detail-attention-panel"] .attention-chip-compact.mud-chip,
.pb-shell [data-testid="admin-tenant-detail-incidents-panel"] .attention-chip-compact.mud-chip {
    height: auto;
    min-height: 0;
    padding-block: 3px;
    padding-inline: 8px;
    font-size: 11px;
    line-height: 1.4;
    margin: 0;
}
.pb-shell [data-testid="admin-dashboard-attention-panel"] .attention-chip-compact .mud-chip-content,
.pb-shell [data-testid="admin-dashboard-incidents-panel"] .attention-chip-compact .mud-chip-content,
.pb-shell [data-testid="admin-tenant-detail-attention-panel"] .attention-chip-compact .mud-chip-content,
.pb-shell [data-testid="admin-tenant-detail-incidents-panel"] .attention-chip-compact .mud-chip-content {
    padding: 0;
}

.pb-shell .tenant-detail-scroll {
    overflow-y: auto;
    scrollbar-width: thin;
}

.pb-shell .tenant-detail-scroll--list {
    max-height: 320px;
    padding-right: 4px;
}

.pb-shell .tenant-detail-incident-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pb-shell .tenant-detail-incident-item {
    display: flex;
    width: 100%;
    padding: 8px 0;
    color: inherit;
}

.pb-shell .tenant-detail-incident-item + .tenant-detail-incident-item {
    border-top: 1px solid var(--pb-line-soft);
}

.pb-shell .tenant-detail-scroll-table--five-rows .mud-table-container {
    max-height: 328px;
    overflow-y: auto;
}

.pb-shell .page-shell[data-testid="admin-dashboard-page"],
.pb-shell .page-shell[data-testid="admin-attention-page"] {
    margin-top: -0.5rem;
}

.pb-shell .admin-attention-filterbar {
    flex-wrap: wrap;
    justify-content: flex-start;
}

.pb-shell .admin-attention-search,
.pb-shell .admin-attention-level-filter {
    flex: 0 1 clamp(220px, 30vw, 420px);
    width: clamp(220px, 30vw, 420px);
    min-width: min(100%, 220px);
    max-width: 100%;
}

@media (max-width: 599.98px) {
    .pb-shell .admin-attention-search,
    .pb-shell .admin-attention-level-filter {
        flex-basis: 100%;
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }
}

/* ── Avatars + chips prototype ────────────────────────────────────── */

.pb-shell .avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    display: inline-grid; place-items: center;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    flex: 0 0 auto;
    background: linear-gradient(145deg, var(--pb-primary-light), var(--pb-primary));
}
.pb-shell .avatar--lg { width: 44px; height: 44px; font-size: 14px; }
.pb-shell .avatar--sm { width: 26px; height: 26px; font-size: 10px; }
.pb-shell .avatar.av--peach { background: linear-gradient(145deg, #ffb693, var(--pb-peach)); }
.pb-shell .avatar.av--gold  { background: linear-gradient(145deg, #f0c870, var(--pb-gold)); }
.pb-shell .avatar.av--mint  { background: linear-gradient(145deg, #6fdfb6, var(--pb-mint)); }
.pb-shell .avatar.av--coral { background: linear-gradient(145deg, #ff8aa1, var(--pb-coral)); }
.pb-shell .avatar.av--info  { background: linear-gradient(145deg, #8ed1ff, #58b8ff); }

.pb-shell .chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 500;
    border: 1px solid transparent;
    white-space: nowrap;
}
.pb-shell .chip--success { background: rgba(62, 201, 154, 0.15); color: var(--pb-mint); border-color: rgba(62, 201, 154, 0.25); }
.pb-shell .chip--warning { background: rgba(228, 176, 64, 0.15); color: var(--pb-gold); border-color: rgba(228, 176, 64, 0.25); }
.pb-shell .chip--error   { background: rgba(255, 94, 122, 0.15); color: var(--pb-coral); border-color: rgba(255, 94, 122, 0.25); }
.pb-shell .chip--info    { background: rgba(88, 184, 255, 0.15); color: #58b8ff; border-color: rgba(88, 184, 255, 0.25); }
.pb-shell .chip--neutral { background: var(--pb-surface-2); color: var(--pb-text-muted); border-color: var(--pb-line); }
.pb-shell .chip--accent  { background: var(--pb-accent-dim); color: var(--pb-primary-ink); border-color: rgba(var(--pb-primary-rgb), 0.30); }
.pb-shell .chip .led {
    width: 6px; height: 6px; border-radius: 50%; background: currentColor;
    box-shadow: 0 0 8px currentColor;
}

/* ── Form fields + switch ─────────────────────────────────────────── */

.pb-shell .field { display: flex; flex-direction: column; gap: 6px; }
.pb-shell .field__label {
    font-size: 12px;
    font-weight: 500;
    color: var(--pb-text-muted);
    letter-spacing: -0.005em;
}
.pb-shell .field__input,
.pb-shell .field__select,
.pb-shell .field__textarea {
    width: 100%;
    padding: 12px 14px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line-strong);
    border-radius: var(--pb-radius-md);
    color: var(--pb-text);
    font: 400 14px "DM Sans", system-ui, sans-serif;
    transition: border-color var(--pb-transition-fast), box-shadow var(--pb-transition-fast);
}
.pb-shell .field__input:hover,
.pb-shell .field__select:hover,
.pb-shell .field__textarea:hover { border-color: rgba(var(--pb-primary-rgb), 0.45); }
.pb-shell .field__input:focus,
.pb-shell .field__select:focus,
.pb-shell .field__textarea:focus {
    outline: none;
    border-color: var(--pb-primary);
    box-shadow: 0 0 0 3px var(--pb-focus);
}
.pb-shell .field__textarea { min-height: 96px; resize: vertical; font-family: inherit; }

.pb-shell .switch {
    --w: 42px; --h: 24px;
    position: relative;
    width: var(--w); height: var(--h);
    border-radius: 999px;
    background: var(--pb-surface-3);
    border: 1px solid var(--pb-line-strong);
    cursor: pointer;
    transition: background var(--pb-transition-fast);
    flex: 0 0 auto;
    display: inline-block;
}
.pb-shell .switch::after {
    content: "";
    position: absolute;
    top: 2px; left: 2px;
    width: calc(var(--h) - 6px);
    height: calc(var(--h) - 6px);
    border-radius: 50%;
    background: var(--pb-text-muted);
    transition: transform var(--pb-transition-fast), background var(--pb-transition-fast);
}
.pb-shell .switch.is-on { background: var(--pb-accent-dim); border-color: rgba(var(--pb-primary-rgb), 0.40); }
.pb-shell .switch.is-on::after {
    transform: translateX(calc(var(--w) - var(--h)));
    background: var(--pb-primary);
}

/* ── Tabs prototype ───────────────────────────────────────────────── */

.pb-shell .tabs {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--pb-line);
    padding-inline: 4px;
}

.pb-shell .tab {
    padding: 12px 18px;
    color: var(--pb-text-muted);
    font-size: 14px;
    font-weight: 500;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color var(--pb-transition-fast), border-color var(--pb-transition-fast);
    cursor: pointer;
    background: none;
}

.pb-shell .tab:hover { color: var(--pb-text); }
.pb-shell .tab.is-active { color: var(--pb-primary-ink); border-bottom-color: var(--pb-primary); }

.pb-shell .table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.pb-shell .table thead th {
    text-align: left;
    padding: 12px 18px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--pb-text-muted);
    border-bottom: 1px solid var(--pb-line-strong);
    background: transparent;
    white-space: nowrap;
}

.pb-shell .table tbody td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--pb-line);
    vertical-align: middle;
}

.pb-shell .table tbody tr:last-child td { border-bottom: none; }
.pb-shell .table tbody tr { transition: background var(--pb-transition-fast); }
.pb-shell .table tbody tr:hover { background: var(--pb-hover); }

/* ── Clientes: table header + segmented filters ───────────────────── */

.pb-shell .clientes-table-panel {
    display: flex;
    flex-direction: column;
}

.pb-shell .clientes-table-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--pb-space-md);
    margin-bottom: var(--pb-space-md);
}

.pb-shell .clientes-table-title-group {
    min-width: 0;
}

.pb-shell .clientes-table-title {
    font-family: "Times New Roman", Times, serif;
    font-size: clamp(1.45rem, 1.7vw, 1.75rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--pb-text);
}

.pb-shell .clientes-create-button {
    flex: 0 0 auto;
}

.pb-shell .clientes-tab-selector {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    width: fit-content;
    max-width: 100%;
    padding: 0.28rem;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: var(--pb-surface);
}

.pb-shell .clientes-tab-option {
    min-height: 2.25rem;
    padding: 0.45rem 0.9rem;
    border: 1px solid transparent;
    border-radius: calc(var(--pb-radius-md) - 4px);
    background: transparent;
    color: var(--pb-text-muted);
    font: inherit;
    font-size: 0.86rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    transition:
        background var(--pb-transition-fast),
        border-color var(--pb-transition-fast),
        color var(--pb-transition-fast);
}

.pb-shell .clientes-tab-option:hover {
    color: var(--pb-text);
    background: var(--pb-surface-2);
}

.pb-shell .clientes-tab-option.is-active {
    border-color: rgba(var(--pb-primary-rgb), 0.32);
    background: rgba(var(--pb-primary-rgb), 0.14);
    color: var(--pb-primary-ink);
}

.pb-shell .clientes-phone {
    font-family: ui-monospace, "SFMono-Regular", "Roboto Mono", Consolas, monospace;
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

@media (max-width: 600px) {
    .pb-shell .clientes-table-header {
        align-items: stretch;
        flex-direction: column;
    }

    .pb-shell .clientes-create-button {
        width: 100%;
    }

    .pb-shell .clientes-tab-selector {
        width: 100%;
    }

    .pb-shell .clientes-tab-option {
        flex: 1 1 calc(50% - 0.35rem);
    }
}

/* ── Empty state prototype ────────────────────────────────────────── */

.pb-shell .empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
    padding: 48px 24px;
    background: var(--pb-surface-2);
    border: 1px dashed var(--pb-line-strong);
    border-radius: var(--pb-radius-lg);
}
.pb-shell .empty-state__icon {
    width: 56px; height: 56px;
    border-radius: var(--pb-radius-md);
    display: grid; place-items: center;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    color: var(--pb-text-disabled);
}
.pb-shell .empty-state h3 {
    font-family: "Times New Roman", Times, serif;
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--pb-text);
}
.pb-shell .empty-state h3 em { font-style: italic; font-weight: 300; color: var(--pb-primary); }
.pb-shell .empty-state p { color: var(--pb-text-muted); max-width: 48ch; font-size: 14px; line-height: 1.6; }
.pb-shell .empty-state__actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin-top: 6px; }

/* ── Login surface prototype ──────────────────────────────────────── */

.pb-shell .login-stage {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 32px;
    position: relative;
    z-index: 1;
}

.pb-shell .login-card {
    width: min(100%, 460px);
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    padding: 40px 36px;
    box-shadow: var(--pb-shadow-md);
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.pb-shell .login-card__brand {
    display: flex; flex-direction: column; align-items: center; gap: 14px;
    text-align: center;
}
.pb-shell .login-card__brand-mark {
    width: 100%;
    max-width: 240px;
    height: auto;
    display: grid;
    place-items: center;
    background: none;
    border-radius: 0;
    box-shadow: none;
}
.pb-shell .login-card__brand-mark svg,
.pb-shell .login-card__brand-mark img {
    width: 100%;
    height: auto;
    display: block;
}
.pb-shell .login-card__brand h1 {
    font-family: "Times New Roman", Times, serif;
    font-size: 32px;
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.05;
    margin: 0;
}
.pb-shell .login-card__brand h1 em { font-style: italic; font-weight: 300; color: var(--pb-primary); }
.pb-shell .login-card__brand p { font-size: 14px; color: var(--pb-text-muted); max-width: 38ch; margin: 0; }

.pb-shell .login-card .field { gap: 8px; }
.pb-shell .login-card .field__label {
    font-size: 13px;
    color: var(--pb-text);
    font-weight: 500;
}

.pb-shell .login-card .btn.btn--primary.btn--lg {
    width: 100%;
    justify-content: center;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 600;
}

.pb-shell .login-card__row [data-testid="login-forgot-password"] {
    font-size: 13px;
    text-decoration: none;
}
.pb-shell .login-card__row [data-testid="login-forgot-password"]:hover {
    text-decoration: underline;
}

.pb-shell .login-card__form { display: flex; flex-direction: column; gap: 14px; }
.pb-shell .login-card__row {
    display: flex; align-items: center; justify-content: space-between;
    font-size: 13px; color: var(--pb-text-muted);
}
.pb-shell .login-card__row a { color: var(--pb-primary-ink); }
.pb-shell .login-card__divider {
    display: flex; align-items: center; gap: 12px;
    color: var(--pb-text-muted);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}
.pb-shell .login-card__divider::before,
.pb-shell .login-card__divider::after {
    content: ""; flex: 1; height: 1px; background: var(--pb-line);
}

/* ── Drawer prototype (.drawer__brand etc.) ───────────────────────── */

.pb-shell .drawer__brand {
    padding: 18px 12px 14px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border-bottom: 1px solid var(--pb-line);
    flex: 0 0 auto;
}
.pb-shell .drawer__brand-main {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}
.pb-shell .drawer__brand-mark {
    width: 34px;
    height: 48px;
    color: #fff;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
}
.pb-shell .drawer__brand-mark .brand-mark {
    width: 100%;
    height: 100%;
}
.pb-shell .drawer__brand-name {
    font-family: inherit;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0;
    color: var(--pb-text);
    margin: 0;
}
.pb-shell .drawer__toggle {
    width: 34px;
    height: 34px;
    min-width: 34px;
    color: var(--pb-text-muted);
}
.pb-shell .drawer__toggle:hover,
.pb-shell .drawer__toggle:focus-visible {
    color: var(--pb-text);
    background: var(--pb-hover);
}
.pb-shell .main-drawer--mini .drawer__brand {
    padding: 14px 10px;
    justify-content: center;
}
.pb-shell .main-drawer--mini .drawer__brand-main {
    display: none;
}
.pb-shell .main-drawer--mini .drawer__toggle {
    margin: 0 auto;
}
.pb-shell .drawer__footer {
    padding: 12px 18px;
    border-top: 1px solid var(--pb-line);
    font-size: 11px;
    color: var(--pb-text-muted);
    letter-spacing: 0.04em;
    flex: 0 0 auto;
}

/* ── Page header prototype helpers (já temos page-header básico) ─── */

.pb-shell .page-title-icon {
    width: 44px; height: 44px;
    border-radius: var(--pb-radius-md);
    display: grid; place-items: center;
    background: var(--pb-accent-dim);
    border: 1px solid rgba(var(--pb-primary-rgb), 0.30);
    color: var(--pb-primary-ink);
    flex: 0 0 auto;
}

/* ── Conversas / chat layout ──────────────────────────────────────── */

.pb-shell .chat-layout {
    display: grid;
    grid-template-columns: 320px 1fr 280px;
    gap: var(--pb-space-md);
    height: calc(100dvh - 12.25rem);
    min-height: min(520px, calc(100dvh - 12.25rem));
}
@media (max-width: 1200px) {
    .pb-shell .chat-layout { grid-template-columns: 280px 1fr; }
    .pb-shell .chat-layout > .chat-side { display: none; }
}
@media (max-width: 900px) {
    .pb-shell .chat-layout { grid-template-columns: 1fr; }
    .pb-shell .chat-layout > .chat-list { display: none; }
}

.pb-shell .chat-list,
.pb-shell .chat-thread,
.pb-shell .chat-side {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.pb-shell .chat-list__head,
.pb-shell .chat-thread__head,
.pb-shell .chat-side__head {
    padding: 14px var(--pb-space-md);
    border-bottom: 1px solid var(--pb-line);
    display: flex;
    align-items: center;
    gap: 10px;
}
.pb-shell .chat-list__items { flex: 1; overflow-y: auto; padding: 6px; }
.pb-shell .chat-list__item {
    appearance: none;
    width: 100%;
    display: flex;
    gap: 12px;
    padding: 10px 12px;
    border-radius: var(--pb-radius-md);
    cursor: pointer;
    transition: background var(--pb-transition-fast);
    border: 1px solid transparent;
    background: transparent;
    color: inherit;
    text-align: left;
}
.pb-shell .chat-list__item:hover { background: var(--pb-hover); }
.pb-shell .chat-list__item.is-active { background: var(--pb-accent-dim); border-color: rgba(var(--pb-primary-rgb), 0.20); }
.pb-shell .chat-list__item-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pb-shell .chat-list__item-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pb-shell .chat-list__item-name { font-weight: 600; font-size: 13px; color: var(--pb-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pb-shell .chat-list__item-time { font-size: 11px; color: var(--pb-text-muted); flex: 0 0 auto; }
.pb-shell .chat-list__item-preview { font-size: 12px; color: var(--pb-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pb-shell .chat-list__item-tags { display: flex; align-items: center; gap: 4px; margin-top: 4px; min-height: 20px; }
.pb-shell .chat-list__unread {
    margin-left: auto;
    min-width: 20px;
    height: 20px;
    border-radius: 10px;
    background: var(--pb-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    display: inline-grid;
    place-items: center;
    padding: 0 6px;
}

.pb-shell .chat-thread__messages {
    flex: 1; overflow-y: auto;
    padding: 22px 28px;
    display: flex; flex-direction: column; gap: 12px;
    background: var(--pb-bg-soft);
}
.pb-shell .chat-thread__date {
    align-self: center;
    padding: 4px 12px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: 100px;
    font-size: 11px;
    color: var(--pb-text-muted);
    margin: 4px 0 12px;
}

.pb-shell .bub {
    max-width: min(620px, 75%);
    padding: 10px 14px;
    font-size: 14px;
    line-height: 1.45;
    border-radius: 18px;
    display: flex; flex-direction: column;
}
.pb-shell .bub__meta { font-size: 10px; color: var(--pb-text-muted); margin-top: 4px; align-self: flex-end; }
.pb-shell .bub--in {
    align-self: flex-start;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    color: var(--pb-text);
    border-bottom-left-radius: 6px;
}
.pb-shell .bub--out {
    align-self: flex-end;
    background: var(--pb-primary);
    color: #fff;
    border-bottom-right-radius: 6px;
}
.pb-shell .bub--ai {
    align-self: flex-start;
    background: var(--pb-accent-dim);
    border: 1px solid rgba(var(--pb-primary-rgb), 0.30);
    color: var(--pb-text);
    border-bottom-left-radius: 6px;
}
.pb-shell .bub--ai .bub__role {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pb-primary-ink);
    margin-bottom: 4px;
    display: flex; align-items: center; gap: 6px;
}
.pb-shell .bub--quote {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12.5px;
    background: var(--pb-surface-2);
    border: 1px solid var(--pb-line-strong);
    border-left: 2px solid var(--pb-primary);
    align-self: flex-start;
    color: var(--pb-text);
    border-radius: 8px;
    padding: 10px 14px;
    white-space: pre-wrap;
}
.pb-shell .bub--ok {
    background: rgba(62, 201, 154, 0.10);
    border: 1px solid rgba(62, 201, 154, 0.25);
    color: var(--pb-text);
    align-self: flex-start;
    font-weight: 500;
}

.pb-shell .typing {
    display: inline-flex; gap: 4px;
    padding: 12px 14px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: 18px;
    border-bottom-left-radius: 6px;
    align-self: flex-start;
}
.pb-shell .typing i {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--pb-text-disabled);
    animation: tydot 1.2s ease-in-out infinite;
}
.pb-shell .typing i:nth-child(2) { animation-delay: 0.15s; }
.pb-shell .typing i:nth-child(3) { animation-delay: 0.30s; }
@keyframes tydot {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30% { transform: translateY(-3px); opacity: 1; }
}

.pb-shell .chat-thread__composer {
    padding: 14px 18px;
    border-top: 1px solid var(--pb-line);
    background: var(--pb-surface);
    display: flex; align-items: center; gap: 10px;
}
.pb-shell .chat-thread__composer .field__input { padding: 10px 14px; }
.pb-shell .chat-thread__composer .conversation-composer-shell--mockup {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
    width: 100%;
    flex-wrap: nowrap;
}
.pb-shell .chat-thread__composer .conversation-composer-file-input {
    display: none;
}

.pb-shell .chat-side__body { flex: 1; padding: var(--pb-space-md); display: flex; flex-direction: column; gap: 14px; }
.pb-shell .kv { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; }
.pb-shell .kv__k { color: var(--pb-text-muted); }
.pb-shell .kv__v { color: var(--pb-text); font-weight: 500; }
.pb-shell .chat-side-profile {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--pb-line);
}
.pb-shell .chat-side-profile .avatar--lg {
    width: 60px;
    height: 60px;
    font-size: 18px;
}
.pb-shell .chat-side-profile__name {
    font-family: var(--pb-font-display);
    font-size: 20px;
    font-weight: 600;
    color: var(--pb-text);
}
.pb-shell .chat-side-profile__meta,
.pb-shell .chat-side-pet__meta,
.pb-shell .chat-side-list-item__meta {
    font-size: 11px;
    color: var(--pb-text-muted);
}
.pb-shell .chat-side-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.pb-shell .chat-side-section__title {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.10em;
    color: var(--pb-text-muted);
}
.pb-shell .chat-side-stack,
.pb-shell .chat-side-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.pb-shell .chat-side-pet,
.pb-shell .chat-side-list-item {
    display: flex;
    align-items: center;
    gap: 10px;
}
.pb-shell .chat-side-pet__name,
.pb-shell .chat-side-list-item__title {
    font-size: 13px;
    font-weight: 500;
    color: var(--pb-text);
}
.pb-shell .chat-side-actions .btn {
    justify-content: flex-start;
    width: 100%;
}

/* ── Calendar grid ────────────────────────────────────────────────── */

.pb-shell .cal {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    overflow: hidden;
    position: relative;
}
.pb-shell .cal__head {
    display: grid;
    grid-template-columns: 64px repeat(7, 1fr);
    background: var(--pb-surface-2);
    border-bottom: 1px solid var(--pb-line);
}
.pb-shell .cal__head-cell {
    padding: 12px 10px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--pb-text-muted);
    text-align: center;
    border-left: 1px solid var(--pb-line);
}
.pb-shell .cal__head-cell:first-child { border-left: none; }
.pb-shell .cal__head-cell strong {
    display: block;
    font-family: "Times New Roman", Times, serif;
    color: var(--pb-text);
    font-size: 22px;
    letter-spacing: -0.02em;
    text-transform: none;
    font-weight: 600;
    margin-top: 2px;
}
.pb-shell .cal__head-cell.is-today strong { color: var(--pb-primary); }

.pb-shell .cal__body {
    display: grid;
    grid-template-columns: 64px repeat(7, 1fr);
}
.pb-shell .cal__hours {
    border-right: 1px solid var(--pb-line);
    display: grid;
    grid-auto-rows: 64px;
}
.pb-shell .cal__hour {
    padding: 4px 8px;
    font-size: 10px;
    color: var(--pb-text-muted);
    text-align: right;
    letter-spacing: 0.05em;
    border-top: 1px solid var(--pb-line);
}
.pb-shell .cal__hour:first-child { border-top: none; }
.pb-shell .cal__col {
    border-left: 1px solid var(--pb-line);
    position: relative;
    display: grid;
    grid-auto-rows: 64px;
    min-height: 64px;
}
.pb-shell .cal__col:first-child { border-left: none; }
.pb-shell .cal__slot { border-top: 1px solid var(--pb-line); }
.pb-shell .cal__slot:first-child { border-top: none; }

.pb-shell .cal__event {
    position: absolute;
    left: 4px; right: 4px;
    border-radius: var(--pb-radius-sm);
    padding: 8px 10px;
    font-size: 12px;
    overflow: hidden;
    background: var(--pb-accent-dim);
    border: 1px solid rgba(var(--pb-primary-rgb), 0.30);
    border-left-width: 3px;
    color: var(--pb-text);
    box-shadow: var(--pb-shadow-sm);
    cursor: pointer;
    transition: transform var(--pb-transition-fast);
}
.pb-shell .cal__event:hover { transform: translateY(-1px); }
.pb-shell .cal__event-title { font-weight: 600; font-size: 13px; line-height: 1.2; }
.pb-shell .cal__event-meta { color: var(--pb-text-muted); font-size: 11px; margin-top: 2px; }
.pb-shell .cal__event--peach { background: rgba(255, 154, 108, 0.12); border-color: rgba(255, 154, 108, 0.35); border-left-color: var(--pb-peach); }
.pb-shell .cal__event--gold  { background: rgba(228, 176, 64, 0.12);  border-color: rgba(228, 176, 64, 0.35);  border-left-color: var(--pb-gold); }
.pb-shell .cal__event--mint  { background: rgba(62, 201, 154, 0.12);  border-color: rgba(62, 201, 154, 0.35);  border-left-color: var(--pb-mint); }
.pb-shell .cal__event--coral { background: rgba(255, 94, 122, 0.12);  border-color: rgba(255, 94, 122, 0.35);  border-left-color: var(--pb-coral); }

.pb-shell .cal__now {
    position: absolute;
    left: 64px; right: 0;
    height: 0;
    border-top: 2px solid var(--pb-coral);
    z-index: 5;
    pointer-events: none;
}
.pb-shell .cal__now::before {
    content: "";
    position: absolute;
    left: -4px; top: -5px;
    width: 8px; height: 8px;
    background: var(--pb-coral);
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(255, 94, 122, 0.25);
}

/* ── Legenda do calendário ────────────────────────────────────────── */

.pb-shell .cal-legend {
    display: flex; flex-wrap: wrap; gap: var(--pb-space-md);
    font-size: 12px; color: var(--pb-text-muted);
    padding: 12px 0;
}
.pb-shell .cal-legend span {
    display: inline-flex; align-items: center; gap: 6px;
}
.pb-shell .cal-legend i {
    width: 10px; height: 10px; border-radius: 3px; display: inline-block;
}
.pb-shell .cal-legend .square--peach { background: var(--pb-peach); }
.pb-shell .cal-legend .square--gold  { background: var(--pb-gold); }
.pb-shell .cal-legend .square--mint  { background: var(--pb-mint); }
.pb-shell .cal-legend .square--coral { background: var(--pb-coral); }

/* ── Settings tabs (Sephira screens-config.jsx) ───────────────────── */

.pb-shell .settings-section-row {
    display: grid;
    grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
    gap: 36px;
}

@media (max-width: 900px) {
    .pb-shell .settings-section-row {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

.pb-shell .settings-section-row__copy {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.pb-shell .settings-section-row__title {
    font-family: "Times New Roman", Times, serif;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--pb-text);
    margin: 0;
}

.pb-shell .settings-section-row__title em {
    font-style: italic;
    font-weight: 300;
    color: var(--pb-primary);
}

.pb-shell .settings-section-row__desc {
    font-size: 13px;
    color: var(--pb-text-muted);
    line-height: 1.55;
    margin: 0;
}

.pb-shell .settings-day-list {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: 14px;
    overflow: hidden;
}

.pb-shell .settings-day-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .settings-day-row:first-child { border-top: none; }
.pb-shell .settings-day-row.is-off { opacity: 0.55; }

.pb-shell .settings-day-row__label {
    display: flex;
    align-items: center;
    gap: 12px;
}

.pb-shell .settings-day-row__name {
    font-weight: 500;
    font-size: 14px;
}

.pb-shell .settings-day-row__sep {
    color: var(--pb-text-muted);
    font-size: 12px;
}

.pb-shell .settings-time-input {
    width: 96px;
    padding: 6px 10px;
    font-variant-numeric: tabular-nums;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.pb-shell .field__input {
    width: 100%;
    padding: 12px 14px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line-strong);
    border-radius: var(--pb-radius-md);
    color: var(--pb-text);
    font: 400 14px "DM Sans", sans-serif;
    transition: border-color var(--pb-transition-fast), box-shadow var(--pb-transition-fast);
}

.pb-shell .field__input:hover { border-color: rgba(var(--pb-primary-rgb), 0.45); }

.pb-shell .field__input:focus {
    outline: none;
    border-color: var(--pb-primary);
    box-shadow: 0 0 0 3px var(--pb-focus);
}

.pb-shell .settings-insight-card {
    margin-top: 12px;
    padding: 14px;
    border-radius: 12px;
    border: 1px dashed var(--pb-line);
    display: flex;
    align-items: center;
    gap: 12px;
}

.pb-shell .settings-insight-card__icon { color: var(--pb-primary); }

.pb-shell .settings-insight-card__copy {
    flex: 1;
    font-size: 12.5px;
    color: var(--pb-text-muted);
    line-height: 1.5;
}

.pb-shell .settings-grid-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 14px;
}

@media (max-width: 700px) {
    .pb-shell .settings-grid-3 { grid-template-columns: 1fr; }
}

.pb-shell .settings-holiday-row {
    padding: 12px 14px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 14px;
}

.pb-shell .settings-holiday-row__bar {
    width: 6px;
    height: 32px;
    border-radius: 4px;
    flex: 0 0 auto;
}

.pb-shell .settings-holiday-row__copy {
    flex: 1;
}

.pb-shell .settings-holiday-row__name {
    font-weight: 500;
    font-size: 14px;
}

.pb-shell .settings-holiday-row__date {
    font-size: 12px;
    color: var(--pb-text-muted);
    font-variant-numeric: tabular-nums;
}

.pb-shell .switch {
    --w: 42px;
    --h: 24px;
    position: relative;
    display: inline-block;
    width: var(--w);
    height: var(--h);
    border-radius: 999px;
    background: var(--pb-surface-3);
    border: 1px solid var(--pb-line-strong);
    cursor: pointer;
    transition: background var(--pb-transition-fast);
    flex: 0 0 auto;
}

.pb-shell .switch::after {
    content: "";
    position: absolute;
    top: 2px;
    left: 2px;
    width: calc(var(--h) - 6px);
    height: calc(var(--h) - 6px);
    border-radius: 50%;
    background: var(--pb-text-muted);
    transition: transform var(--pb-transition-fast), background var(--pb-transition-fast);
}

.pb-shell .switch.is-on {
    background: var(--pb-accent-dim);
    border-color: rgba(var(--pb-primary-rgb), 0.40);
}

.pb-shell .switch.is-on::after {
    transform: translateX(calc(var(--w) - var(--h)));
    background: var(--pb-primary);
}

/* Integrations cards */
.pb-shell .settings-integration-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 12px;
}

.pb-shell .settings-integration-card {
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    padding: 16px;
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .settings-integration-card.is-off { opacity: 0.85; }

.pb-shell .settings-integration-card__head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}

.pb-shell .settings-integration-card__icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
}

.pb-shell .settings-integration-card__title {
    font-weight: 600;
    font-size: 14px;
}

.pb-shell .settings-integration-card__sub {
    font-size: 12px;
    color: var(--pb-text-muted);
    margin-top: 2px;
}

.pb-shell .settings-integration-card__actions {
    display: flex;
    gap: 6px;
    padding-top: 12px;
    border-top: 1px solid var(--pb-line);
}

/* Webhook block */
.pb-shell .settings-webhook-events {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.pb-shell .settings-webhook-events .mud-chip {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 11px;
}

/* Tone of voice tiles */
.pb-shell .settings-tone-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
}

@media (max-width: 700px) {
    .pb-shell .settings-tone-grid { grid-template-columns: repeat(2, 1fr); }
}

.pb-shell .settings-tone-tile {
    padding: 12px;
    border-radius: 12px;
    border: 1px solid var(--pb-line);
    background: var(--pb-surface);
    cursor: pointer;
    text-align: center;
    transition: border-color var(--pb-transition-fast), background var(--pb-transition-fast);
}

.pb-shell .settings-tone-tile:hover {
    border-color: rgba(var(--pb-primary-rgb), 0.30);
}

.pb-shell .settings-tone-tile.is-active {
    border-color: rgba(var(--pb-primary-rgb), 0.45);
    background: var(--pb-accent-dim);
}

.pb-shell .settings-tone-tile__emoji {
    font-size: 22px;
    margin-bottom: 4px;
}

.pb-shell .settings-tone-tile__label {
    font-size: 13px;
    font-weight: 500;
}

.pb-shell .settings-tone-tile__sub {
    font-size: 11px;
    color: var(--pb-text-muted);
}

/* Plan hero */
.pb-shell .settings-plan-hero {
    padding: 22px;
    border: 1px solid color-mix(in srgb, var(--pb-primary) 28%, transparent);
    background: linear-gradient(180deg, color-mix(in srgb, var(--pb-primary) 8%, var(--pb-surface)), var(--pb-surface));
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .settings-plan-hero__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.pb-shell .settings-plan-hero__price {
    font-family: "Times New Roman", Times, serif;
    font-size: 32px;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: var(--pb-primary);
}

.pb-shell .settings-plan-hero__price-suffix {
    font-size: 14px;
    color: var(--pb-text-muted);
    margin-left: 4px;
}

.pb-shell .settings-plan-hero__features {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
}

@media (max-width: 700px) {
    .pb-shell .settings-plan-hero__features { grid-template-columns: 1fr; }
}

.pb-shell .settings-plan-hero__feature {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    padding: 4px 0;
    line-height: 1.45;
}

.pb-shell .settings-plan-hero__feature--off { color: var(--pb-text-disabled); }

.pb-shell .settings-plan-hero__check {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    margin-top: 1px;
}

.pb-shell .settings-plan-hero__check--ok {
    background: color-mix(in srgb, var(--pb-mint) 18%, transparent);
    color: var(--pb-mint);
}

.pb-shell .settings-plan-hero__check--off {
    background: var(--pb-surface-2);
    color: var(--pb-text-disabled);
}

.pb-shell .settings-plan-hero__cta {
    display: flex;
    gap: 8px;
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .settings-payment-card {
    padding: 18px;
    display: flex;
    align-items: center;
    gap: 16px;
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .settings-payment-card__visa {
    width: 56px;
    height: 38px;
    border-radius: 8px;
    background: linear-gradient(135deg, #1a1a2e, #2d3561);
    color: #fff;
    display: grid;
    place-items: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    flex: 0 0 auto;
}

.pb-shell .settings-payment-card__number {
    font-weight: 500;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-variant-numeric: tabular-nums;
}

.pb-shell .settings-payment-card__sub {
    font-size: 12px;
    color: var(--pb-text-muted);
}

/* Roles grid */
.pb-shell .settings-roles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
}

.pb-shell .settings-role-card {
    padding: 16px;
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .settings-role-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 8px;
}

.pb-shell .settings-role-card__title {
    font-weight: 600;
    font-size: 14px;
}

.pb-shell .settings-role-card__desc {
    font-size: 12.5px;
    color: var(--pb-text-muted);
    line-height: 1.5;
    margin: 0 0 12px;
}

.pb-shell .settings-role-card--add {
    border-style: dashed;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--pb-text-muted);
    box-shadow: none;
}

/* Members table */
.pb-shell .settings-members-list {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: 14px;
    overflow: hidden;
}

.pb-shell .settings-member-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1.4fr) minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .settings-member-row:first-child { border-top: none; }

.pb-shell .settings-member-avatar {
    position: relative;
}

.pb-shell .settings-member-avatar__dot {
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--pb-text-disabled);
    box-shadow: 0 0 0 2px var(--pb-surface);
}

.pb-shell .settings-member-avatar__dot.is-online { background: var(--pb-mint); }

.pb-shell .settings-member-name { font-weight: 500; font-size: 14px; }
.pb-shell .settings-member-email { font-size: 12px; color: var(--pb-text-muted); }
.pb-shell .settings-member-last { font-size: 11px; color: var(--pb-text-disabled); }

/* Servicos cards grid */
.pb-shell .servicos-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 14px;
}

.pb-shell .servico-card {
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
    transition: border-color var(--pb-transition-base);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.pb-shell .servico-card:hover {
    border-color: var(--pb-line-strong);
}

.pb-shell .servico-card__name {
    font-family: "Times New Roman", Times, serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--pb-text);
}

.pb-shell .servico-card__desc {
    font-size: 12.5px;
    color: var(--pb-text-muted);
    line-height: 1.5;
    margin-top: 4px;
}

.pb-shell .servico-card__commercial {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 14px;
}

.pb-shell .servico-card__price {
    font-family: "Times New Roman", Times, serif;
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: var(--pb-primary);
    line-height: 1;
    min-width: 0;
}

.pb-shell .servico-card__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--pb-text-muted);
    flex: 0 0 auto;
    margin-top: 0;
    text-align: right;
}

.pb-shell .servico-card__meta span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.pb-shell .servico-card__actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 46px;
    gap: 0;
    margin: auto -16px 0;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .servico-card__actions .mud-button-root,
.pb-shell .servico-card__actions .mud-icon-button {
    min-height: 44px;
    border-radius: 0;
}

.pb-shell .servico-card__actions .mud-button-root {
    justify-content: center;
}

.pb-shell .servico-card__actions .mud-icon-button {
    width: 46px;
}

.pb-shell .service-category-chip--tosa-cachorro.mud-chip {
    background: rgba(var(--pb-success-rgb), 0.16);
    color: var(--pb-success);
    border: 1px solid rgba(var(--pb-success-rgb), 0.32);
}

@media (max-width: 420px) {
    .pb-shell .servico-card__commercial {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.45rem;
    }

    .pb-shell .servico-card__meta {
        text-align: left;
    }
}

/* Equipe screen layout */
.pb-shell .tenant-team-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.pb-shell .tenant-team-metric {
    min-height: 84px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 16px;
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    background: var(--pb-card-bg);
}

.pb-shell .tenant-team-metric span {
    color: var(--pb-text-muted);
    font-size: 12px;
    font-weight: 600;
}

.pb-shell .tenant-team-metric strong {
    color: var(--pb-text);
    font-family: "Times New Roman", Times, serif;
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
}

.pb-shell .equipe-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(340px, 0.8fr);
    gap: 16px;
    align-items: flex-start;
}

@media (max-width: 1100px) {
    .pb-shell .equipe-layout { grid-template-columns: 1fr; }
}

.pb-shell .equipe-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 14px;
    align-content: flex-start;
}

.pb-shell .equipe-member-card {
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-md);
    cursor: pointer;
    min-width: 0;
    transition: border-color var(--pb-transition-fast), background var(--pb-transition-fast);
}

.pb-shell .equipe-member-card:hover,
.pb-shell .equipe-member-card:focus-visible {
    border-color: var(--pb-line-strong);
    outline: none;
}

.pb-shell .equipe-member-card.is-active {
    border-color: rgba(var(--pb-primary-rgb), 0.42);
    background: var(--pb-accent-dim);
}

.pb-shell .tenant-team-card-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.pb-shell .tenant-team-card-title {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.pb-shell .equipe-member-card__name {
    color: var(--pb-text);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.25;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .tenant-team-card-email {
    color: var(--pb-text-muted);
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pb-shell .tenant-team-card-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--pb-line);
}

.pb-shell .tenant-team-card-row {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.pb-shell .tenant-team-card-row--wide {
    grid-column: 1 / -1;
}

.pb-shell .tenant-team-card-row span {
    color: var(--pb-text-muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.pb-shell .tenant-team-card-row strong {
    color: var(--pb-text);
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
    min-width: 0;
    overflow-wrap: anywhere;
}

.pb-shell .equipe-detail {
    align-self: flex-start;
    position: sticky;
    top: 84px;
}

.pb-shell .tenant-team-editor {
    border-radius: var(--pb-radius-md);
    background: var(--pb-card-bg);
}

.pb-shell .tenant-team-editor-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.pb-shell .equipe-detail__name {
    color: var(--pb-text);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.pb-shell .equipe-detail__role {
    color: var(--pb-text-muted);
    font-size: 13px;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.pb-shell .tenant-team-finance {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.pb-shell .tenant-team-finance span,
.pb-shell .tenant-team-finance small {
    color: var(--pb-text-muted);
    font-size: 12px;
}

.pb-shell .tenant-team-finance strong {
    color: var(--pb-text);
    font-family: "Times New Roman", Times, serif;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: 0;
}

.pb-shell .tenant-team-editor-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

@media (max-width: 760px) {
    .pb-shell .tenant-team-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pb-shell .equipe-detail {
        position: static;
    }
}

@media (max-width: 520px) {
    .pb-shell .tenant-team-metrics {
        grid-template-columns: 1fr;
    }

    .pb-shell .tenant-team-editor-actions {
        align-items: stretch;
        flex-direction: column-reverse;
    }

    .pb-shell .tenant-team-editor-actions .mud-button-root {
        width: 100%;
    }
}

/* Avatar tints (av--*) */
.pb-shell .av--primary { background: linear-gradient(145deg, var(--pb-primary-light), var(--pb-primary)); color: #fff; }
.pb-shell .av--peach   { background: linear-gradient(145deg, #ffb693, var(--pb-peach));  color: #fff; }
.pb-shell .av--gold    { background: linear-gradient(145deg, #f0c870, var(--pb-gold));   color: #fff; }
.pb-shell .av--mint    { background: linear-gradient(145deg, #6fdfb6, var(--pb-mint));   color: #fff; }
.pb-shell .av--coral   { background: linear-gradient(145deg, #ff8aa1, var(--pb-coral));  color: #fff; }

/* Assistente IA layout */
.pb-shell .assistente-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
}

@media (max-width: 1100px) {
    .pb-shell .assistente-layout { grid-template-columns: 1fr; }
}

.pb-shell .assistente-insight-card {
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .assistente-insight-card__icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
}

.pb-shell .assistente-insight-card__title {
    font-family: "Times New Roman", Times, serif;
    font-size: 17px;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.pb-shell .assistente-insight-card__body {
    font-size: 13px;
    color: var(--pb-text-muted);
    line-height: 1.55;
    margin: 0;
}

.pb-shell .assistente-insight-card__meta {
    font-size: 11px;
    color: var(--pb-text-disabled);
    text-transform: uppercase;
    letter-spacing: 0.10em;
    font-weight: 600;
}

.pb-shell .assistente-suggester {
    background: var(--pb-card-bg);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    box-shadow: var(--pb-shadow-sm);
    align-self: flex-start;
    position: sticky;
    top: 84px;
    overflow: hidden;
}

.pb-shell .assistente-suggester__head {
    padding: 16px 18px;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .assistente-suggester__title {
    font-family: "Times New Roman", Times, serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.02em;
    margin-top: 4px;
}

.pb-shell .assistente-suggester__sub {
    font-size: 12px;
    color: var(--pb-text-muted);
    margin-top: 2px;
}

.pb-shell .assistente-suggester__thread {
    max-height: 220px;
    overflow-y: auto;
    padding: 16px 18px;
    background: var(--pb-bg-soft);
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .bub {
    max-width: 80%;
    padding: 8px 12px;
    font-size: 13px;
    line-height: 1.45;
    border-radius: 14px;
}

.pb-shell .bub.bub--in {
    align-self: flex-start;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-bottom-left-radius: 6px;
}

.pb-shell .bub.bub--out {
    align-self: flex-end;
    background: var(--pb-primary);
    color: #fff;
    border-bottom-right-radius: 6px;
}

.pb-shell .bub.is-hl {
    box-shadow: 0 0 0 2px rgba(var(--pb-primary-rgb), 0.4);
}

.pb-shell .bub__meta {
    font-size: 10px;
    opacity: 0.7;
    margin-top: 4px;
    text-align: right;
}

.pb-shell .assistente-suggester__suggestions {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .assistente-suggestion {
    padding: 12px 14px;
    border: 1px solid var(--pb-line);
    border-radius: 12px;
    cursor: pointer;
    transition: border-color var(--pb-transition-fast), background var(--pb-transition-fast);
}

.pb-shell .assistente-suggestion:hover { border-color: var(--pb-line-strong); }

.pb-shell .assistente-suggestion.is-active {
    border-color: rgba(var(--pb-primary-rgb), 0.40);
    background: var(--pb-accent-dim);
}

.pb-shell .assistente-suggestion__bullet {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.pb-shell .assistente-suggestion__label {
    font-weight: 600;
    font-size: 13px;
}

.pb-shell .assistente-suggestion__confidence {
    font-size: 11px;
    color: var(--pb-text-muted);
    font-variant-numeric: tabular-nums;
}

.pb-shell .assistente-suggestion__text {
    font-size: 12.5px;
    color: var(--pb-text-muted);
    line-height: 1.5;
}

.pb-shell .assistente-suggester__prompts {
    padding: 12px 18px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .assistente-suggester__send {
    padding: 14px 18px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Tenant page layout */
.pb-shell .tenant-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
    gap: 16px;
    align-items: flex-start;
}

@media (max-width: 1100px) {
    .pb-shell .tenant-page-layout { grid-template-columns: 1fr; }
}

.pb-shell .tenant-logo-mark {
    width: 72px;
    height: 72px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--pb-primary), var(--pb-peach));
    color: #fff;
    display: grid;
    place-items: center;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--pb-primary) 30%, transparent);
    flex: 0 0 auto;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .pb-shell *,
    .pb-shell *::before,
    .pb-shell *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* =============================================================
 * Sephira-themed "Novo serviço" dialog
 * Renders outside .pb-shell (via MudDialogProvider portal),
 * so all tokens are re-declared here for safety.
 * ============================================================= */

.pb-sephira-servico-dialog.mud-dialog {
    --psd-bg: #0f0e1a;
    --psd-bg-soft: #131225;
    --psd-bg-elevated: #1c1a30;
    --psd-line: #1c1a30;
    --psd-line-strong: #2a2740;
    --psd-fg: #edeaf5;
    --psd-fg-muted: #9590c0;
    --psd-fg-disabled: #6b6490;
    --psd-primary: #7c5cfc;
    --psd-primary-rgb: 124, 92, 252;
    --psd-accent-glow: rgba(124, 92, 252, 0.30);
    --psd-accent-dim: rgba(124, 92, 252, 0.12);
    --psd-peach: #ff9a6c;
    --psd-peach-rgb: 255, 154, 108;
    --psd-gold: #e4b040;
    --psd-gold-rgb: 228, 176, 64;
    --psd-mint: #3ec99a;
    --psd-mint-rgb: 62, 201, 154;
    --psd-coral: #ff5e7a;
    --psd-coral-rgb: 255, 94, 122;
    --psd-tone: var(--psd-primary);
    --psd-tone-rgb: var(--psd-primary-rgb);
    --psd-radius-md: 16px;
    --psd-radius-lg: 24px;
    --psd-ease: cubic-bezier(0.2, 0.8, 0.2, 1);

    background: var(--psd-bg) !important;
    color: var(--psd-fg) !important;
    border: 1px solid var(--psd-line-strong) !important;
    border-radius: var(--psd-radius-lg) !important;
    box-shadow:
        0 32px 80px rgba(0, 0, 0, 0.55),
        0 0 0 1px rgba(var(--psd-primary-rgb), 0.10) !important;
    overflow: hidden !important;
    padding: 0 !important;
    font-family: "DM Sans", system-ui, sans-serif;
}

/* Tone variants driven by category — applies to dialog or any inner wrapper */
.pb-sephira-servico-dialog[data-tone="peach"],
.pb-sephira-servico-dialog [data-tone="peach"]   { --psd-tone: var(--psd-peach);   --psd-tone-rgb: var(--psd-peach-rgb); }
.pb-sephira-servico-dialog[data-tone="gold"],
.pb-sephira-servico-dialog [data-tone="gold"]    { --psd-tone: var(--psd-gold);    --psd-tone-rgb: var(--psd-gold-rgb); }
.pb-sephira-servico-dialog[data-tone="mint"],
.pb-sephira-servico-dialog [data-tone="mint"]    { --psd-tone: var(--psd-mint);    --psd-tone-rgb: var(--psd-mint-rgb); }
.pb-sephira-servico-dialog[data-tone="coral"],
.pb-sephira-servico-dialog [data-tone="coral"]   { --psd-tone: var(--psd-coral);   --psd-tone-rgb: var(--psd-coral-rgb); }

/* Reset MudDialog internal padding (TitleContent/DialogContent/DialogActions wrappers) */
.pb-sephira-servico-dialog .mud-dialog-title {
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
}
.pb-sephira-servico-dialog .mud-dialog-content {
    padding: 0 !important;
    overflow: visible !important;
}
.pb-sephira-servico-dialog .mud-dialog-actions {
    padding: 16px 26px !important;
    border-top: 1px solid var(--psd-line) !important;
    background: var(--psd-bg-soft) !important;
    margin: 0 !important;
}

/* Header */
.pb-sephira-servico-dialog .psd-head {
    padding: 22px 26px 18px;
    border-bottom: 1px solid var(--psd-line);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}
.pb-sephira-servico-dialog .psd-head__lead {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    flex: 1;
    min-width: 0;
}
.pb-sephira-servico-dialog .psd-head__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    flex: 0 0 auto;
    background: rgba(var(--psd-tone-rgb), 0.14);
    color: var(--psd-tone);
    border: 1px solid rgba(var(--psd-tone-rgb), 0.30);
    display: grid;
    place-items: center;
    transition: background 220ms var(--psd-ease), border-color 220ms var(--psd-ease), color 220ms var(--psd-ease);
}
.pb-sephira-servico-dialog .psd-head__icon .mud-icon-root {
    color: var(--psd-tone);
}
.pb-sephira-servico-dialog .psd-title {
    font-family: "Times New Roman", Times, serif;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.1;
    margin: 0;
    color: var(--psd-fg);
}
.pb-sephira-servico-dialog .psd-title em {
    font-weight: 300;
    color: var(--psd-primary);
    font-style: italic;
}
.pb-sephira-servico-dialog .psd-sub {
    font-size: 13px;
    color: var(--psd-fg-muted);
    margin: 4px 0 0;
    line-height: 1.5;
}

/* Body */
.pb-sephira-servico-dialog .psd-body {
    padding: 22px 26px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    overflow-y: auto;
    max-height: calc(100vh - 240px);
}
.pb-sephira-servico-dialog .psd-section {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.pb-sephira-servico-dialog .psd-divider {
    border: none;
    border-top: 1px solid var(--psd-line);
    margin: 4px 0;
}

/* Field labels (Sephira eyebrow style) */
.pb-sephira-servico-dialog .psd-label {
    font-family: "DM Sans", system-ui, sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    color: var(--psd-fg-muted);
    text-transform: uppercase;
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.pb-sephira-servico-dialog .psd-label__hint {
    color: var(--psd-fg-disabled);
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
}

/* 2-column grid for nome + categoria */
.pb-sephira-servico-dialog .psd-grid-2 {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: 14px;
}
@media (max-width: 720px) {
    .pb-sephira-servico-dialog .psd-grid-2 { grid-template-columns: 1fr; }
}

.pb-sephira-servico-dialog .psd-commercial-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

@media (max-width: 640px) {
    .pb-sephira-servico-dialog .psd-commercial-grid { grid-template-columns: 1fr; }
}

/* Stepper-like row (currency + numeric + suffix) */
.pb-sephira-servico-dialog .psd-stepper-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap;
}
.pb-sephira-servico-dialog .psd-currency-prefix {
    color: var(--psd-fg-muted);
    font-weight: 600;
    font-size: 14px;
}
.pb-sephira-servico-dialog .psd-step-hint {
    color: var(--psd-fg-disabled);
    font-size: 12px;
}
.pb-sephira-servico-dialog .psd-numeric {
    width: 200px;
    flex: 1 1 auto;
    min-width: 0;
}

/* Quick-pick pills */
.pb-sephira-servico-dialog .psd-pill-row {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
}
.pb-sephira-servico-dialog .psd-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 12px;
    border-radius: 100px;
    border: 1px solid var(--psd-line-strong);
    background: var(--psd-bg-soft);
    font-family: inherit;
    font-size: 11.5px;
    font-weight: 500;
    color: var(--psd-fg-muted);
    cursor: pointer;
    transition: color 160ms var(--psd-ease), background 160ms var(--psd-ease), border-color 160ms var(--psd-ease);
    line-height: 1.4;
}
.pb-sephira-servico-dialog .psd-pill:hover {
    color: var(--psd-fg);
    border-color: var(--psd-fg-muted);
}
.pb-sephira-servico-dialog .psd-pill.is-on {
    background: var(--psd-accent-dim);
    color: var(--psd-primary);
    border-color: rgba(var(--psd-primary-rgb), 0.45);
}

/* Toggle rows (active / agendable) */
.pb-sephira-servico-dialog .psd-toggles {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.pb-sephira-servico-dialog .psd-toggle {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 8px 0;
}
.pb-sephira-servico-dialog .psd-toggle + .psd-toggle {
    border-top: 1px solid var(--psd-line);
}
.pb-sephira-servico-dialog .psd-toggle__copy {
    flex: 1;
    min-width: 0;
}
.pb-sephira-servico-dialog .psd-toggle__title {
    display: block;
    font-weight: 500;
    font-size: 14px;
    color: var(--psd-fg);
}
.pb-sephira-servico-dialog .psd-toggle__desc {
    display: block;
    font-size: 12px;
    color: var(--psd-fg-muted);
    line-height: 1.4;
    margin-top: 2px;
}

/* Live preview card */
.pb-sephira-servico-dialog .psd-preview {
    margin-top: 4px;
    padding: 14px;
    border-radius: 14px;
    background: color-mix(in srgb, var(--psd-tone) 6%, var(--psd-bg));
    border: 1px solid color-mix(in srgb, var(--psd-tone) 25%, transparent);
}
.pb-sephira-servico-dialog .psd-preview__kicker {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--psd-fg-muted);
    margin-bottom: 10px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.pb-sephira-servico-dialog .psd-preview__kicker .mud-icon-root {
    font-size: 14px;
    width: 14px;
    height: 14px;
}
.pb-sephira-servico-dialog .psd-preview__row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.pb-sephira-servico-dialog .psd-preview__copy {
    min-width: 0;
    flex: 1;
}
.pb-sephira-servico-dialog .psd-preview__name {
    font-family: "Times New Roman", Times, serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--psd-fg);
}
.pb-sephira-servico-dialog .psd-preview__placeholder {
    color: var(--psd-fg-disabled);
    font-style: italic;
}
.pb-sephira-servico-dialog .psd-preview__meta {
    font-size: 12px;
    color: var(--psd-fg-muted);
    margin-top: 2px;
}
.pb-sephira-servico-dialog .psd-preview__pricewrap {
    text-align: right;
    flex: 0 0 auto;
}
.pb-sephira-servico-dialog .psd-preview__priceLabel {
    font-size: 10px;
    color: var(--psd-fg-muted);
    text-transform: uppercase;
    letter-spacing: 0.10em;
    font-weight: 600;
}
.pb-sephira-servico-dialog .psd-preview__price {
    font-family: "Times New Roman", Times, serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.04em;
    color: var(--psd-tone);
    line-height: 1.1;
    margin-top: 2px;
}
.pb-sephira-servico-dialog .psd-preview__price-currency {
    font-size: 0.55em;
    margin-right: 2px;
}

.pb-sephira-servico-dialog .psd-foot-buttons {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}
.pb-sephira-servico-dialog .psd-foot-buttons--right {
    margin-left: auto;
    justify-content: flex-end;
}

.pb-sephira-service-form-dialog.mud-dialog {
    width: min(920px, calc(100vw - 40px)) !important;
    max-width: min(920px, calc(100vw - 40px)) !important;
}

.pb-sephira-service-form-dialog .mud-dialog-actions {
    padding: 14px 24px !important;
}

.pb-sephira-service-form-dialog .psd-head {
    padding: 20px 24px 16px;
}

.pb-sephira-service-form-dialog .psd-body {
    padding: 22px 24px 24px;
    gap: 18px;
    max-height: calc(100vh - 220px);
}

.pb-sephira-service-form-dialog .psd-section {
    gap: 8px;
}

.pb-sephira-operation-dialog.mud-dialog {
    width: min(920px, calc(100vw - 40px)) !important;
    max-width: min(920px, calc(100vw - 40px)) !important;
}

.pb-sephira-operation-dialog.pb-sephira-operation-dialog--compact.mud-dialog {
    width: min(600px, calc(100vw - 40px)) !important;
    max-width: min(600px, calc(100vw - 40px)) !important;
}

.pb-sephira-operation-dialog .mud-dialog-title {
    padding: 20px 24px 8px !important;
}

.pb-sephira-operation-dialog .mud-dialog-content {
    padding: 16px 24px 20px !important;
    max-height: calc(100vh - 190px);
    overflow-x: hidden;
    overflow-y: auto;
}

.pb-sephira-operation-dialog .mud-dialog-actions {
    gap: 8px;
    padding: 14px 24px !important;
}

/* Tema Sephira aplicado aos modais operacionais que usam markup MudBlazor padrão. */
.pb-sephira-operation-dialog .mud-dialog-title {
    border-bottom: 1px solid var(--psd-line) !important;
    background: var(--psd-bg) !important;
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-dialog-title .mud-typography,
.pb-sephira-operation-dialog .mud-dialog-title h1,
.pb-sephira-operation-dialog .mud-dialog-title h2,
.pb-sephira-operation-dialog .mud-dialog-title h3 {
    font-family: "Times New Roman", Times, serif;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.1;
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-dialog-content {
    background: var(--psd-bg) !important;
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-dialog-content .mud-typography,
.pb-sephira-operation-dialog .mud-dialog-content .mud-input-control,
.pb-sephira-operation-dialog .mud-dialog-content .mud-input,
.pb-sephira-operation-dialog .mud-dialog-content .mud-list-item-text,
.pb-sephira-operation-dialog .mud-dialog-content td,
.pb-sephira-operation-dialog .mud-dialog-content th {
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-dialog-content .mud-typography.mud-typography-body2,
.pb-sephira-operation-dialog .mud-dialog-content .mud-typography-caption,
.pb-sephira-operation-dialog .mud-dialog-content .mud-secondary-text,
.pb-sephira-operation-dialog .mud-dialog-content .mud-input-helper-text {
    color: var(--psd-fg-muted) !important;
}

.pb-sephira-operation-dialog .mud-input-root,
.pb-sephira-operation-dialog .mud-input-slot,
.pb-sephira-operation-dialog .mud-select-input,
.pb-sephira-operation-dialog .mud-picker-input {
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-input-control input,
.pb-sephira-operation-dialog .mud-input-control textarea,
.pb-sephira-operation-dialog .mud-select .mud-select-input input {
    color: var(--psd-fg) !important;
    caret-color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-input-label {
    color: var(--psd-fg-muted) !important;
}

.pb-sephira-operation-dialog .mud-input-outlined .mud-input-outlined-border {
    border-color: var(--psd-line-strong) !important;
    border-radius: 12px !important;
}

.pb-sephira-operation-dialog .mud-input-outlined:hover .mud-input-outlined-border {
    border-color: rgba(var(--psd-primary-rgb), 0.45) !important;
}

.pb-sephira-operation-dialog .mud-input-outlined.mud-focused .mud-input-outlined-border,
.pb-sephira-operation-dialog .mud-focused .mud-input-outlined-border {
    border-color: var(--psd-primary) !important;
    border-width: 1px !important;
}

.pb-sephira-operation-dialog .mud-input-underline:before {
    border-bottom-color: var(--psd-line-strong) !important;
}

.pb-sephira-operation-dialog .mud-input-underline:hover:not(.mud-disabled):before {
    border-bottom-color: rgba(var(--psd-primary-rgb), 0.45) !important;
}

.pb-sephira-operation-dialog .mud-input-underline:after {
    border-bottom-color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-paper,
.pb-sephira-operation-dialog .mud-card,
.pb-sephira-operation-dialog .mud-table,
.pb-sephira-operation-dialog .mud-tabs-panels {
    background: var(--psd-bg-soft) !important;
    color: var(--psd-fg) !important;
    border-color: var(--psd-line) !important;
}

.pb-sephira-operation-dialog .mud-paper-outlined,
.pb-sephira-operation-dialog .mud-card-outlined,
.pb-sephira-operation-dialog .mud-table-root,
.pb-sephira-operation-dialog .mud-simple-table {
    border-color: var(--psd-line) !important;
}

.pb-sephira-operation-dialog .mud-table-cell,
.pb-sephira-operation-dialog .mud-table-row,
.pb-sephira-operation-dialog .mud-simple-table td,
.pb-sephira-operation-dialog .mud-simple-table th {
    border-color: var(--psd-line) !important;
}

.pb-sephira-operation-dialog .mud-tabs-toolbar {
    background: var(--psd-bg-soft) !important;
    border-bottom: 1px solid var(--psd-line) !important;
}

.pb-sephira-operation-dialog .mud-tab {
    color: var(--psd-fg-muted) !important;
    text-transform: none;
}

.pb-sephira-operation-dialog .mud-tab.mud-tab-active {
    color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-tabs-toolbar .mud-tabs-toolbar-content .mud-tabs-indicator {
    background-color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-stepper {
    background: transparent !important;
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-stepper .mud-step-label,
.pb-sephira-operation-dialog .mud-stepper .mud-step-content {
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-stepper .mud-step-label-description,
.pb-sephira-operation-dialog .mud-stepper .mud-step-optional {
    color: var(--psd-fg-muted) !important;
}

.pb-sephira-operation-dialog .mud-stepper .mud-step-icon,
.pb-sephira-operation-dialog .mud-stepper .mud-step-icon-root {
    background: var(--psd-bg-soft) !important;
    color: var(--psd-fg-muted) !important;
    border: 1px solid var(--psd-line-strong) !important;
}

.pb-sephira-operation-dialog .mud-stepper .mud-step-icon-current,
.pb-sephira-operation-dialog .mud-stepper .mud-step-icon-completed {
    background: var(--psd-primary) !important;
    color: #fff !important;
    border-color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-chip {
    border-color: rgba(var(--psd-primary-rgb), 0.35) !important;
    color: var(--psd-fg) !important;
}

.pb-sephira-operation-dialog .mud-alert {
    background: color-mix(in srgb, var(--psd-tone) 10%, var(--psd-bg-soft)) !important;
    color: var(--psd-fg) !important;
    border: 1px solid color-mix(in srgb, var(--psd-tone) 28%, transparent) !important;
    border-radius: 12px !important;
}

.pb-sephira-operation-dialog .mud-switch .mud-switch-track {
    background: var(--psd-line-strong) !important;
}

.pb-sephira-operation-dialog .mud-switch .mud-switch-base.mud-checked + .mud-switch-track {
    background: rgba(var(--psd-primary-rgb), 0.50) !important;
}

.pb-sephira-operation-dialog .mud-checkbox .mud-icon-root,
.pb-sephira-operation-dialog .mud-radio .mud-icon-root,
.pb-sephira-operation-dialog .mud-switch .mud-switch-thumb {
    color: var(--psd-primary) !important;
}

.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root {
    text-transform: none;
    border-radius: 12px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--psd-fg-muted);
    border: 1px solid rgba(var(--psd-primary-rgb), 0.35);
    background: transparent;
    transition: filter 160ms var(--psd-ease), border-color 160ms var(--psd-ease), background 160ms var(--psd-ease), color 160ms var(--psd-ease);
}

.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root:hover {
    color: var(--psd-fg);
    border-color: var(--psd-primary);
    background: rgba(var(--psd-primary-rgb), 0.08);
}

.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-text-primary,
.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-filled-primary,
.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-outlined-primary {
    background: var(--psd-primary) !important;
    color: #fff !important;
    border: 1px solid var(--psd-primary) !important;
    box-shadow: 0 4px 14px rgba(var(--psd-primary-rgb), 0.25);
}

.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-text-primary:hover,
.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-filled-primary:hover,
.pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root.mud-button-outlined-primary:hover {
    filter: brightness(1.1);
    box-shadow: 0 8px 28px var(--psd-accent-glow);
}

.pb-package-create-dialog.mud-dialog {
    max-height: calc(100dvh - 32px) !important;
    display: flex;
    flex-direction: column;
}

.pb-package-create-dialog .mud-focus-trap,
.pb-package-create-dialog .mud-focus-trap-child-container {
    min-height: 0;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
}

.pb-package-create-dialog .mud-dialog-content {
    min-height: 0;
    flex: 0 0 auto;
    padding: 18px 24px 24px !important;
    overflow: visible !important;
}

.pb-package-create-body {
    min-height: 0;
    overflow: visible;
}

.pb-package-create-body--scroll {
    max-height: calc(100dvh - 224px);
    overflow-x: hidden;
    overflow-y: auto;
    padding-right: 2px;
    scrollbar-gutter: stable;
}

.pb-package-create-dialog .mud-dialog-actions {
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    align-items: center;
    min-height: 72px;
    background: var(--psd-bg-soft) !important;
}

.pb-package-create-stepper {
    min-height: 0;
}

.pb-package-create-stepper .mud-stepper-nav {
    margin-bottom: 22px;
}

.pb-package-create-stepper .mud-stepper-actions {
    display: none !important;
}

.pb-package-create-stepper .mud-step-content {
    padding-bottom: 6px;
}

.pb-package-create-dialog .mud-input-control {
    margin-bottom: 2px;
}

.pb-sephira-cliente-form-dialog.mud-dialog {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 48px) !important;
    max-height: calc(100vh - 48px) !important;
}

.pb-sephira-cliente-form-dialog .mud-focus-trap,
.pb-sephira-cliente-form-dialog .mud-focus-trap-child-container {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
}

.pb-sephira-cliente-form-dialog .mud-dialog-title {
    flex: 0 0 auto;
    padding: 0 !important;
}

.pb-sephira-cliente-form-dialog .mud-dialog-content {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    overflow: hidden !important;
    padding: 0 !important;
}

.pb-sephira-cliente-form-dialog .mud-dialog-actions {
    flex: 0 0 auto;
    justify-content: flex-end;
    min-height: 64px;
    padding: 12px 24px !important;
}

.pb-sephira-cliente-form-dialog .psd-head {
    padding: 18px 24px 14px;
}

.pb-sephira-servico-dialog.pb-sephira-cliente-form-dialog .petshop-customer-dialog-body {
    flex: 1 1 auto;
    gap: 14px;
    max-height: none;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 18px 24px;
    scrollbar-gutter: stable;
}

.pb-sephira-cliente-form-dialog .psd-section {
    gap: 9px;
}

.pb-sephira-cliente-form-dialog .psd-grid-2 {
    gap: 12px;
}

.pb-sephira-cliente-form-dialog .psd-divider {
    margin: 2px 0;
}

.pb-sephira-cliente-form-dialog .psd-preview {
    margin-top: 0;
    padding: 12px 14px;
}

.pb-sephira-product-form-dialog.mud-dialog {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 48px) !important;
    max-height: calc(100vh - 48px) !important;
}

.pb-sephira-product-form-dialog .mud-focus-trap,
.pb-sephira-product-form-dialog .mud-focus-trap-child-container {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
}

.pb-sephira-product-form-dialog .mud-dialog-title {
    flex: 0 0 auto;
    padding: 0 !important;
}

.pb-sephira-product-form-dialog .mud-dialog-content {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
    max-height: none;
    overflow: hidden !important;
    padding: 0 !important;
}

.pb-sephira-product-form-dialog .mud-dialog-actions {
    flex: 0 0 auto;
    justify-content: flex-end;
    min-height: 64px;
    padding: 12px 24px !important;
}

.pb-sephira-product-form-dialog .psd-head {
    padding: 18px 24px 14px;
}

.pb-sephira-servico-dialog.pb-sephira-product-form-dialog .inventory-product-dialog-body {
    flex: 1 1 auto;
    gap: 14px;
    max-height: none;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 18px 24px;
    scrollbar-gutter: stable;
}

.pb-sephira-product-form-dialog .inventory-product-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.pb-sephira-product-form-dialog .psd-section {
    gap: 9px;
}

.pb-sephira-product-form-dialog .psd-grid-2 {
    gap: 12px;
}

.pb-sephira-product-form-dialog .psd-divider {
    margin: 2px 0;
}

.pb-sephira-product-form-dialog .inventory-product-form__switches {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pb-sephira-product-form-dialog .inventory-product-form__switches .mud-switch {
    min-height: 34px;
}

.pb-sephira-product-form-dialog .psd-preview {
    margin-top: 0;
    padding: 12px 14px;
}

@media (max-width: 720px) {
    .pb-sephira-service-form-dialog.mud-dialog {
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        border-radius: 18px !important;
    }

    .pb-sephira-service-form-dialog .psd-head {
        padding: 18px 18px 14px;
    }

    .pb-sephira-service-form-dialog .psd-body {
        padding: 18px;
        gap: 14px;
        max-height: calc(100vh - 196px);
    }

    .pb-sephira-service-form-dialog .mud-dialog-actions {
        padding: 12px 18px !important;
    }

    .pb-sephira-operation-dialog.mud-dialog,
    .pb-sephira-operation-dialog.pb-sephira-operation-dialog--compact.mud-dialog {
        width: calc(100vw - 16px) !important;
        max-width: calc(100vw - 16px) !important;
        border-radius: 18px !important;
    }

    .pb-sephira-operation-dialog .mud-dialog-title {
        padding: 18px 18px 8px !important;
    }

    .pb-sephira-operation-dialog .mud-dialog-content {
        padding: 14px 18px 18px !important;
        max-height: calc(100vh - 172px);
    }

    .pb-sephira-operation-dialog .mud-dialog-actions {
        padding: 12px 18px !important;
    }

    .pb-sephira-product-form-dialog.mud-dialog {
        max-height: calc(100vh - 16px) !important;
    }

    .pb-sephira-product-form-dialog .psd-head,
    .pb-sephira-servico-dialog.pb-sephira-product-form-dialog .inventory-product-dialog-body {
        padding-left: 18px;
        padding-right: 18px;
    }

    .pb-sephira-cliente-form-dialog.mud-dialog {
        max-height: calc(100vh - 16px) !important;
    }

    .pb-sephira-cliente-form-dialog .psd-head,
    .pb-sephira-servico-dialog.pb-sephira-cliente-form-dialog .petshop-customer-dialog-body {
        padding-left: 18px;
        padding-right: 18px;
    }
}

@media (max-width: 520px) {
    .pb-sephira-service-form-dialog .psd-foot-buttons--right,
    .pb-sephira-service-form-dialog .psd-foot-buttons--right .mud-button-root {
        width: 100%;
    }

    .pb-sephira-service-form-dialog .psd-foot-buttons--right {
        margin-left: 0;
        flex-direction: column-reverse;
    }

    .pb-sephira-operation-dialog .mud-dialog-actions {
        flex-direction: column-reverse;
    }

    .pb-sephira-operation-dialog .mud-dialog-actions .mud-button-root {
        width: 100%;
    }
}

.pb-sephira-hotel-reservation-dialog.mud-dialog {
    display: flex;
    max-height: calc(100dvh - 64px) !important;
    flex-direction: column;
}

.pb-sephira-hotel-reservation-dialog .mud-focus-trap,
.pb-sephira-hotel-reservation-dialog .mud-focus-trap-child-container {
    display: flex;
    min-height: 0;
    flex: 1 1 auto;
    flex-direction: column;
}

.pb-sephira-hotel-reservation-dialog .mud-dialog-content {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    padding: 18px 24px 24px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.pb-sephira-hotel-reservation-dialog .mud-dialog-actions {
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    border-top-color: var(--psd-line-strong) !important;
    box-shadow: 0 -18px 32px rgba(15, 14, 26, 0.72);
}

.pb-sephira-hotel-reservation-dialog .hotel-reservation-dialog-body {
    gap: 14px;
    padding-bottom: 2px;
}

.pb-sephira-hotel-reservation-dialog .hotel-reservation-dialog-section.mud-paper {
    border-radius: 14px !important;
    padding: 16px !important;
}

@media (max-width: 720px) {
    .pb-sephira-hotel-reservation-dialog.mud-dialog {
        max-height: calc(100dvh - 16px) !important;
    }

    .pb-sephira-hotel-reservation-dialog .mud-dialog-content {
        padding: 14px 18px 20px !important;
    }

    .pb-sephira-hotel-reservation-dialog .hotel-reservation-dialog-section.mud-paper {
        padding: 14px !important;
    }
}

/* MudBlazor input/button skinning inside the dialog */
.pb-sephira-servico-dialog .mud-input-outlined .mud-input-outlined-border {
    border-radius: 12px;
    border-color: var(--psd-line-strong);
    transition: border-color 160ms var(--psd-ease);
}
.pb-sephira-servico-dialog .mud-input-outlined:hover .mud-input-outlined-border {
    border-color: rgba(var(--psd-primary-rgb), 0.45);
}
.pb-sephira-servico-dialog .mud-input-outlined.mud-focused .mud-input-outlined-border,
.pb-sephira-servico-dialog .mud-focused .mud-input-outlined-border {
    border-color: var(--psd-primary);
    border-width: 1px;
}
.pb-sephira-servico-dialog .mud-input-control input,
.pb-sephira-servico-dialog .mud-input-control textarea,
.pb-sephira-servico-dialog .mud-select .mud-select-input input {
    color: var(--psd-fg);
    caret-color: var(--psd-primary);
}
.pb-sephira-servico-dialog .mud-input-label {
    color: var(--psd-fg-muted);
}
.pb-sephira-servico-dialog .mud-input-label.mud-input-label-shrink {
    color: var(--psd-fg-muted);
}
.pb-sephira-servico-dialog .mud-input-helper-text {
    color: var(--psd-fg-disabled);
}

.pb-sephira-servico-dialog .psd-btn.mud-button-root {
    text-transform: none;
    border-radius: 12px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.01em;
    transition: filter 160ms var(--psd-ease), border-color 160ms var(--psd-ease), background 160ms var(--psd-ease);
}
.pb-sephira-servico-dialog .psd-btn--ghost.mud-button-root {
    background: transparent;
    color: var(--psd-fg-muted);
    border: 1px solid rgba(var(--psd-primary-rgb), 0.35);
}
.pb-sephira-servico-dialog .psd-btn--ghost.mud-button-root:hover {
    color: var(--psd-fg);
    border-color: var(--psd-primary);
    background: rgba(var(--psd-primary-rgb), 0.08);
}
.pb-sephira-servico-dialog .psd-btn--primary.mud-button-root {
    background: var(--psd-primary);
    color: #fff;
    border: 1px solid var(--psd-primary);
    box-shadow: 0 4px 14px rgba(var(--psd-primary-rgb), 0.25);
}
.pb-sephira-servico-dialog .psd-btn--primary.mud-button-root:hover {
    filter: brightness(1.1);
    box-shadow: 0 8px 28px var(--psd-accent-glow);
}

/* MudSwitch tweak so the toggle lines up with the Sephira preview */
.pb-sephira-servico-dialog .psd-toggle .mud-switch {
    margin: 0;
}
.pb-sephira-servico-dialog .psd-toggle .mud-switch-label {
    display: none;
}

/* Inventory subsection (existing fields) — restyled to feel native here */
.pb-sephira-servico-dialog .psd-inventory {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px;
    border-radius: 14px;
    background: var(--psd-bg-soft);
    border: 1px solid var(--psd-line);
}
.pb-sephira-servico-dialog .psd-inventory__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 8px;
}
.pb-sephira-servico-dialog .psd-inventory__title {
    font-size: 14px;
    font-weight: 600;
    color: var(--psd-fg);
    margin: 0;
}
.pb-sephira-servico-dialog .psd-inventory__sub {
    font-size: 12px;
    color: var(--psd-fg-muted);
    line-height: 1.4;
    margin: 2px 0 0;
}
.pb-sephira-servico-dialog .psd-inventory__row {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 3fr) minmax(0, 3fr) auto;
    gap: 10px;
    align-items: end;
    padding: 10px;
    border-radius: 10px;
    background: var(--psd-bg);
    border: 1px solid var(--psd-line);
}
@media (max-width: 720px) {
    .pb-sephira-servico-dialog .psd-inventory__row {
        grid-template-columns: 1fr 1fr;
    }
    .pb-sephira-servico-dialog .psd-inventory__row > :last-child { grid-column: span 2; justify-self: end; }
}

/* Admin Center tenant provisioning uses the same Sephira dialog skin with
 * small layout tweaks for company identity, owner access and billing setup. */
.pb-sephira-admin-provision-dialog .admin-provision-shell {
    gap: 18px;
}

.pb-sephira-admin-provision-dialog .psd-title,
.pb-sephira-admin-provision-dialog .psd-preview__name,
.pb-sephira-admin-provision-dialog .psd-preview__price,
.pb-sephira-admin-provision-dialog .psd-label,
.pb-sephira-admin-provision-dialog .psd-preview__kicker,
.pb-sephira-admin-provision-dialog .psd-preview__priceLabel {
    letter-spacing: 0;
}

.pb-sephira-admin-provision-dialog .admin-provision-facts {
    gap: 8px;
}

.pb-sephira-admin-provision-dialog .admin-provision-fact {
    cursor: default;
    gap: 7px;
    color: var(--psd-fg-muted);
}

.pb-sephira-admin-provision-dialog .admin-provision-fact:hover {
    color: var(--psd-fg-muted);
    border-color: var(--psd-line-strong);
}

.pb-sephira-admin-provision-dialog .admin-provision-fact .mud-icon-root {
    color: var(--psd-tone);
    width: 15px;
    height: 15px;
    font-size: 15px;
}

.pb-sephira-admin-provision-dialog .admin-provision-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pb-sephira-admin-provision-dialog .admin-provision-toggle {
    padding: 8px 0;
}

.pb-sephira-admin-provision-dialog .admin-provision-toggle .mud-checkbox {
    margin: 0;
}

.pb-sephira-admin-provision-dialog .admin-provision-preview {
    margin-top: 0;
}

.pb-sephira-admin-provision-dialog .admin-provision-preview__status {
    min-width: 132px;
}

.pb-sephira-admin-provision-dialog .admin-provision-preview__status .psd-preview__price {
    font-size: 19px;
}

.pb-sephira-admin-provision-dialog .admin-provision-preview__owner {
    max-width: 180px;
    margin-top: 4px;
    color: var(--psd-fg-muted);
    font-size: 12px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

@media (max-width: 720px) {
    .pb-sephira-admin-provision-dialog .admin-provision-field-grid {
        grid-template-columns: 1fr;
    }

    .pb-sephira-admin-provision-dialog .psd-preview__row {
        flex-direction: column;
    }

    .pb-sephira-admin-provision-dialog .admin-provision-preview__status {
        min-width: 0;
        text-align: left;
    }
}

@media (max-width: 520px) {
    .pb-sephira-admin-provision-dialog .mud-dialog-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .pb-sephira-admin-provision-dialog .admin-provision-actions,
    .pb-sephira-admin-provision-dialog .admin-provision-actions .mud-button-root {
        width: 100%;
    }
}

/* Shared Sephira skin for Admin Center operational dialogs. */
.pb-sephira-admin-modal .psd-title,
.pb-sephira-admin-modal .psd-preview__name,
.pb-sephira-admin-modal .psd-preview__price,
.pb-sephira-admin-modal .psd-label,
.pb-sephira-admin-modal .psd-preview__kicker,
.pb-sephira-admin-modal .psd-preview__priceLabel {
    letter-spacing: 0;
}

.pb-sephira-admin-modal .admin-modal-field-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pb-sephira-admin-modal .admin-modal-actions {
    width: 100%;
    justify-content: flex-end;
}

.pb-sephira-admin-modal .psd-btn--danger.mud-button-root {
    background: var(--psd-coral);
    color: #fff;
    border: 1px solid var(--psd-coral);
    box-shadow: 0 4px 14px rgba(var(--psd-coral-rgb), 0.22);
    text-transform: none;
    border-radius: 12px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.01em;
}

.pb-sephira-admin-modal .psd-btn--danger.mud-button-root:hover {
    filter: brightness(1.08);
    box-shadow: 0 8px 28px rgba(var(--psd-coral-rgb), 0.28);
}

.pb-sephira-admin-modal .mud-input-control {
    margin-top: 0;
}

.pb-sephira-admin-modal .mud-input-adornment .mud-icon-root,
.pb-sephira-admin-modal .mud-select .mud-icon-root {
    color: var(--psd-fg-muted);
}

.pb-sephira-admin-modal .mud-select-input,
.pb-sephira-admin-modal .mud-input-slot {
    color: var(--psd-fg);
}

.pb-sephira-admin-modal .admin-modal-alert {
    background: rgba(var(--psd-tone-rgb), 0.10);
    border: 1px solid rgba(var(--psd-tone-rgb), 0.28);
    color: var(--psd-fg);
}

.pb-sephira-admin-modal .admin-modal-confirm-preview {
    margin-top: 0;
}

.pb-sephira-admin-modal .admin-modal-confirm-text {
    color: var(--psd-fg);
    line-height: 1.55;
}

.pb-sephira-admin-modal .admin-modal-billing-preview {
    margin-top: 0;
}

.pb-sephira-admin-modal .admin-modal-billing-preview .psd-preview__price {
    max-width: 190px;
    font-size: 19px;
    overflow-wrap: anywhere;
}

.pb-sephira-admin-modal .admin-modal-detail-list {
    display: grid;
    gap: 8px;
}

.pb-sephira-admin-modal .admin-modal-detail-list > div {
    display: grid;
    grid-template-columns: minmax(112px, auto) minmax(0, 1fr);
    gap: 12px;
    align-items: baseline;
    padding: 8px 0;
    border-top: 1px solid var(--psd-line);
}

.pb-sephira-admin-modal .admin-modal-detail-list > div:first-child {
    border-top: 0;
}

.pb-sephira-admin-modal .admin-modal-detail-list span {
    color: var(--psd-fg-muted);
    font-size: 12px;
}

.pb-sephira-admin-modal .admin-modal-detail-list strong {
    color: var(--psd-fg);
    font-size: 13px;
    font-weight: 600;
    overflow-wrap: anywhere;
}

.pb-sephira-admin-modal .admin-modal-table.mud-table {
    overflow: hidden;
    border: 1px solid var(--psd-line);
    border-radius: 14px;
    background: var(--psd-bg-soft);
}

.pb-sephira-admin-modal .admin-modal-table .mud-table-container,
.pb-sephira-admin-modal .admin-modal-table table,
.pb-sephira-admin-modal .admin-modal-table .mud-table-head,
.pb-sephira-admin-modal .admin-modal-table .mud-table-body {
    background: transparent;
}

.pb-sephira-admin-modal .admin-modal-table .mud-table-cell {
    color: var(--psd-fg);
    border-color: var(--psd-line);
}

.pb-sephira-admin-modal .admin-modal-table .mud-table-head .mud-table-cell {
    color: var(--psd-fg-muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.pb-sephira-admin-modal .admin-modal-table .mud-table-row:hover {
    background: rgba(var(--psd-tone-rgb), 0.08);
}

@media (max-width: 720px) {
    .pb-sephira-admin-modal .admin-modal-field-grid {
        grid-template-columns: 1fr;
    }

    .pb-sephira-admin-modal .psd-preview__row {
        flex-direction: column;
    }

    .pb-sephira-admin-modal .psd-preview__pricewrap {
        text-align: left;
    }
}

@media (max-width: 520px) {
    .pb-sephira-admin-modal .mud-dialog-actions {
        align-items: stretch;
    }

    .pb-sephira-admin-modal .admin-modal-actions,
    .pb-sephira-admin-modal .admin-modal-actions .mud-button-root {
        width: 100%;
    }

    .pb-sephira-admin-modal .admin-modal-actions {
        flex-direction: column-reverse;
    }

    .pb-sephira-admin-modal .admin-modal-detail-list > div {
        grid-template-columns: 1fr;
        gap: 3px;
    }
}

/* ────────────────────────────────────────────────────────────────────
   SEPHIRA — PetShop Dashboard / Agenda / Servicos / Clientes / Equipe
   Estilos específicos para layouts do mockup Sephira (PetShop tenant).
   ──────────────────────────────────────────────────────────────────── */

.pb-shell .pb-sephira-dashboard [data-testid="dashboard-hero"] .mud-typography-h4 {
    font-family: "Times New Roman", Times, serif;
    font-weight: 600;
    letter-spacing: -0.035em;
    line-height: 1.08;
}

.pb-shell .pb-sephira-dashboard .dashboard-sephira-grid {
    display: grid;
    grid-template-columns: minmax(0, 2.1fr) minmax(0, 1fr);
    gap: var(--pb-space-md);
}

@media (max-width: 1100px) {
    .pb-shell .pb-sephira-dashboard .dashboard-sephira-grid {
        grid-template-columns: 1fr;
    }
}

.pb-shell .pb-sephira-dashboard .dashboard-sephira-side {
    display: flex;
    flex-direction: column;
    gap: var(--pb-space-md);
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item {
    display: grid;
    grid-template-columns: 62px 36px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 10px 12px;
    border-radius: var(--pb-radius-md);
    border: 1px solid var(--pb-line);
    background: var(--pb-surface-2);
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__time {
    font-family: "Times New Roman", Times, serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--pb-text);
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__copy {
    min-width: 0;
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__title {
    font-weight: 600;
    font-size: 14px;
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__sep,
.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__client {
    color: var(--pb-text-muted);
    font-weight: 400;
}

.pb-shell .pb-sephira-dashboard .dashboard-agenda-item__svc {
    font-size: 12px;
    color: var(--pb-text-muted);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__row {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    margin-bottom: 6px;
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__name {
    font-weight: 500;
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__count {
    color: var(--pb-text-muted);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__track {
    height: 6px;
    border-radius: 999px;
    background: var(--pb-surface-3);
    overflow: hidden;
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__bar {
    height: 100%;
    border-radius: 999px;
    transition: width var(--pb-transition-base);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__bar.tone-peach {
    background: var(--pb-peach);
    box-shadow: 0 0 12px rgba(255, 154, 108, 0.45);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__bar.tone-gold {
    background: var(--pb-gold);
    box-shadow: 0 0 12px rgba(228, 176, 64, 0.45);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__bar.tone-mint {
    background: var(--pb-mint);
    box-shadow: 0 0 12px rgba(62, 201, 154, 0.45);
}

.pb-shell .pb-sephira-dashboard .dashboard-services-list__bar.tone-coral {
    background: var(--pb-coral);
    box-shadow: 0 0 12px rgba(255, 94, 122, 0.45);
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 13px;
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list span {
    color: var(--pb-text-muted);
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list small {
    color: var(--pb-text-muted);
    font-size: 11px;
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list__icon {
    width: 30px;
    height: 30px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    border: 1px solid rgba(var(--pb-primary-rgb), 0.28);
    color: var(--pb-primary);
    background: rgba(var(--pb-primary-rgb), 0.14);
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list__icon.tone-mint {
    color: var(--pb-mint);
    background: rgba(62, 201, 154, 0.14);
    border-color: rgba(62, 201, 154, 0.30);
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list__icon.tone-peach {
    color: var(--pb-peach);
    background: rgba(255, 154, 108, 0.14);
    border-color: rgba(255, 154, 108, 0.30);
}

.pb-shell .pb-sephira-dashboard .dashboard-activity-list__icon.tone-gold {
    color: var(--pb-gold);
    background: rgba(228, 176, 64, 0.14);
    border-color: rgba(228, 176, 64, 0.30);
}

/* ── Sephira Agenda calendar wrapper (PetShop) ────────────────────── */

.pb-shell .pb-sephira-agenda .cal {
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    overflow: hidden;
    box-shadow: var(--pb-shadow-sm);
}

.pb-shell .pb-sephira-agenda .cal-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

.pb-shell .pb-sephira-agenda .cal-pill-group {
    display: inline-flex;
    border-radius: 100px;
    padding: 4px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
}

.pb-shell .pb-sephira-agenda .cal-pill {
    padding: 6px 14px;
    border-radius: 100px;
    background: transparent;
    color: var(--pb-text-muted);
    font-size: 12px;
    font-weight: 500;
    border: none;
    cursor: pointer;
    transition: background var(--pb-transition-fast), color var(--pb-transition-fast);
}

.pb-shell .pb-sephira-agenda .cal-pill.is-active {
    background: var(--pb-primary);
    color: #fff;
}

.pb-shell .mockup-date-nav {
    display: inline-flex;
}

.pb-shell .mockup-date-nav .btn--icon {
    border-radius: 0;
}

.pb-shell .mockup-date-nav .btn--icon:first-child {
    border-radius: 12px 0 0 12px;
}

.pb-shell .mockup-date-nav .btn--icon:last-child {
    border-radius: 0 12px 12px 0;
}

.pb-shell .mockup-date-nav__today {
    width: auto;
    min-width: 54px;
    padding-inline: 14px;
    font-size: 12px;
    border-left-width: 0;
    border-right-width: 0;
}

.pb-shell .mockup-segmented {
    display: inline-flex;
    border-radius: 100px;
    padding: 4px;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
}

.pb-shell .mockup-segmented button {
    padding: 6px 14px;
    border-radius: 100px;
    background: transparent;
    color: var(--pb-text-muted);
    font-size: 12px;
    font-weight: 500;
    border: 0;
}

.pb-shell .mockup-segmented button.is-active {
    background: var(--pb-primary);
    color: #fff;
}

.pb-shell .cal__now {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--pb-primary);
    box-shadow: 0 0 12px var(--pb-accent-glow);
    z-index: 1;
}

.pb-shell .cal__now span {
    position: absolute;
    left: -6px;
    top: -5px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--pb-primary);
    box-shadow: 0 0 0 3px var(--pb-bg);
}

/* ── Sephira Servicos cards grid (PetShop) ────────────────────────── */

.pb-shell .pb-sephira-servicos .servicos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--pb-space-md);
}

.pb-shell .pb-sephira-servicos .servico-card {
    position: relative;
    background: var(--pb-surface);
    border: 1px solid var(--pb-line);
    border-radius: var(--pb-radius-lg);
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow: hidden;
    transition: border-color var(--pb-transition-base);
    padding-bottom: 0 !important;
}

.pb-shell .pb-sephira-servicos .servico-card:hover {
    border-color: var(--pb-line-strong);
}

.pb-shell .pb-sephira-servicos .servico-card__bar {
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
}

.pb-shell .pb-sephira-servicos .servico-card.tone-peach .servico-card__bar { background: var(--pb-peach); }
.pb-shell .pb-sephira-servicos .servico-card.tone-gold  .servico-card__bar { background: var(--pb-gold); }
.pb-shell .pb-sephira-servicos .servico-card.tone-mint  .servico-card__bar { background: var(--pb-mint); }
.pb-shell .pb-sephira-servicos .servico-card.tone-coral .servico-card__bar { background: var(--pb-coral); }

.pb-shell .pb-sephira-servicos .servico-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.pb-shell .pb-sephira-servicos .servico-card__name {
    font-family: "Times New Roman", Times, serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: var(--pb-text);
}

.pb-shell .pb-sephira-servicos .servico-card__price {
    font-family: "Times New Roman", Times, serif;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: var(--pb-primary);
}

.pb-shell .pb-sephira-servicos .servico-card__price small {
    font-size: 0.55em;
    margin-right: 2px;
    color: var(--pb-primary);
    font-weight: 600;
}

.pb-shell .pb-sephira-servicos .servico-card__meta {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.pb-shell .pb-sephira-servicos .servico-card__desc {
    font-size: 12.5px;
    color: var(--pb-text-muted);
    line-height: 1.5;
}

.pb-shell .pb-sephira-servicos .servico-card__actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 46px;
    gap: 0;
    margin: auto -20px 0;
    padding-top: 0;
    border-top: 1px solid var(--pb-line-soft);
}

.pb-shell .pb-sephira-servicos .servico-card__actions .mud-button-root,
.pb-shell .pb-sephira-servicos .servico-card__actions .mud-icon-button {
    min-height: 44px;
    border-radius: 0;
}

/* ── Sephira PetShop modal content patterns ──────────────────────── */

.pb-sephira-servico-dialog .petshop-customer-dialog-body,
.pb-sephira-servico-dialog .petshop-conversation-dialog-body,
.pb-sephira-servico-dialog .petshop-team-dialog-body {
    padding: 20px 24px;
    gap: 16px;
}

.pb-sephira-servico-dialog .petshop-customer-dialog-section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.pb-sephira-servico-dialog .petshop-customer-dialog-section-head span {
    color: var(--psd-fg-disabled);
    font-size: 12px;
}

.pb-sephira-servico-dialog .petshop-segmented {
    display: inline-flex;
    gap: 4px;
    padding: 4px;
    border: 1px solid var(--psd-line);
    border-radius: 999px;
    background: var(--psd-bg-soft);
}

.pb-sephira-servico-dialog .petshop-segmented__option {
    border: 0;
    border-radius: 999px;
    padding: 8px 14px;
    background: transparent;
    color: var(--psd-fg-muted);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background 160ms var(--psd-ease), color 160ms var(--psd-ease);
}

.pb-sephira-servico-dialog .petshop-segmented__option.is-on {
    background: var(--psd-primary);
    color: #fff;
}

.pb-sephira-servico-dialog .petshop-template-grid,
.pb-sephira-servico-dialog .petshop-check-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.pb-sephira-servico-dialog .petshop-template-card,
.pb-sephira-servico-dialog .petshop-check-card {
    border: 1px solid var(--psd-line-strong);
    border-radius: 14px;
    background: var(--psd-bg-soft);
    color: var(--psd-fg-muted);
    padding: 12px;
    cursor: pointer;
    transition: border-color 160ms var(--psd-ease), background 160ms var(--psd-ease), color 160ms var(--psd-ease);
}

.pb-sephira-servico-dialog .petshop-template-card {
    text-align: left;
}

.pb-sephira-servico-dialog .petshop-template-card span,
.pb-sephira-servico-dialog .petshop-check-card span {
    display: block;
    color: var(--psd-fg);
    font-size: 13px;
    font-weight: 600;
}

.pb-sephira-servico-dialog .petshop-template-card small {
    display: block;
    margin-top: 4px;
    color: var(--psd-fg-disabled);
    font-size: 11px;
}

.pb-sephira-servico-dialog .petshop-template-card.is-on,
.pb-sephira-servico-dialog .petshop-check-card.is-on {
    border-color: rgba(var(--psd-tone-rgb), 0.50);
    background: rgba(var(--psd-tone-rgb), 0.12);
}

.pb-sephira-servico-dialog .petshop-check-card {
    display: flex;
    align-items: center;
    gap: 6px;
}

.pb-sephira-servico-dialog .petshop-message-preview {
    margin: 10px 0 0;
    color: var(--psd-fg);
    font-size: 13px;
    line-height: 1.5;
}

@media (max-width: 720px) {
    .pb-sephira-servico-dialog .petshop-customer-dialog-body,
    .pb-sephira-servico-dialog .petshop-conversation-dialog-body,
    .pb-sephira-servico-dialog .petshop-team-dialog-body {
        padding: 18px;
    }

    .pb-sephira-servico-dialog .petshop-template-grid,
    .pb-sephira-servico-dialog .petshop-check-grid {
        grid-template-columns: 1fr;
    }

    .pb-sephira-servico-dialog .petshop-customer-dialog-section-head {
        flex-direction: column;
        gap: 4px;
    }
}

.pb-shell .clientes-pet-chip-row {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.pb-shell .clientes-pet-chip-row .chip span:not(.avatar) {
    color: var(--pb-text-muted);
    font-size: 11px;
}

.pb-shell .clientes-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 16px;
}

.pb-shell .clientes-detail-heading,
.pb-shell .clientes-detail-actions {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.pb-shell .clientes-metric-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-bottom: 18px;
}

.pb-shell .clientes-metric {
    padding: 14px;
    border-radius: var(--pb-radius-md);
}

.pb-shell .clientes-metric span {
    display: block;
    font-size: 11px;
    color: var(--pb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.10em;
    font-weight: 600;
}

.pb-shell .clientes-metric strong {
    display: block;
    margin-top: 4px;
    font-family: "Times New Roman", Times, serif;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.pb-shell .clientes-metric .tone-peach { color: var(--pb-peach); }
.pb-shell .clientes-metric .tone-mint { color: var(--pb-mint); }

.pb-shell .clientes-detail-pets {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
}

.pb-shell .clientes-detail-pet-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: var(--pb-radius-md);
    border: 1px solid var(--pb-line);
    background: var(--pb-surface-2);
}

.pb-shell .clientes-detail-pet-card strong,
.pb-shell .clientes-detail-pet-card span {
    display: block;
}

.pb-shell .clientes-detail-pet-card span {
    color: var(--pb-text-muted);
    font-size: 12px;
}

.pb-shell .clientes-history-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding-left: 0;
    margin: 0;
}

.pb-shell .clientes-history-list li {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    list-style: none;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--pb-line);
}

.pb-shell .clientes-history-list li > span {
    font-size: 11px;
    color: var(--pb-text-muted);
    width: 50px;
    padding-top: 2px;
}

.pb-shell .clientes-history-list div {
    flex: 1;
}

.pb-shell .clientes-history-list small {
    display: block;
    font-size: 12px;
    color: var(--pb-text-muted);
}

@media (max-width: 900px) {
    .pb-shell .clientes-detail-grid,
    .pb-shell .clientes-metric-grid {
        grid-template-columns: 1fr;
    }
}
