/**
 * Salesbooth Admin - Core App Styles
 * Layout rules based on presentation mode:
 * - Browser (layout-browser): Any device in browser — uses sidebar navigation
 * - App (layout-app): Standalone/PWA on tablet or mobile — uses bottom tab bar
 */

:root {
    --f7-searchbar-height: 0px;
    --f7-searchbar-input-border-radius:6px;
    --f7-searchbar-input-bg-color: #f5f6f8;
    --f7-searchbar-input-font-size: 14px;
    --f7-searchbar-input-border-color: transparent;

    --f7-glass-shadow: 0 0 0 1px var(--sb-border-color);
    --f7-glass-shadow-thumb: 0 0 0 1px var(--sb-border-color);
    --f7-navbar-bg-color: var(--sb-bg-card, #fff);

    /* Salesbooth Theme Colors - Light Mode */
    --f7-page-bg-color: #fff;
    --sb-text-primary: #1a1f36;
    --sb-text-secondary: #3c4257;
    --sb-text-muted: #697386;
    --sb-bg-page: #fff;
    --sb-bg-card: #fff;
    --sb-bg-elevated: #fff;
    --sb-bg-hover: #f6f9fc;
    --sb-bg-input: #fff;
    --sb-border-color: #e3e8ee;
    --sb-border-hover: #c4c9d4;
    --sb-primary: #0071e3;
    --sb-primary-hover: #0076DF;
    --sb-primary-gradient: #007fff;
    --sb-primary-tint: rgba(0, 113, 227, 0.08);
    --sb-primary-subtle: rgba(0, 113, 227, 0.02);
    --sb-row-hover: #f9fafb;
    --sb-empty-bg: #f6f9fc;
    --sb-danger: #ef4444;
    --sb-success: #10b981;
    --sb-success-text: #047857;
    --sb-success-bg: rgba(4, 120, 87, 0.1);
    --sb-warning: #f59e0b;

    /* ─── F7 Theme Integration ─────────────────────────────────────────── */
    /* Map Salesbooth brand to F7's theme system so all F7 components      */
    /* (buttons, toggles, dialogs, cards) automatically use our palette.   */
    --f7-theme-color: var(--sb-primary);
    --f7-theme-color-rgb: 0, 113, 227;
    --f7-theme-color-shade: var(--sb-primary-hover);
    --f7-theme-color-tint: var(--sb-primary-gradient);
    --f7-card-bg-color: var(--sb-bg-card);
    --f7-card-border-radius: 8px;
    --f7-card-box-shadow: none;
    --f7-card-border-color: var(--sb-border-color);
    --f7-list-bg-color: var(--sb-bg-card);
    --f7-list-border-color: var(--sb-border-color);
    --f7-block-strong-bg-color: var(--sb-bg-card);
    --f7-input-bg-color: var(--sb-bg-input);
    --f7-text-color: var(--sb-text-primary);
    --f7-list-item-title-text-color: var(--sb-text-primary);
    --f7-list-item-text-text-color: var(--sb-text-muted);
    --f7-list-item-after-text-color: var(--sb-text-muted);
    --f7-button-fill-bg-color: var(--sb-primary);
    --f7-button-outline-border-color: var(--sb-border-color);
    --f7-button-border-radius: 6px;
    --f7-button-font-size: 14px;
    --f7-button-font-weight: 500;
    --f7-toggle-active-color: var(--sb-primary);
    --f7-dialog-border-radius: 12px;
    --f7-popup-border-radius: 12px;
    --f7-sheet-border-radius: 12px 12px 0 0;
    --f7-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* F7 card border (F7 cards use box-shadow, we want a clean 1px border) */
.card {
    border: 1px solid var(--sb-border-color);
}

/* F7 button styling overrides to match Salesbooth design */
.button.button-fill {
    --f7-button-fill-bg-color: var(--sb-primary);
    color: #fff;
}
.button.button-outline {
    --f7-button-outline-border-color: var(--sb-border-color);
    color: var(--sb-text-secondary);
}
.button.color-red {
    --f7-button-fill-bg-color: var(--sb-danger);
}

.ios {
    --f7-ios-primary: #0071e3;
    --f7-tabbar-link-inactive-color: #8b8d98;
    --f7-tabbar-link-active-color: #000;
    --f7-ios-primary-shade: #0076DF;
    --f7-ios-primary-tint: #4da3ff;
    --f7-ios-primary-rgb: 0, 113, 227;
    --f7-popover-border-radius: 12px;
    --f7-dialog-border-radius: 12px;
    --f7-tabbar-label-font-size: 8px;
}

.dark {
    /* Salesbooth Theme Colors - Dark Mode */
    --f7-tabbar-link-active-color: #fff;
    --sb-text-primary: #f0f0f3;
    --sb-text-secondary: #c1c4cc;
    --sb-text-muted: #8b8d98;
    --sb-bg-page: #0d0d0f;
    --sb-bg-card: #1a1a1f;
    --sb-bg-elevated: #232329;
    --sb-bg-hover: #2a2a32;
    --sb-bg-input: #232329;
    --sb-border-color: #2e2e38;
    --sb-border-hover: #3e3e4a;
    --sb-primary: #4da3ff;
    --sb-primary-hover: #66b3ff;
    --sb-primary-gradient: #5aadff;
    --sb-primary-tint: rgba(77, 163, 255, 0.15);
    --sb-primary-subtle: rgba(77, 163, 255, 0.05);
    --sb-row-hover: #232329;
    --sb-empty-bg: #1a1a1f;
    --sb-danger: #f87171;
    --sb-success: #34d399;
    --sb-success-text: #34d399;
    --sb-success-bg: rgba(52, 211, 153, 0.1);
    --sb-warning: #fbbf24;

    --f7-searchbar-input-bg-color: #232329;
}

.dark body, body.dark {
    --f7-page-bg-color: var(--sb-bg-page);
    --f7-card-bg-color: var(--sb-bg-page);
    --f7-table-selected-row-bg-color: var(--sb-bg-hover);
}

.ios .fab-buttons a, .ios .fab>a {
    box-shadow: none;
}
.fab-assistant {
    background: var(--sb-primary) !important;
    color: #fff !important;
}
.ios .navbar .left a+a, .ios .navbar .right a+a {
    margin-left: 0px;
}

.ios .navbar a:is(.icon-only,:has(i:only-child),:has(svg:only-child)) {
    width: auto;
}

.ios .tab-link-highlight:before {
    background-color: transparent;
    border: 1px solid var(--sb-border-color);
}

.navbar .right .icon {
    font-size: 16px;
}
.button {
    border-radius: 12px;
}
.btn-add {
    background: var(--sb-primary);
    border-radius: 50%;
    color: #fff !important;
    width: 22px !important;
    height: 22px !important;
    padding: 0px !important;
}

.btn-add .icon {
    font-size: 16px;
    font-weight: bold;
}

.navbar .btn-primary {
    border-radius: 50%;
    color: #fff !important;
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
}

.navbar .btn-primary .icon {
    font-size: 16px !important;
    color: #fff !important;
    font-weight: 600;
}

.layout-app .navbar .btn-primary .icon {
    color: var(--f7-navbar-link-color,var(--f7-bars-link-color,var(--f7-theme-color))) !important;
}

/* Minimum 44×44px touch targets for navbar icon buttons (Apple HIG / WCAG 2.5.5) */
.navbar .link.icon-only {
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Extend circular create button tap area without changing its visual size */
.navbar .btn-primary {
    position: relative;
    overflow: visible;
}
.navbar .btn-primary::before {
    content: '';
    position: absolute;
    inset: -9px;
}

.icons .link i+span, .ios .tabbar-icons .tab-link i+span {
margin: 3px 0 0;
}

/* Global Tenant Logo (app mode - in global toolbar) */
.global-tenant-logo {
    width: 40px;
    height: 40px;
    min-width: 44px;
    min-height: 44px;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    z-index: 99;
    border-radius: 10px;
    color: #fff;
}

.global-tenant-logo .tenant-icon {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
}

.global-tenant-logo .tenant-icon-initials {
    font-size: 16px;
}

/* Tenant Switch Splash Screen (app mode) */
.tenant-splash {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.tenant-splash.active {
    opacity: 1;
    visibility: visible;
}

.tenant-splash-content {
    text-align: center;
}

.tenant-splash-name {
    font-size: 32px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.5px;
}

/* =============================================
   Browser Mode (layout-browser) - Sidebar Nav
   ============================================= */

/* Hide tab bar in browser mode */
body.layout-browser #main-tabbar {
    display: none !important;
}

/* =============================================
   App Mode (layout-app) - Tab Bar Nav
   ============================================= */

/* Hide sidebar in app mode */
body.layout-app #sidebar-panel {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

/* Hide panel backdrop in app mode */
body.layout-app .panel-backdrop {
    display: none !important;
}



/* Allow hiding tabbar on specific pages (e.g., login) */
body.layout-app #main-tabbar.tabbar-hidden {
    display: none !important;
}



/* Hide browser bottom bar in app mode */
body.layout-app .browser-bottom-bar {
    display: none !important;
}

/* Global toolbar safe area for app mode */
body.layout-app .global-toolbar {
    padding-top: env(safe-area-inset-top, 0px);
    max-width: calc(100vw - 80px);
}

/* Navbar safe area for app mode (PWA standalone) — ensures navbar content
   clears the device notch/status bar when viewport-fit=cover is active.
   .navbar gets padding-top to extend the background behind the status bar.
   .navbar-inner gets top offset so the actual buttons/title clear the status bar
   (navbar-inner is position:absolute within navbar so padding-top alone is
   insufficient — it must have an explicit top offset). */
body.layout-app .navbar {
    padding-top: env(safe-area-inset-top, 0px);
}
body.layout-app .navbar .navbar-inner {
    top: env(safe-area-inset-top, 0px);
}

.global-toolbar {
    display: flex;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    margin-top: 2.5rem;
    padding-left: 2.5rem;
    position: relative;
    z-index: 99;
    background: var(--f7-page-bg-color);
}

/* App mode: animate global searchbar visibility based on page transitions (tenant logo always visible) */
body.layout-app .global-toolbar .global-searchbar {
    opacity: 0;
    transform: translateX(-20px);
    pointer-events: none;
    transition: opacity 400ms var(--f7-page-transition-timing-function, ease),
                transform 400ms var(--f7-page-transition-timing-function, ease);
}

.global-searchbar {
    max-width: 480px;
}

@media (max-width: 959px) {
    .global-toolbar {
        margin-left: 0rem;
        padding-left: 1rem;
        margin-top: 1rem;
    }
}

.global-searchbar input {
    box-shadow: none !important;
}

/* Global Search Results Dropdown */
.global-search-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--f7-page-bg-color, #fff);
    border: 1px solid var(--sb-border-color, #e5e7eb);
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    max-height: 400px;
    overflow-y: auto;
    z-index: 15000;
    display: none;
    margin-top: 24px;
}

.global-search-results.active {
    display: block;
}

.search-result-item {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    cursor: pointer;
    transition: background-color 0.15s;
    text-decoration: none;
    color: inherit;
}

.search-result-item:hover,
.search-result-item.highlighted {
    background: var(--f7-list-bg-color, #f7f7f8);
}

.search-result-item + .search-result-item {
    border-top: 1px solid var(--sb-border-color, #e5e7eb);
}

.search-result-icon {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    flex-shrink: 0;
}

.search-result-icon.type-customer {
    background: #dbeafe;
    color: #2563eb;
}

.search-result-icon.type-product {
    background: #dcfce7;
    color: #16a34a;
}

.search-result-icon.type-deal {
    background: #fef3c7;
    color: #d97706;
}

.search-result-icon.type-contract {
    background: #e8f4fd;
    color: #0071e3;
}

.search-result-icon i {
    font-size: 16px;
}

.search-result-content {
    flex: 1;
    min-width: 0;
}

.search-result-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary, #111827);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-result-subtitle {
    font-size: 12px;
    color: var(--sb-text-muted, #9ca3af);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}

.search-result-type {
    font-size: 11px;
    color: var(--sb-text-muted, #9ca3af);
    text-transform: capitalize;
    margin-left: 12px;
    flex-shrink: 0;
}

.search-no-results {
    padding: 20px;
    text-align: center;
    color: var(--sb-text-muted, #9ca3af);
    font-size: 13px;
}

.search-loading {
    padding: 20px;
    text-align: center;
}

/* Position container for dropdown */
.global-searchbar {
    position: relative;
}

/* App mode: Show global searchbar on list and dashboard pages (when NOT transitioning) */
body.layout-app .view-main:not(.router-transition-forward):not(.router-transition-backward):has(.page-current.page-list) .global-toolbar .global-searchbar,
body.layout-app .view-main:not(.router-transition-forward):not(.router-transition-backward):has(.page-current.page-dashboard) .global-toolbar .global-searchbar {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

/* App mode: During forward transition - show searchbar only if going TO a list/dashboard page */
body.layout-app .view-main.router-transition-forward:has(.page-next.page-list) .global-toolbar .global-searchbar,
body.layout-app .view-main.router-transition-forward:has(.page-next.page-dashboard) .global-toolbar .global-searchbar {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

/* App mode: During backward transition - show searchbar only if going back TO a list/dashboard page */
body.layout-app .view-main.router-transition-backward:has(.page-previous.page-list) .global-toolbar .global-searchbar,
body.layout-app .view-main.router-transition-backward:has(.page-previous.page-dashboard) .global-toolbar .global-searchbar {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

/* Hide global toolbar on auth pages */
.view-main:has(.page-current.auth-page) .global-toolbar {
    display: none !important;
}

/* App mode: Hide entire global toolbar on form pages — saves vertical space on mobile and
   removes the empty search/notification row (both logo and searchbar are already non-functional
   on form pages; the F7 navbar provides back+save navigation instead) */
body.layout-app .view-main:has(.page-current.page-form) .global-toolbar {
    display: none;
}

/* Browser mode: Hide global search bar on form pages — search is non-contextual on creation/edit forms */
body.layout-browser .view-main:has(.page-current.page-form) .global-toolbar .global-searchbar {
    display: none;
}

/* App mode: Hide tenant logo on website sub-pages (pages list, blocks list) to prevent overlap
   with the back button in the navbar left slot. These are child pages within the website section
   where the F7 navbar is the primary navigation element. */
body.layout-app .view-main:has(.page-current[data-name="website-pages"]) .global-toolbar .global-tenant-logo,
body.layout-app .view-main:has(.page-current[data-name="website-blocks"]) .global-toolbar .global-tenant-logo {
    display: none;
}

.navbar-inner {
    left: 0;
    right: 0;
    max-width: 1200px;
    margin: 0 auto;
}

@media (min-width: 960px) {
    body.layout-browser .view-main:not(:has(.page-form)) .navbar-inner .left {
        display: none;
    }
}

.page-wrapper {
    padding: 0;
    max-width: 1200px;
    margin: 0 auto;
}

.page-form .page-wrapper {
    max-width: 760px;
}

.page-wrapper section {
    padding: 0rem 24px;
    margin-bottom: 32px;
}

/* =============================================
   Auth Pages - InfrastructureLike-inspired Design
   (Login, Sign Up, Forgot Password, etc.)
   ============================================= */
.page.auth-page {
    --auth-primary: var(--sb-primary);
    --auth-primary-hover: var(--sb-primary-hover);
    --auth-text: var(--sb-text-secondary);
    --auth-text-muted: var(--sb-text-muted);
    --auth-border: var(--sb-border-color);
    --auth-bg: var(--sb-bg-page);
    --auth-input-bg: var(--sb-bg-input);
    --auth-card-bg: var(--sb-bg-card);
    --auth-surface: var(--sb-bg-hover);
    background: transparent !important;
}

.page.auth-page .auth-background {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(120, 119, 198, 0.3) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(255, 119, 198, 0.25) 0%, transparent 40%),
        radial-gradient(ellipse at 60% 80%, rgba(255, 179, 71, 0.2) 0%, transparent 40%),
        radial-gradient(ellipse at 90% 60%, rgba(255, 99, 198, 0.3) 0%, transparent 35%),
        linear-gradient(180deg, #f6f9fc 0%, #eef2f7 100%);
    z-index: 0;
}

.dark .page.auth-page .auth-background {
    background:
        radial-gradient(ellipse at 20% 50%, rgba(0, 113, 227, 0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(0, 113, 227, 0.12) 0%, transparent 40%),
        radial-gradient(ellipse at 60% 80%, rgba(59, 130, 246, 0.1) 0%, transparent 40%),
        radial-gradient(ellipse at 90% 60%, rgba(236, 72, 153, 0.12) 0%, transparent 35%),
        linear-gradient(180deg, #0d0d0f 0%, #131318 100%);
}

.page.auth-page .page-content.auth-page-content {
    position: relative;
    z-index: 1;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100% !important;
    padding: 40px 20px !important;
    box-sizing: border-box;
    background: transparent !important;
}

.page.auth-page .auth-card {
    width: 100%;
    max-width: 400px;
    background: var(--auth-card-bg);
    border-radius: 8px;
    box-shadow:
        0 2px 4px rgba(0, 0, 0, 0.05),
        0 4px 12px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    border: 1px solid transparent;
}

.dark .page.auth-page .auth-card {
    border-color: var(--auth-border);
    box-shadow:
        0 2px 4px rgba(0, 0, 0, 0.2),
        0 4px 12px rgba(0, 0, 0, 0.3);
}

.page.auth-page .auth-card-content {
    padding: 40px 40px 32px;
}

.page.auth-page .auth-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 32px;
}

.page.auth-page .auth-logo-img {
    width: 36px;
    height: 36px;
    object-fit: contain;
    border-radius: 8px;
}

.page.auth-page .auth-logo-text {
    font-size: 22px;
    font-weight: 700;
    color: var(--sb-text-primary);
    letter-spacing: -0.3px;
}

.page.auth-page .auth-title {
    font-size: 24px !important;
    font-weight: 600 !important;
    color: var(--sb-text-primary) !important;
    margin: 0 0 28px 0 !important;
    text-align: left;
}

.page.auth-page .auth-form-group {
    margin-bottom: 20px;
}

.page.auth-page .auth-form-row {
    display: flex;
    gap: 12px;
}

.page.auth-page .auth-form-row .auth-form-group {
    flex: 1;
}

.page.auth-page .auth-label-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}

.page.auth-page .auth-label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--auth-text);
    margin-bottom: 8px;
}

.page.auth-page .auth-link {
    font-size: 13px;
    font-weight: 400;
    color: var(--sb-primary, #0071e3);
    text-decoration: none;
    margin-bottom: 8px;
}

.page.auth-page .auth-link:hover {
    text-decoration: underline;
}

.page.auth-page .auth-input {
    width: 100% !important;
    height: 44px !important;
    padding: 0 12px !important;
    font-size: 16px !important;
    color: var(--auth-text) !important;
    background: var(--auth-input-bg) !important;
    border: 1px solid var(--auth-border) !important;
    border-radius: 6px !important;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}

.page.auth-page .auth-input:focus {
    border-color: var(--auth-primary) !important;
    box-shadow: 0 0 0 3px var(--sb-primary-tint) !important;
}

/* F7 list overrides for auth page — maintains visual design while using F7 structure */
.page.auth-page .list {
    margin: 0 0 20px !important;
    background: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.page.auth-page .list::before,
.page.auth-page .list::after,
.page.auth-page .list ul::before,
.page.auth-page .list ul::after {
    display: none !important;
}

.page.auth-page .list ul {
    background: none !important;
}

.page.auth-page .list .item-content.item-input {
    min-height: auto !important;
    padding: 0 !important;
    margin-bottom: 20px;
}

.page.auth-page .list .item-content.item-input:last-child {
    margin-bottom: 0;
}

.page.auth-page .list .item-inner {
    padding: 0 !important;
    min-height: auto !important;
}

.page.auth-page .list .item-inner::after {
    display: none !important;
}

.page.auth-page .list .item-title.item-label {
    display: block;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--auth-text) !important;
    margin-bottom: 8px;
    max-width: none !important;
    padding: 0 !important;
    width: 100%;
    white-space: normal;
    transform: none !important;
}

.page.auth-page .list .item-title.item-label.auth-label-row {
    display: flex !important;
    justify-content: space-between;
    align-items: baseline;
}

.page.auth-page .list .item-input-wrap {
    padding: 0 !important;
    width: 100%;
}

.page.auth-page .list .item-input-wrap input {
    width: 100% !important;
    height: 44px !important;
    padding: 0 12px !important;
    font-size: 16px !important;
    color: var(--auth-text) !important;
    background: var(--auth-input-bg) !important;
    border: 1px solid var(--auth-border) !important;
    border-radius: 6px !important;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    box-sizing: border-box !important;
    box-shadow: none !important;
    -webkit-appearance: none;
    appearance: none;
    margin: 0 !important;
}

.page.auth-page .list .item-input-wrap input:focus {
    border-color: var(--auth-primary) !important;
    box-shadow: 0 0 0 3px var(--sb-primary-tint) !important;
}

.page.auth-page .auth-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 10px;
    margin-bottom: 24px;
    cursor: pointer;
    user-select: none;
}

.page.auth-page .auth-checkbox input {
    display: none !important;
}

.page.auth-page .auth-checkbox-box {
    width: 18px;
    height: 18px;
    border: 2px solid var(--auth-border);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
    flex-shrink: 0;
    background: var(--auth-input-bg);
}

.page.auth-page .auth-checkbox input:checked + .auth-checkbox-box {
    background: var(--auth-primary);
    border-color: var(--auth-primary);
}

.page.auth-page .auth-checkbox input:checked + .auth-checkbox-box::after {
    content: '';
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-bottom: 2px;
}

.page.auth-page .auth-checkbox-label {
    font-size: 14px;
    color: var(--auth-text);
}

.page.auth-page .auth-button {
    width: 100% !important;
    height: 44px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
    cursor: pointer;
    transition: all 0.15s ease;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px;
    border: none !important;
    box-sizing: border-box;
    font-family: inherit;
}

.page.auth-page .auth-button.auth-button-primary {
    background: var(--auth-primary) !important;
    color: #fff !important;
}

.page.auth-page .auth-button.auth-button-primary:hover {
    background: var(--auth-primary-hover) !important;
}

.page.auth-page .auth-button.auth-button-primary:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

.page.auth-page .auth-button.auth-button-outline {
    background: var(--auth-card-bg) !important;
    color: var(--auth-text) !important;
    border: 1px solid var(--auth-border) !important;
    margin-top: 12px;
}

.page.auth-page .auth-button.auth-button-outline:hover {
    background: var(--auth-surface) !important;
}

.page.auth-page .auth-btn-icon {
    flex-shrink: 0;
}

.page.auth-page .auth-divider {
    display: flex;
    align-items: center;
    margin: 20px 0;
    gap: 12px;
}

.page.auth-page .auth-divider::before,
.page.auth-page .auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--sb-border-color, #e3e8ee);
}

.page.auth-page .auth-divider span {
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted, #697386);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.page.auth-page .auth-card-footer {
    background: var(--auth-surface);
    padding: 16px 40px;
    text-align: center;
    font-size: 14px;
    color: var(--auth-text-muted);
    border-top: 1px solid var(--auth-border);
}

.page.auth-page .auth-card-footer a {
    color: var(--auth-primary);
    text-decoration: none;
    margin-left: 4px;
}

.page.auth-page .auth-card-footer a:hover {
    text-decoration: underline;
}

.page.auth-page .auth-terms {
    font-size: 12px;
    color: var(--auth-text-muted);
    text-align: center;
    margin-top: 16px;
    line-height: 1.5;
}

.page.auth-page .auth-terms a {
    color: var(--auth-primary);
    text-decoration: none;
}

.page.auth-page .auth-terms a:hover {
    text-decoration: underline;
}

/* Auth page - override tabbar padding (auth pages don't have tabbar) */
body.layout-app .page.auth-page .page-content.auth-page-content {
    padding-bottom: 40px !important;
    padding-bottom: calc(40px + env(safe-area-inset-bottom, 0px)) !important;
}

/* Auth page - proper mobile viewport height */
.page.auth-page .page-content.auth-page-content {
    min-height: 100vh !important;
    min-height: 100dvh !important; /* Dynamic viewport height for mobile */
    padding-top: calc(40px + env(safe-area-inset-top, 0px)) !important;
    padding-bottom: calc(40px + env(safe-area-inset-bottom, 0px)) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
}

/* Mobile adjustments */
@media (max-width: 480px) {

    .layout-browser .page {
        margin-top: 30px;
    }
    .global-searchbar {
        max-width: calc(100vw - 2rem);
    }
    .page.auth-page .page-content.auth-page-content {
        padding: 20px 16px !important;
        padding-top: calc(20px + env(safe-area-inset-top, 0px)) !important;
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
        align-items: flex-start !important;
    }

    .page.auth-page .auth-card {
        margin-top: 20px;
        border-radius: 12px;
    }

    .page.auth-page .auth-card-content {
        padding: 32px 24px 24px;
    }

    .page.auth-page .auth-card-footer {
        padding: 16px 24px;
    }

    .page.auth-page .auth-title {
        font-size: 22px !important;
    }

    .page.auth-page .auth-form-row {
        flex-direction: column;
        gap: 0;
    }
}

/* =============================================
   Tenant Selector Page
   ============================================= */
.page.auth-page .auth-subtitle {
    color: var(--auth-text-muted);
    font-size: 14px;
    margin: 0 0 24px 0;
    line-height: 1.5;
    text-align: center;
}

.page.auth-page .tenant-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.page.auth-page .tenant-item {
    display: flex;
    align-items: center;
    padding: 16px;
    background: var(--auth-surface);
    border: 1px solid var(--auth-border);
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.page.auth-page .tenant-item:hover {
    background: var(--auth-card-bg);
    border-color: var(--auth-primary);
    box-shadow: 0 2px 8px rgba(0, 113, 227, 0.1);
}

.dark .page.auth-page .tenant-item:hover {
    box-shadow: 0 2px 8px rgba(77, 163, 255, 0.15);
}

.page.auth-page .tenant-item:active {
    transform: scale(0.98);
}

.page.auth-page .tenant-item-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--auth-primary), var(--sb-primary-gradient));
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    flex-shrink: 0;
    margin-right: 14px;
}

.page.auth-page .tenant-item-info {
    flex: 1;
    min-width: 0;
}

.page.auth-page .tenant-item-name {
    font-weight: 600;
    color: var(--sb-text-primary);
    font-size: 15px;
    line-height: 1.3;
    margin-bottom: 2px;
}

.page.auth-page .tenant-item-role {
    font-size: 13px;
    color: var(--auth-text-muted);
    text-transform: capitalize;
}

.page.auth-page .tenant-item-arrow {
    color: var(--auth-text-muted);
    margin-left: 8px;
}

.page.auth-page .tenant-item:hover .tenant-item-arrow {
    color: var(--auth-primary);
}

/* Tenant list loading state */
.page.auth-page .tenant-list.loading {
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page.auth-page .tenant-list.loading::after {
    content: '';
    width: 32px;
    height: 32px;
    border: 3px solid var(--auth-border);
    border-top-color: var(--auth-primary);
    border-radius: 50%;
    animation: tenant-spin 0.8s linear infinite;
}

@keyframes tenant-spin {
    to { transform: rotate(360deg); }
}

/* =============================================
   Reusable Multi-Step Wizard
   Use .wizard-page on a .page element to enable wizard styles.
   Steps should have .wizard-step with data-step="N" attributes.
   ============================================= */

/* Override framework7-root height restriction for wizard pages */
body.layout-browser:has(.wizard-page) .framework7-root {
    max-height: none;
}

.page.wizard-page .page-content {
    position: relative;
    z-index: 1;
    display: flex !important;
    flex-direction: column !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
    padding: 0 !important;
    background: transparent !important;
}


/* App mode: Use absolute positioning for auth-background in wizard pages to fix transition issues */
body.layout-app .page.wizard-page .auth-background {
    position: absolute;
}

body.layout-app .page.wizard-page .page-content {
    padding-left: env(safe-area-inset-left, 0px) !important;
    padding-right: env(safe-area-inset-right, 0px) !important;
    width: 100%;
    max-width: 100vw;
    box-sizing: border-box;
    overflow-x: hidden;
}

/* Wizard Header */
.page.wizard-page .wizard-header {
    position: sticky;
    top: 0;
    padding: 20px 24px;
    padding-top: calc(20px + env(safe-area-inset-top, 0px));
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--auth-border);
    z-index: 10;
}

.dark .page.wizard-page .wizard-header {
    background: rgba(26, 26, 31, 0.95);
}

.page.wizard-page .wizard-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

/* Tenant Info in Wizard Header (for import wizard) */
.page.wizard-page .wizard-tenant-info {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.page.wizard-page .wizard-tenant-logo {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.page.wizard-page .wizard-tenant-logo .tenant-icon {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
}

.page.wizard-page .wizard-tenant-logo .tenant-icon-initials {
    font-size: 16px;
}

.page.wizard-page .wizard-tenant-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.page.wizard-page .wizard-progress {
    display: flex;
    align-items: center;
    gap: 16px;
}

.page.wizard-page .progress-bar {
    flex: 1;
    height: 4px;
    background: var(--auth-border);
    border-radius: 2px;
    overflow: hidden;
}

.page.wizard-page .progress-fill {
    height: 100%;
    background: var(--auth-primary);
    border-radius: 2px;
    transition: width 0.3s ease;
}

.page.wizard-page .progress-text {
    font-size: 13px;
    color: var(--auth-text-muted);
    white-space: nowrap;
}

/* Wizard Steps Container */
.page.wizard-page .wizard-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 40px 24px;
    overflow-y: auto;
}

.page.wizard-page .wizard-step {
    width: 100%;
    max-width: 480px;
    display: none;
}

.page.wizard-page .wizard-step.step-active {
    display: block !important;
    animation: wizardStepFadeIn 0.3s ease;
}

.page.wizard-page .wizard-step.step-skip {
    display: none !important;
}

@keyframes wizardStepFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.page.wizard-page .step-content {
    background: var(--auth-card-bg);
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border: 1px solid transparent;
}

.dark .page.wizard-page .step-content {
    border-color: var(--auth-border);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.page.wizard-page .step-title {
    font-size: 24px !important;
    font-weight: 600 !important;
    color: var(--sb-text-primary) !important;
    margin: 0 0 8px 0 !important;
    text-align: center;
}

.page.wizard-page .step-subtitle {
    font-size: 15px;
    color: var(--auth-text-muted);
    text-align: center;
    margin: 0 0 28px 0;
}

.page.wizard-page .step-form {
    margin-top: 0;
}

/* Wizard Option Grid (e.g., industry selection) */
.page.wizard-page .option-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

.page.wizard-page .option-item {
    cursor: pointer;
}

.page.wizard-page .option-item input {
    display: none;
}

.page.wizard-page .option-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px 16px;
    background: var(--auth-surface);
    border: 2px solid var(--auth-border);
    border-radius: 12px;
    transition: all 0.2s ease;
}

.page.wizard-page .option-item input:checked + .option-card {
    border-color: var(--auth-primary);
    background: var(--sb-primary-subtle);
}

.page.wizard-page .option-item:hover .option-card {
    border-color: var(--auth-primary);
}

.page.wizard-page .option-icon {
    font-size: 28px;
    margin-bottom: 8px;
}

.page.wizard-page .option-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--auth-text);
    text-align: center;
}

.page.wizard-page .option-custom-group {
    margin-top: 12px;
}

/* Wizard Repeatable Item List (e.g., services) */
.page.wizard-page .repeatable-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-bottom: 20px;
}

.page.wizard-page .repeatable-item {
    background: var(--auth-surface);
    border: 1px solid var(--auth-border);
    border-radius: 12px;
    padding: 20px;
}

.page.wizard-page .repeatable-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.page.wizard-page .repeatable-number {
    font-size: 13px;
    font-weight: 600;
    color: var(--auth-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.page.wizard-page .repeatable-remove {
    font-size: 13px;
    color: #dc2626;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 8px;
}

.page.wizard-page .repeatable-remove:hover {
    text-decoration: underline;
}

.page.wizard-page .add-repeatable-btn {
    width: 100%;
    padding: 14px;
    background: none;
    border: 2px dashed var(--auth-border);
    border-radius: 12px;
    color: var(--auth-text-muted);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.page.wizard-page .add-repeatable-btn:hover {
    border-color: var(--auth-primary);
    color: var(--auth-primary);
}

.page.wizard-page .add-icon {
    font-size: 18px;
}

/* Wizard Slider Selector (e.g., deposit percentage) */
.page.wizard-page .slider-selector {
    text-align: center;
    padding: 20px 0;
}

.page.wizard-page .slider-value {
    display: flex;
    align-items: baseline;
    justify-content: center;
    margin-bottom: 24px;
}

.page.wizard-page .slider-number {
    font-size: 64px;
    font-weight: 700;
    color: var(--auth-primary);
    line-height: 1;
}

.page.wizard-page .slider-suffix {
    font-size: 32px;
    font-weight: 600;
    color: var(--auth-text-muted);
    margin-left: 4px;
}

.page.wizard-page .wizard-slider {
    width: 100%;
    height: 8px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--auth-border);
    border-radius: 4px;
    outline: none;
    margin-bottom: 12px;
}

.page.wizard-page .wizard-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    background: var(--auth-primary);
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 8px var(--sb-primary-tint);
}

.page.wizard-page .wizard-slider::-moz-range-thumb {
    width: 24px;
    height: 24px;
    background: var(--auth-primary);
    border-radius: 50%;
    cursor: pointer;
    border: none;
    box-shadow: 0 2px 8px var(--sb-primary-tint);
}

.page.wizard-page .slider-labels {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--auth-text-muted);
}

.page.wizard-page .slider-tip {
    margin-top: 24px;
    padding: 14px 16px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    font-size: 13px;
    color: var(--auth-text);
    line-height: 1.5;
}

/* Wizard Choice Toggle (e.g., template vs custom) */
.page.wizard-page .choice-toggle {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
}

.page.wizard-page .choice-option {
    flex: 1;
    cursor: pointer;
}

.page.wizard-page .choice-option input {
    display: none;
}

.page.wizard-page .choice-card {
    padding: 16px;
    background: var(--auth-surface);
    border: 2px solid var(--auth-border);
    border-radius: 10px;
    text-align: center;
    transition: all 0.2s ease;
}

.page.wizard-page .choice-option input:checked + .choice-card {
    border-color: var(--auth-primary);
    background: var(--sb-primary-subtle);
}

.page.wizard-page .choice-option:hover .choice-card {
    border-color: var(--auth-primary);
}

.page.wizard-page .choice-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--auth-text);
    margin-bottom: 4px;
}

.page.wizard-page .choice-desc {
    font-size: 12px;
    color: var(--auth-text-muted);
}

.page.wizard-page .wizard-textarea {
    min-height: 160px !important;
    padding: 12px !important;
    resize: vertical;
}

/* Wizard File Upload Area */
.page.wizard-page .upload-area {
    border: 2px dashed var(--auth-border);
    border-radius: 12px;
    padding: 40px 20px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.page.wizard-page .upload-area:hover {
    border-color: var(--auth-primary);
    background: var(--sb-primary-subtle);
}

.page.wizard-page .upload-area.dragging {
    border-color: var(--auth-primary);
    background: var(--sb-primary-tint);
}

.page.wizard-page .upload-placeholder-icon {
    font-size: 48px;
    margin-bottom: 12px;
}

.page.wizard-page .upload-placeholder-text {
    font-size: 15px;
    font-weight: 500;
    color: var(--auth-text);
    margin-bottom: 4px;
}

.page.wizard-page .upload-placeholder-hint {
    font-size: 13px;
    color: var(--auth-text-muted);
}

.page.wizard-page .upload-preview {
    position: relative;
    display: inline-block;
}

.page.wizard-page .upload-preview img {
    max-width: 160px;
    max-height: 160px;
    border-radius: 12px;
}

.page.wizard-page .upload-remove {
    position: absolute;
    top: -8px;
    right: -8px;
    background: #dc2626;
    color: #fff;
    border: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    font-size: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Wizard Integration Connect Area (e.g., Stripe) */
.page.wizard-page .connect-area {
    text-align: center;
    padding: 20px 0;
}

.page.wizard-page .connect-logo {
    margin-bottom: 20px;
}

.page.wizard-page .connect-description {
    font-size: 14px;
    color: var(--auth-text);
    margin-bottom: 24px;
    line-height: 1.6;
}

.page.wizard-page .connect-btn {
    max-width: 240px;
    margin: 0 auto;
}

.page.wizard-page .connect-skip {
    margin-top: 16px;
    font-size: 13px;
    color: var(--auth-text-muted);
}

.page.wizard-page .skip-link {
    color: var(--auth-primary);
    text-decoration: none;
}

.page.wizard-page .skip-link:hover {
    text-decoration: underline;
}

/* Wizard Review Section */
.page.wizard-page .review-sections {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.page.wizard-page .review-section {
    background: var(--auth-surface);
    border: 1px solid var(--auth-border);
    border-radius: 12px;
    overflow: hidden;
}

.page.wizard-page .review-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    background: var(--auth-card-bg);
    border-bottom: 1px solid var(--auth-border);
}

.page.wizard-page .review-section-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--auth-text);
}

.page.wizard-page .review-edit-btn {
    font-size: 13px;
    color: var(--auth-primary);
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 8px;
}

.page.wizard-page .review-edit-btn:hover {
    text-decoration: underline;
}

.page.wizard-page .review-section-content {
    padding: 14px 16px;
}

.page.wizard-page .review-item {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
}

.page.wizard-page .review-label {
    font-size: 13px;
    color: var(--auth-text-muted);
}

.page.wizard-page .review-value {
    font-size: 13px;
    font-weight: 500;
    color: var(--auth-text);
    text-align: right;
}

/* Wizard Navigation */
.page.wizard-page .wizard-nav {
    position: sticky;
    bottom: 0;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 20px 24px;
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-top: 1px solid var(--auth-border);
}

.dark .page.wizard-page .wizard-nav {
    background: rgba(26, 26, 31, 0.95);
}

.page.wizard-page .wizard-btn {
    flex: 1;
    max-width: 180px;
    height: 48px;
    font-size: 15px;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
    border: none;
    font-family: inherit;
}

.page.wizard-page .wizard-back {
    background: var(--auth-card-bg);
    color: var(--auth-text);
    border: 1px solid var(--auth-border);
}

.page.wizard-page .wizard-back:hover {
    background: var(--auth-surface);
}

.page.wizard-page .wizard-next {
    background: var(--auth-primary);
    color: #fff;
    margin-left: auto;
}

.page.wizard-page .wizard-next:hover {
    background: var(--auth-primary-hover);
}

.page.wizard-page .wizard-next:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.page.wizard-page .wizard-next.btn-loading {
    pointer-events: none;
    position: relative;
}

.page.wizard-page .wizard-next.btn-loading::after {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: wizardBtnSpin 0.6s linear infinite;
}

@keyframes wizardBtnSpin {
    to { transform: rotate(360deg); }
}

/* Wizard Footer */
.page.wizard-page .wizard-footer {
    padding: 16px 24px;
    text-align: center;
    font-size: 14px;
    color: var(--auth-text-muted);
    background: rgba(255, 255, 255, 0.8);
}

.dark .page.wizard-page .wizard-footer {
    background: rgba(26, 26, 31, 0.8);
}

.page.wizard-page .wizard-footer a {
    color: var(--auth-primary);
    text-decoration: none;
    margin-left: 4px;
}

.page.wizard-page .wizard-footer a:hover {
    text-decoration: underline;
}

/* Mobile adjustments for wizard */
@media (max-width: 480px) {
    .page.wizard-page .wizard-header {
        padding: 16px 16px;
        padding-top: calc(16px + env(safe-area-inset-top, 0px));
    }

    .page.wizard-page .wizard-container {
        padding: 24px 16px;
    }

    .page.wizard-page .step-content {
        padding: 24px 20px;
    }

    .page.wizard-page .step-title {
        font-size: 20px !important;
    }

    .page.wizard-page .option-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .page.wizard-page .option-card {
        padding: 16px 12px;
    }

    .page.wizard-page .option-icon {
        font-size: 24px;
    }

    .page.wizard-page .choice-toggle {
        flex-direction: column;
    }

    .page.wizard-page .wizard-nav {
        padding: 16px;
        padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
    }

    .page.wizard-page .wizard-btn {
        max-width: none;
    }

    .page.wizard-page .slider-number {
        font-size: 48px;
    }

    .page.wizard-page .slider-suffix {
        font-size: 24px;
    }
}

/* App mode: Add safe-area padding for wizard pages */
body.layout-app .page.wizard-page .wizard-header {
    padding-left: calc(24px + env(safe-area-inset-left, 0px));
    padding-right: calc(24px + env(safe-area-inset-right, 0px));
}

body.layout-app .page.wizard-page .wizard-container {
    padding-left: calc(40px + env(safe-area-inset-left, 0px));
    padding-right: calc(40px + env(safe-area-inset-right, 0px));
}

body.layout-app .page.wizard-page .wizard-nav {
    padding-left: calc(24px + env(safe-area-inset-left, 0px));
    padding-right: calc(24px + env(safe-area-inset-right, 0px));
}

body.layout-app .page.wizard-page .wizard-footer {
    padding-left: calc(24px + env(safe-area-inset-left, 0px));
    padding-right: calc(24px + env(safe-area-inset-right, 0px));
}

/* App mode mobile: Override for smaller screens */
@media (max-width: 480px) {
    body.layout-app .page.wizard-page .wizard-header {
        padding-left: calc(16px + env(safe-area-inset-left, 0px));
        padding-right: calc(16px + env(safe-area-inset-right, 0px));
    }

    body.layout-app .page.wizard-page .wizard-container {
        padding-left: calc(16px + env(safe-area-inset-left, 0px));
        padding-right: calc(16px + env(safe-area-inset-right, 0px));
    }

    body.layout-app .page.wizard-page .wizard-nav {
        padding-left: calc(16px + env(safe-area-inset-left, 0px));
        padding-right: calc(16px + env(safe-area-inset-right, 0px));
    }

    body.layout-app .page.wizard-page .wizard-footer {
        padding-left: calc(16px + env(safe-area-inset-left, 0px));
        padding-right: calc(16px + env(safe-area-inset-right, 0px));
    }
}

/* =============================================
   Catalogue Page - InfrastructureLike-inspired Design
   (Products, Customers, Deals, Contracts)
   ============================================= */


/* Catalogue Header */
.catalogue-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    padding: 24px 16px 16px;
    gap: 8px 16px;
}

.catalogue-header-left {
    flex: 1;
    min-width: 200px;
}

.catalogue-title {
    font-size: 28px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0;
}

/* On mobile: stack header title/desc above action buttons to prevent title truncation (#2251) */
@media (max-width: 768px) {
    .catalogue-header {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .catalogue-header-left {
        min-width: 0;
    }
    /* Compact inline pills on mobile — prevent full-width stacked buttons (#2553) */
    .catalogue-header-right {
        padding-top: 0;
        flex-wrap: wrap;
        align-self: flex-start;
    }
    .catalogue-header-right .button {
        flex: 0 0 auto;
        min-height: 34px;
        height: 34px;
        font-size: 13px;
        padding: 0 12px;
    }
}

/* On mobile the navbar already shows the page title — hide the in-page h1 to avoid duplication */
@media (max-width: 768px) {
    .page-catalogue .catalogue-title,
    .page-list .catalogue-title {
        display: none;
    }
    .page-bookings .catalogue-title,
    .page-bookings .catalogue-desc {
        display: none;
    }
    /* Move primary action to navbar on mobile — hide the inline catalogue header button */
    .page-bookings .catalogue-header-right {
        display: none;
    }
}
/* On desktop the inline catalogue header button is visible — hide the compact navbar add button */
@media (min-width: 769px) {
    .booking-navbar-add {
        display: none !important;
    }
}
/* On desktop, FAB is redundant with the header Create button — hide it on list pages */
@media (min-width: 769px) {
    .page-list .fab {
        display: none !important;
    }
}

.catalogue-desc {
    color: var(--sb-text-muted);
    font-size: 14px;
    margin: 4px 0 0;
    line-height: 1.4;
}

.catalogue-header-right {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
    padding-top: 4px; /* align buttons with title baseline */
}

.sb-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    border: none;
    font-family: inherit;
    white-space: nowrap;
    width: auto;
}

.sb-btn .icon {
    font-size: 16px;
}

.sb-btn-outline {
    background: var(--sb-bg-card);
    color: var(--sb-text-secondary);
    border: 1px solid var(--sb-border-color);
}

.sb-btn-outline:hover {
    background: var(--sb-bg-hover);
}

.sb-btn.sb-btn-primary {
    background: var(--sb-primary);
    color: #fff;
}

.sb-btn-primary:hover {
    background: var(--sb-primary-hover);
}

.sb-btn.sb-btn-danger {
    color: var(--sb-danger);
    border-color: var(--sb-danger);
}

.sb-btn-danger:hover {
    background: rgba(239, 68, 68, 0.1);
}

/* Filter Tabs (Segmented Control) */
.catalogue-filter-tabs {
    display: flex;
    gap: 0;
    padding: 16px 32px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.filter-tab {
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-right: none;
    border-radius: 0;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
    white-space: nowrap;
    flex-shrink: 0;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.filter-tab:first-child {
    border-radius: 8px 0 0 8px;
}

.filter-tab:last-child {
    border-right: 1px solid var(--sb-border-color);
    border-radius: 0 8px 8px 0;
}

.filter-tab:hover {
    background: var(--sb-bg-hover);
}

.filter-tab.active {
    background: var(--sb-primary-tint);
    color: var(--sb-primary);
    font-weight: 600;
}

/* Filter Chips Row */
.catalogue-filters-row {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 12px 32px;
    gap: 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.catalogue-filters-left {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
}

.catalogue-filters-right {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-muted);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    font-family: inherit;
    white-space: nowrap;
    min-height: 44px;
}

.filter-chip .icon {
    font-size: 14px;
}

.filter-chip:hover {
    border-color: var(--sb-border-hover);
    color: var(--sb-text-secondary);
}

.filter-chip.active {
    background: var(--sb-primary);
    border-color: var(--sb-primary);
    color: #fff;
}

.filter-clear {
    font-size: 13px;
    color: var(--sb-primary);
    text-decoration: none;
    margin-left: 8px;
}

.filter-clear:hover {
    text-decoration: underline;
}

.filter-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
    font-family: inherit;
    white-space: nowrap;
}

.filter-action-btn .icon {
    font-size: 14px;
}

.filter-action-btn:hover {
    background: var(--sb-bg-hover);
}

/* Data Table */
.catalogue-table {
    margin: 0 32px;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: none;
}

section .catalogue-table {
    margin: 0px !important;
}

.catalogue-table table {
    width: 100%;
    border-collapse: collapse;
}

.catalogue-table thead {
    border-bottom: 1px solid var(--sb-border-color);
}


.catalogue-table th {
    padding: 4px 16px;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--sb-text-muted) !important;
    text-align: left;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.catalogue-table td {
    padding: 16px;
    font-size: 14px;
    color: var(--sb-text-secondary);
    border-bottom: 1px solid var(--sb-border-color);
    vertical-align: middle;
}

.catalogue-table tbody tr:last-child td {
    border-bottom: none;
}

.catalogue-table tbody tr {
    cursor: pointer;
    transition: background-color 0.1s ease;
}

.catalogue-table tbody tr:hover {
    background: var(--sb-row-hover);
}

.catalogue-table .checkbox-cell {
    width: 40px;
    padding-left: 16px;
}

.catalogue-table .actions-cell {
    width: 96px;
    text-align: center;
}

/* Minimum 44×44px touch targets for table action icon buttons (Apple HIG / WCAG 2.5.5) */
.catalogue-table .actions-cell .link.icon-only {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Spacing between adjacent action buttons in table cells */
.catalogue-table .actions-cell .sb-btn + .sb-btn {
    margin-left: 8px;
}

/* Minimum 44×44px touch targets for card row action icon buttons */
.sb-card-row-action .link.icon-only {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.catalogue-table tbody td:before, .catalogue-table tbody th:before {
    display: none;
}

/* Replays page: dual-view layout (table on desktop, cards on mobile) */
.replays-card-view {
    display: none;
}

/* Row Styling */
.row-icon {
    width: 36px;
    height: 36px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    flex-shrink: 0;
}

.row-icon .icon {
    font-size: 18px;
    color: var(--sb-primary);
}

.name-cell {
    display: flex;
    align-items: center;
    min-width: 200px;
    width: auto;
    max-width: 40vw;
}

.row-name {
    font-weight: 500;
    color: var(--sb-text-primary);
}

.catalogue-table .actions-cell .row-actions-btn {
    color: var(--sb-text-muted);
    border-radius: 4px;
}

.catalogue-table .actions-cell .row-actions-btn:hover {
    background: var(--sb-border-color);
    color: var(--sb-text-secondary);
}

/* Catalogue Footer */
.catalogue-footer {
    padding: 16px 24px;
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* ── Deals Export Panel (#2130) ─────────────────────────────────── */
.deals-export-panel {
    margin: 0 0 12px;
}

.deals-export-panel .card-header {
    justify-content: space-between;
}

.deals-export-download-btn {
    width: 100%;
    justify-content: center;
}

.page-wrapper:has(.catalogue-empty-state:not([style*="none"])) .catalogue-footer {
    display: none;
}

/* Catalogue Pagination */
.catalogue-pagination {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px 24px 16px;
}

.catalogue-load-more {
    margin: 8px 0;
    font-size: 13px;
    padding: 8px 24px;
}

.catalogue-pagination-loader {
    display: flex;
    justify-content: center;
    padding: 12px;
}

.catalogue-pagination-loader.hidden {
    display: none;
}

.catalogue-cap-message {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 12px 16px;
    font-size: 13px;
    color: var(--sb-text-muted);
    background: var(--sb-empty-bg);
    border-radius: 8px;
    margin: 8px 0;
}

.catalogue-cap-message .icon {
    font-size: 16px;
    opacity: 0.5;
}

/* Empty State - InfrastructureLike Style */
.catalogue-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 24px;
    text-align: center;
    max-width: 400px;
    margin: 0 auto;
}

.catalogue-empty-state .empty-state-icon {
    width: 64px;
    height: 64px;
    background: var(--sb-empty-bg);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
}

.catalogue-empty-state .empty-state-icon .icon {
    font-size: 28px;
    color: var(--sb-text-muted);
}

.catalogue-empty-state .empty-state-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0 0 8px 0;
}

.catalogue-empty-state .empty-state-text {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 0 0 12px 0;
    max-width: 400px;
    line-height: 1.5;
}

.catalogue-empty-state .empty-state-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    color: var(--sb-primary);
    text-decoration: none;
    margin-bottom: 20px;
}

.catalogue-empty-state .empty-state-link:hover {
    text-decoration: underline;
}

.catalogue-empty-state .empty-state-link .icon {
    font-size: 14px;
}

.catalogue-empty-state .empty-state-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    margin-top: 4px;
    padding: 0 4px;
}

.catalogue-empty-state .empty-state-btn {
    margin-top: 0;
    width: auto;
}

/* Mobile Responsive */
@media (max-width: 768px) {

    .catalogue-filter-tabs {
        padding: 12px 16px;
        scrollbar-width: none;
        mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
        -webkit-mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
    }

    .catalogue-filter-tabs::-webkit-scrollbar {
        display: none;
    }

    .filter-tab {
        padding: 7px 14px;
        font-size: 13px;
        min-height: 44px;
    }

    .catalogue-filters-row {
        padding: 12px 16px;
    }

    .catalogue-table {
        margin: 0 16px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        mask-image: linear-gradient(to right, black calc(100% - 40px), transparent);
        -webkit-mask-image: linear-gradient(to right, black calc(100% - 40px), transparent);
    }

    .catalogue-table table {
        min-width: 600px;
    }

    .catalogue-footer {
        padding: 12px 16px;
    }

    .catalogue-pagination {
        padding: 8px 16px 12px;
    }

    .catalogue-empty-state {
        padding: 60px 16px;
    }

    .catalogue-empty-state .empty-state-actions {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        padding: 0;
    }

    .catalogue-empty-state .empty-state-actions .sb-btn {
        justify-content: center;
        width: 100%;
    }

    /* Replays page: switch to card layout on mobile */
    .replays-table-view {
        display: none;
    }

    .replays-card-view {
        display: block;
    }
}

/* Catalogue table: hide secondary columns on narrow phones */
@media (max-width: 480px) {
    .catalogue-table th.col-mobile-hidden,
    .catalogue-table td.col-mobile-hidden {
        display: none;
    }

    /* With secondary columns hidden the table fits without forced scroll */
    .catalogue-table table {
        min-width: 0;
    }

    /* Remove the right-edge fade mask — table no longer scrolls at this breakpoint */
    .catalogue-table {
        mask-image: none;
        -webkit-mask-image: none;
    }

    /* Truncate overflowing cell text with ellipsis instead of hard clipping (#2560) */
    .catalogue-table td.label-cell {
        max-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    /* name-cell: allow the flex container to shrink below its default min-width */
    .catalogue-table td.label-cell .name-cell {
        min-width: 0;
        overflow: hidden;
    }

    /* Truncate the row name text within name-cell with an ellipsis */
    .catalogue-table td.label-cell .name-cell .row-name {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        min-width: 0;
    }
}

/* Mobile list item simplification */
@media (max-width: 640px) {
    .sb-card-row-meta .meta-item[data-mobile-hidden] {
        display: none;
    }

    .sb-card-row-meta {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .widget-inline-metrics {
        display: none !important;
    }
}

/* =============================================
   Dashboard Page - InfrastructureLike-inspired Design
   ============================================= */
.dashboard-wrapper {
    padding: 0;
    max-width: 1200px;
    margin: 0 auto;
}

.dashboard-section {
    padding: 24px;
}

.dashboard-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.dashboard-section-title {
    font-size: 28px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0;
}

.dashboard-assistant-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: linear-gradient(135deg, var(--sb-primary) 0%, #007fff 100%);
    color: #fff;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    box-shadow: 0 2px 8px rgba(0, 113, 227, 0.25);
}

.dashboard-assistant-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 113, 227, 0.35);
}

.dashboard-assistant-btn:active {
    transform: translateY(0);
}

.dashboard-assistant-btn i {
    font-size: 16px;
}

.dashboard-divider {
    height: 1px;
    background: var(--sb-border-color);
    margin-bottom: 24px;
}

/* Today Grid */
.dashboard-today-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 24px;
}

/* When recommendations card is hidden, chart fills full width */
.dashboard-today-grid:has(.recommendations-card.hidden),
.dashboard-today-grid:not(:has(.recommendations-card)) {
    grid-template-columns: 1fr;
}

.recommendations-card.hidden {
    display: none;
}

.sidebar-restore-link {
    float: right;
    font-size: 13px;
    color: var(--f7-theme-color);
}
.sidebar-restore-link.hidden {
    display: none;
}

.dashboard-chart-area {
    display: flex;
    flex-direction: column;
}

.dashboard-chart-label {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin-bottom: 12px;
}

.dashboard-chart-placeholder {
    height: 180px;
    background: var(--sb-empty-bg);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
}

.dashboard-chart-container {
    position: relative;
    height: 200px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 24px;
    padding: 12px;
}

.dashboard-chart-container canvas {
    width: 100% !important;
    height: 100% !important;
}

.dashboard-chart-container .chart-no-data {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.chart-period-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    font-weight: 400;
}

.chart-no-data {
    font-size: 14px;
    color: var(--sb-text-muted);
}

.dashboard-balance-row {
    display: flex;
    align-items: flex-end;
    gap: 48px;
}

.balance-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.balance-label {
    font-size: 14px;
    color: var(--sb-text-muted);
}

.balance-value {
    font-size: 24px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.balance-link {
    font-size: 14px;
    color: var(--sb-primary);
    text-decoration: none;
    margin-left: auto;
}

.balance-link:hover {
    text-decoration: underline;
}

/* Sidebar Card */
.dashboard-sidebar-card {
    background: var(--sb-border-color);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    overflow: hidden;
}

.sidebar-card-header {
    padding: 16px;
    border-bottom: 1px solid var(--sb-border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.sidebar-card-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sidebar-card-close {
    width: 44px;
    height: 44px;
    margin: -10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: var(--sb-text-muted);
    transition: all 0.15s ease;
}

.sidebar-card-close:hover {
    background: var(--sb-bg-hover);
    color: var(--sb-text-secondary);
}

.sidebar-card-close .icon {
    font-size: 14px;
}

.sidebar-card-content {
    padding: 8px 0;
}

/* Recommendations Card */
.recommendations-card .sidebar-card-content {
    padding: 0 16px 16px;
}

.recommendation-item {
    padding: 8px 0;
}

.recommendation-item + .recommendation-item {
    border-top: 1px solid var(--sb-border-color);
}

.recommendation-text {
    font-size: 14px;
    color: var(--sb-text-secondary);
    line-height: 1.5;
    margin: 0;
}

.recommendation-text a {
    color: var(--sb-primary);
    text-decoration: none;
}

.recommendation-text a:hover {
    text-decoration: underline;
}

.sidebar-card-divider {
    height: 1px;
    background: var(--sb-border-color);
    margin: 0;
}

.sidebar-card-section {
    padding: 16px;
}

.sidebar-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.sidebar-section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sidebar-section-link {
    font-size: 13px;
    color: var(--sb-primary);
    text-decoration: none;
}

.sidebar-section-link:hover {
    text-decoration: underline;
}

.sidebar-section-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.progress-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.progress-label {
    font-size: 14px;
    color: var(--sb-text-muted);
}

.progress-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.quick-action-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    font-size: 14px;
    color: var(--sb-text-secondary);
    text-decoration: none;
    transition: background 0.15s ease;
}

.quick-action-link:hover {
    background: var(--sb-bg-hover);
}

.quick-action-link .icon {
    font-size: 18px;
    color: var(--sb-text-muted);
}

/* Dashboard Filters */
.dashboard-filters {
    display: flex;
    align-items: center;
    gap: 16px;
}

.dashboard-filters-left {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dashboard-filters .filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.dashboard-filters .chip-value {
    color: var(--sb-primary);
    font-weight: 500;
}

.dashboard-filters .filter-chip .icon {
    font-size: 12px;
    color: var(--sb-text-muted);
}

/* Metrics Grid */
.dashboard-metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}

.metric-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 16px;
}

.metric-card-empty {
    border-style: dashed;
}

.metric-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.metric-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary);
}

.metric-header-link {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.metric-value {
    font-size: 32px;
    font-weight: 600;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.metric-subtitle {
    font-size: 13px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

.metric-subtitle-inline {
    font-size: 0.55em;
    color: var(--sb-text-muted);
    font-weight: 400;
}

.metric-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
    border: 1px dashed var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    color: var(--sb-text-muted);
}

/* Pipeline Funnel */
.pipeline-funnel {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 20px;
}

.pipeline-stages {
    display: flex;
    gap: 4px;
    margin-bottom: 12px;
    min-height: 80px;
}

.pipeline-stage {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 0;
    flex-grow: 1;
}

.pipeline-stage-bar {
    width: 100%;
    height: 8px;
    border-radius: 4px;
    margin-bottom: 8px;
    transition: opacity 0.15s ease;
}

.pipeline-stage:hover .pipeline-stage-bar {
    opacity: 0.8;
}

.pipeline-stage-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    text-align: center;
    min-width: 0;
    width: 100%;
}

.pipeline-stage-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.pipeline-stage-count {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.pipeline-stage-value {
    font-size: 11px;
    color: var(--sb-text-muted);
}

.pipeline-bottleneck {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: rgba(234, 179, 8, 0.08);
    border-radius: 6px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin-top: 4px;
}

.pipeline-bottleneck .icon {
    font-size: 14px;
    color: #eab308;
}

.pipeline-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px;
    color: var(--sb-text-muted);
    font-size: 13px;
}

.pipeline-empty-state .icon {
    font-size: 24px;
    opacity: 0.4;
}

/* Attention Widget */
.attention-grid {
    display: flex;
    flex-direction: column;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    overflow: hidden;
}

.attention-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    text-decoration: none;
    color: inherit;
    transition: background 0.15s ease;
}

.attention-item:not(:last-child) {
    border-bottom: 1px solid var(--sb-border-color);
}

.attention-item:hover {
    background: var(--sb-bg-hover);
}

.attention-item-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.attention-item-icon .icon {
    font-size: 14px;
}

.attention-item-content {
    flex: 1;
    min-width: 0;
}

.attention-item-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.attention-item-desc {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 1px;
}

.attention-item-value {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
}

/* Mobile Responsive */
@media (max-width: 900px) {
    .dashboard-today-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-sidebar-card {
        order: -1;
    }
}

@media (max-width: 768px) {
    .dashboard-section {
        padding: 16px;
    }

    .dashboard-section-title {
        font-size: 24px;
    }

    .dashboard-section-header {
        flex-direction: row;
        align-items: center;
        gap: 12px;
    }

    .dashboard-assistant-btn {
        padding: 6px 12px;
        font-size: 13px;
    }

    .dashboard-balance-row {
        flex-wrap: wrap;
        gap: 24px;
    }

    .balance-link {
        margin-left: 0;
        width: 100%;
    }

    .dashboard-metrics-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .pipeline-stages {
        flex-wrap: wrap;
        gap: 8px;
    }

    .pipeline-stage {
        flex-basis: calc(33% - 8px);
        min-width: 70px;
    }

    .dashboard-chart-container {
        height: 160px;
    }

    .metric-value {
        font-size: 28px;
    }
}

@media (max-width: 480px) {
    .dashboard-metrics-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .metric-card {
        padding: 12px;
    }

    .pipeline-stage {
        flex-basis: calc(50% - 8px);
    }

    /* Negotiations: hide metric cards when all values are zero so the empty
       state is visible above the fold (progressive disclosure, #2421) */
    .dashboard-metrics-grid.neg-metrics-no-data {
        display: none;
    }
}

/* App mode (mobile/PWA): ensure dashboard content clears the bottom tab bar.
   The tab bar is fixed at the bottom in body.layout-app and overlaps .page-content
   without explicit bottom padding. This applies to the PHP dashboard page that also
   renders when developer sub-pages fall back to the home dashboard (#2307).
   Breathing room increased to 24px (from 16px) to keep the activity empty-state
   CTA fully visible above the tab bar on mobile/PWA viewports (#2367). */
body.layout-app .page-dashboard .page-content {
    padding-bottom: calc(var(--f7-toolbar-height, 56px) + env(safe-area-inset-bottom, 0px) + 24px);
}

/* App mode (mobile/PWA): ensure analytics dashboard content clears the bottom tab bar.
   The "Configure Tracking" quick link and "Getting started" card at the bottom of the
   analytics dashboard were hidden behind the tab bar on mobile/PWA viewports (#2314). */
body.layout-app .page-analytics-dashboard .page-content {
    padding-bottom: calc(var(--f7-toolbar-height, 56px) + env(safe-area-inset-bottom, 0px) + 16px);
}

/* App mode (mobile/PWA): ensure form page content clears the bottom tab bar.
   In PWA standalone mode the tab bar is fixed at the bottom and overlaps the last
   form fields (e.g. State/Postal Code/Status on the New Customer form) when the user
   scrolls to the bottom of a long form. Adding explicit bottom padding guarantees
   every form field and the submit button remain fully visible above the tab bar.
   Systemic fix — applies to all pages with the .page-form class (#2558). */
body.layout-app .page-form .page-content {
    padding-bottom: calc(var(--f7-toolbar-height, 56px) + env(safe-area-inset-bottom, 0px) + 24px);
}

/* =============================================
   Activity Feed & Notifications
   ============================================= */

/* Activity Feed Card */
.activity-feed-card {
    grid-column: 1 / -1;
    border-style: solid;
}

.activity-feed-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}

.activity-feed-header-left {
    display: flex;
    align-items: center;
    gap: 8px;
}

.activity-status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--sb-text-muted);
    opacity: 0.4;
    transition: all 0.3s ease;
}

.activity-status-dot.connected {
    background: #22c55e;
    opacity: 1;
    box-shadow: 0 0 4px rgba(34, 197, 94, 0.4);
}

/* Filter Chips */
.activity-feed-filters {
    display: flex;
    gap: 6px;
    margin-bottom: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.activity-feed-filters::-webkit-scrollbar {
    display: none;
}

.activity-filter-chip {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 14px;
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted);
    background: var(--sb-empty-bg);
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.15s ease;
}

.activity-filter-chip:hover {
    color: var(--sb-text-secondary);
    border-color: var(--sb-border-color);
}

.activity-filter-chip.active {
    background: var(--sb-primary);
    border-color: var(--sb-primary);
    color: #fff;
}

/* Feed List */
.activity-feed-list {
    display: flex;
    flex-direction: column;
    max-height: 400px;
    overflow-y: auto;
    scrollbar-width: thin;
}

/* Activity Item */
.activity-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--sb-border-color);
    transition: opacity 0.3s ease, transform 0.3s ease, background 0.15s ease;
}

.activity-item:last-child {
    border-bottom: none;
}

.activity-item:hover {
    background: var(--sb-bg-hover);
    border-radius: 6px;
    margin: 0 -4px;
    padding-left: 4px;
    padding-right: 4px;
}

.activity-item-new {
    opacity: 0;
    transform: translateY(-8px);
}

.activity-item-high {
    border-left: 3px solid #ef4444;
    padding-left: 8px;
}

/* Icon */
.activity-item-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.activity-item-icon .icon {
    font-size: 13px;
}

.activity-icon-blue {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.activity-icon-green {
    background: rgba(34, 197, 94, 0.1);
    color: #15803d;
}

.activity-icon-yellow {
    background: rgba(234, 179, 8, 0.1);
    color: #eab308;
}

.activity-icon-red {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.activity-icon-purple {
    background: rgba(0, 113, 227, 0.1);
    color: #0071e3;
}

.activity-icon-gray {
    background: var(--sb-empty-bg);
    color: var(--sb-text-muted);
}

/* Content */
.activity-item-content {
    flex: 1;
    min-width: 0;
}

.activity-item-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.activity-item-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    line-height: 1.3;
}

.activity-item-desc {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Agent Badge */
.activity-agent-badge {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    background: linear-gradient(135deg, var(--sb-primary) 0%, var(--sb-primary-gradient) 100%);
    color: #fff;
}

/* Time */
.activity-item-time {
    flex-shrink: 0;
    font-size: 11px;
    color: var(--sb-text-muted);
    white-space: nowrap;
    margin-top: 2px;
}

/* Empty State */
.activity-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 32px 16px;
    color: var(--sb-text-muted);
    font-size: 13px;
}

.activity-empty-state .icon {
    font-size: 48px;
}

.activity-empty-state .activity-empty-heading {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.activity-empty-state .activity-empty-sub {
    font-size: 12px;
    text-align: center;
    max-width: 260px;
}

.activity-empty-state .activity-empty-cta {
    display: inline-block;
    margin-top: 4px;
    padding: 8px 20px;
    border-radius: 8px;
    background: var(--f7-theme-color, #007aff);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

/* Feed Loader */
.activity-feed-loader {
    display: flex;
    justify-content: center;
    padding: 12px;
}

.activity-feed-loader.hidden {
    display: none;
}

/* Notification Badge */
.notification-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 8px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.notification-badge.hidden {
    display: none;
}

/* Notification Popover */
.notification-popover {
    width: 360px;
    max-height: 480px;
}

.notification-popover .popover-inner {
    display: flex;
    flex-direction: column;
    max-height: 480px;
}

.notification-popover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sb-border-color);
    flex-shrink: 0;
}

.notification-popover-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.notification-popover-mark-read {
    font-size: 12px;
    color: var(--sb-primary);
    text-decoration: none;
    cursor: pointer;
}

.notification-popover-mark-read:hover {
    text-decoration: underline;
}

.notification-popover-list {
    overflow-y: auto;
    flex: 1;
    min-height: 80px;
    max-height: 360px;
}

.notification-popover-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
}

.system-loading,
.r-loading {
    text-align: center;
    padding: 32px 16px;
}

.notification-popover-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
    color: var(--sb-text-muted);
    gap: 8px;
}

.notification-popover-empty .icon {
    font-size: 24px;
    opacity: 0.5;
}

.notification-popover-empty span {
    font-size: 13px;
}

.notification-popover-item {
    display: flex;
    align-items: flex-start;
    padding: 10px 16px;
    gap: 10px;
    border-bottom: 1px solid var(--sb-border-color);
    transition: background 0.15s ease;
}

.notification-popover-item:last-child {
    border-bottom: none;
}

.notification-popover-item:hover {
    background: var(--sb-bg-hover);
}

.notification-popover-item.unread {
    background: color-mix(in srgb, var(--sb-primary) 5%, transparent);
}

.notification-popover-item.unread:hover {
    background: color-mix(in srgb, var(--sb-primary) 10%, transparent);
}

.notification-popover-item-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-top: 5px;
    flex-shrink: 0;
    background: transparent;
}

.notification-popover-item.unread .notification-popover-item-dot {
    background: var(--sb-primary);
}

.notification-popover-item-content {
    flex: 1;
    min-width: 0;
}

.notification-popover-item-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    line-height: 1.4;
}

.notification-popover-item-body {
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.3;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.notification-popover-item-time {
    font-size: 11px;
    color: var(--sb-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 2px;
}

.notification-popover-footer {
    padding: 8px 16px;
    border-top: 1px solid var(--sb-border-color);
    text-align: center;
    flex-shrink: 0;
}

.notification-popover-settings {
    font-size: 12px;
    color: var(--sb-text-muted);
    text-decoration: none;
}

.notification-popover-settings:hover {
    color: var(--sb-primary);
}

/* Notification Sheet (mobile/app mode) */
.notification-sheet {
    height: 70vh;
}

.notification-sheet .toolbar {
    background: var(--sb-bg-card, #fff);
    border-bottom: 1px solid var(--sb-border-color);
}

.notification-sheet .toolbar .title {
    font-size: 14px;
    font-weight: 600;
}

.notification-sheet .notification-sheet-mark-read {
    font-size: 13px;
    color: var(--sb-primary);
}

/* Mark All Read Link */
.activity-mark-read {
    font-size: 12px;
    color: var(--sb-primary);
    text-decoration: none;
    cursor: pointer;
}

.activity-mark-read:hover {
    text-decoration: underline;
}

@media (max-width: 768px) {
    .activity-feed-list {
        max-height: 300px;
    }
}

/* =============================================
   Popover Styles (shared between browser & app)
   ============================================= */

/* Base Popover */
.popover.app-popover {
    --f7-popover-width: 280px;
}

/* Remove ALL chevrons from app popovers */
.app-popover .item-inner::after,
.app-popover .item-inner::before {
    display: none !important;
    content: none !important;
    background: none !important;
    width: 0 !important;
    height: 0 !important;
}

.app-popover .popover-inner {
    padding: 0.5rem 0;
}

.app-popover .list li {
    padding: 1px 8px;
}

.app-popover .list li a {
    border-radius: 6px;
}

/* Popover Header */
.popover-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
}

.popover-header-logo {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.popover-header-logo .icon {
    font-size: 20px;
    color: #fff;
}

.popover-header-logo .tenant-icon {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
}

.popover-header-logo .tenant-icon-initials {
    font-size: 16px;
}

.popover-header-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

/* Popover Divider */
.popover-divider {
    height: 1px;
    background: var(--sb-border-color);
    margin: 8px 0;
}

/* Popover Section Title */
.popover-section-title {
    padding: 8px 16px 4px;
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Popover Menu List */
.popover-menu.list {
    margin: 0;
}

.popover-menu.list ul {
    background: transparent;
}

.popover-menu.list ul::before,
.popover-menu.list ul::after {
    display: none;
}

.popover-menu .item-link {
    padding: 0 16px !important;
    min-height: 44px !important;
}

.popover-menu .item-content {
    padding-left: 10px !important;
    min-height: 44px !important;
}

.popover-menu .item-inner {
    padding: 0 !important;
    min-height: 44px !important;
}

.popover-menu .item-inner::after,
.popover-menu .item-inner::before {
    display: none !important;
    content: none !important;
    background: none !important;
    width: 0 !important;
    height: 0 !important;
}

.popover-menu .item-media {
    min-width: 20px !important;
    margin-right: 10px !important;
}

.popover-menu .item-media .icon {
    font-size: 17px !important;
    color: var(--sb-text-muted) !important;
}

.popover-menu .color-red .item-media .icon {
    color: var(--f7-color-red) !important;
}

.popover-menu .color-red .item-title {
    color: var(--f7-color-red) !important;
}

.popover-menu .item-title {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--sb-text-secondary) !important;
}

.popover-menu .item-link:hover {
    background-color: var(--sb-bg-hover) !important;
}

.popover-menu li::after {
    display: none;
}

/* More Popup (App/Standalone mode) */
.more-popup .page-content {
    padding-bottom: env(safe-area-inset-bottom);
}

.more-popup .block-title-small {
    margin-top: 24px;
}

.more-popup-menu .item-media .icon {
    font-size: 20px;
    color: var(--sb-text-muted);
}

/* Popover Item List (for selectable items like tenants) */
.popover-item-list.list {
    margin: 0;
}

.popover-item-list.list ul {
    background: transparent;
}

.popover-item-list.list ul::before,
.popover-item-list.list ul::after {
    display: none;
}

.popover-item-list .item-link {
    padding: 0 16px !important;
    min-height: 44px !important;
}

.popover-item-list .item-content {
    padding-left: 10px !important;
    min-height: 44px !important;
}

.popover-item-list .item-inner {
    padding: 0 !important;
    min-height: 44px !important;
}

.popover-item-list .item-inner::after,
.popover-item-list .item-inner::before {
    display: none !important;
    content: none !important;
    background: none !important;
    width: 0 !important;
    height: 0 !important;
}

.popover-item-list .item-media {
    min-width: 28px !important;
    margin-right: 10px !important;
}

.popover-item-list .item-title-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.popover-item-list .item-title {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--sb-text-secondary) !important;
}

.popover-item-list .item-link:hover {
    background-color: var(--sb-bg-hover) !important;
}

.popover-item-list .item-link.active {
    background-color: var(--sb-primary-tint) !important;
}

.popover-item-list .item-link.active .item-title {
    color: var(--sb-primary) !important;
    font-weight: 600 !important;
}

.popover-item-list li::after {
    display: none;
}

/* Popover Item Logo */
.popover-item-logo {
    width: 28px;
    height: 28px;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.popover-item-logo .icon {
    font-size: 14px;
    color: #fff;
}

.popover-item-logo .tenant-icon {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
}

.popover-item-logo .tenant-icon-initials {
    font-size: 12px;
}

.popover-item-logo.sandbox {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

/* Popover Badge */
.popover-badge {
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 4px;
    text-transform: uppercase;
}

.popover-badge.sandbox {
    background: #fef3c7;
    color: #92400e;
}

/* Popover Checkmark (for active items) */
.popover-check {
    color: var(--sb-primary);
    font-size: 16px !important;
    margin-left: auto;
}

/* Popover User Section */
.popover-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
}

.popover-user-avatar {
    width: 32px;
    height: 32px;
    background: var(--sb-border-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.popover-user-avatar .icon {
    font-size: 20px;
    color: var(--sb-text-muted);
}

.popover-user-info {
    flex: 1;
    min-width: 0;
}

.popover-user-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

/* Tenant Icon Styles (shared) */
.tenant-icon-initials {
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
}

/* =============================================
   Settings Page - InfrastructureLike-inspired Design
   ============================================= */


/* Section Component (reusable across all pages) */
.sb-section {
    margin-bottom: 32px;
}

.sb-section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 16px;
}

.sb-section-header-content {
    flex: 1;
}

.sb-section-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0;
}

.sb-section-desc {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 4px 0 0 0;
}

.sb-section-header-action {
    flex-shrink: 0;
    margin-left: 16px;
}

.sb-section-link {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.sb-section-link:hover {
    text-decoration: underline;
}

.sb-section-meta {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Section Danger Variant */
.sb-section-danger .sb-section-title {
    color: var(--sb-danger);
}

/* SB Card - Reusable card component */
.sb-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    overflow: hidden;
}

.sb-card-danger {
    border-color: rgba(220, 38, 38, 0.2);
}

.dark .sb-card-danger {
    border-color: rgba(248, 113, 113, 0.2);
}

/* SB Card Row */
.sb-card-row {
    display: flex;
    align-items: center;
    padding: 16px;
    gap: 16px;
    text-decoration: none;
    transition: background-color 0.15s ease;
    border-bottom: 1px solid var(--sb-border-color);
}

.sb-card-row:last-child {
    border-bottom: none;
}

.sb-card-row.link,
.sb-card-row.doc-scroll-link {
    cursor: pointer;
}

.sb-card-row.link:hover,
.sb-card-row.doc-scroll-link:hover {
    background-color: var(--sb-bg-hover);
}

.sb-card-row.link:active,
.sb-card-row.doc-scroll-link:active {
    background-color: var(--sb-border-color);
}

/* API Documentation moved to standalone /docs page */

/* SB Card Row Icon */
.sb-card-row-icon {
    width: 36px;
    height: 36px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.sb-card-row-icon .icon {
    font-size: 18px;
    color: var(--sb-primary);
}

/* Icon color variants */
.sb-card-row-icon-stripe {
    background: rgba(0, 113, 227, 0.1);
}

.sb-card-row-icon-stripe .icon {
    color: #0071e3;
}

.sb-card-row-icon-calendar {
    background: rgba(52, 168, 83, 0.1);
}

.sb-card-row-icon-calendar .icon {
    color: #34a853;
}

.sb-card-row-icon-api {
    background: rgba(66, 133, 244, 0.1);
}

.sb-card-row-icon-api .icon {
    color: #4285f4;
}

.sb-card-row-icon-usage {
    background: rgba(0, 113, 227, 0.1);
}

.sb-card-row-icon-usage .icon {
    color: #007fff;
}

/* SB Card Row Content */
.sb-card-row-content {
    flex: 1;
    min-width: 0;
}

.sb-card-row-title {
    font-size: 15px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.sb-card-row-desc {
    font-size: 13px;
    color: var(--sb-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* SB Card Row Action */
.sb-card-row-action {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.sb-card-row-action > .icon {
    font-size: 14px;
    color: var(--sb-text-muted);
}

/* Theme Switcher (3-way: light / auto / dark) */
.sb-theme-switcher {
    display: flex;
    background: var(--sb-bg-hover);
    border-radius: 8px;
    padding: 2px;
    gap: 2px;
}

.sb-theme-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 30px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--sb-text-muted);
    cursor: pointer;
    transition: all 0.2s;
}

.sb-theme-btn .icon {
    font-size: 16px;
}

.sb-theme-btn.active {
    background: var(--sb-bg-card);
    color: var(--sb-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* SB Card Row Badge */
.sb-card-row-badge {
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    background: var(--sb-primary);
    padding: 2px 8px;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
}

/* SB Card Row Status */
.sb-card-row-status {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.sb-card-row-status-connected {
    color: #15803d;
}

/* SB Card Row Meta (for timestamps/secondary text) */
.sb-card-row-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-right: 4px;
}

/* Danger Row */
.sb-card-row-danger .sb-card-row-icon {
    background: rgba(220, 38, 38, 0.1);
}

.sb-card-row-danger .sb-card-row-icon .icon {
    color: #dc2626;
}

.sb-card-row-danger .sb-card-row-title {
    color: #dc2626;
}

.dark .sb-card-row-danger .sb-card-row-icon {
    background: rgba(248, 113, 113, 0.1);
}

.dark .sb-card-row-danger .sb-card-row-icon .icon {
    color: #f87171;
}

.dark .sb-card-row-danger .sb-card-row-title {
    color: #f87171;
}

/* SB Card Row Subtitle (secondary text line) */
.sb-card-row-subtitle {
    font-size: 13px;
    color: var(--sb-text-secondary);
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
}

/* SB Card Row Icon Variants */
.sb-card-row-icon.test {
    background: rgba(245, 158, 11, 0.1);
}

.sb-card-row-icon.test .icon {
    color: #f59e0b;
}

.sb-card-row-icon.success {
    background: rgba(34, 197, 94, 0.1);
}

.sb-card-row-icon.success .icon {
    color: #15803d;
}

.sb-card-row-icon.danger {
    background: rgba(220, 38, 38, 0.1);
}

.sb-card-row-icon.danger .icon {
    color: #dc2626;
}

.sb-card-row-icon.muted {
    background: var(--sb-bg-tertiary);
}

.sb-card-row-icon.muted .icon {
    color: var(--sb-text-muted);
}

/* SB Card with padding (for code blocks, etc.) */
.sb-card-padded {
    padding: 20px;
}

/* Legacy aliases - for backward compatibility */
.settings-card { background: var(--sb-bg-card); border: 1px solid var(--sb-border-color); border-radius: 12px; overflow: hidden; }
.settings-card-danger { border-color: rgba(220, 38, 38, 0.2); }
.settings-row { display: flex; align-items: center; padding: 16px; gap: 14px; text-decoration: none; transition: background-color 0.15s ease; border-bottom: 1px solid var(--sb-border-color); }
.settings-row:last-child { border-bottom: none; }
.settings-row.link:hover { background-color: var(--sb-bg-hover); }
.settings-row-icon { width: 36px; height: 36px; background: var(--sb-primary-tint); border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.settings-row-icon .icon { font-size: 18px; color: var(--sb-primary); }
.settings-row-content { flex: 1; min-width: 0; }
.settings-row-title { font-size: 15px; font-weight: 500; color: var(--sb-text-primary); margin-bottom: 2px; }
.settings-row-desc { font-size: 13px; color: var(--sb-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.settings-row-action { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.settings-row-action > .icon { font-size: 14px; color: var(--sb-text-muted); }
.settings-row-badge { font-size: 12px; font-weight: 600; color: #fff; background: var(--sb-primary); padding: 2px 8px; border-radius: 10px; min-width: 20px; text-align: center; }
.settings-row-status { font-size: 13px; color: var(--sb-text-muted); }
.settings-row-status-connected { color: #15803d; }
.settings-row-meta { font-size: 12px; color: var(--sb-text-muted); margin-right: 4px; }
.settings-row-danger .settings-row-icon { background: rgba(220, 38, 38, 0.1); }
.settings-row-danger .settings-row-icon .icon { color: #dc2626; }
.settings-row-danger .settings-row-title { color: #dc2626; }

/* Settings Footer */
.settings-footer {
    text-align: center;
    padding: 24px 0 40px;
}

.settings-footer-version {
    font-size: 13px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}

.settings-footer-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 13px;
}

.settings-footer-links a {
    color: var(--sb-text-muted);
    text-decoration: none;
}

.settings-footer-links a:hover {
    color: var(--sb-primary);
}

.settings-footer-dot {
    width: 3px;
    height: 3px;
    background: var(--sb-text-muted);
    border-radius: 50%;
}

/* Mobile Responsive */
@media (max-width: 480px) {

    .settings-row {
        padding: 14px;
        gap: 12px;
    }

    .settings-row-icon {
        width: 32px;
        height: 32px;
    }

    .settings-row-icon .icon {
        font-size: 16px;
    }

    .settings-row-title {
        font-size: 14px;
    }

    .settings-row-desc {
        font-size: 12px;
    }
}

/* Communications Settings Page */
.settings-status-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    border-radius: 12px;
    margin-bottom: 24px;
}

.settings-status-banner.status-configured {
    background: rgba(52, 199, 89, 0.1);
    color: #34c759;
}

.settings-status-banner.status-not-configured {
    background: rgba(255, 149, 0, 0.1);
    color: #ff9500;
}

.settings-status-banner .status-icon {
    font-size: 24px;
}

.settings-status-banner .status-text {
    font-size: 14px;
    font-weight: 500;
}

.sb-card-footer {
    padding: 12px 16px;
    border-top: 1px solid var(--sb-border-color);
}

.sb-card-footer a {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--sb-primary);
    text-decoration: none;
}

.sb-card-footer a .icon {
    font-size: 14px;
}

.sb-card-footer-note {
    padding: 12px 16px;
    font-size: 12px;
    color: var(--sb-text-muted);
    border-top: 1px solid var(--sb-border-color);
}

.sb-card-footer-note code {
    background: var(--sb-bg-secondary);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 11px;
}

.sb-card-actions {
    display: flex;
    gap: 8px;
    padding: 12px 16px;
    border-top: 1px solid var(--sb-border-color);
}

.sb-card-actions .button {
    display: flex;
    align-items: center;
    gap: 6px;
}

.sb-card-actions .button .icon {
    font-size: 14px;
}

.webhook-url-container {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
}

.webhook-url {
    flex: 1;
    font-size: 12px;
    background: var(--sb-bg-secondary);
    padding: 8px 12px;
    border-radius: 6px;
    overflow-x: auto;
    white-space: nowrap;
}

.sb-card-row-icon-comms {
    background: linear-gradient(135deg, #0062c7, #4da3ff);
}

/* ============================================
   Entity View Pages (InfrastructureLike-like layout)
   ============================================ */

/* View Page Layout */
.page-view .page-content {
    background: var(--sb-bg-page);
}

.view-layout {
    display: flex;
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px;
}

.view-main {
    flex: 1;
    min-width: 0;
}

.view-sidebar {
    width: 320px;
    flex-shrink: 0;
}

/* View Breadcrumb */
.view-breadcrumb {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 16px;
    font-size: 14px;
}

.view-breadcrumb-link {
    color: var(--sb-primary, #0071e3);
    text-decoration: none;
    font-weight: 500;
}

.view-breadcrumb-link:hover {
    text-decoration: underline;
}

.view-breadcrumb .icon {
    font-size: 12px;
    color: var(--sb-text-muted, #6b7280);
}

@media (min-width:960px) {
    .framework7-root>.view, .framework7-root>.views {
        margin-left: 240px;
    }
}
@media (max-width: 959px) {
    .view-breadcrumb {
        display: none;
    }
}

/* View Header */
.view-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
}

.view-header-left {
    display: flex;
    align-items: center;
    gap: 16px;
}

.view-header-icon {
    width: 48px;
    height: 48px;
    background: var(--sb-primary-tint);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.view-header-icon .icon {
    font-size: 24px;
    color: var(--sb-primary);
}

.view-header-info h1 {
    font-size: 20px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0 0 4px 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.view-header-meta {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.view-header-id {
    font-size: 12px;
    color: var(--sb-text-muted);
    font-family: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;
    opacity: 0.7;
    margin-top: 2px;
}

.view-header-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.view-edit-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.view-edit-btn:hover {
    background: var(--sb-bg-hover);
    border-color: var(--sb-border-hover);
}

.view-more-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.view-more-btn:hover {
    background: var(--sb-bg-hover);
}

.view-more-btn .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
}

/* Status Badge */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    font-size: 12px;
    font-weight: 500;
    border-radius: 4px;
    text-transform: capitalize;
}

.status-badge-active,
.status-badge-signed,
.status-badge-closed {
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

.status-badge-inactive,
.status-badge-expired,
.status-badge-cancelled {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.status-badge-draft {
    background: rgba(0, 113, 227, 0.1);
    color: var(--sb-primary);
}

.status-badge-pending {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.status-badge-terminated {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dark .status-badge-active,
.dark .status-badge-signed,
.dark .status-badge-closed {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
}

.dark .status-badge-inactive,
.dark .status-badge-expired,
.dark .status-badge-cancelled {
    background: rgba(107, 114, 128, 0.15);
    color: #9ca3af;
}

.dark .status-badge-pending {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}

.dark .status-badge-terminated {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

/* View Section */
.view-section {
    margin-bottom: 24px;
}

.view-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.view-section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.view-section-action {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.view-section-action:hover {
    background: var(--sb-bg-hover);
}

.view-section-action .icon {
    font-size: 14px;
    color: var(--sb-text-muted);
}

/* View Card */
.view-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    overflow: hidden;
}

/* View Table */
.view-table {
    width: 100%;
    border-collapse: collapse;
}

.view-table th {
    text-align: left;
    padding: 10px 16px;
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--sb-bg-hover);
    border-bottom: 1px solid var(--sb-border-color);
}

.view-table td {
    padding: 12px 16px;
    font-size: 14px;
    color: var(--sb-text-primary);
    border-bottom: 1px solid var(--sb-border-color);
}

.view-table tr:last-child td {
    border-bottom: none;
}

.view-table .cell-price {
    font-weight: 500;
}

.view-table .cell-muted {
    color: var(--sb-text-muted);
}

.view-table .cell-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 500;
    background: var(--sb-primary-tint);
    color: var(--sb-primary);
    border-radius: 4px;
}

.view-table .table-link {
    color: var(--sb-primary);
    text-decoration: none;
}

.view-table .table-link:hover {
    text-decoration: underline;
}

.view-table-actions {
    display: flex;
    justify-content: flex-end;
}

.view-table-action {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    color: var(--sb-text-muted);
}

.view-table-action:hover {
    background: var(--sb-bg-hover);
}

/* View Empty State */
.view-empty {
    padding: 32px 16px;
    text-align: center;
    border: 2px dashed var(--sb-border-color);
    border-radius: 8px;
    background: var(--sb-empty-bg);
}

.view-empty-text {
    font-size: 14px;
    color: var(--sb-text-muted);
}

/* Product View — Linked Option Groups */
.pv-og-list {
    padding: 0;
}

.pv-og-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}

.pv-og-item:last-child {
    border-bottom: none;
}

.pv-og-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.pv-og-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

/* Communication List */
.comm-list {
    padding: 0;
}

.comm-item {
    display: flex;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}

.comm-item:last-child {
    border-bottom: none;
}

.comm-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--sb-bg-secondary);
}

.comm-icon .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
}

.comm-item-sms .comm-icon {
    background: rgba(52, 199, 89, 0.1);
}
.comm-item-sms .comm-icon .icon {
    color: #34c759;
}

.comm-item-voice .comm-icon {
    background: rgba(0, 122, 255, 0.1);
}
.comm-item-voice .comm-icon .icon {
    color: #007aff;
}

.comm-item-email .comm-icon {
    background: rgba(255, 149, 0, 0.1);
}
.comm-item-email .comm-icon .icon {
    color: #ff9500;
}

.comm-content {
    flex: 1;
    min-width: 0;
}

.comm-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}

.comm-type {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.comm-time {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.comm-subject {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.comm-body {
    font-size: 13px;
    color: var(--sb-text-secondary);
    line-height: 1.4;
    margin-bottom: 6px;
}

.comm-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
}

.comm-status {
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 500;
    text-transform: capitalize;
}

.comm-status-delivered,
.comm-status-received {
    background: rgba(52, 199, 89, 0.1);
    color: #34c759;
}

.comm-status-sent,
.comm-status-pending {
    background: rgba(255, 204, 0, 0.1);
    color: #cc9900;
}

.comm-status-failed {
    background: rgba(255, 59, 48, 0.1);
    color: #ff3b30;
}

.comm-recipient {
    color: var(--sb-text-muted);
}

.comm-item-inbound {
    background: rgba(0, 122, 255, 0.02);
}

/* Sidebar Card */
.sidebar-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 16px;
}

.sidebar-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}

.sidebar-card-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sidebar-card-action {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--sb-border-color);
    border-radius: 4px;
    cursor: pointer;
}

.sidebar-card-action:hover {
    background: var(--sb-bg-hover);
}

.sidebar-card-action .icon {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.sidebar-card-content {
    padding: 12px 16px;
}

/* Sidebar Detail Row */
.sidebar-detail {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 8px 0;
}

.sidebar-detail:first-child {
    padding-top: 0;
}

.sidebar-detail:last-child {
    padding-bottom: 0;
}

.sidebar-detail-label {
    font-size: 13px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.sidebar-detail-value {
    font-size: 13px;
    color: var(--sb-text-primary);
    text-align: right;
    word-break: break-word;
}

.sidebar-detail-value a {
    color: var(--sb-primary);
    text-decoration: none;
}

.sidebar-detail-value a:hover {
    text-decoration: underline;
}

.sidebar-detail-value .icon-copy {
    font-size: 12px;
    color: var(--sb-text-muted);
    cursor: pointer;
    margin-left: 4px;
}

.sidebar-detail-value .icon-copy:hover {
    color: var(--sb-primary);
}

/* Sidebar Empty */
.sidebar-empty {
    padding: 24px 16px;
    text-align: center;
    color: var(--sb-text-muted);
    font-size: 13px;
}

/* View Activity/Logs */
.view-log-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}

.view-log-item:last-child {
    border-bottom: none;
}

.view-log-method {
    font-size: 12px;
    font-weight: 600;
    font-family: monospace;
    padding: 2px 6px;
    border-radius: 4px;
    background: var(--sb-bg-hover);
    color: var(--sb-text-secondary);
}

.view-log-content {
    flex: 1;
    min-width: 0;
}

.view-log-path {
    font-size: 13px;
    color: var(--sb-text-primary);
    font-family: monospace;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.view-log-status {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 4px;
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

.view-log-time {
    font-size: 12px;
    color: var(--sb-text-muted);
    white-space: nowrap;
}

/* Edit Panel (Right side sheet) */
.panel-edit {
    --f7-panel-width: 480px;
}

.panel-edit .page-content {
    background: var(--sb-bg-page);
}

.panel-edit .navbar {
    background: var(--sb-bg-card);
    border-bottom: 1px solid var(--sb-border-color);
}

/* ─── Negotiation Panel ─────────────────────────────────────── */

.neg-panel {
    padding: 16px;
}

/* Timeline */
.neg-timeline {
    position: relative;
}

.neg-loading {
    display: flex;
    justify-content: center;
    padding: 32px 0;
}

.neg-error {
    text-align: center;
    padding: 24px 0;
    color: var(--sb-text-muted);
    font-size: 14px;
}

.neg-empty {
    text-align: center;
    padding: 32px 16px;
}

.neg-empty-icon {
    margin-bottom: 12px;
}

.neg-empty-icon .icon {
    font-size: 32px;
    color: var(--sb-text-muted);
    opacity: 0.5;
}

.neg-empty-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
}

.neg-empty-desc {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Round */
.neg-round {
    display: flex;
    gap: 12px;
    position: relative;
}

.neg-round + .neg-round {
    margin-top: 0;
}

.neg-round-connector {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 20px;
    flex-shrink: 0;
    padding-top: 6px;
}

.neg-round-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--sb-border-color);
    border: 2px solid var(--sb-bg-card);
    box-shadow: 0 0 0 2px var(--sb-border-color);
    flex-shrink: 0;
    z-index: 1;
}

.neg-round-latest .neg-round-dot {
    background: var(--sb-primary);
    box-shadow: 0 0 0 2px var(--sb-primary);
}

.neg-status-accepted .neg-round-dot {
    background: #22c55e;
    box-shadow: 0 0 0 2px #22c55e;
}

.neg-status-rejected .neg-round-dot {
    background: #ef4444;
    box-shadow: 0 0 0 2px #ef4444;
}

.neg-round-line {
    width: 2px;
    flex: 1;
    background: var(--sb-border-color);
    margin: 4px 0;
}

.neg-round-content {
    flex: 1;
    min-width: 0;
    padding-bottom: 20px;
}

.neg-round-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 6px;
    flex-wrap: wrap;
    gap: 6px;
}

.neg-round-header-left {
    display: flex;
    align-items: center;
    gap: 6px;
}

.neg-round-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.neg-round-status {
    display: inline-flex;
    padding: 1px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 500;
}

.neg-round-status.neg-status-proposed {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.neg-round-status.neg-status-counter_proposed {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.neg-round-status.neg-status-accepted {
    background: rgba(34, 197, 94, 0.1);
    color: #15803d;
}

.neg-round-status.neg-status-rejected {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.neg-round-status.neg-status-expired {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.neg-user-badge {
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    background: rgba(107, 114, 128, 0.15);
    color: var(--sb-text-muted);
}

.neg-round-time {
    font-size: 12px;
    color: var(--sb-text-muted);
    white-space: nowrap;
}

/* Message */
.neg-message {
    font-size: 13px;
    color: var(--sb-text-secondary);
    padding: 8px 12px;
    background: var(--sb-bg-hover, rgba(0,0,0,0.02));
    border-radius: 6px;
    margin-bottom: 8px;
    display: flex;
    align-items: flex-start;
    gap: 6px;
    line-height: 1.5;
}

.neg-message .icon {
    font-size: 14px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
    margin-top: 1px;
}

/* Term Diffs */
.neg-diff {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 8px;
}

.neg-diff-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    padding: 4px 8px;
    border-radius: 4px;
}

.neg-diff-added {
    background: rgba(34, 197, 94, 0.08);
}

.neg-diff-removed {
    background: rgba(239, 68, 68, 0.08);
}

.neg-diff-modified {
    background: rgba(245, 158, 11, 0.08);
}

.neg-diff-field {
    font-weight: 500;
    color: var(--sb-text-primary);
    min-width: 100px;
}

.neg-diff-value {
    color: var(--sb-text-secondary);
}

.neg-diff-from {
    text-decoration: line-through;
    opacity: 0.7;
}

.neg-diff-to {
    font-weight: 500;
}

.neg-diff-added .neg-diff-to {
    color: #22c55e;
}

.neg-diff-removed .neg-diff-from {
    color: #ef4444;
    text-decoration: none;
}

.neg-diff-modified .neg-diff-to {
    color: #f59e0b;
}

.neg-diff-item .icon {
    font-size: 10px;
    color: var(--sb-text-muted);
}

/* Terms Toggle */
.neg-terms-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--sb-primary);
    cursor: pointer;
    padding: 2px 0;
    user-select: none;
}

.neg-terms-toggle:hover {
    opacity: 0.8;
}

.neg-terms-toggle .icon {
    font-size: 12px;
    transition: transform 0.2s;
}

/* Terms Detail */
.neg-terms-detail {
    margin-top: 8px;
    padding: 10px 12px;
    background: var(--sb-bg-hover, rgba(0,0,0,0.02));
    border-radius: 6px;
}

.neg-term-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 12px;
    border-bottom: 1px solid var(--sb-border-color);
}

.neg-term-row:last-child {
    border-bottom: none;
}

.neg-term-label {
    color: var(--sb-text-muted);
    font-weight: 500;
}

.neg-term-value {
    color: var(--sb-text-primary);
    text-align: right;
    max-width: 60%;
    word-break: break-word;
}

.neg-terms-empty {
    font-size: 12px;
    color: var(--sb-text-muted);
    text-align: center;
    padding: 8px 0;
}

/* Actions */
.neg-actions {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--sb-border-color);
}

.neg-action-group {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.neg-btn-propose,
.neg-btn-accept,
.neg-btn-counter,
.neg-btn-reject {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.neg-btn-reject {
    color: #ef4444;
    border-color: #ef4444;
}

.neg-btn-reject:hover {
    background: rgba(239, 68, 68, 0.08);
}

/* Result badge */
.neg-result {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 12px;
}

.neg-result .icon {
    font-size: 20px;
}

.neg-result-accepted {
    background: rgba(34, 197, 94, 0.08);
    color: #15803d;
}

.neg-result-rejected {
    background: rgba(239, 68, 68, 0.08);
    color: #ef4444;
}

/* Proposal Form Overlay */
.neg-form-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 13500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

.neg-form-container {
    background: var(--sb-bg-card);
    border-radius: 12px;
    width: 100%;
    max-width: 520px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.neg-form-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--sb-border-color);
}

.neg-form-header h3 {
    margin: 0;
    font-size: 17px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.neg-form-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--sb-text-muted);
    border-radius: 6px;
}

.neg-form-close:hover {
    background: var(--sb-bg-hover);
}

.neg-form-body {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.neg-form-group {
    margin-bottom: 16px;
}

.neg-form-group:last-child {
    margin-bottom: 0;
}

.neg-form-group label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 6px;
}

.neg-required {
    color: #ef4444;
}

.neg-form-row {
    display: flex;
    gap: 12px;
}

.neg-form-row .neg-form-group {
    flex: 1;
}

.neg-input {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
    font-family: inherit;
    box-sizing: border-box;
}

.neg-input:focus {
    outline: none;
    border-color: var(--sb-primary);
    box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.1);
}

.neg-textarea {
    resize: vertical;
    min-height: 60px;
}

.neg-form-footer {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding: 16px 20px;
    border-top: 1px solid var(--sb-border-color);
}

/* Negotiation Status Indicator (deals list) */
.neg-indicator {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 500;
    padding: 2px 8px;
    border-radius: 10px;
    white-space: nowrap;
}

.neg-indicator-pending {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.neg-indicator-countered {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.neg-indicator-accepted {
    background: rgba(34, 197, 94, 0.1);
    color: #15803d;
}

.neg-indicator-rejected {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

/* Mobile Responsive */
@media (max-width: 900px) {
    .view-layout {
        flex-direction: column;
        padding: 16px;
    }

    .view-sidebar {
        width: 100%;
    }

    .view-header {
        flex-direction: column;
        gap: 16px;
    }

    .view-header-right {
        width: 100%;
        justify-content: flex-end;
    }
}

@media (max-width: 600px) {
    .view-header-icon {
        width: 40px;
        height: 40px;
    }

    .view-header-icon .icon {
        font-size: 20px;
    }

    .view-header-info h1 {
        font-size: 18px;
    }

    .view-table th,
    .view-table td {
        padding: 10px 12px;
        font-size: 13px;
    }

    .panel-edit {
        --f7-panel-width: 100%;
    }

    .neg-form-container {
        max-width: 100%;
        max-height: 100vh;
        border-radius: 0;
    }

    .neg-form-overlay {
        padding: 0;
    }

    .neg-diff-field {
        min-width: auto;
    }

    .neg-diff-item {
        flex-wrap: wrap;
    }

    .neg-action-group {
        flex-direction: column;
    }

    .neg-form-row {
        flex-direction: column;
        gap: 0;
    }
}

/* ============================================
   NEGOTIATIONS DASHBOARD
   ============================================ */

.page-negotiations .dashboard-wrapper {
    max-width: 1200px;
    padding-bottom: 80px;
}

/* Tabs */
.neg-tabs {
    margin-bottom: 20px;
}

.neg-section.hidden {
    display: none;
}

/* Poll indicator */
.neg-poll-indicator {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    opacity: 0.5;
    color: var(--f7-text-color);
}

.neg-poll-indicator .icon {
    font-size: 14px;
}

/* Active metric highlight */
.neg-metric-active .metric-value {
    color: var(--f7-theme-color);
}

/* Filter row */
.neg-filter-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.neg-filter-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 6px 28px 6px 12px;
    border: 1px solid var(--sb-border-color, #e3e8ee);
    border-radius: 6px;
    background-color: var(--sb-bg-card, #fff);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23697386' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary, #1a1f36);
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
    line-height: 1.4;
}
.neg-filter-select:hover {
    border-color: var(--sb-border-hover, #c4c9d4);
}
.neg-filter-select:focus {
    outline: none;
    border-color: var(--sb-primary, #0071e3);
    box-shadow: 0 0 0 3px var(--sb-primary-tint, rgba(0, 113, 227, 0.08));
}
.dark .neg-filter-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%238b8d98' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Table row styling */
.neg-row {
    cursor: pointer;
    transition: background 0.15s;
}

.neg-row:hover {
    background: rgba(0, 122, 255, 0.04);
}

.neg-deal-link {
    color: var(--f7-theme-color);
    text-decoration: none;
    font-family: monospace;
    font-size: 12px;
}

.neg-deal-link:hover {
    text-decoration: underline;
}

.neg-original-price {
    text-decoration: line-through;
    opacity: 0.5;
    font-size: 12px;
    margin-left: 4px;
}

/* Row actions */
.neg-row-actions {
    display: flex;
    gap: 4px;
    flex-wrap: nowrap;
}

.sb-btn-xs {
    padding: 2px 8px;
    font-size: 11px;
    min-height: auto;
    line-height: 1.6;
}

/* Status badges */
.neg-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.neg-badge-pending {
    background: #fff3cd;
    color: #856404;
}

.neg-badge-countered {
    background: #cce5ff;
    color: #004085;
}

.neg-badge-accepted {
    background: #d4edda;
    color: #155724;
}

.neg-badge-rejected {
    background: #f8d7da;
    color: #721c24;
}

.neg-badge-expired {
    background: #e2e3e5;
    color: #383d41;
}

@media (prefers-color-scheme: dark) {
    .neg-badge-pending { background: rgba(255, 193, 7, 0.2); color: #ffc107; }
    .neg-badge-countered { background: rgba(0, 123, 255, 0.2); color: #66b2ff; }
    .neg-badge-accepted { background: rgba(40, 167, 69, 0.2); color: #5cb85c; }
    .neg-badge-rejected { background: rgba(220, 53, 69, 0.2); color: #e57373; }
    .neg-badge-expired { background: rgba(108, 117, 125, 0.2); color: #adb5bd; }
}

/* Nav badge */
.neg-nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: #ef4444;
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    margin-left: auto;
}

/* Detail panel */
.neg-detail-panel {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 2px solid var(--f7-theme-color);
}

.neg-detail-actions {
    margin-top: 16px;
}

.neg-detail-actions .neg-action-group {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* Intelligence hints */
.neg-intel-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--f7-list-border-color);
}

.neg-intel-row:last-child {
    border-bottom: none;
}

.neg-intelligence-hint {
    padding: 10px 14px;
    background: rgba(255, 193, 7, 0.1);
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 16px;
    color: var(--f7-text-color);
}

.neg-intelligence-hint .icon {
    font-size: 14px;
    color: #f59e0b;
}

/* Counter form context */
.neg-counter-context {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
    padding: 12px;
    background: var(--f7-block-strong-bg-color, #f8f9fa);
    border-radius: 8px;
}

.neg-counter-context-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.neg-counter-context-item span {
    font-size: 12px;
    opacity: 0.7;
}

.neg-counter-context-item strong {
    font-size: 18px;
}

/* Auto-accept management */
.neg-auto-accept-desc {
    font-size: 14px;
    opacity: 0.7;
    margin-bottom: 16px;
    line-height: 1.5;
}

.neg-auto-accept-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: var(--f7-card-bg-color, #fff);
    border-radius: 10px;
    border: 1px solid var(--f7-list-border-color);
    margin-bottom: 12px;
}

.neg-auto-accept-name {
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 4px;
}

.neg-auto-accept-mode {
    font-size: 12px;
    opacity: 0.6;
}

.neg-auto-accept-control label {
    font-size: 12px;
    font-weight: 500;
    opacity: 0.7;
    display: block;
    margin-bottom: 4px;
}

.neg-threshold-input-row {
    display: flex;
    align-items: center;
    gap: 4px;
}

.neg-threshold-input {
    width: 70px;
    padding: 4px 8px;
    text-align: right;
}

.neg-threshold-unit {
    font-size: 13px;
    opacity: 0.6;
}

@media (max-width: 600px) {
    .neg-auto-accept-card {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .neg-row-actions {
        flex-wrap: wrap;
    }

    .neg-counter-context {
        flex-direction: column;
        gap: 8px;
    }
}

/* AI Counter-Proposal Suggestion Card */
.neg-ai-suggestion-card {
    border-left: 3px solid #8b5cf6;
}

.neg-ai-data-quality {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 8px;
    border-radius: 10px;
    background: rgba(139, 92, 246, 0.1);
    color: #8b5cf6;
}

.neg-quality-high { color: #059669; background: rgba(5, 150, 105, 0.1); }
.neg-quality-moderate { color: #d97706; background: rgba(217, 119, 6, 0.1); }
.neg-quality-low { color: #dc2626; background: rgba(220, 38, 38, 0.1); }

.neg-ai-suggestion-item {
    padding: 12px;
    border-radius: 8px;
    background: var(--f7-page-bg-color, #f5f5f5);
    margin-bottom: 8px;
    position: relative;
}

.neg-ai-suggestion-item.neg-ai-top-pick {
    background: rgba(139, 92, 246, 0.06);
    border: 1px solid rgba(139, 92, 246, 0.2);
}

.neg-ai-top-badge {
    position: absolute;
    top: -8px;
    right: 12px;
    background: #8b5cf6;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 2px 8px;
    border-radius: 8px;
}

.neg-ai-suggestion-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.neg-ai-price {
    font-size: 18px;
    font-weight: 700;
    color: var(--f7-text-color);
}

.neg-ai-confidence {
    font-size: 12px;
    font-weight: 600;
    color: #8b5cf6;
}

.neg-ai-risk {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 4px;
}

.neg-risk-low { color: #059669; background: rgba(5, 150, 105, 0.1); }
.neg-risk-medium { color: #d97706; background: rgba(217, 119, 6, 0.1); }
.neg-risk-high { color: #dc2626; background: rgba(220, 38, 38, 0.1); }

.neg-ai-rationale {
    font-size: 13px;
    line-height: 1.5;
    color: var(--f7-text-color);
    opacity: 0.85;
    margin-bottom: 6px;
}

.neg-ai-risk-detail {
    font-size: 12px;
    color: #d97706;
    margin-bottom: 6px;
}

.neg-ai-win-delta {
    font-size: 12px;
    font-weight: 600;
    color: #059669;
}

.neg-ai-apply-btn {
    margin-top: 8px;
}

.neg-ai-actions {
    margin-top: 8px;
}

.neg-ai-meta {
    font-size: 11px;
    opacity: 0.5;
    text-align: right;
}

.neg-ai-type-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #888;
    margin-bottom: 4px;
}

.neg-ai-insufficient {
    padding: 12px 0;
    font-size: 13px;
    color: #888;
    display: flex;
    align-items: center;
    gap: 6px;
}

.neg-ai-insufficient .icon {
    font-size: 16px;
    flex-shrink: 0;
}

.neg-ai-compact-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    font-weight: 600;
    color: #8b5cf6;
    background: rgba(139, 92, 246, 0.1);
    border-radius: 4px;
    padding: 2px 6px;
    margin-left: 4px;
    cursor: default;
    white-space: nowrap;
}

.neg-ai-compact-badge .icon {
    font-size: 12px;
}

/* ============================================
   RIGHT FORM PANEL (Offcanvas style)
   ============================================ */

#form-panel {
    --f7-panel-width: 480px;
    --f7-panel-shadow: -4px 0 20px rgba(0, 0, 0, 0.15);
}


/* Panel backdrop */
.panel-backdrop {
    background: rgba(0, 0, 0, 0.3);
}

@media (max-width: 600px) {
    #form-panel {
        --f7-panel-width: 100%;
    }
}

/* ============================================
   FORM POPUP (App mode)
   ============================================ */

#form-popup {
    --f7-popup-border-radius: 0;
}

#form-popup .navbar {
    --f7-navbar-bg-color: var(--f7-page-bg-color);
    --f7-navbar-border-color: var(--sb-border-color, #e5e7eb);
}

/* In standalone/app mode, force the form popup to always cover the full screen.
   Without this, F7 9.x's built-in responsive popup behavior renders the popup as
   a centered 630×630 dialog on screens ≥ 630px, leaving background page content
   (catalogue header, family filter chips) visible above the popup header. */
body.layout-app #form-popup {
    left: 0 !important;
    top: 0 !important;
    margin-left: 0 !important;
    margin-top: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 !important;
}

/* ============================================
   STRIPE-STYLE FORM INPUTS
   ============================================ */

/* Card styling for form sections */
.page .card {
    background: var(--sb-bg-card);
    border-radius: 8px;
    border: 1px solid var(--sb-border-color);
    box-shadow: none;
    margin: 16px;
}

.page .card-header {
    background: transparent;
    border-bottom: none;
    padding: 16px 16px 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    min-height: auto;
}

.page .card-header:after {
    display: none;
}

.page .card-content {
    padding: 0 16px 16px;
}

/* List inside cards - remove borders */
.page .card .list {
    margin: 0;
    padding: 0px 16px 28px;
}

.page .card .list ul {
    background: transparent;
}

.page .card .list ul:before,
.page .card .list ul:after {
    display: none;
}

/* Item styling */
.page .list .item-content {
    padding-left: 0;
    min-height: auto;
}

.page .list .item-inner {
    padding-right: 0;
    min-height: auto;
}

.page .list .item-inner:after {
    display: none;
}

/* Label styling - above input */
.page .list .item-title.item-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    margin-bottom: 6px;
    width: auto;
    max-width: none;
    flex-shrink: 0;
}

/* Input wrapper */
.page .list .item-input-wrap {
    width: 100%;
}

/* All text inputs, textareas, selects */
.page .list input[type="text"],
.page .list input[type="email"],
.page .list input[type="password"],
.page .list input[type="number"],
.page .list input[type="tel"],
.page .list input[type="url"],
.page .list input[type="date"],
.page .list input[type="time"],
.page .list input[type="datetime-local"],
.page .list textarea,
.page .list select {
    background: var(--sb-bg-input);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    padding: 10px 12px;
    font-size: 14px;
    color: var(--sb-text-primary);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    width: 100%;
    box-sizing: border-box;
    height: auto;
    min-height: 40px;
}

.page .list textarea {
    min-height: 80px;
    resize: none;
    overflow: hidden;
    line-height: 1.5;
}

/* Focus state - purple/blue border */
.page .list input:focus,
.page .list textarea:focus,
.page .list select:focus {
    outline: none;
    border-color: var(--sb-primary);
    box-shadow: 0 0 0 3px var(--sb-primary-tint);
}

/* Hover state */
.page .list input:hover:not(:focus),
.page .list textarea:hover:not(:focus),
.page .list select:hover:not(:focus) {
    border-color: var(--sb-border-hover);
}

/* Placeholder styling */
.page .list input::placeholder,
.page .list textarea::placeholder {
    color: var(--sb-text-muted);
    opacity: 1;
}

/* Select dropdown styling */
.page .list select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23697386' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 40px;
    cursor: pointer;
}

/* Remove Framework7's default hairlines */
.page .list .item-input-wrap:after,
.page .list .item-input-wrap:before {
    display: none !important;
}

/* Phone input with country code selector */
.page .list .item-input-wrap.phone-input-group {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 8px;
    align-items: center;
    width: 100%;
}

.page .list .phone-input-group .phone-country-select {
    flex: 0 0 110px !important;
    width: 110px !important;
    min-width: 110px !important;
    max-width: 110px !important;
    padding-right: 24px;
    font-size: 14px;
}

.page .list .phone-input-group .phone-number-input {
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
}

/* Dark mode adjustments */
.dark .page .list select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238b8d98' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}

/* Input error state */
.page .list input.input-invalid,
.page .list textarea.input-invalid,
.page .list select.input-invalid {
    border-color: #df1b41;
}

.page .list input.input-invalid:focus,
.page .list textarea.input-invalid:focus,
.page .list select.input-invalid:focus {
    box-shadow: 0 0 0 3px rgba(223, 27, 65, 0.1);
}

/* Helper/description text below inputs */
.page .list .item-input-info {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 6px;
    line-height: 1.4;
}

/* Error message */
.page .list .item-input-error-message {
    font-size: 12px;
    color: #df1b41;
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Required indicator */
.page .list .item-title.item-label .required,
.page .list .item-title.item-label:has(+ .item-input-wrap input[required])::after {
    color: #df1b41;
}

/* Toggle/Choice buttons (like InfrastructureLike's Recurring/One-off) */
.stripe-toggle {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
}

.stripe-toggle-btn {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-input);
    color: var(--sb-text-secondary);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    text-align: center;
}

.stripe-toggle-btn:hover {
    border-color: var(--sb-border-hover);
}

.stripe-toggle-btn.active {
    border-color: var(--sb-primary);
    background: var(--sb-primary-tint);
    color: var(--sb-primary);
}

/* Section headers inside forms */
.form-section-header {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 24px 0 12px;
    padding: 0;
}

.form-section-header:first-child {
    margin-top: 0;
}

/* Inline input groups (like price + currency) */
.input-group {
    display: flex;
    gap: 8px;
}

.input-group .input-main {
    flex: 1;
}

.input-group .input-addon {
    width: 100px;
    flex-shrink: 0;
}

/* Checkbox styling */
.page .list .checkbox {
    --f7-checkbox-size: 18px;
    --f7-checkbox-border-radius: 4px;
}

/* Action buttons at bottom of form */
.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 16px;
    border-top: 1px solid var(--sb-border-color);
    margin-top: 16px;
}

.form-actions .button {
    min-width: 80px;
    height: 36px;
    font-size: 14px;
    font-weight: 500;
    border-radius: 6px;
}

.form-actions .button-outline {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    color: var(--sb-text-secondary);
}

.form-actions .button-outline:hover {
    background: var(--sb-bg-hover);
}

.form-actions .button-fill {
    background: var(--sb-primary);
    color: #fff;
}

.form-actions .button-fill:hover {
    background: var(--sb-primary-hover);
}

/* Autocomplete dropdown styling */
.autocomplete-dropdown {
    border: 1px solid var(--sb-border-color) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
    margin-top: 4px !important;
    background: var(--sb-bg-card) !important;
    overflow: visible !important;
    max-height: none !important;
}

.autocomplete-dropdown .autocomplete-dropdown-inner {
    overflow: visible !important;
    max-height: none !important;
    display: flex;
    flex-direction: column;
}

.autocomplete-dropdown .list {
    max-height: 220px;
    overflow-y: auto;
    flex-shrink: 1;
}

.autocomplete-dropdown .list ul {
    background: var(--sb-bg-card);
}

.autocomplete-dropdown .list li {
    padding: 10px 12px;
    cursor: pointer;
    transition: background 0.1s ease;
}

.autocomplete-dropdown .list li:hover {
    background: var(--sb-bg-hover);
}

/* Autocomplete "Add new" button */
.autocomplete-add-new {
    border-top: 1px solid var(--sb-border-color);
    padding: 8px 12px;
    background: var(--sb-bg-card);
    border-radius: 0 0 8px 8px;
    flex-shrink: 0;
    position: relative;
    z-index: 10;
}

.autocomplete-add-new .add-new-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    color: var(--sb-primary);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    border-radius: 6px;
    transition: background 0.1s ease;
}

.autocomplete-add-new .add-new-link:hover {
    background: var(--sb-primary-tint);
}

.autocomplete-add-new .add-new-link .icon {
    font-size: 18px;
}

/* ==========================================================================
   Import Page Styles
   Uses existing wizard component styles from onboarding.
   Only import-specific functional styles below.
   ========================================================================== */

/* Required fields info box */
.import-info-box {
    margin-top: 24px;
    padding: 16px;
    background: var(--sb-bg-surface);
    border-radius: 8px;
    border: 1px solid var(--sb-border-color);
}

.import-info-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    margin-bottom: 8px;
}

.import-info-content {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.import-required-field {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--sb-primary-tint);
    color: var(--sb-primary);
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
}

.upload-file-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.upload-file-info .icon {
    font-size: 32px;
    color: var(--sb-primary);
}

.upload-file-details {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.upload-file-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.upload-file-size {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.page[data-name="import"] .upload-placeholder-icon .icon {
    font-size: 48px;
    color: var(--sb-text-muted);
}

/* Column mapping list */
.import-mapping-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 24px;
}

.import-mapping-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
}

.import-mapping-csv {
    flex: 1;
    min-width: 0;
}

.import-mapping-header {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.import-mapping-sample {
    display: block;
    font-size: 12px;
    color: var(--sb-text-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.import-mapping-arrow {
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.import-mapping-arrow .icon {
    font-size: 16px;
}

.import-mapping-field {
    flex: 1;
    min-width: 0;
}

.import-mapping-select {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-input);
    color: var(--sb-text-primary);
    cursor: pointer;
}

.import-mapping-select:focus {
    outline: none;
    border-color: var(--sb-primary);
    box-shadow: 0 0 0 3px var(--sb-primary-tint);
}

/* Default Values Section */
.import-defaults-section {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--sb-border-color);
}

.import-defaults-header {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 12px;
}

.import-defaults-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.import-defaults-hint {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.import-defaults-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 12px;
}

.import-default-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--sb-bg-surface);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
}

.import-default-field {
    flex: 1;
    min-width: 0;
}

.import-default-field select {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-input);
    color: var(--sb-text-primary);
    cursor: pointer;
}

.import-default-field select:focus {
    outline: none;
    border-color: var(--sb-primary);
}

.import-default-equals {
    color: var(--sb-text-muted);
    font-size: 14px;
    flex-shrink: 0;
}

.import-default-value {
    flex: 1;
    min-width: 0;
}

.import-default-value input {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-input);
    color: var(--sb-text-primary);
}

.import-default-value input:focus {
    outline: none;
    border-color: var(--sb-primary);
    box-shadow: 0 0 0 3px var(--sb-primary-tint);
}

.import-default-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--sb-text-muted);
    cursor: pointer;
    flex-shrink: 0;
}

.import-default-remove:hover {
    background: var(--sb-bg-hover);
    color: var(--sb-danger);
}

.import-default-remove .icon {
    font-size: 16px;
}

.import-add-default-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    background: transparent;
    border: 1px dashed var(--sb-primary);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.import-add-default-btn:hover {
    background: var(--sb-primary-tint);
}

.import-add-default-btn .icon {
    font-size: 16px;
}

.import-mapping-status {
    width: 24px;
    flex-shrink: 0;
    text-align: center;
}

.import-mapping-status .icon {
    font-size: 18px;
}

/* Preview box */
.import-preview-box {
    margin-top: 24px;
}

.import-preview-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    margin-bottom: 12px;
}

.import-preview-scroll {
    overflow-x: auto;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
}

.import-preview-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.import-preview-table th,
.import-preview-table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid var(--sb-border-color);
    white-space: nowrap;
}

.import-preview-table th {
    background: var(--sb-bg-surface);
    font-weight: 600;
    color: var(--sb-text-secondary);
}

.import-preview-table td {
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
}

.import-preview-table tr:last-child td {
    border-bottom: none;
}

/* Validation summary */
.import-summary {
    margin-bottom: 24px;
}

.import-validation-cards {
    display: flex;
    gap: 16px;
}

.import-validation-card {
    flex: 1;
    padding: 24px;
    border-radius: 12px;
    text-align: center;
}

.import-validation-success {
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.import-validation-warning {
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.import-validation-number {
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 4px;
}

.import-validation-success .import-validation-number {
    color: #10b981;
}

.import-validation-warning .import-validation-number {
    color: #f59e0b;
}

.import-validation-label {
    font-size: 14px;
    color: var(--sb-text-secondary);
}

/* Errors box */
.import-errors-box {
    margin-top: 24px;
}

.import-errors-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.import-errors-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-secondary);
}

.import-errors-header .checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    cursor: pointer;
}

.import-errors-header .checkbox-label input {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.import-errors-list {
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    overflow: hidden;
    max-height: 300px;
    overflow-y: auto;
}

.import-error-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: var(--sb-bg-card);
    border-bottom: 1px solid var(--sb-border-color);
    font-size: 13px;
}

.import-error-item:last-child {
    border-bottom: none;
}

.import-error-row {
    flex-shrink: 0;
    padding: 2px 8px;
    background: var(--sb-bg-surface);
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted);
}

.import-error-field {
    flex-shrink: 0;
    font-weight: 500;
    color: var(--sb-text-secondary);
}

.import-error-message {
    flex: 1;
    color: #ef4444;
}

.import-error-duplicate .import-error-message {
    color: #f59e0b;
}

.import-error-more {
    padding: 10px 12px;
    text-align: center;
    font-size: 13px;
    color: var(--sb-text-muted);
    background: var(--sb-bg-surface);
}

/* Results page */
.import-results-header {
    text-align: center;
    padding-bottom: 24px;
}

.import-results-icon {
    margin-bottom: 16px;
}

.import-results-icon .icon {
    font-size: 64px;
}

.import-results-stats {
    display: flex;
    justify-content: center;
    gap: 24px;
    margin-bottom: 24px;
}

.import-result-stat {
    padding: 24px 40px;
    border-radius: 12px;
    text-align: center;
}

.import-result-success {
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.2);
}

.import-result-skipped {
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.import-result-number {
    font-size: 48px;
    font-weight: 700;
    margin-bottom: 4px;
}

.import-result-success .import-result-number {
    color: #10b981;
}

.import-result-skipped .import-result-number {
    color: #f59e0b;
}

.import-result-label {
    font-size: 14px;
    color: var(--sb-text-secondary);
}

.import-results-errors {
    margin-top: 24px;
}

.import-results-errors-header {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    margin-bottom: 12px;
}

.import-results-errors-list {
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    overflow: hidden;
}

/* Mobile responsive */
@media (max-width: 480px) {
    .import-mapping-row {
        flex-wrap: wrap;
    }

    .import-mapping-csv {
        flex: 0 0 100%;
        margin-bottom: 8px;
    }

    .import-mapping-arrow {
        display: none;
    }

    .import-mapping-field {
        flex: 1;
    }

    .import-validation-cards {
        flex-direction: column;
    }

    .import-results-stats {
        flex-direction: column;
        align-items: center;
    }

    .import-result-stat {
        width: 100%;
        max-width: 200px;
    }
}

/* ==========================================================================
   Chat Page - Claude Assistant
   ========================================================================== */

.layout-app .page-chat {
    z-index: 601;
}
.page-chat .page-content {
    display: flex;
    padding: 0;
    height: 100%;
}

.chat-page-content {
    display: flex;
    flex-direction: row;
    height: 100%;
    overflow: hidden;
}

/* Context Popup */
.chat-context-popup.popup {
    --f7-popup-tablet-width: 400px;
    --f7-popup-tablet-height: 70vh;
}

.chat-context-popup .page {
    background: var(--sb-bg-card);
}

.context-panel-content {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
}

.context-info {
    padding: 8px 12px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    margin-bottom: 12px;
}

.context-info p {
    margin: 0;
    font-size: 12px;
    color: var(--sb-text-secondary);
}

/* File Tree */
.file-tree {
    font-size: 13px;
}

.file-tree-item {
    user-select: none;
}

.file-tree-item-content {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 8px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.1s ease;
}

.file-tree-item-content:hover {
    background: var(--sb-bg-hover);
}

.file-tree-item.selected > .file-tree-item-content {
    background: var(--sb-primary-tint);
    color: var(--sb-primary);
}

.file-tree-item .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.file-tree-item.directory > .file-tree-item-content .folder-toggle .icon {
    color: var(--sb-primary);
}

.file-tree-item.selected > .file-tree-item-content .icon {
    color: var(--sb-primary);
}

.folder-toggle {
    display: flex;
    align-items: center;
}

.folder-select {
    display: flex;
    align-items: center;
    margin-left: auto;
    opacity: 0;
    transition: opacity 0.15s ease;
    padding: 4px;
    border-radius: 4px;
}

.file-tree-item-content:hover .folder-select {
    opacity: 1;
}

.folder-select:hover,
.folder-select:active {
    background: var(--sb-primary-tint);
}

.folder-select .icon {
    font-size: 14px;
    color: var(--sb-primary);
}

/* Always show folder select on touch devices / app mode */
@media (hover: none), (pointer: coarse) {
    .folder-select {
        opacity: 1;
    }
}

body.layout-app .folder-select {
    opacity: 1;
}

.file-name {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.file-ext {
    color: var(--sb-text-muted);
    font-size: 11px;
}

.file-tree-children {
    padding-left: 16px;
    display: none;
}

.file-tree-item.directory.expanded > .file-tree-children {
    display: block;
}

/* Selected Files */
.selected-files {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--sb-border-color);
}

.selected-files h5 {
    margin: 0 0 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.selected-files-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.selected-files-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 8px;
    font-size: 12px;
    background: var(--sb-bg-hover);
    border-radius: 4px;
    margin-bottom: 4px;
}

.selected-files-list li.no-files {
    color: var(--sb-text-muted);
    font-style: italic;
    background: none;
}

.selected-file-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.selected-files-list .remove-file {
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.selected-files-list .remove-file:hover {
    color: #ef4444;
}

/* Chat Area */
.chat-area {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    background: var(--sb-bg-page);
    
}

/* Messages Container */
.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding-top: calc(var(--f7-page-navbar-offset, 0px) + var(--f7-page-toolbar-top-offset, 0px) + var(--f7-page-subnavbar-offset, 0px) + var(--f7-page-searchbar-offset, 0px) + var(--f7-page-content-extra-padding-top, 0px)) !important;
}

/* Welcome Screen */
.chat-welcome {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 60px 24px;
    max-width: 600px;
    margin: auto;
}

.welcome-icon {
    width: 64px;
    height: 64px;
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
}

.welcome-icon .icon {
    font-size: 32px;
    color: #fff;
}

.chat-welcome h2 {
    margin: 0 0 12px;
    font-size: 24px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.chat-welcome p {
    margin: 0 0 32px;
    color: var(--sb-text-secondary);
    font-size: 15px;
    line-height: 1.6;
}

.welcome-suggestions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
}

.suggestion-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 20px;
    font-size: 13px;
    color: var(--sb-text-primary);
    cursor: pointer;
    transition: all 0.15s ease;
}

.suggestion-chip:hover {
    border-color: var(--sb-primary);
    background: var(--sb-primary-tint);
}

.suggestion-chip .icon {
    font-size: 14px;
    color: var(--sb-primary);
}

/* Chat Messages */
.chat-message {
    display: flex;
    gap: 12px;
    max-width: 900px;
}

.chat-message.user {
    flex-direction: row-reverse;
    margin-left: auto;
}

.message-avatar {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: var(--sb-bg-hover);
}

.chat-message.assistant .message-avatar {
    background: linear-gradient(135deg, var(--sb-primary), var(--sb-primary-gradient));
}

.chat-message.assistant .message-avatar .icon {
    font-size: 16px;
    color: #fff;
}


.chat-message.user .message-avatar .icon {
    font-size: 16px;
}

.chat-message.error .message-avatar {
    background: #fef2f2;
}

.chat-message.error .message-avatar .icon {
    color: #ef4444;
}

.message-content {
    flex: 1;
    min-width: 0;
}

.message-text {
    padding: 12px 16px;
    border-radius: 12px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--sb-text-primary);
}

.chat-message.user .message-text {
    background: var(--sb-primary);
    color: #fff;
    border-bottom-right-radius: 4px;
}

.chat-message.assistant .message-text {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-bottom-left-radius: 4px;
}

.chat-message.error .message-text {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
}

/* Code blocks in messages */
.message-text pre.code-block {
    margin: 12px 0;
    padding: 16px;
    background: #1e1e1e;
    border-radius: 8px;
    overflow-x: auto;
    font-size: 13px;
    line-height: 1.5;
}

.message-text pre.code-block code {
    color: #d4d4d4;
    font-family: 'SF Mono', Monaco, 'Cascadia Code', Consolas, monospace;
}

.message-text code.inline-code {
    padding: 2px 6px;
    background: var(--sb-bg-hover);
    border-radius: 4px;
    font-size: 13px;
    font-family: 'SF Mono', Monaco, 'Cascadia Code', Consolas, monospace;
}

.chat-message.user .message-text code.inline-code {
    background: rgba(255, 255, 255, 0.2);
}

/* Code block with file path and Apply button */
.code-block-wrapper {
    margin: 12px 0;
    border-radius: 8px;
    overflow: hidden;
    background: #1e1e1e;
}

.code-block-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 12px;
    background: #2d2d2d;
    border-bottom: 1px solid #3d3d3d;
}

.code-file-path {
    font-size: 12px;
    font-family: 'SF Mono', Monaco, 'Cascadia Code', Consolas, monospace;
    color: #9cdcfe;
}

.apply-code-btn {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border: none;
    background: var(--sb-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 500;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.apply-code-btn:hover:not(:disabled) {
    background: var(--sb-primary-hover);
}

.apply-code-btn:disabled {
    cursor: default;
}

.apply-code-btn.applied {
    background: #22c55e;
}

.apply-code-btn.loading {
    background: var(--sb-text-muted);
    pointer-events: none;
}

.apply-code-btn .icon {
    font-size: 12px;
}

.apply-code-btn .preloader {
    width: 14px;
    height: 14px;
}

.code-block-wrapper pre.code-block {
    margin: 0;
    border-radius: 0;
}

/* File write compact card (mobile-friendly) */
.file-write-card {
    margin: 8px 0;
    border-radius: 8px;
    background: var(--sb-bg-elevated);
    border: 2px solid var(--sb-border-color);
    overflow: hidden;
}

.file-write-card.applied {
    border-color: #22c55e;
}

.file-write-card.failed {
    border-color: #ef4444;
}

.file-write-card.pending {
    border-color: var(--sb-primary);
}

.file-write-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 10px;
    gap: 6px;
}

.file-write-card.applied .file-write-card-header {
    background: rgba(34, 197, 94, 0.06);
}

.file-write-card.failed .file-write-card-header {
    background: rgba(239, 68, 68, 0.06);
}

.file-write-card.pending .file-write-card-header {
    background: rgba(0, 113, 227, 0.06);
}

.file-write-card-info {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    flex: 1;
}

.file-write-card-info .file-icon {
    font-size: 14px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.file-write-card-path {
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-family: 'SF Mono', Monaco, 'Cascadia Code', Consolas, monospace;
}

.file-write-card-status {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 6px;
    font-size: 10px;
    font-weight: 600;
    border-radius: 3px;
    flex-shrink: 0;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.file-write-card-status.applied {
    background: rgba(34, 197, 94, 0.15);
    color: #15803d;
}

.file-write-card-status.failed {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.file-write-card-status.pending {
    background: rgba(0, 113, 227, 0.15);
    color: var(--sb-primary);
}

.file-write-card-status .icon {
    font-size: 10px;
}

.file-write-card-error {
    padding: 6px 10px;
    background: rgba(239, 68, 68, 0.08);
    color: #ef4444;
    font-size: 11px;
    border-top: 1px solid rgba(239, 68, 68, 0.15);
}

.file-write-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 10px;
    border-top: 1px solid var(--sb-border-color);
    background: var(--sb-bg-secondary);
}

.file-write-card-meta {
    font-size: 10px;
    color: var(--sb-text-muted);
}

.file-write-toggle-btn {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 3px 6px;
    font-size: 11px;
    font-weight: 500;
    color: var(--sb-primary);
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    white-space: nowrap;
}

.file-write-toggle-btn:active {
    background: var(--sb-bg-hover);
}

.file-write-toggle-btn .icon {
    font-size: 10px;
}

.file-write-code-container {
    max-height: 400px;
    overflow: auto;
    transition: max-height 0.3s ease;
}

.file-write-code-container.collapsed {
    max-height: 0;
    overflow: hidden;
}

.file-write-code-container pre.code-block {
    margin: 0;
    border-radius: 0;
}

/* Thinking block (Claude's reasoning) */
.thinking-block {
    margin-bottom: 12px;
    background: var(--sb-bg-hover);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--sb-border-color);
}

.thinking-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    cursor: pointer;
    user-select: none;
    transition: background 0.15s ease;
}

.thinking-header:hover {
    background: var(--sb-bg-elevated);
}

.thinking-header .icon:first-child {
    font-size: 16px;
    color: var(--sb-primary);
}

.thinking-header span {
    flex: 1;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
}

.thinking-toggle {
    font-size: 14px !important;
    color: var(--sb-text-muted);
    transition: transform 0.2s ease;
}

.thinking-block.collapsed .thinking-toggle {
    transform: rotate(-90deg);
}

.thinking-content {
    padding: 12px;
    padding-top: 0;
    font-size: 13px;
    line-height: 1.6;
    color: var(--sb-text-muted);
    white-space: pre-wrap;
    word-break: break-word;
    max-height: 300px;
    overflow-y: auto;
}

.thinking-block.collapsed .thinking-content {
    display: none;
}

/* Loading indicator with rotating messages */
.loading-indicator {
    color: var(--sb-text-muted);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.loading-indicator span {
    animation: fadeInOut 2s ease-in-out infinite;
}

@keyframes fadeInOut {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

/* Hide loading indicator when message has content */
.chat-message:not(.streaming) .loading-indicator {
    display: none;
}

/* Streaming message state - hide empty message text when loading */
.chat-message.streaming .message-text:empty {
    display: none;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

.chat-message.streaming .thinking-content:empty::after {
    content: '▊';
    animation: blink 1s step-end infinite;
    color: var(--sb-text-muted);
}

/* Error text in messages */
.error-text {
    color: #ef4444;
}

/* Typing indicator */
.typing-indicator {
    display: flex;
    gap: 4px;
    padding: 8px 0;
}

.typing-indicator span {
    width: 8px;
    height: 8px;
    background: var(--sb-text-muted);
    border-radius: 50%;
    animation: typing 1.4s infinite ease-in-out both;
}

.typing-indicator span:nth-child(1) { animation-delay: -0.32s; }
.typing-indicator span:nth-child(2) { animation-delay: -0.16s; }

@keyframes typing {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40% { transform: scale(1); opacity: 1; }
}

/* Input Area */
.chat-input-area {
    padding: 16px 24px 24px;
    background: var(--sb-bg-page);
    border-top: 1px solid var(--sb-border-color);
}

.chat-input-container {
    max-width: 900px;
    margin: 0 auto;
}

.context-indicator {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    background: var(--sb-primary-tint);
    border-radius: 8px 8px 0 0;
    font-size: 12px;
    color: var(--sb-primary);
}

.context-indicator .icon {
    font-size: 14px;
}

.chat-input-wrapper {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 8px 12px;
    transition: border-color 0.15s ease;
}

.chat-input-wrapper:focus-within {
    border-color: var(--sb-primary);
}

.context-indicator + .chat-input-wrapper {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

#chat-input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 14px;
    line-height: 1.5;
    resize: none;
    min-height: 24px;
    max-height: 200px;
    padding: 4px 0;
    color: var(--sb-text-primary);
}

#chat-input:focus {
    outline: none;
}

#chat-input::placeholder {
    color: var(--sb-text-muted);
}

.chat-send-btn {
    min-width: 44px;
    min-height: 44px;
    border: none;
    background: transparent;
    color: var(--sb-primary);
    cursor: pointer;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.chat-send-btn:hover:not(:disabled) {
    background: var(--sb-primary-tint);
}

.chat-send-btn:disabled {
    color: var(--sb-text-muted);
    cursor: not-allowed;
}

.chat-send-btn .icon {
    font-size: 24px;
}

/* Stop button state */
.chat-send-btn.stop-btn {
    color: #ef4444;
}

.chat-send-btn.stop-btn:hover {
    background: rgba(239, 68, 68, 0.1);
}

/* Microphone button */
.chat-mic-btn {
    min-width: 44px;
    min-height: 44px;
    border: none;
    background: transparent;
    color: var(--sb-text-muted);
    cursor: pointer;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.chat-mic-btn:hover {
    background: var(--sb-bg-secondary);
    color: var(--sb-text-primary);
}

.chat-mic-btn .icon {
    font-size: 20px;
}

/* Listening state - pulsing red */
.chat-mic-btn.listening {
    color: #ef4444;
    animation: mic-pulse 1.5s ease-in-out infinite;
}

.chat-mic-btn.listening:hover {
    background: rgba(239, 68, 68, 0.1);
}

@keyframes mic-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Mic not supported state */
.chat-mic-btn.not-supported {
    display: none;
}

/* Voice mode button in navbar */
#voice-mode-btn.active {
    color: var(--sb-primary);
}

#voice-mode-btn.active .icon {
    animation: voice-mode-pulse 2s ease-in-out infinite;
}

@keyframes voice-mode-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* Voice mode overlay indicator */
.voice-mode-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.voice-mode-overlay.active {
    opacity: 1;
    visibility: visible;
}

.voice-mode-visual {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: var(--sb-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    transition: all 0.3s ease;
}

.voice-mode-visual .icon {
    font-size: 48px;
    color: white;
}

/* Listening state */
.voice-mode-overlay.listening .voice-mode-visual {
    animation: listening-pulse 1.5s ease-in-out infinite;
    box-shadow: 0 0 0 0 rgba(0, 113, 227, 0.7);
}

@keyframes listening-pulse {
    0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(0, 113, 227, 0.7); }
    50% { transform: scale(1.05); box-shadow: 0 0 0 20px rgba(0, 113, 227, 0); }
    100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(0, 113, 227, 0); }
}

/* Thinking state */
.voice-mode-overlay.thinking .voice-mode-visual {
    background: #f59e0b;
    animation: thinking-spin 2s linear infinite;
}

@keyframes thinking-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Speaking state */
.voice-mode-overlay.speaking .voice-mode-visual {
    background: #10b981;
    animation: speaking-bounce 0.6s ease-in-out infinite;
}

@keyframes speaking-bounce {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.voice-mode-status {
    color: white;
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 8px;
}

.voice-mode-hint {
    color: rgba(255, 255, 255, 0.6);
    font-size: 14px;
}

.voice-mode-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
}

.voice-mode-close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.voice-mode-close .icon {
    font-size: 24px;
}

/* Stopped text in messages */
.stopped-text {
    color: var(--sb-text-muted);
    font-style: italic;
}

.chat-input-hint {
    margin-top: 8px;
    font-size: 11px;
    color: var(--sb-text-muted);
    text-align: center;
}

/* Responsive Chat Styles */
@media (max-width: 768px) {
    .chat-messages {
        padding: 16px;
    }

    .chat-input-area {
        padding: 12px 16px 16px;
    }

    .welcome-suggestions {
        flex-direction: column;
    }

    .suggestion-chip {
        width: 100%;
        justify-content: center;
    }
}

/* =============================================
   API Plugin - InfrastructureLike-inspired Styles
   ============================================= */

/* Stats Grid (reusable component) */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 24px;
}

@media (max-width: 640px) {
    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.stat-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 16px;
    text-align: center;
}

.stat-value {
    font-size: 24px;
    font-weight: 600;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.stat-value.success {
    color: #10b981;
}

.stat-value.error {
    color: #ef4444;
}

.stat-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

.api-empty-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 8px;
}

.api-empty-text {
    font-size: 14px;
    color: var(--sb-text-muted);
    max-width: 300px;
    margin: 0 auto 20px;
}

.api-empty-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    background: var(--sb-primary);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.api-empty-btn:hover {
    background: var(--sb-primary-hover);
}

.api-empty-btn .icon {
    font-size: 16px;
}

/* API Section */
.api-section {
    margin-bottom: 24px;
}

.api-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.api-section-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    margin: 0;
}

.api-section-action {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.api-section-action:hover {
    text-decoration: underline;
}

/* API Card */
.api-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    overflow: hidden;
}

/* API Key Row */
.api-key-row {
    display: flex;
    align-items: center;
    padding: 14px 16px;
    gap: 14px;
    border-bottom: 1px solid var(--sb-border-color);
}

.api-key-row:last-child {
    border-bottom: none;
}

.api-key-icon {
    width: 36px;
    height: 36px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.api-key-icon .icon {
    font-size: 16px;
    color: var(--sb-primary);
}

.api-key-icon.test {
    background: #fef3c7;
}

.api-key-icon.test .icon {
    color: #d97706;
}

.api-key-content {
    flex: 1;
    min-width: 0;
}

.api-key-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.api-key-prefix {
    font-size: 13px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--sb-text-muted);
}

.api-key-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

.api-key-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* API Status Badge */
.api-status {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.api-status.active {
    background: var(--sb-success-bg);
    color: var(--sb-success-text);
}

.api-status.revoked {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

/* API Guide Card */
.api-guide-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    padding: 20px;
}

/* API Code Label */
.api-code-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}

/* API Code Block */
.api-code-block {
    background: var(--sb-bg-tertiary);
    border-radius: 8px;
    padding: 14px 16px;
    overflow-x: auto;
}

.api-code-block code {
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 13px;
    color: var(--sb-text-secondary);
    white-space: pre-wrap;
    word-break: break-all;
}

/* API Navigation List */
.api-nav-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.api-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--sb-text-secondary);
    font-size: 14px;
    font-weight: 500;
    transition: background-color 0.15s ease;
}

.api-nav-item:hover {
    background: var(--sb-bg-hover);
}

.api-nav-item .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
}

/* API Endpoint */
.api-endpoint {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 12px;
}

.api-endpoint:last-child {
    margin-bottom: 0;
}

.api-endpoint-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.api-endpoint-path {
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 14px;
    color: var(--sb-text-primary);
    font-weight: 500;
}

.api-endpoint-desc {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 0;
    line-height: 1.5;
}

.api-endpoint-params {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* API Method Badge */
.api-method {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    flex-shrink: 0;
}

.api-method.get {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.api-method.post {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.api-method.patch {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.api-method.delete {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

/* API Parameter Item */
.api-param-item {
    display: flex;
    align-items: center;
    gap: 12px;
}

.api-param-name {
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-primary);
    background: var(--sb-bg-tertiary);
    padding: 2px 6px;
    border-radius: 4px;
    min-width: fit-content;
}

.api-param-desc {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* API Tester Form */
.api-tester-form {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    overflow: hidden;
}

.api-tester-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--sb-border-color);
    gap: 12px;
}

.api-tester-row:last-child {
    border-bottom: none;
}

.api-tester-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-muted);
    min-width: 80px;
    flex-shrink: 0;
}

.api-tester-select {
    flex: 1;
    padding: 8px 12px;
    background: var(--sb-bg-tertiary);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    color: var(--sb-text-primary);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
}

.api-tester-input {
    flex: 1;
    padding: 8px 12px;
    background: var(--sb-bg-tertiary);
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    color: var(--sb-text-primary);
}

.api-tester-input:focus,
.api-tester-select:focus {
    outline: none;
    border-color: var(--sb-primary);
}

.api-tester-textarea {
    width: 100%;
    min-height: 150px;
    padding: 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 13px;
    color: var(--sb-text-primary);
    resize: vertical;
    box-sizing: border-box;
}

.api-tester-textarea:focus {
    outline: none;
    border-color: var(--sb-primary);
}

/* API Response Card */
.api-response-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    overflow: hidden;
}

.api-response-body {
    max-height: 400px;
    overflow: auto;
}

.api-response-body pre {
    margin: 0;
    padding: 16px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 12px;
    color: var(--sb-text-secondary);
    white-space: pre-wrap;
    word-break: break-all;
}

/* Log Row (for API logs and similar) */
.log-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 12px;
    border-bottom: 1px solid var(--sb-border-color);
}

.log-row:last-child {
    border-bottom: none;
}

.log-method {
    min-width: 50px;
}

/* Method Badge (reusable) */
.method-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    flex-shrink: 0;
}

.method-badge.get {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
}

.method-badge.post {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.method-badge.patch {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.method-badge.delete {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.log-status {
    font-size: 12px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 4px;
    min-width: 36px;
    text-align: center;
}

.log-status.success {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.log-status.warning {
    background: rgba(245, 158, 11, 0.1);
    color: #f59e0b;
}

.log-status.error {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.log-content {
    flex: 1;
    min-width: 0;
}

.log-path {
    font-size: 13px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--sb-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.log-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.log-time {
    font-size: 12px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.log-time.fast {
    color: #10b981;
}

.log-time.medium {
    color: #f59e0b;
}

.log-time.slow {
    color: #ef4444;
}

/* =============================================
   Analytics Plugin - Stats Dashboard Styles
   ============================================= */

/* Stats Cards Grid */
.stats-cards-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin: 16px;
}

@media (max-width: 640px) {
    .stats-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Stats Card */
.stats-card {
    margin: 0 !important;
}

.stats-card .card-content {
    text-align: center;
    padding: 16px !important;
}

.stats-value {
    font-size: 24px;
    font-weight: 600;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.stats-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

/* Analytics Lists - Override F7 defaults for clean look */
.page[data-name="analytics-dashboard"] .list,
.page[data-name="analytics-events"] .list,
.page[data-name="analytics-settings"] .list {
    margin: 0 16px 16px;
}

.page[data-name="analytics-dashboard"] .block-title,
.page[data-name="analytics-events"] .block-title,
.page[data-name="analytics-settings"] .block-title {
    margin: 24px 16px 12px;
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-secondary);
}

/* =============================================
   Generic Empty State Component
   ============================================= */

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    text-align: center;
}

.empty-state-icon {
    width: 64px;
    height: 64px;
    background: var(--sb-bg-tertiary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.empty-state-icon .icon {
    font-size: 28px;
    color: var(--sb-text-muted);
}

.empty-state-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 8px;
}

.empty-state-text {
    font-size: 14px;
    color: var(--sb-text-muted);
    max-width: 280px;
    line-height: 1.5;
}

/* =============================================
   Replay Plugin Styles
   ============================================= */

/* Replay Sessions page */
.page[data-name="replay-sessions"] .list,
.page[data-name="replay-viewer"] .list {
    margin: 0 16px 16px;
}

.page[data-name="replay-sessions"] .block-title {
    margin: 24px 16px 12px;
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-secondary);
}

/* =============================================
   Plugin Inline Styles (moved from page files)
   ============================================= */

/* Analytics Settings - Embed Code Block */
.embed-code {
    background: var(--sb-bg-tertiary);
    border-radius: 8px;
    padding: 12px;
    margin: 0 0 12px 0;
    overflow-x: auto;
}

.embed-code code {
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    font-size: 11px;
    white-space: pre-wrap;
    word-break: break-all;
    color: var(--sb-text-secondary);
}

/* Replay Viewer - Player Container */
.replay-player-container {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    border-radius: 8px;
    background: var(--sb-bg-tertiary);
}

.replay-player-container .rr-player {
    max-width: 100%;
}

.replay-player-container .rr-player__frame {
    max-width: 100%;
}

/* =============================================
   Reusable Action Rows (for plugin pages)
   ============================================= */

/* Action Row - Clickable list item with icon */
.api-action-row {
    display: flex;
    align-items: center;
    padding: 14px 16px;
    gap: 14px;
    text-decoration: none;
    border-bottom: 1px solid var(--sb-border-color);
    transition: background-color 0.15s ease;
}

.api-action-row:last-child {
    border-bottom: none;
}

.api-action-row:hover {
    background-color: var(--sb-bg-hover);
}

.api-action-row:active {
    background-color: var(--sb-border-color);
}

.api-action-icon {
    width: 36px;
    height: 36px;
    background: var(--sb-primary-tint);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.api-action-icon .icon {
    font-size: 18px;
    color: var(--sb-primary);
}

.api-action-content {
    flex: 1;
    min-width: 0;
}

.api-action-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.api-action-subtitle {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.api-action-badge {
    font-size: 12px;
    font-weight: 600;
    padding: 4px 10px;
    background: var(--sb-bg-tertiary);
    border-radius: 12px;
    color: var(--sb-text-secondary);
}

.api-action-chevron {
    font-size: 14px !important;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

/* Session Row - For replay sessions list */
.api-session-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 12px;
    text-decoration: none;
    border-bottom: 1px solid var(--sb-border-color);
    transition: background-color 0.15s ease;
}

.api-session-row:last-child {
    border-bottom: none;
}

.api-session-row:hover {
    background-color: var(--sb-bg-hover);
}

.api-session-icon {
    width: 32px;
    height: 32px;
    background: var(--sb-bg-tertiary);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.api-session-icon .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
}

.api-session-content {
    flex: 1;
    min-width: 0;
}

.api-session-title {
    font-size: 13px;
    font-weight: 500;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--sb-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.api-session-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.api-session-date {
    font-size: 12px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

/* Event Row - For analytics events list */
.api-event-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    gap: 12px;
    border-bottom: 1px solid var(--sb-border-color);
}

.api-event-row:last-child {
    border-bottom: none;
}

.api-event-icon {
    width: 32px;
    height: 32px;
    background: var(--sb-bg-tertiary);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.api-event-icon .icon {
    font-size: 14px;
    color: var(--sb-text-muted);
}

.api-event-content {
    flex: 1;
    min-width: 0;
}

.api-event-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.api-event-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
}

.api-event-time {
    font-size: 12px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

/* ========================================
   MARKETPLACE STYLES
   ======================================== */

.page-marketplace .page-content {
    overflow-x: hidden;
}

.marketplace-container {
    max-width: 1200px;
    width: 100%;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 0 24px 48px;
}

/* Hero Subtitle */
.marketplace-hero {
    padding: 16px 0 0;
    text-align: left;
}

.marketplace-hero p {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 0;
}

/* Stats Bar */
.marketplace-stats {
    display: flex;
    justify-content: center;
    gap: 48px;
    padding: 24px 0 40px;
    border-bottom: 1px solid var(--sb-border-color);
    margin-bottom: 40px;
}

.marketplace-stats .stat-item {
    text-align: center;
}

.marketplace-stats .stat-value {
    display: block;
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
    line-height: 1;
}

.marketplace-stats .stat-label {
    display: block;
    font-size: 13px;
    color: var(--sb-text-muted);
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Plugin Card */
.plugin-card {
    position: relative;
    min-width: 0; /* prevent grid item overflow on narrow viewports */
}

.plugin-card-inner {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    transition: all 0.2s ease;
}

.plugin-card-inner:hover {
    border-color: var(--sb-border-hover);
    box-shadow: 0 1px 3px rgba(50, 50, 93, 0.06);
}

.plugin-card.is-installed .plugin-card-inner {
    border-color: var(--sb-success-text);
    background: linear-gradient(to bottom, rgba(72, 187, 120, 0.05), var(--sb-bg-card));
}

/* Plugin Header */
.plugin-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
}

.plugin-icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.plugin-icon i {
    font-size: 22px;
}

.plugin-icon-content  { background: rgba(99, 91, 255, 0.08); color: #635bff; }
.plugin-icon-analytics { background: var(--sb-primary-tint); color: var(--sb-primary); }
.plugin-icon-developer { background: var(--sb-success-bg); color: var(--sb-success-text); }
.plugin-icon-tools    { background: rgba(245, 158, 11, 0.08); color: var(--sb-warning); }

.plugin-badge {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-success-text);
    background: var(--sb-success-bg);
    padding: 4px 10px;
    border-radius: 20px;
}

.plugin-badge i {
    font-size: 12px;
}

/* Plugin Content */
.plugin-content {
    flex: 1;
    margin-bottom: 20px;
}

.plugin-name {
    font-size: 17px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0 0 8px;
}

.plugin-desc {
    font-size: 14px;
    color: var(--sb-text-muted);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Plugin Footer */
.plugin-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 16px;
    border-top: 1px solid var(--sb-border-color);
}

.plugin-meta {
    display: flex;
    align-items: center;
    gap: 12px;
}

.plugin-category {
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted);
    background: var(--sb-bg-hover);
    padding: 3px 10px;
    border-radius: 999px;
}

.plugin-version {
    font-size: 12px;
    color: var(--sb-text-muted);
}


/* Empty State */
.marketplace-empty {
    text-align: center;
    padding: 40px 24px;
}

.marketplace-empty .empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 20px;
    background: var(--sb-bg-hover);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.marketplace-empty .empty-icon i {
    font-size: 28px;
    color: var(--sb-text-muted);
}

.marketplace-empty h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0 0 8px;
}

.marketplace-empty p {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 0;
}

/* Responsive */
@media (max-width: 768px) {
    .marketplace-container {
        padding: 0 16px 32px;
    }

    .marketplace-hero {
        padding: 12px 0 0;
    }

    .marketplace-stats {
        gap: 32px;
        padding: 20px 0 32px;
        margin-bottom: 32px;
    }

    .marketplace-stats .stat-value {
        font-size: 24px;
    }

    .plugin-card-inner {
        padding: 20px;
    }

    .plugin-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .plugin-actions {
        width: 100%;
    }

    .plugin-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ==========================================
   Usage Page Styles
   ========================================== */

.usage-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
    padding: 0;
}

.usage-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
    margin: 0;
}

.usage-period {
    font-size: 14px;
    color: var(--sb-text-muted);
    margin: 4px 0 0;
}

.usage-period-select {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 14px;
    color: var(--sb-text-primary);
    cursor: pointer;
}

.usage-period-select:focus {
    outline: none;
    border-color: var(--sb-primary);
}

/* Stats Grid */
.usage-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 0;
    margin-bottom: 32px;
}

.usage-stat-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 16px;
}

.usage-stat-card.usage-stat-primary {
    grid-column: span 2;
    padding-bottom: 12px;
}

.usage-stat-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.usage-stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
}

.usage-stat-primary .usage-stat-value {
    font-size: 36px;
    background: linear-gradient(135deg, var(--sb-primary) 0%, var(--sb-primary-gradient) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Mini Chart */
.usage-stat-chart {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    height: 60px;
    margin-top: 16px;
    padding-top: 8px;
    border-top: 1px solid var(--sb-border-color);
}

.usage-mini-bar {
    flex: 1;
    background: linear-gradient(180deg, var(--sb-primary) 0%, var(--sb-primary-gradient) 100%);
    border-radius: 2px;
    min-height: 2px;
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.usage-mini-bar:hover {
    opacity: 0.8;
}

/* Services Grid */
.usage-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}

.usage-service-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 20px;
}

.usage-service-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.usage-service-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.usage-service-icon-chat {
    background: rgba(0, 113, 227, 0.15);
    color: #007fff;
}

.usage-service-icon-realtime {
    background: rgba(34, 197, 94, 0.15);
    color: #15803d;
}

.usage-service-icon-whisper {
    background: rgba(59, 130, 246, 0.15);
    color: #3b82f6;
}

.usage-service-icon-sms {
    background: rgba(249, 115, 22, 0.15);
    color: #f97316;
}

.usage-service-icon-voice {
    background: rgba(20, 184, 166, 0.15);
    color: #14b8a6;
}

.usage-service-icon-email {
    background: rgba(236, 72, 153, 0.15);
    color: #ec4899;
}

.usage-service-info {
    flex: 1;
}

.usage-service-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.usage-service-model {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.usage-service-stats {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
}

.usage-service-stat {
    display: flex;
    flex-direction: column;
}

.usage-service-stat-value {
    font-size: 18px;
    font-weight: 700;
    color: var(--sb-text-primary);
}

.usage-service-stat-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.usage-service-bar {
    height: 6px;
    background: var(--sb-bg-hover);
    border-radius: 3px;
    overflow: hidden;
}

.usage-service-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.5s ease;
}

.usage-bar-purple {
    background: linear-gradient(90deg, #0071e3 0%, #4da3ff 100%);
}

.usage-bar-green {
    background: linear-gradient(90deg, #22c55e 0%, #4ade80 100%);
}

.usage-bar-blue {
    background: linear-gradient(90deg, #3b82f6 0%, #60a5fa 100%);
}

.usage-bar-orange {
    background: linear-gradient(90deg, #f97316 0%, #fb923c 100%);
}

.usage-bar-teal {
    background: linear-gradient(90deg, #14b8a6 0%, #2dd4bf 100%);
}

.usage-bar-pink {
    background: linear-gradient(90deg, #ec4899 0%, #f472b6 100%);
}

/* Activity List */
.usage-activity-list {
    min-height: 100px;
}

.usage-activity-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}

.usage-activity-empty {
    padding: 40px 20px;
    text-align: center;
    color: var(--sb-text-muted);
    font-size: 14px;
}

.usage-activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}

.usage-activity-item:last-child {
    border-bottom: none;
}

.usage-activity-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.usage-activity-content {
    flex: 1;
    min-width: 0;
}

.usage-activity-desc {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.usage-activity-time {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.usage-activity-badge {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 4px 8px;
    border-radius: 4px;
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
}

/* Budget stat card (inside usage stats grid) */
.usage-stat-budget .usage-stat-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.budget-edit-link {
    font-size: 12px;
    font-weight: 500;
    color: var(--f7-theme-color);
}

.budget-stat-bar {
    height: 6px !important;
    border-radius: 3px;
    margin-top: 8px;
}

.budget-stat-sub {
    font-size: 12px;
    color: var(--sb-text-muted, var(--f7-list-item-footer-text-color));
    margin-top: 4px;
}

.budget-stat-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 8px;
}

/* Budget Progress (on budget form page) */
.budget-progress-display {
    text-align: center;
}

.budget-progress-amounts {
    margin-bottom: 12px;
}

.budget-progress-spent {
    font-size: 24px;
    font-weight: 700;
    color: var(--sb-text-primary, var(--f7-text-color));
}

.budget-progress-limit {
    font-size: 14px;
    color: var(--sb-text-muted, var(--f7-list-item-footer-text-color));
}

.budget-progress-display .progressbar {
    height: 8px;
    border-radius: 4px;
    margin-bottom: 8px;
}

.budget-progress-percent {
    font-size: 13px;
    color: var(--sb-text-muted, var(--f7-list-item-footer-text-color));
}

/* Dark mode adjustments */
.dark .usage-stat-primary .usage-stat-value {
    background: linear-gradient(135deg, #4da3ff 0%, #99ccff 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.dark .usage-service-icon-chat {
    background: rgba(77, 163, 255, 0.2);
    color: #4da3ff;
}

.dark .usage-service-icon-realtime {
    background: rgba(74, 222, 128, 0.2);
    color: #4ade80;
}

.dark .usage-service-icon-whisper {
    background: rgba(96, 165, 250, 0.2);
    color: #60a5fa;
}

.dark .usage-service-icon-sms {
    background: rgba(251, 146, 60, 0.2);
    color: #fb923c;
}

.dark .usage-service-icon-voice {
    background: rgba(45, 212, 191, 0.2);
    color: #2dd4bf;
}

.dark .usage-service-icon-email {
    background: rgba(244, 114, 182, 0.2);
    color: #f472b6;
}

/* Mobile adjustments */
@media (max-width: 600px) {
    .usage-header {
        flex-direction: column;
        gap: 12px;
    }

    .usage-period-select {
        width: 100%;
    }

    .usage-stats-grid {
        grid-template-columns: 1fr;
    }

    .usage-stat-card.usage-stat-primary {
        grid-column: span 1;
    }

    .usage-services-grid {
        grid-template-columns: 1fr;
    }

    .usage-service-stats {
        flex-wrap: wrap;
    }
}

/* ─── System Admin ─────────────────────────────────────────── */

/* Impersonation Banner */
.impersonation-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 12000;
    background: #f59e0b;
    color: #1a1a1a;
    font-size: 13px;
    font-weight: 500;
    padding-top: env(safe-area-inset-top, 0px);
}

.impersonation-banner-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 6px 16px;
}

.impersonation-banner-inner i {
    font-size: 14px;
}

.impersonation-exit {
    margin-left: 12px;
    color: #1a1a1a;
    font-weight: 600;
    text-decoration: underline;
    cursor: pointer;
}

body.is-impersonating #app {
    padding-top: 32px;
}

body.is-impersonating .panel {
    top: 32px;
}

/* System settings rate input */
.system-rate-input {
    display: flex;
    align-items: center;
    gap: 4px;
}

.system-rate-field {
    width: 72px;
    text-align: right;
    padding: 6px 8px;
    border: 1px solid var(--f7-list-item-border-color);
    border-radius: 6px;
    font-size: 14px;
    background: var(--f7-list-bg-color);
    color: var(--f7-text-color);
}

.system-rate-unit {
    font-size: 13px;
    color: var(--f7-list-item-footer-text-color);
    min-width: 14px;
}

.system-rate-unit-left {
    order: -1;
}

.system-save-row {
    padding: 8px 16px 20px;
}

.system-save-row .button {
    max-width: 280px;
}

/* ================================================
   AI Website Generator Styles
   ================================================ */

.ai-gen-step .catalogue-header {
    padding-bottom: 8px;
}

.ai-progress-item .ai-progress-icon {
    color: var(--sb-text-muted);
    transition: color 0.3s ease;
}

.ai-progress-item .ai-progress-icon.checkmark_circle_fill {
    color: var(--sb-success);
}

.preloader-central {
    display: block;
    margin: 0 auto;
}

/* Sidebar bottom section (sign-out when no tenant popover) */
.sidebar-section-bottom {
    margin-top: auto;
    padding-bottom: 16px;
}

/* Notification bell positioning */
.notification-bell-link {
    position: relative;
}

/* Sandbox mode segmented toggle */
.sandbox-toggle {
    display: inline-flex;
    align-items: center;
    background: var(--f7-bars-bg-color, #f5f5f5);
    border-radius: 6px;
    padding: 2px;
    cursor: pointer;
    margin-right: 4px;
}
.sandbox-toggle-opt {
    display: block;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
    color: var(--f7-bars-text-color, #999);
    transition: all 0.2s ease;
    user-select: none;
}
/* Live mode active (default) — --sb-success-text (#047857) gives 5.38:1 contrast with white (WCAG AA) */
.sandbox-toggle:not(.sandbox-active) .sandbox-toggle-opt[data-mode="live"] {
    background: var(--sb-success-text);
    color: #fff;
    box-shadow: 0 1px 3px rgba(4, 120, 87, 0.3);
}
/* Dark mode: use a mid-toned green that maintains white text readability */
.dark .sandbox-toggle:not(.sandbox-active) .sandbox-toggle-opt[data-mode="live"] {
    background: #047857;
    box-shadow: 0 1px 3px rgba(4, 120, 87, 0.3);
}
/* Test mode active */
.sandbox-toggle.sandbox-active .sandbox-toggle-opt[data-mode="test"] {
    background: #ff9500;
    color: #fff;
    box-shadow: 0 1px 3px rgba(255, 149, 0, 0.3);
}
/* Inline sandbox bar — sits in page content below catalogue-header */
.widgets-sandbox-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 16px 16px;
}
.widgets-help-btn {
    color: var(--sb-text-muted) !important;
    font-size: 20px;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.sandbox-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: #fff3e0;
    color: #e65100;
    font-size: 13px;
    font-weight: 500;
    border-bottom: 1px solid #ffe0b2;
}
.sandbox-banner .icon {
    font-size: 16px;
}

/* ─── Deal Template Pages ──────────────────────────────────── */

/* Search bar */
.tpl-search-bar {
    padding: 0 16px 16px;
}
.tpl-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    background: var(--f7-page-bg-color);
}
.tpl-search-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-tertiary);
}
.tpl-search-wrap input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 14px;
    color: var(--sb-text-primary);
}

/* Template cards grid */
.tpl-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
    padding-bottom: 24px;
}
.tpl-card {
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    background: var(--sb-bg-card);
    padding: 16px;
    transition: box-shadow 0.15s, border-color 0.15s;
}
.tpl-card:hover {
    border-color: var(--sb-primary, #007aff);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.tpl-card-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.tpl-card-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--sb-primary-subtle, #e8f0fe);
    display: flex;
    align-items: center;
    justify-content: center;
}
.tpl-card-icon .icon {
    font-size: 18px;
    color: var(--sb-primary, #007aff);
}
.tpl-card-title-wrap {
    flex: 1;
    min-width: 0;
}
.tpl-card-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.tpl-card-desc {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin: 2px 0 0;
    line-height: 1.4;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.tpl-card-more {
    flex-shrink: 0;
    border: none;
    background: none;
    cursor: pointer;
    padding: 4px;
    border-radius: 6px;
    color: var(--sb-text-tertiary);
}
.tpl-card-more:hover {
    background: var(--sb-hover-bg, #f5f5f5);
    color: var(--sb-text-primary);
}
.tpl-card-more .icon {
    font-size: 18px;
}
.tpl-card-meta {
    display: flex;
    gap: 16px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--sb-border-light, #f0f0f0);
}
.tpl-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--sb-text-tertiary);
}
.tpl-meta-item .icon {
    font-size: 12px;
}
.tpl-card-footer {
    margin-top: 12px;
    display: flex;
    justify-content: flex-end;
}
.tpl-version-badge {
    color: var(--sb-primary, #007aff);
    font-weight: 500;
}
.tpl-card-value {
    color: var(--sb-text-secondary);
    font-weight: 500;
}
.tpl-no-results {
    text-align: center;
    padding: 40px 20px;
    color: var(--sb-text-tertiary);
    font-size: 14px;
}

/* Product family card image icon */
.pf-card-image {
    background-color: transparent !important;
    border-radius: 8px;
    overflow: hidden;
}
.pf-card .tpl-card-meta {
    flex-wrap: wrap;
}

/* Product family badge on products list */
.product-family-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 4px;
    background: var(--sb-primary-subtle, #e8f0fe);
    color: var(--sb-primary, #007aff);
    font-size: 11px;
    font-weight: 500;
    line-height: 1.4;
}

/* Family filter chips on products list */
.family-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 0 0 12px;
}
.family-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    border-radius: 16px;
    border: 1px solid var(--sb-border-color);
    background: var(--sb-bg-card);
    color: var(--sb-text-secondary);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s;
}
.family-filter-chip:hover {
    border-color: var(--sb-primary, #007aff);
    color: var(--sb-primary, #007aff);
}
.family-filter-chip.active {
    background: var(--sb-primary, #007aff);
    border-color: var(--sb-primary, #007aff);
    color: #fff;
}

/* Template form */
.card-header-action {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: var(--sb-primary, #007aff);
    cursor: pointer;
    text-decoration: none;
}
.card-header-action .icon {
    font-size: 14px;
}
.card-header-action:hover {
    opacity: 0.8;
}

/* Line items builder */
.tpl-line-items {
    padding: 0 16px 16px;
}
.tpl-line-items-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px;
    color: var(--sb-text-tertiary);
    font-size: 13px;
    text-align: center;
}
.tpl-line-items-empty .icon {
    font-size: 28px;
    opacity: 0.4;
}
.tpl-line-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    background: var(--f7-page-bg-color);
}
.tpl-line-item-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.tpl-line-item-product {
    flex: 1;
}
.tpl-line-item-product input {
    width: 100%;
    padding: 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    background: var(--sb-bg-card);
}
.tpl-line-item-fields {
    display: flex;
    gap: 8px;
}
.tpl-li-field {
    flex: 1;
}
.tpl-li-field label {
    display: block;
    font-size: 11px;
    color: var(--sb-text-tertiary);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.tpl-li-field input {
    width: 100%;
    padding: 6px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 13px;
    background: var(--sb-bg-card);
}
.tpl-line-item-remove {
    flex-shrink: 0;
    border: none;
    background: none;
    cursor: pointer;
    padding: 8px;
    color: var(--sb-text-tertiary);
    border-radius: 6px;
}
.tpl-line-item-remove:hover {
    background: var(--f7-color-red-tint, #fff0f0);
    color: var(--f7-color-red, #ff3b30);
}
.tpl-line-item-remove .icon {
    font-size: 16px;
}

/* Template preview */
.tpl-preview {
    padding: 16px;
}
.tpl-preview-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px;
    color: var(--sb-text-tertiary);
    font-size: 13px;
    text-align: center;
}
.tpl-preview-empty .icon {
    font-size: 28px;
    opacity: 0.4;
}
.tpl-preview-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.tpl-preview-table th {
    font-weight: 600;
    text-align: left;
    padding: 8px;
    border-bottom: 2px solid var(--sb-border-color);
    color: var(--sb-text-secondary);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.tpl-preview-table td {
    padding: 8px;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
    color: var(--sb-text-primary);
}
.tpl-preview-table tfoot td {
    border-bottom: none;
}
.tpl-preview-total-row td {
    padding-top: 12px;
    border-top: 2px solid var(--sb-border-color);
    font-size: 14px;
}

/* Template selector on deal form */
.template-selector-bar {
    padding: 0 0 12px;
}
.template-selector-inner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border: 1px solid var(--sb-primary-subtle, #e8f0fe);
    border-radius: 8px;
    background: var(--sb-primary-subtle, #f0f5ff);
}
.template-selector-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary, #007aff);
    white-space: nowrap;
}
.template-selector-label .icon {
    font-size: 16px;
}
.template-selector-dropdown {
    flex: 1;
    padding: 6px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 13px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
}

/* Save as Template button on deal view */
.save-as-template-btn {
    font-size: 13px !important;
    color: var(--sb-primary, #007aff) !important;
    white-space: nowrap;
}

/* Responsive */
@media (max-width: 600px) {
    .tpl-cards-grid {
        grid-template-columns: 1fr;
    }
    .tpl-line-item-fields {
        flex-direction: column;
    }
    .template-selector-inner {
        flex-direction: column;
        align-items: stretch;
    }
}

/* ================================================================
   Multi-Lookup Chips Field (#177)
   ================================================================ */

.multi-lookup-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    min-height: 0;
    margin-bottom: 4px;
}

.multi-lookup-chips:empty {
    margin-bottom: 0;
}

.multi-lookup-chips .chip {
    font-size: 13px;
}

.multi-lookup-chips .chip-delete {
    cursor: pointer;
}

/* ================================================================
   Agent Delegations — Settings & Dashboard (#76)
   ================================================================ */

/* Settings icon color */
.sb-card-row-icon-delegations {
    background: rgba(16, 185, 129, 0.1);
}

.sb-card-row-icon-delegations .icon {
    color: #10b981;
}

/* Filter chips */
.deleg-filters {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.deleg-filter-chip {
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    background: var(--sb-bg-card);
    color: var(--sb-text-secondary);
    border: 1px solid var(--sb-border-color);
    cursor: pointer;
    transition: all 0.15s ease;
    user-select: none;
}

.deleg-filter-chip:hover {
    border-color: var(--sb-primary);
    color: var(--sb-primary);
}

.deleg-filter-chip.active {
    background: var(--sb-primary);
    color: #fff;
    border-color: var(--sb-primary);
}

/* Delegation cards */
.deleg-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.deleg-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 16px;
    transition: border-color 0.15s ease;
    cursor: pointer;
}

.deleg-card:hover {
    border-color: var(--sb-primary);
}

.deleg-card-alert {
    border-color: #ef4444;
}

.deleg-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.deleg-card-agent {
    display: flex;
    align-items: center;
    gap: 8px;
}

.deleg-card-agent .icon {
    font-size: 18px;
    color: var(--sb-text-muted);
}

.deleg-card-key {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
    font-family: 'SF Mono', 'Fira Code', monospace;
}

/* Status badges */
.deleg-status {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.deleg-status-active {
    background: rgba(16, 185, 129, 0.12);
    color: #059669;
}

.deleg-status-expired {
    background: rgba(107, 114, 128, 0.12);
    color: #6b7280;
}

.deleg-status-revoked {
    background: rgba(239, 68, 68, 0.12);
    color: #dc2626;
}

.deleg-card-scopes {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-bottom: 12px;
    font-family: 'SF Mono', 'Fira Code', monospace;
}

.deleg-card-metrics {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.deleg-card-metric {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.deleg-metric-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.deleg-metric-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

/* Spending progress bar */
.deleg-spending-bar {
    width: 100%;
    height: 4px;
    background: var(--sb-border-color);
    border-radius: 2px;
    overflow: hidden;
    margin: 8px 0;
}

.deleg-spending-fill {
    height: 100%;
    background: var(--sb-primary);
    border-radius: 2px;
    transition: width 0.3s ease;
}

.deleg-spending-fill.deleg-bar-danger {
    background: #ef4444;
}

/* Card actions */
.deleg-card-actions {
    display: flex;
    gap: 16px;
    padding-top: 10px;
    border-top: 1px solid var(--sb-border-color);
    margin-top: 4px;
}

.deleg-card-actions a {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.deleg-card-actions .deleg-action-revoke {
    color: #ef4444;
}

/* Empty state */
.deleg-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--sb-text-muted);
}

.deleg-empty .icon {
    font-size: 48px;
    margin-bottom: 16px;
    opacity: 0.4;
}

.deleg-empty h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 8px;
}

.deleg-empty p {
    font-size: 14px;
    margin-bottom: 20px;
}

.deleg-create-empty-btn {
    background: var(--sb-primary) !important;
    color: #fff !important;
}

.deleg-loading {
    display: flex;
    justify-content: center;
    padding: 32px;
}

.deleg-error {
    text-align: center;
    padding: 32px;
    color: var(--sb-text-muted);
    font-size: 14px;
}

.hidden {
    display: none !important;
}

/* Sheet modal styles for delegations */
.deleg-sheet,
.deleg-detail-sheet {
    height: 85vh;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
}

/* Scope picker */
.deleg-scopes {
    padding: 0 16px 16px;
}

.deleg-scope-group {
    margin-bottom: 16px;
}

.deleg-scope-group-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}

.deleg-scope-select-all,
.deleg-scope-select-none {
    font-size: 11px;
    text-transform: none;
    font-weight: 500;
    color: var(--sb-primary);
    margin-left: 4px;
}

.deleg-scope-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 14px;
    color: var(--sb-text-primary);
    cursor: pointer;
}

.deleg-scope-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--sb-primary);
}

/* Detail view */
.deleg-detail {
    padding: 16px;
}

.deleg-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
}

.deleg-detail-agent {
    display: flex;
    align-items: center;
    gap: 12px;
}

.deleg-detail-agent .icon {
    font-size: 24px;
    color: var(--sb-text-muted);
}

.deleg-detail-key {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    font-family: 'SF Mono', 'Fira Code', monospace;
}

.deleg-detail-id {
    font-size: 11px;
    color: var(--sb-text-muted);
    font-family: 'SF Mono', 'Fira Code', monospace;
}

.deleg-detail-section {
    margin-bottom: 24px;
}

.deleg-detail-section h3 {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    margin-bottom: 12px;
}

.deleg-detail-spend-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.deleg-spend-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.deleg-spend-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
}

/* Scope badges */
.deleg-detail-scopes {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.deleg-scope-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    font-family: 'SF Mono', 'Fira Code', monospace;
    background: rgba(0, 113, 227, 0.08);
    color: var(--sb-primary);
    border: 1px solid rgba(0, 113, 227, 0.2);
}

.deleg-detail-none {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Info rows */
.deleg-detail-info {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.deleg-info-row {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
}

.deleg-info-row span:first-child {
    color: var(--sb-text-muted);
}

.deleg-info-row span:last-child {
    color: var(--sb-text-primary);
    font-weight: 500;
}

/* Activity timeline */
.deleg-activity-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.deleg-timeline-item {
    display: flex;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--sb-border-color);
}

.deleg-timeline-item:last-child {
    border-bottom: none;
}

.deleg-timeline-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--sb-primary);
    margin-top: 5px;
    flex-shrink: 0;
}

.deleg-timeline-content {
    flex: 1;
    min-width: 0;
}

.deleg-timeline-action {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.deleg-timeline-meta {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    color: var(--sb-text-muted);
}

.deleg-activity-empty {
    text-align: center;
    padding: 20px;
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Detail actions */
.deleg-detail-actions {
    display: flex;
    gap: 12px;
    padding-top: 16px;
}

.deleg-detail-actions .button {
    flex: 1;
}

.deleg-detail-edit-btn {
    background: var(--sb-primary) !important;
    color: #fff !important;
}

/* Delegation form page */
.dform-scope-group {
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
}

.dform-scope-group:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.dform-scope-group-title {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}

.dform-scope-group-name {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.dform-scope-group-desc {
    display: block;
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.dform-scope-group-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

.dform-scope-select-all,
.dform-scope-select-none {
    font-size: 12px;
    font-weight: 500;
    color: var(--sb-primary);
}

.dform-scope-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 14px;
    color: var(--sb-text-primary);
    cursor: pointer;
}

.dform-scope-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--sb-primary);
}

/* Dashboard delegation widget */
.dashboard-section-link {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.deleg-widget-alert-value {
    color: #ef4444 !important;
}

.deleg-widget-recent {
    margin-top: 12px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 12px 16px;
}

.deleg-widget-recent-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}

.deleg-widget-recent-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.deleg-widget-recent-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
}

.deleg-widget-recent-action {
    color: var(--sb-text-primary);
    font-weight: 500;
}

.deleg-widget-recent-time {
    color: var(--sb-text-muted);
    font-size: 12px;
}

/* Responsive */
@media (max-width: 600px) {
    .deleg-card-metrics {
        flex-direction: column;
        gap: 8px;
    }

    .deleg-detail-header {
        flex-direction: column;
        gap: 12px;
    }

    .deleg-sheet,
    .deleg-detail-sheet {
        height: 90vh;
    }

    .deleg-detail-actions {
        flex-direction: column;
    }
}

/* ── Delegation View Page (#481) ── */

.page-delegation-view .dv-overview-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
}

.dv-overview-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--sb-primary-light, rgba(99,102,241,.1));
    display: flex;
    align-items: center;
    justify-content: center;
}

.dv-overview-icon .f7-icons {
    font-size: 22px;
    color: var(--sb-primary);
}

.dv-overview-id {
    font-size: 12px;
    font-family: monospace;
    color: var(--sb-text-muted);
    margin-bottom: 4px;
}

.dv-overview-card .dv-info-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 16px;
}

.dv-info-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
}

.dv-info-label {
    color: var(--sb-text-muted);
    flex-shrink: 0;
    min-width: 80px;
}

.dv-info-value {
    color: var(--sb-text-primary);
    text-align: right;
    word-break: break-all;
}

.dv-monospace {
    font-family: monospace;
    font-size: 12px;
}

.dv-section-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}

.dv-scopes-section {
    border-top: 1px solid var(--sb-border-light, #f0f0f0);
    padding-top: 12px;
    margin-top: 4px;
}

.dv-scopes-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.dv-no-scopes {
    color: var(--sb-text-muted);
    font-size: 13px;
}

/* Spending Summary */
.dv-spend-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.dv-spend-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dv-spend-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.dv-spend-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--sb-text-primary);
}

.dv-spend-limit {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.dv-spend-sublabel {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.dv-spending-bar {
    height: 6px;
    background: var(--sb-border-light, #f0f0f0);
    border-radius: 3px;
    overflow: hidden;
    margin-top: 2px;
}

.dv-spending-fill {
    height: 100%;
    background: var(--sb-primary);
    border-radius: 3px;
    transition: width .3s ease;
}

.dv-spending-fill.deleg-bar-warning {
    background: #f59e0b;
}

.dv-spending-fill.deleg-bar-danger {
    background: #ef4444;
}

/* ROI Card */
.dv-roi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

.dv-roi-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dv-roi-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    font-weight: 500;
}

.dv-roi-value {
    font-size: 18px;
    font-weight: 700;
    color: var(--sb-text-primary);
}

.dv-roi-highlight .dv-roi-value {
    color: var(--sb-primary);
}

/* 30-day chart */
.dv-chart-wrap {
    padding: 4px 0 8px;
}

.dv-chart-bars {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 80px;
    overflow: hidden;
}

.dv-chart-bar {
    flex: 1;
    background: var(--sb-primary);
    border-radius: 2px 2px 0 0;
    opacity: 0.75;
    min-height: 2px;
    cursor: pointer;
    transition: opacity .15s;
}

.dv-chart-bar:hover {
    opacity: 1;
}

.dv-chart-labels {
    display: flex;
    gap: 2px;
    margin-top: 4px;
}

.dv-chart-label {
    flex: 1;
    text-align: center;
    font-size: 9px;
    color: var(--sb-text-muted);
    overflow: hidden;
}

.dv-chart-empty {
    color: var(--sb-text-muted);
    font-size: 14px;
    text-align: center;
    padding: 24px 0;
}

/* Deals */
.dv-deals-kpi {
    padding: 8px 16px 12px;
    font-size: 13px;
    color: var(--sb-text-muted);
}

.dv-deals-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.dv-deals-table th {
    text-align: left;
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: 6px 16px;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
}

.dv-deals-table td {
    padding: 10px 16px;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
    color: var(--sb-text-primary);
}

.dv-deal-row {
    cursor: pointer;
    transition: background .1s;
}

.dv-deal-row:hover {
    background: var(--sb-bg-hover, rgba(0,0,0,.03));
}

.dv-deal-link {
    color: var(--sb-primary);
    text-decoration: none;
    font-weight: 500;
}

.dv-section-badge {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    background: var(--sb-bg-hover, rgba(0,0,0,.06));
    border-radius: 10px;
    padding: 2px 8px;
    margin-left: 8px;
}

/* Activity Timeline */
.dv-activity-timeline {
    padding: 8px 0;
}

.dv-timeline-item {
    display: flex;
    gap: 12px;
    padding: 8px 16px;
    position: relative;
}

.dv-timeline-item:not(:last-child)::after {
    content: '';
    position: absolute;
    left: 23px;
    top: 28px;
    bottom: -8px;
    width: 1px;
    background: var(--sb-border-light, #f0f0f0);
}

.dv-timeline-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--sb-primary);
    flex-shrink: 0;
    margin-top: 4px;
    z-index: 1;
}

.dv-timeline-failure .dv-timeline-dot {
    background: #ef4444;
}

.dv-timeline-content {
    flex: 1;
    min-width: 0;
}

.dv-timeline-action {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.dv-timeline-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 2px;
    font-size: 12px;
    color: var(--sb-text-muted);
}

.dv-timeline-outcome-fail {
    color: #ef4444;
    font-weight: 600;
}

.dv-timeline-load-more {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    float: right;
}

/* Empty states */
.dv-empty-state {
    text-align: center;
    padding: 32px 16px;
    color: var(--sb-text-muted);
}

.dv-empty-state .f7-icons {
    font-size: 40px;
    opacity: 0.3;
    display: block;
    margin-bottom: 8px;
}

.dv-empty-state p {
    font-size: 14px;
    margin: 0;
}

/* Loading & Error */
.dv-loading {
    display: flex;
    justify-content: center;
    padding: 48px 0;
}

.dv-error {
    margin: 16px;
}

@media (max-width: 600px) {
    .dv-spend-grid {
        grid-template-columns: 1fr 1fr;
    }
    .dv-roi-grid {
        grid-template-columns: 1fr 1fr;
    }
    .dv-roi-highlight {
        grid-column: 1 / -1;
    }
}

/* ── Delegation View Tabs (#663) ── */

.dv-tabs-nav {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--sb-bg-primary, #fff);
    border-bottom: 1px solid var(--sb-border-color);
    margin: 0 0 8px;
}

.dv-tabs-nav .toolbar-inner {
    gap: 0;
}

.dv-tabs-nav .tab-link {
    flex: 1;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-muted);
    padding: 10px 4px;
    text-align: center;
    border-bottom: 2px solid transparent;
    text-decoration: none;
}

.dv-tabs-nav .tab-link-active {
    color: var(--sb-primary);
    border-bottom-color: var(--sb-primary);
}

.dv-tab {
    /* visibility controlled by JS */
}

/* Burn Rate Projection */
.dv-burn-rate {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dv-burn-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 0;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
}

.dv-burn-row:last-child {
    border-bottom: none;
}

.dv-burn-label {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.dv-burn-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.dv-burn-exhausted {
    color: #ef4444;
    font-weight: 700;
}

/* Audit Trail Tab */
.dv-audit-filters {
    padding: 4px 0 12px;
}

.dv-audit-filter-row {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.dv-audit-filter-input {
    flex: 1;
    min-width: 100px;
    font-size: 13px;
    padding: 6px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-input, #fff);
    color: var(--sb-text-primary);
}

.dv-audit-apply-btn {
    flex-shrink: 0;
    font-size: 13px;
    padding: 6px 14px;
    border-radius: 6px;
}

.dv-audit-list {
    padding: 0;
}

.dv-audit-entry {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 10px 16px;
    border-bottom: 1px solid var(--sb-border-light, #f0f0f0);
}

.dv-audit-entry:last-child {
    border-bottom: none;
}

.dv-audit-entry.dv-audit-failure .dv-audit-action {
    color: #ef4444;
}

.dv-audit-action {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.dv-audit-meta {
    display: flex;
    gap: 10px;
    align-items: center;
    font-size: 12px;
    color: var(--sb-text-muted);
    flex-wrap: wrap;
}

.dv-audit-entity {
    font-family: monospace;
    font-size: 11px;
    background: var(--sb-bg-code, #f5f5f5);
    padding: 1px 5px;
    border-radius: 3px;
}

.dv-audit-time {
    color: var(--sb-text-muted);
}

.dv-audit-outcome-fail {
    color: #ef4444;
    font-weight: 600;
}

.dv-audit-loading {
    display: flex;
    justify-content: center;
    padding: 20px;
}

.dv-audit-footer {
    padding: 12px 16px;
    text-align: center;
}

.dv-audit-load-more {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

/* ── Team Management ── */

.team-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.team-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 16px;
}

.team-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.team-card-info {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.team-card-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--sb-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
    flex-shrink: 0;
}

.team-card-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.team-you {
    font-weight: 400;
    font-size: 13px;
    color: var(--sb-text-muted);
}

.team-card-email {
    font-size: 13px;
    color: var(--sb-text-muted);
}

.team-card-badges {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* Role badges */
.team-role {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.team-role-blue {
    background: rgba(59, 130, 246, 0.12);
    color: #2563eb;
}

.team-role-purple {
    background: rgba(139, 92, 246, 0.12);
    color: #7c3aed;
}

.team-role-green {
    background: rgba(16, 185, 129, 0.12);
    color: #059669;
}

.team-role-gray {
    background: rgba(107, 114, 128, 0.12);
    color: #6b7280;
}

/* Status badges */
.team-status {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.team-status-pending {
    background: rgba(245, 158, 11, 0.12);
    color: #d97706;
}

.team-status-suspended {
    background: rgba(239, 68, 68, 0.12);
    color: #dc2626;
}

.team-card-meta {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-bottom: 4px;
}

.team-card-actions {
    display: flex;
    gap: 16px;
    padding-top: 10px;
    border-top: 1px solid var(--sb-border-color);
    margin-top: 8px;
}

.team-card-actions a {
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-primary);
    text-decoration: none;
}

.team-action-remove {
    color: #ef4444 !important;
}

/* Empty state */
.team-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--sb-text-muted);
}

.team-empty .icon {
    font-size: 48px;
    margin-bottom: 16px;
    opacity: 0.4;
}

.team-empty h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 8px;
}

.team-empty p {
    font-size: 14px;
    margin-bottom: 20px;
}

.team-loading {
    display: flex;
    justify-content: center;
    padding: 32px;
}

.team-error {
    text-align: center;
    padding: 32px;
    color: var(--sb-text-muted);
    font-size: 14px;
}

@media (max-width: 600px) {
    .team-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .team-card-meta {
        flex-direction: column;
        gap: 4px;
    }
}

/* ── Trust & Verification Dashboard ── */

.trust-metrics {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-top: 8px;
}

.trust-metric-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    padding: 20px 16px;
    text-align: center;
}

.trust-metric-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.trust-metric-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin-top: 4px;
}

.trust-verify-card {
    padding: 20px;
}

.trust-verify-status {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    font-size: 14px;
    color: var(--sb-text-secondary);
}

.trust-verify-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.trust-verify-progress {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 16px;
    font-size: 13px;
    color: var(--sb-text-secondary);
}

.trust-verify-result {
    margin-top: 12px;
}

.trust-result {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 6px;
}

.trust-result i {
    font-size: 16px;
    flex-shrink: 0;
}

.trust-result-verified {
    background: rgba(22, 163, 106, 0.08);
    color: #16a34a;
}

.trust-result-tampered {
    background: rgba(220, 38, 38, 0.08);
    color: #dc2626;
}

.trust-result-unsigned {
    background: rgba(107, 114, 128, 0.08);
    color: #6b7280;
}

.trust-result-error {
    background: rgba(220, 38, 38, 0.08);
    color: #dc2626;
}

.trust-key-card {
    padding: 20px;
}

.trust-key-desc {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin: 0 0 16px;
    line-height: 1.5;
}

.trust-key-display {
    background: var(--sb-bg-page);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 12px 16px;
}

.trust-key-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 6px 0;
    gap: 12px;
}

.trust-key-row + .trust-key-row {
    border-top: 1px solid var(--sb-border-color);
}

.trust-key-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
    flex-shrink: 0;
}

.trust-key-value {
    font-size: 13px;
    color: var(--sb-text-primary);
    text-align: right;
}

.trust-key-copyable {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
}

.trust-key-code {
    flex: 1;
    font-family: monospace;
    font-size: 12px;
    background: var(--sb-bg-page);
    padding: 8px 10px;
    border-radius: 6px;
    border: 1px solid var(--sb-border-color);
    word-break: break-all;
    color: var(--sb-text-primary);
}

.trust-copy-btn {
    padding: 6px 10px !important;
    min-width: auto !important;
}

/* Trust section on deal view */
.trust-card {
    padding: 16px;
}

.trust-status-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.trust-detail-grid {
    margin-top: 12px;
}

.trust-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 6px 0;
    gap: 12px;
}

.trust-detail-row + .trust-detail-row {
    border-top: 1px solid var(--sb-border-color);
}

.trust-detail-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
    flex-shrink: 0;
}

.trust-detail-value {
    font-size: 13px;
    color: var(--sb-text-primary);
    text-align: right;
}

.trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    cursor: default;
}

.trust-badge i {
    vertical-align: middle;
}

.trust-action-btns {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.trust-audit-link {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--sb-border-color);
    font-size: 12px;
}

.trust-audit-link .link {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    color: var(--f7-color-blue);
}

/* Verify page */
.page-verify .sb-card {
    padding: 20px;
    margin-bottom: 12px;
}

/* Deal Verification Dashboard */
.dv-metrics {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 16px;
}

.dv-metric-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    padding: 16px;
    text-align: center;
}

.dv-metric-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
    line-height: 1.2;
}

.dv-metric-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

.dv-actions-card {
    padding: 16px;
    margin-bottom: 16px;
}

.dv-actions-header {
    margin-bottom: 12px;
}

.dv-actions-title,
.dv-section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin: 0;
}

.dv-actions-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.dv-progress {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    color: var(--sb-text-secondary);
    font-size: 13px;
}

.dv-bulk-result {
    margin-top: 12px;
}

.dv-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px 0;
    margin-bottom: 12px;
}

.dv-filter-chips {
    display: flex;
    gap: 6px;
}

.dv-filter-chip {
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    cursor: pointer;
    border: 1px solid var(--sb-border-color);
    background: transparent;
    color: var(--sb-text-secondary);
    transition: background 0.15s, color 0.15s;
}

.dv-filter-chip.active {
    background: var(--sb-primary);
    color: #fff;
    border-color: var(--sb-primary);
}

.dv-report-table {
    margin: 0;
    border-radius: 0;
    border: none;
    box-shadow: none;
}

.dv-loading-cell {
    padding: 24px;
    text-align: center;
    color: var(--sb-text-muted);
    font-size: 13px;
}

.dv-empty-state {
    padding: 32px;
    text-align: center;
    color: var(--sb-text-muted);
}

.dv-empty-state i {
    font-size: 32px;
    display: block;
    margin-bottom: 8px;
}

.dv-section-desc {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin: 0 16px 12px;
}

.dv-url-generator {
    display: flex;
    gap: 8px;
    margin: 0 16px 12px;
    flex-wrap: wrap;
}

.sb-input {
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    background: var(--sb-bg-input);
    color: var(--sb-text-primary);
    font-size: 14px;
    outline: none;
    width: 100%;
}
.sb-input:focus {
    border-color: var(--sb-primary);
}

.dp-lookup-form {
    display: flex;
    gap: 8px;
    align-items: center;
}

.dv-url-generator .sb-input {
    flex: 1;
    min-width: 200px;
}

.dv-url-result {
    margin: 8px 16px 16px;
}

.dv-url-display {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--sb-bg-hover);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 8px 12px;
    margin-bottom: 8px;
    overflow: hidden;
}

.dv-url-display code {
    flex: 1;
    font-family: monospace;
    font-size: 12px;
    color: var(--sb-text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dv-open-link {
    font-size: 13px;
}

.dv-deal-link {
    color: var(--sb-primary);
}

@media (max-width: 640px) {
    .dv-metrics {
        grid-template-columns: repeat(2, 1fr);
    }

    .dv-actions-row {
        flex-direction: column;
    }
}

@media (max-width: 640px) {
    .trust-metrics {
        grid-template-columns: repeat(2, 1fr);
    }

    .trust-verify-actions {
        flex-direction: column;
    }

    .trust-key-row {
        flex-direction: column;
        gap: 2px;
    }

    .trust-key-value {
        text-align: left;
    }
}

.dark .trust-result-verified {
    background: rgba(22, 163, 106, 0.15);
}

.dark .trust-result-tampered,
.dark .trust-result-error {
    background: rgba(220, 38, 38, 0.15);
}

.dark .trust-result-unsigned {
    background: rgba(107, 114, 128, 0.15);
}


/* === widget-analytics page === */
.wa-funnel-step {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 0;
}
.wa-funnel-bar-wrap {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    height: 160px;
}
.wa-funnel-bar {
    width: 80%;
    border-radius: 4px 4px 0 0;
    transition: height 0.3s ease;
    min-height: 2px;
}
.wa-funnel-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
}
.wa-funnel-label {
    font-size: 11px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    text-align: center;
    margin-top: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.wa-funnel-dropoff {
    font-size: 10px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}
.wa-abandon-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--sb-border-color);
}
.wa-abandon-row:last-child {
    border-bottom: none;
}
.wa-abandon-bar {
    height: 6px;
    border-radius: 3px;
    background: #ef4444;
    transition: width 0.3s ease;
}
.wa-product-row {
    padding: 8px 0;
    border-bottom: 1px solid var(--sb-border-color);
}
.wa-product-row:last-child {
    border-bottom: none;
}
.wa-revenue-product-row {
    padding: 8px 0;
    border-bottom: 1px solid var(--sb-border-color);
}
.wa-revenue-product-row:last-child {
    border-bottom: none;
}
.wa-widget-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--sb-border-color);
    gap: 8px;
}
.wa-widget-row:last-child {
    border-bottom: none;
}
.wa-widget-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.wa-widget-stats {
    display: flex;
    gap: 16px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    flex-shrink: 0;
}
.wa-widget-stat-val {
    font-weight: 600;
    color: var(--sb-text-primary);
}

@media (max-width: 768px) {
    .wa-filters { flex-direction: column; }
    .wa-filter-group { min-width: unset !important; }
    .wa-grid-2col {
        grid-template-columns: 1fr !important;
    }
}

/* === bundle-rules page === */
.br-option-chip {
    display: inline-block;
    padding: 2px 8px;
    background: var(--sb-bg-secondary, #f0f0f5);
    border-radius: 12px;
    font-size: 11px;
    color: var(--sb-text-secondary);
}

/* === settings-notifications page === */
/* Notification Preferences Styles */
.page-notifications .notif-channel-row {
    display: flex;
    gap: 0;
    padding: 12px 16px;
    border-top: 1px solid var(--sb-border-color);
    flex-wrap: wrap;
}

.page-notifications .notif-channel-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    flex: 1;
    min-width: 140px;
}

.page-notifications .notif-channel-icon {
    font-size: 14px;
    color: var(--sb-text-muted);
}

.page-notifications .notif-channel-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
    flex: 1;
}

.page-notifications .notif-digest-item {
    min-width: 180px;
}

.page-notifications .notif-digest-select {
    font-size: 13px;
    padding: 4px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
    cursor: pointer;
}

.page-notifications .notif-category-card[data-disabled="true"] .notif-channel-row {
    opacity: 0.4;
    pointer-events: none;
}

/* Threshold inputs */
.page-notifications .notif-threshold-row .notif-input-action {
    display: flex;
    align-items: center;
    gap: 4px;
}

.page-notifications .notif-threshold-input {
    width: 72px;
    padding: 6px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    text-align: right;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
}

.page-notifications .notif-threshold-input:focus {
    border-color: var(--sb-primary, #0071e3);
}

.page-notifications .notif-input-prefix,
.page-notifications .notif-input-suffix {
    font-size: 13px;
    color: var(--sb-text-muted);
    white-space: nowrap;
}

/* Quiet hours */
.page-notifications .notif-quiet-config {
    padding: 16px;
    border-top: 1px solid var(--sb-border-color);
}

.page-notifications .notif-quiet-times {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 16px;
}

.page-notifications .notif-quiet-time-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.page-notifications .notif-quiet-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.page-notifications .notif-time-input {
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
}

.page-notifications .notif-time-input:focus {
    border-color: var(--sb-primary, #0071e3);
}

.page-notifications .notif-quiet-separator {
    color: var(--sb-text-muted);
    margin-top: 18px;
}

.page-notifications .notif-quiet-separator .icon {
    font-size: 14px;
}

.page-notifications .notif-timezone-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.page-notifications .notif-timezone-select {
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 14px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
    cursor: pointer;
    width: 100%;
}

/* Mobile */
@media (max-width: 640px) {
    .page-notifications .notif-channel-row {
        flex-direction: column;
        gap: 4px;
    }

    .page-notifications .notif-channel-item {
        min-width: unset;
    }

    .page-notifications .notif-quiet-times {
        flex-direction: column;
        gap: 12px;
    }

    .page-notifications .notif-quiet-separator {
        display: none;
    }
}

/* Notification Tabs */
.page-notifications .notif-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 20px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    overflow: hidden;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
}

.page-notifications .notif-tab {
    flex: 1;
    padding: 10px 16px;
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    user-select: none;
}

.page-notifications .notif-tab + .notif-tab {
    border-left: 1px solid var(--sb-border-color);
}

.page-notifications .notif-tab.active {
    background: var(--sb-primary, #0071e3);
    color: #fff;
}

.page-notifications .notif-tab:not(.active):hover {
    background: var(--sb-bg-tertiary, rgba(0,0,0,0.04));
}

/* Notification Rule Templates */
.page-notifications .notif-templates {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
}

.page-notifications .notif-template-card {
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    padding: 14px;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s;
    background: var(--sb-bg-card);
}

.page-notifications .notif-template-card:hover {
    border-color: var(--sb-primary, #0071e3);
    box-shadow: 0 0 0 1px var(--sb-primary, #0071e3);
}

.page-notifications .notif-template-icon {
    font-size: 20px;
    color: var(--sb-primary, #0071e3);
    margin-bottom: 8px;
}

.page-notifications .notif-template-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
}

.page-notifications .notif-template-desc {
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
}

/* Notification Rules List */
.page-notifications .notif-rules-empty {
    text-align: center;
    padding: 48px 24px;
    color: var(--sb-text-muted);
}

.page-notifications .notif-rules-empty .icon {
    font-size: 40px;
    margin-bottom: 12px;
    display: block;
    opacity: 0.5;
}

.page-notifications .notif-rules-empty-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
}

.page-notifications .notif-rules-empty-desc {
    font-size: 13px;
}

.page-notifications .notif-rule-card {
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    background: var(--sb-bg-card);
    margin-bottom: 8px;
    overflow: hidden;
}

.page-notifications .notif-rule-card[data-enabled="false"] {
    opacity: 0.55;
}

.page-notifications .notif-rule-row {
    display: flex;
    align-items: center;
    padding: 14px 16px;
    gap: 12px;
}

.page-notifications .notif-rule-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    flex-shrink: 0;
}

.page-notifications .notif-rule-icon .icon {
    font-size: 16px;
    color: var(--sb-primary, #0071e3);
}

.page-notifications .notif-rule-info {
    flex: 1;
    min-width: 0;
}

.page-notifications .notif-rule-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.page-notifications .notif-rule-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.page-notifications .notif-rule-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 1px 6px;
    border-radius: 4px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    font-size: 11px;
}

.page-notifications .notif-rule-meta-chip .icon {
    font-size: 10px;
}

.page-notifications .notif-rule-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.page-notifications .notif-rule-action-btn {
    width: 32px;
    height: 32px;
    border: none;
    background: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    color: var(--sb-text-muted);
    transition: background 0.15s, color 0.15s;
}

.page-notifications .notif-rule-action-btn:hover {
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
}

.page-notifications .notif-rule-action-btn.rule-delete-btn:hover {
    color: var(--sb-danger, #ef4444);
}

.page-notifications .notif-rule-action-btn .icon {
    font-size: 16px;
}

/* Rule Builder Sheet */
.page-notifications .notif-rule-sheet .page-content {
    padding-bottom: 32px;
}

.page-notifications .notif-rule-select {
    width: 100%;
    font-size: 14px;
    padding: 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
    cursor: pointer;
    appearance: auto;
}

.page-notifications .notif-rule-optional {
    font-size: 12px;
    font-weight: 400;
    color: var(--sb-text-muted);
}

/* Condition rows */
.page-notifications .notif-rule-conditions {
    padding: 0 16px 8px;
}

.page-notifications .notif-rule-condition-row {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 8px;
}

.page-notifications .notif-rule-condition-row select,
.page-notifications .notif-rule-condition-row input {
    flex: 1;
    font-size: 13px;
    padding: 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
    min-width: 0;
}

.page-notifications .notif-rule-condition-row select {
    cursor: pointer;
    appearance: auto;
}

.page-notifications .notif-rule-condition-row .rule-condition-field {
    flex: 2;
}

.page-notifications .notif-rule-condition-row .rule-condition-op {
    flex: 1.2;
}

.page-notifications .notif-rule-condition-row .rule-condition-value {
    flex: 1.5;
}

.page-notifications .notif-rule-condition-remove {
    width: 28px;
    height: 28px;
    border: none;
    background: none;
    cursor: pointer;
    color: var(--sb-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 6px;
}

.page-notifications .notif-rule-condition-remove:hover {
    color: var(--sb-danger, #ef4444);
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
}

.page-notifications .notif-rule-condition-remove .icon {
    font-size: 14px;
}

.page-notifications .notif-rule-add-condition {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--sb-primary, #0071e3);
    text-decoration: none;
    padding: 6px 0;
}

/* Channel checkboxes */
.page-notifications .notif-rule-channels {
    display: flex;
    gap: 12px;
    padding: 8px 16px 12px;
    flex-wrap: wrap;
}

.page-notifications .notif-rule-channel-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--sb-text-secondary);
    transition: border-color 0.15s, background 0.15s;
    user-select: none;
}

.page-notifications .notif-rule-channel-item:has(input:checked) {
    border-color: var(--sb-primary, #0071e3);
    background: rgba(0, 113, 227, 0.06);
    color: var(--sb-text-primary);
}

.page-notifications .notif-rule-channel-item input {
    display: none;
}

.page-notifications .notif-rule-channel-item .icon {
    font-size: 14px;
}

.page-notifications .notif-rule-webhook-url {
    padding: 0 16px;
}

.page-notifications .notif-rule-webhook-url .list {
    margin: 0;
}

/* Mobile rules */
@media (max-width: 640px) {
    .page-notifications .notif-templates {
        grid-template-columns: 1fr;
    }

    .page-notifications .notif-rule-condition-row {
        flex-wrap: wrap;
    }

    .page-notifications .notif-rule-condition-row select,
    .page-notifications .notif-rule-condition-row input {
        flex-basis: 100%;
    }

    .page-notifications .notif-rule-channels {
        flex-direction: column;
    }
}

/* === notification-rule-form page (#235) === */

.page[data-name="notification-rule-form"] .nrform-field-desc {
    font-size: 13px;
    color: var(--sb-text-muted);
    margin: 0 0 12px;
}

.page[data-name="notification-rule-form"] .nrform-optional {
    font-size: 12px;
    font-weight: 400;
    color: var(--sb-text-muted);
}

/* Event type search */
.page[data-name="notification-rule-form"] .nrform-event-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.page[data-name="notification-rule-form"] .nrform-event-search-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.page[data-name="notification-rule-form"] .nrform-event-search {
    flex: 1;
    font-size: 14px;
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
}

.page[data-name="notification-rule-form"] .nrform-select {
    width: 100%;
    font-size: 14px;
    padding: 4px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
}

.page[data-name="notification-rule-form"] .nrform-select option {
    padding: 6px 8px;
}

.page[data-name="notification-rule-form"] .nrform-select optgroup {
    font-weight: 600;
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Condition rows */
.page[data-name="notification-rule-form"] .nrform-condition-row {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 8px;
}

.page[data-name="notification-rule-form"] .nrform-condition-row select,
.page[data-name="notification-rule-form"] .nrform-condition-row input {
    flex: 1;
    font-size: 13px;
    padding: 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
    color: var(--sb-text-primary);
    outline: none;
    min-width: 0;
}

.page[data-name="notification-rule-form"] .nrform-condition-row select {
    cursor: pointer;
    appearance: auto;
}

.page[data-name="notification-rule-form"] .nrform-condition-row .rule-condition-field {
    flex: 2;
}

.page[data-name="notification-rule-form"] .nrform-condition-row .rule-condition-op {
    flex: 1.2;
}

.page[data-name="notification-rule-form"] .nrform-condition-row .rule-condition-value {
    flex: 1.5;
}

.page[data-name="notification-rule-form"] .nrform-condition-remove {
    width: 28px;
    height: 28px;
    border: none;
    background: none;
    cursor: pointer;
    color: var(--sb-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 6px;
}

.page[data-name="notification-rule-form"] .nrform-condition-remove:hover {
    color: var(--sb-danger, #ef4444);
    background: var(--sb-bg-secondary, var(--f7-page-bg-color));
}

.page[data-name="notification-rule-form"] .nrform-condition-remove .icon {
    font-size: 14px;
}

.page[data-name="notification-rule-form"] .nrform-conditions-empty {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px;
    color: var(--sb-text-muted);
    font-size: 13px;
    text-align: center;
    justify-content: center;
}

.page[data-name="notification-rule-form"] .nrform-conditions-empty .icon {
    font-size: 18px;
}


.page[data-name="notification-rule-form"] .nrform-webhook-url-wrap .list {
    margin: 0;
}

/* Mobile responsive */
@media (max-width: 640px) {
    .page[data-name="notification-rule-form"] .nrform-condition-row {
        flex-wrap: wrap;
    }

    .page[data-name="notification-rule-form"] .nrform-condition-row select,
    .page[data-name="notification-rule-form"] .nrform-condition-row input {
        flex-basis: 100%;
    }

}

/* === settings-compliance page === */
/* Compliance Page Styles */
.page-compliance .gdpr-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
}

.page-compliance .gdpr-search-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.page-compliance .gdpr-search-wrap input {
    flex: 1;
    border: none;
    background: none;
    font-size: 14px;
    color: var(--sb-text-primary);
    outline: none;
    padding: 4px 0;
}

.page-compliance .gdpr-search-wrap input::placeholder {
    color: var(--sb-text-muted);
}

.page-compliance .gdpr-search-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* GDPR Results */
.page-compliance .gdpr-results-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
}

.page-compliance .gdpr-result-card {
    margin-top: 12px;
}

.page-compliance .gdpr-result-section {
    padding: 12px 0;
}

.page-compliance .gdpr-result-section + .gdpr-result-section {
    border-top: 1px solid var(--sb-border-color);
}

.page-compliance .gdpr-result-section-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 8px;
}

.page-compliance .gdpr-result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.page-compliance .gdpr-result-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.page-compliance .gdpr-result-label {
    font-size: 11px;
    color: var(--sb-text-muted);
}

.page-compliance .gdpr-result-value {
    font-size: 14px;
    color: var(--sb-text-primary);
    word-break: break-all;
}

/* Erasure badge */
.gdpr-erasure-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.dark .gdpr-erasure-badge {
    background: rgba(107, 114, 128, 0.15);
    color: #9ca3af;
}

/* Erasure warning */
.gdpr-erase-warning {
    display: flex;
    gap: 12px;
    margin: 16px;
    padding: 16px;
    background: rgba(239, 68, 68, 0.06);
    border: 1px solid rgba(239, 68, 68, 0.2);
    border-radius: 8px;
}

.dark .gdpr-erase-warning {
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.3);
}

.gdpr-erase-warning .icon {
    font-size: 20px;
    color: #ef4444;
    flex-shrink: 0;
    margin-top: 2px;
}

.gdpr-erase-warning strong {
    display: block;
    font-size: 14px;
    color: var(--sb-text-primary);
    margin-bottom: 4px;
}

.gdpr-erase-warning p {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin: 0;
    line-height: 1.4;
}

/* Sheet */
.gdpr-sheet {
    height: 75vh;
    border-radius: 16px 16px 0 0;
}

.gdpr-sheet-note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 16px;
    padding: 12px;
    background: rgba(59, 130, 246, 0.06);
    border-radius: 8px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    line-height: 1.4;
}

.gdpr-sheet-note .icon {
    font-size: 16px;
    color: #3b82f6;
    flex-shrink: 0;
    margin-top: 1px;
}

/* Consent table */
.gdpr-consent-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.gdpr-consent-table th {
    text-align: left;
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 12px;
    border-bottom: 1px solid var(--sb-border-color);
}

.gdpr-consent-table td {
    padding: 8px 12px;
    border-bottom: 1px solid var(--sb-border-color);
    color: var(--sb-text-primary);
}

.gdpr-consent-active {
    color: #059669;
    font-weight: 500;
}

.gdpr-consent-withdrawn {
    color: #6b7280;
    font-weight: 500;
}

.gdpr-consent-expiring {
    color: #d97706;
    font-weight: 500;
}

.gdpr-consent-expired {
    color: #dc2626;
    font-weight: 500;
}

.compliance-metric {
    text-align: center;
    min-width: 80px;
}
.compliance-metric-value {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2;
}
.compliance-metric-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

/* Mobile */
@media (max-width: 640px) {
    .page-compliance .gdpr-result-grid {
        grid-template-columns: 1fr;
    }

    .page-compliance .gdpr-search-row {
        flex-direction: column;
        align-items: stretch;
    }
}

/* === settings-gdpr page (#127) === */

/* Tab navigation */
.page-gdpr .gdpr-tabs-nav {
    display: flex;
    gap: 0;
    margin: 0 0 20px;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--sb-border-color);
    background: var(--sb-bg-card);
}

.page-gdpr .gdpr-tab-btn {
    flex: 1;
    padding: 10px 12px;
    text-align: center;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    border-right: 1px solid var(--sb-border-color);
    user-select: none;
}

.page-gdpr .gdpr-tab-btn:last-child {
    border-right: none;
}

.page-gdpr .gdpr-tab-btn:hover {
    background: rgba(0, 122, 255, 0.04);
}

.page-gdpr .gdpr-tab-btn.gdpr-tab-active {
    background: var(--f7-theme-color, #007aff);
    color: #fff;
    font-weight: 600;
}

/* Reuse compliance search styles for GDPR page */
.page-gdpr .gdpr-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
}

.page-gdpr .gdpr-search-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.page-gdpr .gdpr-search-wrap input {
    flex: 1;
    border: none;
    background: none;
    font-size: 14px;
    color: var(--sb-text-primary);
    outline: none;
    padding: 4px 0;
}

.page-gdpr .gdpr-search-wrap input::placeholder {
    color: var(--sb-text-muted);
}

.page-gdpr .gdpr-search-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Results */
.page-gdpr .gdpr-results-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px;
}

.page-gdpr .gdpr-result-card {
    margin-top: 12px;
}

.page-gdpr .gdpr-result-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.page-gdpr .gdpr-result-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.page-gdpr .gdpr-result-label {
    font-size: 11px;
    color: var(--sb-text-muted);
}

.page-gdpr .gdpr-result-value {
    font-size: 14px;
    color: var(--sb-text-primary);
    word-break: break-all;
}

/* Action buttons in search results */
.page-gdpr .gdpr-action-buttons {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.page-gdpr .gdpr-btn-sm {
    font-size: 12px !important;
    padding: 4px 10px !important;
    white-space: nowrap;
}

.page-gdpr .gdpr-btn-danger {
    color: #ef4444 !important;
    border-color: rgba(239, 68, 68, 0.3) !important;
}

.page-gdpr .gdpr-btn-danger:hover {
    background: rgba(239, 68, 68, 0.06) !important;
}

/* Export badge */
.gdpr-export-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.dark .gdpr-export-badge {
    background: rgba(59, 130, 246, 0.15);
    color: #60a5fa;
}

/* Purpose ID tag */
.gdpr-purpose-id {
    font-family: var(--sb-font-mono, ui-monospace, SFMono-Regular, monospace);
    font-size: 11px;
    color: var(--sb-text-muted);
    background: var(--sb-bg-secondary, #f3f4f6);
    padding: 2px 6px;
    border-radius: 4px;
}

.dark .gdpr-purpose-id {
    background: rgba(255, 255, 255, 0.06);
}

/* Register table */
.gdpr-register-table {
    min-width: 600px;
}

.gdpr-register-fields {
    font-size: 11px;
    color: var(--sb-text-muted);
}

/* Section header with actions */
.page-gdpr .sb-section-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}

.page-gdpr .sb-section-header-actions {
    flex-shrink: 0;
    margin-top: 4px;
}

.page-gdpr .sb-section-header-actions .sb-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

/* Mobile responsive */
@media (max-width: 640px) {
    .page-gdpr .gdpr-tabs-nav {
        flex-wrap: wrap;
    }

    .page-gdpr .gdpr-tab-btn {
        flex: 1 1 45%;
        border-bottom: 1px solid var(--sb-border-color);
        font-size: 12px;
        padding: 8px 8px;
    }

    .page-gdpr .gdpr-tab-btn:nth-child(2) {
        border-right: none;
    }

    .page-gdpr .gdpr-result-grid {
        grid-template-columns: 1fr;
    }

    .page-gdpr .gdpr-search-row {
        flex-direction: column;
        align-items: stretch;
    }

    .page-gdpr .gdpr-action-buttons {
        flex-direction: column;
    }

    .page-gdpr .sb-section-header {
        flex-direction: column;
        gap: 8px;
    }
}

/* === GDPR Erasure Confirmation Page (#237) === */
.gdpr-erasure-banner {
    display: flex;
    gap: 16px;
    padding: 20px 24px;
    background: var(--f7-color-red);
    border-radius: 12px;
    color: #fff;
    margin-bottom: 24px;
}

.gdpr-erasure-banner-icon .icon {
    font-size: 32px;
    color: #fff;
}

.gdpr-erasure-banner-content h2 {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 700;
}

.gdpr-erasure-banner-content p {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    opacity: 0.95;
}

.gdpr-erasure-summary-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 8px 0;
}

.gdpr-erasure-summary-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.gdpr-erasure-summary-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    font-weight: 600;
}

.gdpr-erasure-summary-value {
    font-size: 14px;
    color: var(--sb-text-primary);
    word-break: break-all;
}

.gdpr-impact-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    padding: 4px 10px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    background: var(--sb-bg-muted, #f0f0f5);
    color: var(--sb-text-primary);
}

.gdpr-impact-destructive {
    background: #fde8e8;
    color: var(--f7-color-red);
}

.dark .gdpr-impact-destructive {
    background: rgba(255, 59, 48, 0.2);
}

.gdpr-impact-preserved {
    background: #e8f5e9;
    color: #2e7d32;
}

.dark .gdpr-impact-preserved {
    background: rgba(76, 175, 80, 0.2);
    color: #81c784;
}

.gdpr-erasure-actions {
    text-align: center;
    padding: 24px 0 40px;
}

.gdpr-erasure-submit-btn {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    height: 48px;
    font-size: 16px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.gdpr-erasure-submit-btn:disabled {
    opacity: 0.5;
    pointer-events: none;
}

.gdpr-erasure-final-warning {
    margin-top: 12px;
    font-size: 12px;
    color: var(--sb-text-muted);
}

/* Erasure success (dead-end page) */
.gdpr-erasure-success {
    text-align: center;
    padding: 60px 24px;
}

.gdpr-erasure-success-icon .icon {
    font-size: 64px;
    color: #4caf50;
}

.gdpr-erasure-success h2 {
    margin: 16px 0 8px;
    font-size: 24px;
    font-weight: 700;
}

.gdpr-erasure-success p {
    margin: 0 0 8px;
    color: var(--sb-text-muted);
    font-size: 15px;
}

.gdpr-erasure-receipt {
    max-width: 460px;
    margin: 24px auto;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    overflow: hidden;
    text-align: left;
}

.gdpr-erasure-receipt-row {
    display: flex;
    justify-content: space-between;
    padding: 12px 16px;
    font-size: 13px;
    border-bottom: 1px solid var(--sb-border-color);
}

.gdpr-erasure-receipt-row:last-child {
    border-bottom: none;
}

.gdpr-erasure-receipt-row span:first-child {
    color: var(--sb-text-muted);
    font-weight: 500;
}

.gdpr-erasure-receipt-row span:last-child {
    font-weight: 600;
    word-break: break-all;
    text-align: right;
    max-width: 60%;
}

.gdpr-erasure-audit-note {
    margin-top: 16px;
    font-size: 13px;
    color: var(--sb-text-muted);
}

@media (max-width: 640px) {
    .gdpr-erasure-banner {
        flex-direction: column;
        gap: 12px;
    }

    .gdpr-erasure-summary-grid {
        grid-template-columns: 1fr;
    }
}

/* === GDPR Audit Evidence Export (#483) === */
.gdpr-evidence-date-row {
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}

.gdpr-evidence-date-fields {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.gdpr-evidence-date-field {
    display: flex;
    align-items: center;
    gap: 8px;
}

.gdpr-evidence-date-label {
    font-size: 13px;
    color: var(--sb-text-muted);
    white-space: nowrap;
}

.gdpr-evidence-date-input {
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 14px;
    color: var(--sb-text);
    background: var(--sb-bg-card);
    outline: none;
}

.gdpr-evidence-date-input:focus {
    border-color: var(--sb-color-primary);
}

@media (max-width: 640px) {
    .gdpr-evidence-date-fields {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* === payments page === */
/* Payment & Escrow Dashboard Styles */

/* Ensure empty state text is not obscured by the FAB on mobile */
.page-payments .catalogue-empty-state {
    padding-bottom: 80px;
}

.page-payments .pay-filters {
    display: flex;
    gap: 8px;
    padding: 0 24px 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; /* Firefox */
}
.page-payments .pay-filters::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}
.page-payments .pay-filters .filter-chip {
    flex-shrink: 0;
}


/* Status badges */
.pay-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.pay-badge-success {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.dark .pay-badge-success {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.pay-badge-warning {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.dark .pay-badge-warning {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}

.pay-badge-error {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dark .pay-badge-error {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

.pay-badge-refunded {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.dark .pay-badge-refunded {
    background: rgba(107, 114, 128, 0.15);
    color: #9ca3af;
}

.pay-badge-default {
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
}

/* Payment row */
.page-payments .pay-row,
.page-payments .escrow-row {
    cursor: pointer;
}

.page-payments .pay-row:hover,
.page-payments .escrow-row:hover {
    background: var(--sb-row-hover);
}

.page-payments .pay-row .sb-card-row-icon .icon {
    font-size: 18px;
}

.page-payments .pay-row[data-status="captured"] .sb-card-row-icon .icon {
    color: #10b981;
}

.page-payments .pay-row[data-status="pending"] .sb-card-row-icon .icon {
    color: #f59e0b;
}

.page-payments .pay-row[data-status="failed"] .sb-card-row-icon .icon {
    color: #ef4444;
}

.page-payments .pay-row[data-status="refunded"] .sb-card-row-icon .icon,
.page-payments .pay-row[data-status="partially_refunded"] .sb-card-row-icon .icon {
    color: #6b7280;
}

.page-payments .escrow-row .sb-card-row-icon .icon {
    font-size: 18px;
    color: #f59e0b;
}

.page-payments .sb-card-row-action {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

.pay-row-amount {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
    white-space: nowrap;
}

.pay-row-currency {
    font-size: 11px;
    font-weight: 400;
    color: var(--sb-text-muted);
}

/* Sheet modals */
.pay-sheet {
    height: 85vh;
    border-radius: 16px 16px 0 0;
}

.pay-detail-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px;
}

/* Payment detail panel */
.pay-detail-section {
    padding: 16px 24px;
}

.pay-detail-section + .pay-detail-section {
    border-top: 1px solid var(--sb-border-color);
}

.pay-detail-section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 12px;
}

.pay-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.pay-detail-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pay-detail-label {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.pay-detail-value {
    font-size: 15px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.pay-detail-value-lg {
    font-size: 24px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.pay-detail-actions {
    display: flex;
    gap: 8px;
    padding: 16px 24px;
    flex-wrap: wrap;
}

.pay-detail-actions .sb-btn {
    flex: 1;
    justify-content: center;
    min-width: 120px;
}

/* Escrow condition display */
.escrow-condition {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
}

.escrow-condition + .escrow-condition {
    border-top: 1px solid var(--sb-border-color);
}

.escrow-condition-indicator {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.escrow-condition-indicator.pending {
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
}

.escrow-condition-indicator.fulfilled {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.dark .escrow-condition-indicator.fulfilled {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.escrow-condition-indicator.expired {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.escrow-condition-indicator .icon {
    font-size: 14px;
}

.escrow-condition-content {
    flex: 1;
    min-width: 0;
}

.escrow-condition-type {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.escrow-condition-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.escrow-condition-action {
    flex-shrink: 0;
}

/* Refund preview */
.pay-refund-preview {
    margin: 16px;
    padding: 16px;
    background: var(--sb-bg-hover);
    border-radius: 8px;
}

.pay-refund-preview-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 0;
    font-size: 14px;
    color: var(--sb-text-secondary);
}

.pay-refund-preview-row + .pay-refund-preview-row {
    border-top: 1px solid var(--sb-border-color);
}

.pay-refund-amount {
    font-weight: 600;
    color: #dc2626;
}

/* Mobile responsive */
@media (max-width: 640px) {
    .page-payments .pay-filters {
        mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
        -webkit-mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
    }

    .page-payments .pay-detail-grid {
        grid-template-columns: 1fr;
    }

    .page-payments .pay-detail-actions {
        flex-direction: column;
    }

    .page-payments .pay-detail-actions .sb-btn {
        min-width: 100%;
    }

    .page-payments .sb-card-row-action {
        min-width: auto;
    }

    .pay-row-amount {
        font-size: 13px;
    }
}

/* === subscriptions page === */

.stats-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 480px) {
    .stats-grid-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

.stats-grid-5 {
    grid-template-columns: repeat(5, 1fr);
}

@media (max-width: 768px) {
    .stats-grid-5 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 480px) {
    .stats-grid-5 {
        grid-template-columns: repeat(2, 1fr);
    }
}

.sub-filters {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    padding: 0 24px 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.sub-filters::-webkit-scrollbar { display: none; }

.sub-filters .filter-chip {
    flex-shrink: 0;
}

.page-subscriptions .sub-filters {
    display: flex;
    gap: 8px;
    padding: 0 24px 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Bookings date filter — compact inline on desktop, stacks on mobile */
.booking-date-row {
    display: flex;
    gap: 8px;
    max-width: 500px;
}

.booking-date-row > li {
    flex: 1;
    min-width: 0;
}

/* Keep calendar icon inside the list row boundary (16px standard left inset) */
.booking-date-row .item-media {
    padding-left: 16px;
}

@media (max-width: 768px) {
    .booking-date-row {
        flex-wrap: wrap;
    }
    .booking-date-row > li {
        flex: 1 1 100%;
    }
}

.sub-search-bar {
    padding: 0 24px 16px;
}

.sub-search-input-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 8px 12px;
}

.sub-search-input-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.sub-search-input-wrap input {
    border: none;
    background: transparent;
    outline: none;
    font-size: 14px;
    color: var(--sb-text-primary);
    width: 100%;
}

.page-subscriptions .sub-search-bar {
    padding: 0 24px 16px;
}

.page-subscriptions .sub-search-input-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 8px 12px;
}

.page-subscriptions .sub-search-input-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.page-subscriptions .sub-search-input-wrap input {
    border: none;
    background: transparent;
    outline: none;
    font-size: 14px;
    color: var(--sb-text-primary);
    width: 100%;
}

/* Subscription badges */
.sub-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.sub-badge-active {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.dark .sub-badge-active {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.sub-badge-paused {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.dark .sub-badge-paused {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}

.sub-badge-past-due {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dark .sub-badge-past-due {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

.sub-badge-cancelled {
    background: rgba(107, 114, 128, 0.1);
    color: #6b7280;
}

.dark .sub-badge-cancelled {
    background: rgba(107, 114, 128, 0.15);
    color: #9ca3af;
}

.sub-badge-default {
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
}

/* Subscription rows */
.page-subscriptions .sub-row {
    cursor: pointer;
}

.page-subscriptions .sub-row:hover {
    background: var(--sb-row-hover);
}

.page-subscriptions .sub-row .sb-card-row-icon .icon {
    font-size: 18px;
}

.page-subscriptions .sub-row[data-status="active"] .sb-card-row-icon .icon {
    color: #10b981;
}

.page-subscriptions .sub-row[data-status="paused"] .sb-card-row-icon .icon {
    color: #f59e0b;
}

.page-subscriptions .sub-row[data-status="past_due"] .sb-card-row-icon .icon {
    color: #ef4444;
}

.page-subscriptions .sub-row[data-status="cancelled"] .sb-card-row-icon .icon {
    color: #6b7280;
}

.page-subscriptions .sb-card-row-action {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

.sub-row-amount {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sub-row-cycle {
    font-size: 12px;
    font-weight: 400;
    color: var(--sb-text-muted);
}

/* Subscription detail sheet */
.sub-sheet {
    height: 85vh;
    border-radius: 16px 16px 0 0;
}

.sub-detail-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 0;
}

.sub-detail-section {
    padding: 16px 20px;
}

.sub-detail-section + .sub-detail-section {
    border-top: 1px solid var(--sb-border-color);
}

.sub-detail-section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 12px;
}

.sub-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.sub-detail-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sub-detail-label {
    font-size: 12px;
    color: var(--sb-text-muted);
}

.sub-detail-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.sub-detail-value-lg {
    font-size: 20px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sub-detail-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 16px 20px;
}

.sub-detail-actions .sb-btn {
    flex: 1;
    min-width: 120px;
}

/* Timeline */
.sub-timeline {
    padding: 0;
    list-style: none;
    margin: 0;
}

.sub-timeline-item {
    display: flex;
    gap: 12px;
    padding: 8px 0;
    position: relative;
}

.sub-timeline-item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 9px;
    top: 28px;
    bottom: -8px;
    width: 2px;
    background: var(--sb-border-color);
}

.sub-timeline-dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--sb-bg-card);
    border: 2px solid var(--sb-border-color);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sub-timeline-dot .icon {
    font-size: 10px;
}

.sub-timeline-dot.active {
    border-color: #10b981;
    background: rgba(16, 185, 129, 0.1);
}

.sub-timeline-dot.active .icon {
    color: #10b981;
}

.sub-timeline-dot.warning {
    border-color: #f59e0b;
    background: rgba(245, 158, 11, 0.1);
}

.sub-timeline-dot.warning .icon {
    color: #f59e0b;
}

.sub-timeline-dot.danger {
    border-color: #ef4444;
    background: rgba(239, 68, 68, 0.1);
}

.sub-timeline-dot.danger .icon {
    color: #ef4444;
}

.sub-timeline-dot.muted {
    border-color: #6b7280;
    background: rgba(107, 114, 128, 0.1);
}

.sub-timeline-dot.muted .icon {
    color: #6b7280;
}

.sub-timeline-body {
    flex: 1;
    min-width: 0;
}

.sub-timeline-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

.sub-timeline-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

/* Action confirmation */
.sub-action-body {
    padding: 40px 20px;
    text-align: center;
}

.sub-action-icon {
    margin-bottom: 16px;
}

.sub-action-icon .icon {
    font-size: 48px;
    color: #f59e0b;
}

.sub-action-message {
    font-size: 16px;
    color: var(--sb-text-primary);
    margin-bottom: 20px;
    line-height: 1.5;
}

/* Past-due row highlight */
.page-subscriptions .sub-row[data-status="past_due"] {
    background: rgba(239, 68, 68, 0.04);
    border-left: 3px solid #ef4444;
}

.dark .page-subscriptions .sub-row[data-status="past_due"] {
    background: rgba(239, 68, 68, 0.08);
}

.page-subscriptions .sub-row[data-status="past_due"]:hover {
    background: rgba(239, 68, 68, 0.08);
}

/* Inline retry button on past-due rows */
.sub-retry-btn {
    margin-top: 4px;
}

/* Proration preview */
.sub-proration-preview {
    padding: 12px 16px;
    margin: 8px 16px 0;
    background: var(--sb-bg-hover);
    border-radius: 8px;
    text-align: center;
}

.sub-proration-label {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-bottom: 4px;
}

.sub-proration-amount {
    font-size: 20px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.sub-proration-amount.charge {
    color: #ef4444;
}

.sub-proration-amount.credit {
    color: #10b981;
}

.sub-proration-detail {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

/* Cancellation reason textarea */
#sub-cancel-reason {
    width: 100%;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    padding: 8px;
    font-size: 14px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
    resize: vertical;
    font-family: inherit;
}

/* Mobile responsive */
@media (max-width: 640px) {
    .page-subscriptions .sub-detail-grid {
        grid-template-columns: 1fr;
    }

    .page-subscriptions .sub-detail-actions {
        flex-direction: column;
    }

    .page-subscriptions .sub-detail-actions .sb-btn {
        min-width: 100%;
    }

    .page-subscriptions .sb-card-row-action {
        min-width: auto;
    }

    .sub-row-amount {
        font-size: 13px;
    }
}

/* Usage Meter Cards */
.sub-meter-card {
    background: var(--sb-bg-hover);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 10px;
}

.sub-meter-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}

.sub-meter-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    font-family: 'SF Mono', 'Fira Code', monospace;
}

.sub-meter-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

.sub-meter-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

.sub-meter-stats {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin-bottom: 8px;
}

.sub-meter-bar-track {
    height: 6px;
    background: var(--sb-border-color);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 8px;
}

.sub-meter-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

.sub-meter-charge {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin-bottom: 8px;
}

.sub-meter-history-btn {
    background: none;
    border: none;
    padding: 0;
    font-size: 12px;
    color: var(--f7-theme-color, #3b82f6);
    cursor: pointer;
    text-decoration: underline;
    margin-bottom: 4px;
}

.sub-meter-history-panel {
    margin-top: 8px;
}

.sub-meter-empty {
    padding: 20px 0;
}

/* Usage Table */
.sub-usage-table-wrap {
    overflow-x: auto;
    margin-top: 4px;
}

.sub-usage-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.sub-usage-table th {
    text-align: left;
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--sb-border-color);
}

.sub-usage-table td {
    padding: 6px 8px;
    color: var(--sb-text-primary);
    border-bottom: 1px solid var(--sb-border-color);
}

.sub-usage-table tr:last-child td {
    border-bottom: none;
}

/* Billing Projection */
.sub-meter-projection {
    background: var(--sb-bg-hover);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 12px 14px;
    margin-top: 12px;
}

.sub-meter-projection-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: var(--sb-text-secondary);
    padding: 4px 0;
}

.sub-meter-projection-row + .sub-meter-projection-row {
    border-top: 1px solid var(--sb-border-color);
}

.sub-meter-projection-total {
    font-size: 15px;
    font-weight: 600;
    color: var(--sb-text-primary);
    padding-top: 8px;
    margin-top: 4px;
    border-top: 2px solid var(--sb-border-color) !important;
}

/* Add Meter / Record Usage tiers textarea */
#sub-meter-tiers {
    width: 100%;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    padding: 8px;
    font-size: 12px;
    font-family: 'SF Mono', 'Fira Code', monospace;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
    resize: vertical;
}

/* === audit page === */
/* Audit Trail Dashboard Styles */
.page-audit .audit-search {
    padding: 0 24px 12px;
}

.page-audit .audit-search-input-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 8px 12px;
}

.page-audit .audit-search-input-wrap .icon {
    font-size: 16px;
    color: var(--sb-text-muted);
    flex-shrink: 0;
}

.page-audit .audit-search-input-wrap input {
    flex: 1;
    border: none;
    background: none;
    font-size: 14px;
    color: var(--sb-text-primary);
    outline: none;
}

.page-audit .audit-search-input-wrap input::placeholder {
    color: var(--sb-text-muted);
}

.page-audit .audit-filters {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0 24px 12px;
}

.page-audit .audit-filter-group {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.page-audit .audit-date-range {
    display: flex;
    gap: 8px;
    padding: 0 24px 16px;
    align-items: flex-end;
}

.page-audit .audit-date-field {
    flex: 1;
}

.page-audit .audit-date-field label {
    display: block;
    font-size: 11px;
    color: var(--sb-text-muted);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.page-audit .audit-date-field input {
    width: 100%;
    padding: 6px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 13px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
}

.page-audit .audit-date-apply,
.page-audit .audit-date-clear {
    padding: 6px 12px !important;
    font-size: 12px !important;
    white-space: nowrap;
}

/* Audit row */
.page-audit .audit-row {
    cursor: pointer;
    flex-wrap: wrap;
}

.page-audit .audit-row:hover {
    background: var(--sb-row-hover);
}

.page-audit .audit-row .sb-card-row-icon .icon {
    font-size: 18px;
}

.page-audit .audit-row[data-action="created"] .sb-card-row-icon .icon {
    color: #10b981;
}

.page-audit .audit-row[data-action="updated"] .sb-card-row-icon .icon {
    color: #3b82f6;
}

.page-audit .audit-row[data-action="deleted"] .sb-card-row-icon .icon {
    color: #ef4444;
}

.page-audit .audit-row[data-action="signed"] .sb-card-row-icon .icon {
    color: #007fff;
}

.page-audit .audit-row[data-action="data_exported"] .sb-card-row-icon .icon {
    color: #f59e0b;
}

.page-audit .audit-expand-icon {
    font-size: 14px;
    color: var(--sb-text-muted);
    transition: transform 0.2s ease;
}

.page-audit .audit-row.expanded .audit-expand-icon {
    transform: rotate(180deg);
}

/* Audit badges */
.audit-badge {
    display: inline-block;
    padding: 1px 6px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-left: 6px;
}

.audit-badge-success {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.dark .audit-badge-success {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.audit-badge-info {
    background: rgba(59, 130, 246, 0.1);
    color: #2563eb;
}

.dark .audit-badge-info {
    background: rgba(59, 130, 246, 0.15);
    color: #60a5fa;
}

.audit-badge-error {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dark .audit-badge-error {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

.audit-badge-primary {
    background: rgba(0, 113, 227, 0.1);
    color: #0062c7;
}

.dark .audit-badge-primary {
    background: rgba(0, 113, 227, 0.15);
    color: #4da3ff;
}

.audit-badge-warning {
    background: rgba(245, 158, 11, 0.1);
    color: #d97706;
}

.dark .audit-badge-warning {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}

.audit-badge-default {
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
}

/* Actor label */
.audit-actor {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 12px;
    color: var(--sb-text-muted);
}

.audit-actor .icon {
    font-size: 12px;
}

/* Entity link */
.audit-entity-link {
    color: var(--sb-text-primary);
    font-weight: 500;
    text-decoration: none;
}

.audit-entity-link:hover {
    color: var(--sb-primary);
}

/* Expandable detail */
.audit-detail {
    width: 100%;
    padding: 12px 0 4px;
    border-top: 1px solid var(--sb-border-color);
    margin-top: 8px;
}

.audit-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 12px;
}

.audit-detail-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.audit-detail-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.audit-detail-value {
    font-size: 13px;
    color: var(--sb-text-primary);
    word-break: break-all;
}

.audit-hash {
    font-family: 'SF Mono', 'Menlo', 'Monaco', monospace;
    font-size: 12px;
}

/* Change diff table */
.audit-changes {
    margin-top: 8px;
}

.audit-changes-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 8px;
}

.audit-diff-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.audit-diff-table th {
    text-align: left;
    font-size: 11px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 4px 8px;
    border-bottom: 1px solid var(--sb-border-color);
}

.audit-diff-table td {
    padding: 6px 8px;
    border-bottom: 1px solid var(--sb-border-color);
    vertical-align: top;
    word-break: break-word;
    max-width: 200px;
}

.audit-diff-field {
    font-weight: 500;
    color: var(--sb-text-primary);
    white-space: nowrap;
}

.audit-diff-old {
    background: rgba(239, 68, 68, 0.06);
    color: #b91c1c;
}

.dark .audit-diff-old {
    background: rgba(239, 68, 68, 0.1);
    color: #fca5a5;
}

.audit-diff-new {
    background: rgba(16, 185, 129, 0.06);
    color: #047857;
}

.dark .audit-diff-new {
    background: rgba(16, 185, 129, 0.1);
    color: #6ee7b7;
}

.audit-detail-actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    padding-top: 8px;
}

.audit-detail-actions .sb-btn {
    font-size: 12px;
    padding: 4px 10px;
}

/* Integrity card */
#audit-integrity-card {
    position: relative;
}

#audit-integrity-card .stat-value .icon {
    font-size: 24px;
    color: var(--sb-text-muted);
}

#audit-integrity-card .stat-value.verified .icon {
    color: #10b981;
}

#audit-integrity-card .stat-value.tampered .icon {
    color: #ef4444;
}

.audit-verify-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 4px;
    border: 1px solid var(--sb-border-color);
    background: var(--sb-bg-card);
    color: var(--sb-text-muted);
    cursor: pointer;
}

.audit-verify-btn:hover {
    background: var(--sb-bg-hover);
    color: var(--sb-primary);
    border-color: var(--sb-primary);
}

/* Pagination */
.audit-pagination {
    text-align: center;
    padding: 16px 24px;
}

.audit-pagination-info {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 8px;
}

/* Sheet modals */
.audit-sheet {
    height: 80vh;
    border-radius: 16px 16px 0 0;
}

/* Export note */
.audit-export-note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 16px;
    padding: 12px;
    background: rgba(59, 130, 246, 0.06);
    border-radius: 8px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    line-height: 1.4;
}

.audit-export-note .icon {
    font-size: 16px;
    color: #3b82f6;
    flex-shrink: 0;
    margin-top: 1px;
}

/* Verification result */
.audit-verify-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 48px;
    color: var(--sb-text-muted);
    font-size: 14px;
}

.audit-verify-result {
    padding: 24px;
}

.audit-verify-status {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    border-radius: 8px;
    margin-bottom: 16px;
}

.audit-verify-status.verified {
    background: rgba(16, 185, 129, 0.08);
}

.audit-verify-status.tampered {
    background: rgba(239, 68, 68, 0.08);
}

.audit-verify-status.no_entries {
    background: var(--sb-bg-hover);
}

.audit-verify-status .icon {
    font-size: 28px;
}

.audit-verify-status.verified .icon {
    color: #10b981;
}

.audit-verify-status.tampered .icon {
    color: #ef4444;
}

.audit-verify-status.no_entries .icon {
    color: var(--sb-text-muted);
}

.audit-verify-status-text {
    flex: 1;
}

.audit-verify-status-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-bottom: 2px;
}

.audit-verify-status-msg {
    font-size: 13px;
    color: var(--sb-text-secondary);
}

.audit-verify-meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.audit-verify-meta-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.audit-verify-meta-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.audit-verify-meta-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-primary);
}

/* Mobile responsive */
@media (max-width: 640px) {
    .page-audit .audit-detail-grid {
        grid-template-columns: 1fr;
    }

    .page-audit .audit-date-range {
        flex-wrap: wrap;
    }

    .page-audit .audit-date-field {
        min-width: calc(50% - 4px);
    }

    .audit-verify-meta {
        grid-template-columns: 1fr;
    }

    .audit-detail-actions {
        flex-wrap: wrap;
    }
}

/* === saved configs analytics === */
.page-saved-configs .sc-tabs {
    display: flex;
    gap: 0;
    padding: 0 0 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.page-saved-configs .sc-tab {
    flex: 1;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
}
.page-saved-configs .sc-tab:first-child { border-radius: 8px 0 0 8px; }
.page-saved-configs .sc-tab:last-child { border-radius: 0 8px 8px 0; }
.page-saved-configs .sc-tab:not(:first-child) { border-left: none; }
.page-saved-configs .sc-tab.active {
    color: var(--sb-primary);
    background: var(--sb-primary-subtle);
    border-color: var(--sb-primary);
    font-weight: 600;
}
.page-saved-configs .sc-tab.active + .sc-tab { border-left-color: var(--sb-primary); }
.page-saved-configs .sc-section.hidden { display: none; }

/* Funnel */
.sc-funnel { padding: 0 8px; }
.sc-funnel-stage { margin-bottom: 4px; }
.sc-funnel-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
    font-size: 14px;
}
.sc-funnel-stage-name { font-weight: 600; color: var(--sb-text); }
.sc-funnel-stage-count { font-weight: 500; color: var(--sb-text-secondary); }
.sc-funnel-pct { font-size: 12px; color: var(--sb-text-muted); }
.sc-funnel-bar-track {
    height: 28px;
    background: var(--sb-bg);
    border-radius: 6px;
    overflow: hidden;
}
.sc-funnel-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--sb-primary), var(--sb-primary-light, rgba(59,130,246,0.7)));
    border-radius: 6px;
    transition: width 0.4s ease;
    min-width: 4px;
}
.sc-funnel-arrow {
    text-align: center;
    padding: 2px 0;
}

/* Analytics tables */
.sc-analytics-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.sc-analytics-table th {
    text-align: left;
    padding: 10px 12px;
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    border-bottom: 1px solid var(--sb-border-color);
}
.sc-analytics-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--sb-border-color);
    color: var(--sb-text-secondary);
}
.sc-analytics-table tbody tr:last-child td { border-bottom: none; }
.sc-table-empty {
    text-align: center;
    padding: 24px;
    color: var(--sb-text-muted);
    font-size: 13px;
}

/* Insight cards */
.sc-insight-card {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    line-height: 1.5;
}

@media (max-width: 768px) {
    .page-saved-configs .sc-tabs { padding: 0 0 12px; }
    .page-saved-configs .sc-tab { padding: 8px 12px; font-size: 13px; }
}

/* === intelligence page === */
/* Intelligence Tab Bar — shared wrapper for F7 segmented control */
.intel-tab-bar {
    padding: 16px 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.intel-tab-bar .segmented {
    flex-wrap: nowrap;
    min-width: max-content;
}
.intel-tab-bar .segmented .button {
    flex-shrink: 0;
    white-space: nowrap;
}

.page-intelligence .intel-section.hidden { display: none; }

/* Config Form */
.page-intelligence .intel-config-form { margin-bottom: 16px; }
.page-intelligence .intel-config-loading {
    text-align: center;
    padding: 24px;
    color: var(--sb-text-muted);
    font-size: 14px;
}
.page-intelligence .intel-scoring-list .item-title.intel-slider-label {
    min-width: 140px;
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary);
    white-space: normal;
}
.page-intelligence .intel-scoring-list .intel-slider-range {
    flex: 1;
    margin: 0 12px;
}
.page-intelligence .intel-scoring-list .item-inner {
    display: flex;
    align-items: center;
    padding-right: 0;
}
.page-intelligence .intel-slider-value {
    min-width: 40px;
    text-align: right;
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}
.page-intelligence .intel-config-actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    padding-top: 16px;
    border-top: 1px solid var(--sb-border-color);
}
.page-intelligence .intel-btn-secondary {
    background: var(--sb-bg-card) !important;
    color: var(--sb-primary) !important;
    border: 1px solid var(--sb-primary) !important;
}

/* Interpretation text */
.page-intelligence .intel-interpretation-text {
    font-size: 14px;
    color: var(--sb-text-secondary);
    line-height: 1.5;
    margin: 0;
}

/* Suggestions */
.page-intelligence .intel-suggestion-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
}
.page-intelligence .intel-suggestion-weights {
    display: flex;
    gap: 8px;
    align-items: center;
    min-width: 120px;
    font-size: 13px;
    font-weight: 600;
}
.page-intelligence .intel-suggestion-arrow {
    color: var(--sb-text-muted);
    font-size: 12px;
}
.page-intelligence .intel-suggestion-reason {
    font-size: 13px;
    color: var(--sb-text-muted);
    flex: 1;
}

/* Table */
.page-intelligence .intel-table,
.page-negotiations .intel-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}
.page-intelligence .intel-table th,
.page-negotiations .intel-table th {
    text-align: left;
    padding: 10px 12px;
    font-weight: 600;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    border-bottom: 1px solid var(--sb-border-color);
}
.page-intelligence .intel-table td,
.page-negotiations .intel-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--sb-border-color);
    color: var(--sb-text-secondary);
}
.page-intelligence .intel-table tbody tr:last-child td,
.page-negotiations .intel-table tbody tr:last-child td { border-bottom: none; }
.page-intelligence .intel-table-empty,
.page-negotiations .intel-table-empty {
    text-align: center;
    padding: 24px;
    color: var(--sb-text-muted);
}

/* Sensitivity badge */
.page-intelligence .intel-sensitivity {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    text-transform: capitalize;
}
.page-intelligence .intel-sensitivity-high { background: rgba(239,68,68,0.1); color: #ef4444; }
.page-intelligence .intel-sensitivity-moderate { background: rgba(245,158,11,0.1); color: #f59e0b; }
.page-intelligence .intel-sensitivity-low { background: rgba(34,197,94,0.1); color: #15803d; }
.page-intelligence .intel-sensitivity-unknown { background: var(--sb-primary-tint); color: var(--sb-text-muted); }

/* Transitions */
.page-intelligence .intel-transition-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
}
.page-intelligence .intel-transition-label {
    flex: 1;
    font-size: 14px;
    color: var(--sb-text-secondary);
}
.page-intelligence .intel-transition-count {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

/* Competitor list */
.page-intelligence .intel-competitor-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
}
.page-intelligence .intel-competitor-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}
.page-intelligence .intel-competitor-stats {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Insights */
.page-intelligence .intel-insight-item {
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    border-left: 3px solid var(--sb-border-color);
}
.page-intelligence .intel-insight-item[data-severity="high"] { border-left-color: #ef4444; }
.page-intelligence .intel-insight-item[data-severity="medium"] { border-left-color: #f59e0b; }
.page-intelligence .intel-insight-item[data-severity="low"] { border-left-color: #22c55e; }
.page-intelligence .intel-insight-text {
    font-size: 14px;
    color: var(--sb-text-secondary);
    line-height: 1.5;
}

/* Loss patterns */
.page-intelligence .intel-pattern-item {
    padding: 14px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    border-left: 3px solid var(--sb-border-color);
}
.page-intelligence .intel-pattern-item[data-severity="high"] { border-left-color: #ef4444; }
.page-intelligence .intel-pattern-item[data-severity="medium"] { border-left-color: #f59e0b; }
.page-intelligence .intel-pattern-item[data-severity="info"] { border-left-color: #3b82f6; }
.page-intelligence .intel-pattern-message {
    font-size: 14px;
    color: var(--sb-text-secondary);
    line-height: 1.5;
}
.page-intelligence .intel-pattern-type {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    margin-bottom: 4px;
}

/* Deal search */
.page-intelligence .intel-deal-search {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}
.page-intelligence .intel-search-input {
    flex: 1;
    padding: 10px 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    font-size: 14px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary);
    outline: none;
}
.page-intelligence .intel-search-input:focus {
    border-color: var(--sb-primary);
}

/* Deal result list */
.page-intelligence .intel-deal-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: border-color 0.15s ease;
}
.page-intelligence .intel-deal-row:hover { border-color: var(--sb-primary); }
.page-intelligence .intel-deal-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.page-intelligence .intel-deal-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
}
.page-intelligence .intel-deal-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
}

/* Deal factors grid */
.page-intelligence .intel-factors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
    margin-top: 16px;
}
.page-intelligence .intel-factor-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 14px;
}
.page-intelligence .intel-factor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}
.page-intelligence .intel-factor-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    text-transform: capitalize;
}
.page-intelligence .intel-factor-score {
    font-size: 13px;
    font-weight: 700;
    color: var(--sb-primary);
}
.page-intelligence .intel-factor-bar {
    height: 6px;
    background: var(--sb-border-color);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 6px;
}
.page-intelligence .intel-factor-bar-fill {
    height: 100%;
    background: var(--sb-primary);
    border-radius: 3px;
    transition: width 0.3s ease;
}
.page-intelligence .intel-factor-detail {
    font-size: 12px;
    color: var(--sb-text-muted);
}

/* Score badge */
.page-intelligence .intel-score-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 28px;
    padding: 0 8px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 700;
}
.page-intelligence .intel-score-high { background: rgba(34,197,94,0.1); color: #15803d; }
.page-intelligence .intel-score-mid { background: rgba(245,158,11,0.1); color: #f59e0b; }
.page-intelligence .intel-score-low { background: rgba(239,68,68,0.1); color: #ef4444; }

/* Backtest deal rows */
.page-intelligence .intel-backtest-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--sb-border-color);
    font-size: 13px;
}
.page-intelligence .intel-backtest-row:last-child { border-bottom: none; }
.page-intelligence .intel-backtest-delta-pos { color: #22c55e; font-weight: 600; }
.page-intelligence .intel-backtest-delta-neg { color: #ef4444; font-weight: 600; }
.page-intelligence .intel-backtest-delta-zero { color: var(--sb-text-muted); }

/* Sortable table headers */
.page-intelligence .intel-sortable {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
.page-intelligence .intel-sortable:hover { color: var(--sb-primary); }
.page-intelligence .intel-sort-active { color: var(--sb-primary); }
.page-intelligence .intel-sort-asc::after { content: ' \2191'; font-size: 11px; }
.page-intelligence .intel-sort-desc::after { content: ' \2193'; font-size: 11px; }

/* Deal score link */
.page-intelligence .intel-deal-link {
    color: var(--sb-primary);
    text-decoration: none;
    font-weight: 600;
}
.page-intelligence .intel-deal-link:hover { text-decoration: underline; }

/* Action link in table */
.page-intelligence .intel-action-link {
    color: var(--sb-primary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
}
.page-intelligence .intel-action-link:hover { text-decoration: underline; }

/* Score loading placeholder */
.page-intelligence .intel-score-loading {
    color: var(--sb-text-muted);
    font-size: 13px;
}

/* Stage label in table */
.page-intelligence .intel-stage-label { text-transform: capitalize; }

/* Value comparison bars */
.page-intelligence .intel-value-bars { padding: 4px 0; }
.page-intelligence .intel-value-bar-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
}
.page-intelligence .intel-value-bar-label {
    min-width: 80px;
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
}
.page-intelligence .intel-value-bar-track {
    flex: 1;
    height: 20px;
    background: var(--sb-border-color);
    border-radius: 4px;
    overflow: hidden;
}
.page-intelligence .intel-value-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.4s ease;
}
.page-intelligence .intel-value-bar-won { background: #22c55e; }
.page-intelligence .intel-value-bar-lost { background: #ef4444; }
.page-intelligence .intel-value-bar-amount {
    min-width: 90px;
    text-align: right;
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

/* Win reason items */
.page-intelligence .intel-win-reason-item {
    padding: 12px 16px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    margin-bottom: 8px;
    border-left: 3px solid #22c55e;
}
.page-intelligence .intel-win-reason-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.page-intelligence .intel-win-reason-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary);
    text-transform: capitalize;
}
.page-intelligence .intel-win-reason-count {
    font-size: 13px;
    color: var(--sb-text-muted);
}
.page-intelligence .intel-win-reason-value {
    font-size: 13px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

/* HTML bar charts (replaces Chart.js) */
.page-intelligence .intel-html-chart { width: 100%; }
.page-intelligence .intel-bar-chart {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    height: 180px;
    padding: 8px 0;
}
.page-intelligence .intel-bar-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
}
.page-intelligence .intel-bar-pair {
    display: flex;
    align-items: flex-end;
    gap: 3px;
    flex: 1;
    width: 100%;
    justify-content: center;
}
.page-intelligence .intel-bar {
    width: 40%;
    max-width: 28px;
    min-height: 2px;
    border-radius: 3px 3px 0 0;
    position: relative;
    transition: height 0.3s ease;
}
.page-intelligence .intel-bar-won { background: rgba(34,197,94,0.75); }
.page-intelligence .intel-bar-lost { background: rgba(239,68,68,0.75); }
.page-intelligence .intel-bar-val {
    position: absolute;
    top: -18px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    color: var(--sb-text-muted);
    white-space: nowrap;
}
.page-intelligence .intel-bar-label {
    font-size: 11px;
    color: var(--sb-text-muted);
    text-align: center;
    margin-top: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.page-intelligence .intel-chart-legend {
    display: flex;
    gap: 16px;
    justify-content: center;
    margin-bottom: 8px;
    font-size: 12px;
    color: var(--sb-text-muted);
}
.page-intelligence .intel-legend-item {
    display: flex;
    align-items: center;
    gap: 4px;
}
.page-intelligence .intel-legend-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

/* Horizontal bar chart */
.page-intelligence .intel-hbar-chart {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 8px 0;
}
.page-intelligence .intel-hbar-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.page-intelligence .intel-hbar-label {
    min-width: 110px;
    font-size: 13px;
    color: var(--sb-text-primary);
    text-transform: capitalize;
    display: flex;
    align-items: center;
    gap: 6px;
}
.page-intelligence .intel-hbar-track {
    flex: 1;
    height: 22px;
    background: var(--sb-primary-tint, rgba(0,122,255,0.06));
    border-radius: 4px;
    overflow: hidden;
}
.page-intelligence .intel-hbar-fill {
    height: 100%;
    border-radius: 4px;
    min-width: 2px;
    transition: width 0.3s ease;
}
.page-intelligence .intel-hbar-val {
    min-width: 60px;
    text-align: right;
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

/* Loading & error states */
.page-intelligence .intel-tab-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px 0;
    font-size: 14px;
    color: var(--sb-text-muted);
}
.page-intelligence .intel-tab-loading .preloader {
    width: 20px;
    height: 20px;
}
.page-intelligence .intel-tab-error {
    text-align: center;
    padding: 24px 16px;
    color: var(--sb-text-muted);
    font-size: 14px;
}
.page-intelligence .intel-tab-error p {
    margin: 0 0 12px 0;
}
.page-intelligence .intel-retry-btn {
    color: var(--sb-primary);
    border-color: var(--sb-primary);
}

/* Responsive */
@media (max-width: 768px) {
    .intel-tab-bar {
        padding: 12px 16px;
        scrollbar-width: none;
        mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
        -webkit-mask-image: linear-gradient(to right, black calc(100% - 32px), transparent);
    }
    .intel-tab-bar::-webkit-scrollbar { display: none; }
    .page-intelligence .intel-scoring-list .item-inner { flex-wrap: wrap; }
    .page-intelligence .intel-scoring-list .item-title.intel-slider-label { min-width: 100%; }
    .page-intelligence .intel-scoring-list .intel-slider-range { margin: 8px 0 8px 0; }
    .page-intelligence .intel-config-actions { flex-direction: column; }
    .page-intelligence .intel-deal-search { flex-direction: column; }
    .page-intelligence .intel-value-bar-label { min-width: 60px; font-size: 12px; }
    .page-intelligence .intel-value-bar-amount { min-width: 70px; font-size: 12px; }
    .page-intelligence .intel-hbar-label { min-width: 80px; font-size: 12px; }
    .page-intelligence .intel-hbar-val { min-width: 50px; font-size: 12px; }
    .page-intelligence .intel-bar-chart { height: 140px; }
}

/* ===== Deal View Intelligence Cards ===== */

/* Loading state */
.deal-intel-loading {
    display: flex;
    justify-content: center;
    padding: 16px 0;
}
.deal-intel-empty {
    font-size: 13px;
    color: var(--sb-text-muted);
    text-align: center;
    padding: 8px 0;
}

/* Score row with gauge */
.deal-intel-score-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}
.deal-intel-gauge {
    position: relative;
    width: 80px;
    height: 44px;
    flex-shrink: 0;
}
.deal-intel-gauge-svg {
    width: 80px;
    height: 44px;
}
.deal-intel-gauge-value {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
}
.deal-intel-score-meta {
    flex: 1;
    min-width: 0;
}
.deal-intel-score-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.deal-intel-score-desc {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 2px;
    line-height: 1.3;
}

/* Win probability */
.deal-intel-prob {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}
.deal-intel-prob-label {
    font-size: 13px;
    color: var(--sb-text-secondary);
}
.deal-intel-prob-value {
    font-size: 14px;
    font-weight: 700;
}
.deal-intel-prob-bar {
    height: 4px;
    background: var(--sb-border-color);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 14px;
}
.deal-intel-prob-bar-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s ease;
}

/* Factor breakdown */
.deal-intel-factors-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}
.deal-intel-factors {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.deal-intel-factor {
    padding-bottom: 8px;
    border-bottom: 1px solid var(--sb-border-color);
}
.deal-intel-factor:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.deal-intel-factor-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}
.deal-intel-factor-name {
    font-size: 13px;
    color: var(--sb-text-secondary);
    text-transform: capitalize;
}
.deal-intel-factor-score {
    font-size: 12px;
    font-weight: 700;
}
.deal-intel-factor-bar {
    height: 4px;
    background: var(--sb-border-color);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 4px;
}
.deal-intel-factor-bar-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s ease;
}
.deal-intel-factor-detail {
    font-size: 11px;
    color: var(--sb-text-muted);
    line-height: 1.3;
}
.deal-intel-factor-indicator {
    font-weight: 700;
    font-size: 14px;
}

/* Recommended actions */
.deal-intel-recs {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.deal-intel-rec {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--sb-text-secondary);
    line-height: 1.4;
}
.deal-intel-rec .icon {
    font-size: 14px;
    color: #f59e0b;
    flex-shrink: 0;
    margin-top: 1px;
}

/* Pricing suggestion */
.deal-intel-pricing-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--sb-text-primary);
    margin-bottom: 8px;
}
.deal-intel-pricing-badge .icon {
    font-size: 14px;
    flex-shrink: 0;
}
.deal-intel-pricing-reason {
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
}

.deal-intel-pricing-actions {
    display: flex;
    gap: 6px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--sb-border-color);
}

.deal-intel-refresh-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 4px;
    color: var(--sb-text-secondary);
    font-size: 14px;
    display: inline-flex;
    align-items: center;
}

.deal-intel-refresh-btn:hover {
    color: var(--f7-color-blue);
    background: var(--sb-hover-bg);
}

.deal-intel-refresh-btn:disabled {
    opacity: 0.5;
    cursor: default;
}

/* Risk assessment sidebar card */
.deal-risk-level {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 12px;
}
.deal-risk-level .icon { font-size: 16px; }
.deal-risk-factors { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.deal-risk-factor {
    padding: 8px 10px;
    border-radius: 6px;
    background: var(--sb-bg-card);
}
.deal-risk-factor-type {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sb-text-muted);
    margin-bottom: 2px;
}
.deal-risk-factor-detail { font-size: 12px; color: var(--sb-text-color); line-height: 1.4; }
.deal-risk-actions { display: flex; flex-direction: column; gap: 6px; }
.deal-risk-action {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
}
.deal-risk-action .icon { font-size: 12px; color: #f59e0b; flex-shrink: 0; margin-top: 2px; }

/* Intelligence card: building/empty state */
.deal-intel-building {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    margin-bottom: 4px;
}
.deal-intel-building-sub {
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
}

/* Intelligence card: inline risk factors */
.deal-intel-risk-factors {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.deal-intel-risk-factor {
    padding: 6px 8px;
    border-radius: 5px;
    background: var(--sb-bg-hover);
}
.deal-intel-risk-factor-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2px;
}
.deal-intel-risk-factor-type {
    font-size: 12px;
    color: var(--sb-text-secondary);
    text-transform: capitalize;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.deal-intel-risk-factor-detail {
    font-size: 11px;
    color: var(--sb-text-muted);
    line-height: 1.3;
}
.deal-intel-severity-badge {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 1px 6px;
    border-radius: 10px;
    flex-shrink: 0;
    margin-left: 6px;
}
.deal-intel-severity-low { background: rgba(34,197,94,0.1); color: #15803d; }
.deal-intel-severity-medium { background: rgba(245,158,11,0.1); color: #f59e0b; }
.deal-intel-severity-high { background: rgba(239,68,68,0.1); color: #ef4444; }
.deal-intel-severity-critical { background: rgba(220,38,38,0.12); color: #dc2626; }

/* Intelligence card: quick recommendation */
.deal-intel-recommendation {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
    padding-top: 10px;
    border-top: 1px solid var(--sb-border-color);
    margin-top: 6px;
}
.deal-intel-recommendation .icon { font-size: 13px; color: #f59e0b; flex-shrink: 0; margin-top: 1px; }

/* Close forecast */
.deal-intel-forecast {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 4px 8px;
    padding: 8px 0;
    margin-bottom: 10px;
    border-bottom: 1px solid var(--sb-border-color);
}
.deal-intel-forecast-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-basis: 100%;
}
.deal-intel-forecast-date {
    font-size: 15px;
    font-weight: 700;
    color: var(--sb-text-primary);
}
.deal-intel-forecast-meta {
    font-size: 12px;
    color: var(--sb-text-muted);
}

/* Score trend sparkline */
.deal-intel-sparkline-wrap {
    margin-bottom: 10px;
}
.deal-intel-sparkline-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--sb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}
.deal-intel-sparkline {
    display: block;
    width: 100%;
    height: 32px;
    overflow: visible;
}

/* Forecast risk badge (intelligence page) */
.intel-risk-badge {
    font-size: 12px;
    font-weight: 600;
    text-transform: capitalize;
}

/* Negotiation history timeline (deal view) */
.deal-neg-timeline {
    padding: 12px 16px;
}
.deal-neg-round {
    position: relative;
    padding-left: 24px;
    padding-bottom: 16px;
}
.deal-neg-round:last-child {
    padding-bottom: 0;
}
.deal-neg-round-dot {
    position: absolute;
    left: 0;
    top: 4px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--sb-border-color);
    border: 2px solid var(--sb-bg-card);
    box-shadow: 0 0 0 2px var(--sb-border-color);
}
.deal-neg-round-latest .deal-neg-round-dot {
    background: var(--sb-primary);
    box-shadow: 0 0 0 2px var(--sb-primary);
}
.deal-neg-status-accepted .deal-neg-round-dot {
    background: #22c55e;
    box-shadow: 0 0 0 2px #22c55e;
}
.deal-neg-status-rejected .deal-neg-round-dot {
    background: #ef4444;
    box-shadow: 0 0 0 2px #ef4444;
}
.deal-neg-round-line {
    position: absolute;
    left: 4px;
    top: 16px;
    bottom: 0;
    width: 2px;
    background: var(--sb-border-color);
}
.deal-neg-round-content {
    min-width: 0;
}
.deal-neg-round-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 2px;
}
.deal-neg-round-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
}
.deal-neg-user-badge {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(99, 102, 241, 0.1);
    color: #6366f1;
}
.deal-neg-round-status {
    font-size: 11px;
    font-weight: 500;
    text-transform: capitalize;
    color: var(--sb-text-muted);
}
.deal-neg-status-accepted .deal-neg-round-status { color: #15803d; }
.deal-neg-status-rejected .deal-neg-round-status { color: #ef4444; }
.deal-neg-round-amount {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary);
    margin-left: auto;
}
.deal-neg-round-message {
    font-size: 12px;
    color: var(--sb-text-muted);
    line-height: 1.4;
    margin-top: 2px;
}
.deal-neg-round-time {
    font-size: 11px;
    color: var(--sb-text-muted);
    margin-top: 2px;
}

/* Deal sign/verify buttons */
.deal-sign-btn,
.deal-verify-btn {
    margin-right: 8px;
    font-size: 13px;
}
.deal-sign-btn .icon,
.deal-verify-btn .icon {
    font-size: 14px;
    margin-right: 4px;
}
.deal-verify-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    margin-left: 8px;
    vertical-align: middle;
}
.deal-verify-chip .icon {
    font-size: 14px;
}
.deal-verify-valid {
    background: rgba(34, 197, 94, 0.1);
    color: #15803d;
}
.deal-verify-invalid {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

/* Negotiation table row action buttons */
.neg-row-accept,
.neg-row-reject {
    padding: 2px 8px;
    font-size: 11px;
}

/* ===== Deal Lifecycle Toolbar ===== */

.deal-lifecycle-toolbar {
    margin: 16px 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.deal-lifecycle-section {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color, #e5e7eb);
    border-radius: 10px;
    padding: 16px;
}

.deal-lifecycle-section-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary, #6b7280);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.deal-lifecycle-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.deal-transition-btn {
    font-size: 13px;
}

.deal-transition-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.deal-payment-btn {
    font-size: 13px;
}

.deal-payment-btn .icon {
    font-size: 14px;
    margin-right: 4px;
}

.deal-lifecycle-signed-msg {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: rgba(245, 158, 11, 0.08);
    border: 1px solid rgba(245, 158, 11, 0.2);
    border-radius: 8px;
    color: #b45309;
    font-size: 13px;
    line-height: 1.4;
    margin-bottom: 12px;
}

.deal-lifecycle-signed-msg .icon {
    font-size: 16px;
    flex-shrink: 0;
    color: #f59e0b;
}

/* Deal manual payment / refund sheets */
.deal-manual-payment-sheet,
.deal-refund-sheet {
    height: auto;
    max-height: 80vh;
}

@media (max-width: 768px) {
    .deal-lifecycle-btns {
        flex-direction: column;
    }
    .deal-lifecycle-btns .sb-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Deal escrow management section */
.deal-escrow-warning {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: rgba(245, 158, 11, 0.08);
    border: 1px solid rgba(245, 158, 11, 0.2);
    border-radius: 8px;
    color: #b45309;
    font-size: 13px;
    line-height: 1.4;
    margin-bottom: 12px;
}

.deal-escrow-warning .icon {
    font-size: 16px;
    flex-shrink: 0;
    color: #f59e0b;
}

.deal-escrow-warning-expired {
    background: rgba(239, 68, 68, 0.08);
    border-color: rgba(239, 68, 68, 0.2);
    color: #dc2626;
}

.deal-escrow-warning-expired .icon {
    color: #ef4444;
}

.dark .deal-escrow-warning {
    background: rgba(245, 158, 11, 0.12);
    color: #fbbf24;
}

.dark .deal-escrow-warning-expired {
    background: rgba(239, 68, 68, 0.12);
    color: #f87171;
}

.deal-escrow-status-card {
    padding: 16px;
    background: var(--sb-bg-hover);
    border-radius: 8px;
    margin-bottom: 12px;
}

.deal-escrow-status-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}

.deal-escrow-status-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    text-transform: capitalize;
}

.deal-escrow-amount {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary);
}

.deal-escrow-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 12px;
    color: var(--sb-text-muted);
}

.deal-escrow-progress {
    margin-top: 12px;
}

.deal-escrow-progress-label {
    font-size: 12px;
    color: var(--sb-text-secondary);
    margin-bottom: 6px;
}

.deal-escrow-progress-bar {
    height: 6px;
    background: var(--sb-border-color);
    border-radius: 3px;
    overflow: hidden;
}

.deal-escrow-progress-fill {
    height: 100%;
    background: #22c55e;
    border-radius: 3px;
    transition: width 0.3s ease;
}

.deal-escrow-conditions-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 16px 0 8px;
}

.deal-escrow-conditions {
    margin-bottom: 12px;
}

.deal-escrow-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid var(--sb-border-color);
}

.deal-escrow-actions .icon {
    font-size: 14px;
    margin-right: 4px;
}

@media (max-width: 768px) {
    .deal-escrow-actions {
        flex-direction: column;
    }
    .deal-escrow-actions .sb-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Deal line item management controls */
.li-qty-controls {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.li-qty-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border: 1px solid var(--sb-border-color, #e5e7eb);
    border-radius: 6px;
    background: var(--sb-bg-card);
    color: var(--sb-text-primary, #374151);
    cursor: pointer;
    padding: 0;
    transition: background 0.15s, border-color 0.15s;
}

.li-qty-btn:hover {
    background: var(--sb-bg-hover, #f3f4f6);
    border-color: var(--sb-text-secondary, #9ca3af);
}

.li-qty-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.li-qty-btn .icon {
    font-size: 12px;
}

.li-qty-value {
    min-width: 24px;
    text-align: center;
    font-weight: 600;
    font-size: 13px;
}

.li-remove-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--sb-text-secondary, #9ca3af);
    cursor: pointer;
    padding: 0;
    transition: color 0.15s, background 0.15s;
}

.li-remove-btn:hover {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.08);
}

.li-remove-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.li-remove-btn .icon {
    font-size: 15px;
}

.cell-actions {
    width: 40px;
    text-align: center;
}

.cell-qty {
    white-space: nowrap;
}

.deal-li-discount-btn {
    margin-top: 12px;
}

.deal-li-discount-btn .icon {
    font-size: 14px;
    margin-right: 4px;
}

.li-actions-th {
    width: 40px;
}

/* ===== Billing Dashboard ===== */

/* Balance Card */
.billing-balance-card {
    background: var(--sb-bg-card);
    border-radius: 12px;
    padding: 24px;
    border: 1px solid var(--sb-border-color);
    transition: border-color 0.2s;
}
.billing-balance-card.billing-balance-healthy {
    border-color: #10b981;
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.04) 0%, var(--sb-bg-card) 100%);
}
.billing-balance-card.billing-balance-low {
    border-color: #f59e0b;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.04) 0%, var(--sb-bg-card) 100%);
}
.billing-balance-card.billing-balance-critical {
    border-color: var(--sb-border-color);
    background: var(--sb-bg-card);
}
.billing-balance-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}
.billing-balance-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--sb-text-secondary, #6b7280);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.billing-balance-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
}
.billing-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}
.billing-status-dot.billing-status-healthy { background: #10b981; }
.billing-status-dot.billing-status-low { background: #f59e0b; }
.billing-status-dot.billing-status-critical { background: #ef4444; }
.billing-balance-amount {
    font-size: 40px;
    font-weight: 700;
    color: var(--sb-text-primary, #111);
    line-height: 1.2;
    margin-bottom: 8px;
}
.billing-balance-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
    margin-bottom: 16px;
}
.billing-balance-actions {
    display: flex;
    gap: 8px;
}

/* Top-up Section */
.billing-topup-section {
    animation: billingSlideIn 0.2s ease-out;
}
@keyframes billingSlideIn {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}
.billing-topup-close {
    color: var(--sb-text-muted, #9ca3af);
    font-size: 18px;
}
.billing-topup-presets {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    margin-bottom: 12px;
}
.billing-preset-btn {
    padding: 12px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    background: var(--sb-bg-card);
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary, #111);
    cursor: pointer;
    transition: all 0.15s;
}
.billing-preset-btn:hover {
    border-color: var(--sb-primary, #0071e3);
    background: rgba(0, 113, 227, 0.04);
}
.billing-preset-btn.active {
    border-color: var(--sb-primary, #0071e3);
    background: rgba(0, 113, 227, 0.08);
    color: var(--sb-primary, #0071e3);
}
.billing-topup-custom {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-bottom: 8px;
}
.billing-topup-input-wrap {
    display: flex;
    align-items: center;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    padding: 0 12px;
    background: var(--sb-bg-card);
    max-width: 180px;
    transition: border-color 0.15s;
}
.billing-topup-input-wrap:focus-within {
    border-color: var(--sb-primary, #0071e3);
    box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.1);
}
.billing-topup-currency {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-secondary, #6b7280);
    margin-right: 4px;
    line-height: 1;
}
.billing-topup-input {
    border: none;
    background: transparent;
    padding: 10px 0;
    font-size: 16px;
    width: 100%;
    outline: none;
    color: var(--sb-text-primary, #111);
    -moz-appearance: textfield;
}
.billing-topup-input::-webkit-outer-spin-button,
.billing-topup-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.billing-topup-note {
    font-size: 12px;
    color: var(--sb-text-muted, #9ca3af);
}

/* Auto Top-Up Config */
.billing-auto-topup-config {
    padding: 12px 16px 16px;
    border-top: 1px solid var(--sb-border-light, #f3f4f6);
}
.billing-auto-topup-row {
    margin-bottom: 12px;
}
.billing-payment-method {
    display: flex;
    align-items: center;
    gap: 12px;
}
.billing-payment-status {
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
}
.billing-payment-status.billing-payment-active {
    color: var(--sb-text-primary, #111827);
    font-weight: 500;
}
.billing-config-label {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: var(--sb-text-secondary, #6b7280);
    margin-bottom: 8px;
}
.billing-amount-select {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.billing-amount-btn {
    padding: 8px 14px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-card);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
    color: var(--sb-text-primary, #111);
}
.billing-amount-btn:hover:not(.disabled) {
    border-color: var(--sb-primary, #0071e3);
}
.billing-amount-btn.active {
    border-color: var(--sb-primary, #0071e3);
    background: rgba(0, 113, 227, 0.08);
    color: var(--sb-primary, #0071e3);
}
.billing-amount-btn.disabled {
    opacity: 0.4;
    cursor: not-allowed;
    background: var(--sb-bg-muted, #f9fafb);
}
.billing-ceiling-info {
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
    margin-bottom: 6px;
}
.billing-ceiling-bar {
    height: 6px;
    background: var(--sb-bg-muted, #f3f4f6);
    border-radius: 3px;
    overflow: hidden;
}
.billing-ceiling-bar-fill {
    height: 100%;
    background: var(--sb-primary, #0071e3);
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* Trust Level Card */
.billing-trust-card {
    padding: 20px;
}
.billing-trust-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}
.billing-trust-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
}
.billing-trust-badge.billing-trust-level-0 { background: #9ca3af; }
.billing-trust-badge.billing-trust-level-1 { background: #0071e3; }
.billing-trust-badge.billing-trust-level-2 { background: #3b82f6; }
.billing-trust-badge.billing-trust-level-3 { background: #10b981; }
.billing-trust-badge.billing-trust-level-4 { background: #f59e0b; color: #111; }
.billing-trust-badge.billing-trust-level-5 { background: linear-gradient(135deg, #0071e3, #3b8df5); }
.billing-trust-label {
    font-size: 18px;
    font-weight: 600;
    color: var(--sb-text-primary, #111);
}
.billing-trust-ceiling {
    font-size: 14px;
    color: var(--sb-text-secondary, #6b7280);
    margin-bottom: 16px;
}
.billing-trust-ceiling strong {
    color: var(--sb-text-primary, #111);
}
.billing-trust-progress {
    margin-bottom: 12px;
}
.billing-trust-next {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-primary, #111);
    margin-bottom: 4px;
}
.billing-trust-next-ceiling {
    font-size: 12px;
    color: var(--sb-text-muted, #9ca3af);
    margin-bottom: 10px;
}
.billing-trust-requirements {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.billing-req-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
}
.billing-req-item i {
    font-size: 16px;
    color: var(--sb-text-muted, #d1d5db);
}
.billing-req-item.billing-req-met {
    color: #10b981;
}
.billing-req-item.billing-req-met i {
    color: #10b981;
}
.billing-trust-maxed,
.billing-trust-manual {
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
    font-style: italic;
}
.billing-trust-tips {
    margin-top: 8px;
    padding: 10px 12px;
    background: var(--sb-bg-muted, #f9fafb);
    border-radius: 8px;
}
.billing-trust-tip {
    font-size: 12px;
    color: var(--sb-text-secondary, #6b7280);
    line-height: 1.5;
}
.billing-trust-link {
    font-size: 13px;
    color: var(--sb-primary, #0071e3);
    text-decoration: none;
}
.billing-trust-link:hover {
    text-decoration: underline;
}

/* Usage Chart */
.billing-chart-card {
    padding: 16px;
}
.billing-chart-container {
    position: relative;
    height: 220px;
    margin-bottom: 12px;
}
.billing-usage-chart {
    width: 100%;
    height: 100%;
}
.billing-chart-total {
    font-size: 12px;
    color: var(--sb-text-secondary, #6b7280);
    margin-bottom: 8px;
    font-weight: 500;
}
.billing-chart-bars {
    display: flex;
    align-items: flex-end;
    gap: 2px;
    height: 170px;
    padding-bottom: 24px;
    position: relative;
}
.billing-chart-bar-col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    height: 100%;
    min-width: 0;
    position: relative;
    cursor: default;
}
.billing-chart-bar-col:hover .billing-chart-bar {
    background: var(--f7-theme-color, #0071e3);
    opacity: 1;
}
.billing-chart-bar-col:hover .billing-chart-bar-value {
    opacity: 1;
}
.billing-chart-bar {
    width: 100%;
    max-width: 24px;
    min-width: 4px;
    background: var(--f7-theme-color, #0071e3);
    opacity: 0.6;
    border-radius: 3px 3px 0 0;
    transition: opacity 0.15s;
}
.billing-chart-bar-value {
    font-size: 10px;
    color: var(--sb-text-secondary, #6b7280);
    white-space: nowrap;
    margin-bottom: 2px;
    opacity: 0;
    transition: opacity 0.15s;
}
.billing-chart-bar-label {
    font-size: 10px;
    color: var(--sb-text-muted, #9ca3af);
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    position: absolute;
    bottom: 0;
    transform: translateY(100%);
}
.billing-chart-empty {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: var(--sb-text-muted, #9ca3af);
}
.billing-chart-empty i {
    display: block;
    font-size: 32px;
    margin-bottom: 8px;
}
.billing-chart-period {
    display: flex;
    align-items: center;
}
.billing-period-select,
.billing-filter-select {
    padding: 4px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    background: var(--sb-bg-card);
    font-size: 13px;
    color: var(--sb-text-primary, #111);
    cursor: pointer;
}
.billing-breakdown-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 8px;
}
.billing-breakdown-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
}
.billing-breakdown-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.billing-breakdown-label {
    color: var(--sb-text-secondary, #6b7280);
    flex: 1;
}
.billing-breakdown-value {
    font-weight: 600;
    color: var(--sb-text-primary, #111);
}

/* Transaction Ledger */
.billing-ledger-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}
.billing-type-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    text-transform: capitalize;
}
.billing-type-credit {
    color: #10b981;
}
.billing-type-badge.billing-type-credit {
    background: rgba(16, 185, 129, 0.1);
}
.billing-type-debit {
    color: #ef4444;
}
.billing-type-badge.billing-type-debit {
    background: rgba(239, 68, 68, 0.1);
}
.billing-ledger-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 12px 16px;
    border-top: 1px solid var(--sb-border-light, #f3f4f6);
}
.billing-pagination-info {
    font-size: 13px;
    color: var(--sb-text-secondary, #6b7280);
}
.billing-invoices-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 12px 16px;
    border-top: 1px solid var(--sb-border-light, #f3f4f6);
}

/* Alert Settings */
.billing-threshold-input-wrap {
    display: flex;
    align-items: center;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    padding: 0 8px;
    background: var(--sb-bg-card);
}
.billing-threshold-input {
    border: none;
    background: transparent;
    padding: 6px 0;
    font-size: 14px;
    width: 70px;
    outline: none;
    text-align: right;
    color: var(--sb-text-primary, #111);
}

/* Billing page responsive */
@media (max-width: 768px) {
    .billing-balance-amount { font-size: 32px; }
    .billing-topup-presets { grid-template-columns: repeat(2, 1fr); }
    .billing-topup-custom { flex-direction: column; align-items: stretch; }
    .billing-topup-input-wrap { max-width: 100%; }
    .billing-topup-custom .sb-btn { width: 100%; }
    .billing-breakdown-grid { grid-template-columns: 1fr; }
    .billing-ledger-actions { flex-direction: column; align-items: flex-start; }
}

/* ============================
   Agent Discovery Page
   ============================ */
.page-agent-discovery .ad-section.hidden { display: none; }

/* Metrics Grid */
.page-agent-discovery .ad-metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}
.page-agent-discovery .ad-metric-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 20px;
}
.page-agent-discovery .ad-metric-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--sb-text-muted);
    margin-bottom: 8px;
}
.page-agent-discovery .ad-metric-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--sb-text-primary);
    line-height: 1.2;
}
.page-agent-discovery .ad-metric-subtitle {
    font-size: 12px;
    color: var(--sb-text-muted);
    margin-top: 4px;
}

/* Warning Card */
.page-agent-discovery .ad-warning-card {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 16px;
    background: rgba(255, 149, 0, 0.08);
    border: 1px solid rgba(255, 149, 0, 0.3);
    border-radius: 12px;
}
.page-agent-discovery .ad-warning-card > .icon { color: #ff9500; font-size: 20px; margin-top: 2px; }
.page-agent-discovery .ad-warning-title { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.page-agent-discovery .ad-warning-desc { font-size: 13px; color: var(--sb-text-secondary); }
.page-agent-discovery .ad-warning-desc a { color: var(--sb-primary); }

/* Filter Bar */
.page-agent-discovery .ad-filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.page-agent-discovery .ad-filter-chips { display: flex; gap: 8px; }
.page-agent-discovery .ad-filter-chip {
    padding: 6px 14px;
    border-radius: 16px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid var(--sb-border-color);
    background: var(--sb-bg);
    color: var(--sb-text-secondary);
    transition: background 0.15s, color 0.15s;
}
.page-agent-discovery .ad-filter-chip.active {
    background: var(--sb-primary);
    color: #fff;
    border-color: var(--sb-primary);
}
.page-agent-discovery .ad-search-wrap { flex: 0 0 auto; }
.page-agent-discovery .ad-search-input {
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    font-size: 13px;
    width: 200px;
    background: var(--sb-bg);
    color: var(--sb-text-primary);
}

/* Product Row */
.page-agent-discovery .ad-product-row {
    display: flex;
    align-items: center;
    padding: 12px 16px;
}
.page-agent-discovery .ad-product-warnings {
    margin-top: 4px;
    font-size: 11px;
    color: #ff9500;
}
.page-agent-discovery .ad-product-warnings .icon { font-size: 11px; }

/* Pagination */
.page-agent-discovery .ad-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 16px 0;
}
.page-agent-discovery .ad-pagination-info {
    font-size: 13px;
    color: var(--sb-text-muted);
}

/* Loading & Empty */
.page-agent-discovery .ad-loading {
    display: flex;
    justify-content: center;
    padding: 40px 0;
}
.page-agent-discovery .ad-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--sb-text-muted);
}
.page-agent-discovery .ad-empty-state .icon { font-size: 32px; margin-bottom: 12px; display: block; }

/* Preview */
.page-agent-discovery .ad-preview-desc {
    font-size: 13px;
    color: var(--sb-text-secondary);
    margin-bottom: 16px;
}
.page-agent-discovery .ad-preview-header {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-muted);
    margin-bottom: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.page-agent-discovery .ad-preview-json {
    background: var(--sb-code-bg, #1e1e1e);
    border-radius: 10px;
    padding: 16px;
    overflow-x: auto;
    max-height: 500px;
    overflow-y: auto;
}
.page-agent-discovery .ad-preview-json pre {
    margin: 0;
    white-space: pre-wrap;
    word-wrap: break-word;
}
.page-agent-discovery .ad-preview-json code {
    font-size: 12px;
    color: #d4d4d4;
    font-family: 'SF Mono', 'Fira Code', monospace;
}

/* Comparison Grid */
.page-agent-discovery .ad-comparison-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
.page-agent-discovery .ad-comparison-card {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    overflow: hidden;
}
.page-agent-discovery .ad-comparison-header {
    padding: 12px 16px;
    font-weight: 600;
    font-size: 14px;
    border-bottom: 1px solid var(--sb-border-color);
    background: var(--sb-bg-hover);
}
.page-agent-discovery .ad-comparison-row {
    display: flex;
    justify-content: space-between;
    padding: 10px 16px;
    border-bottom: 1px solid var(--sb-border-color);
}
.page-agent-discovery .ad-comparison-row:last-child { border-bottom: none; }
.page-agent-discovery .ad-comparison-label { font-size: 13px; color: var(--sb-text-secondary); }
.page-agent-discovery .ad-comparison-value { font-size: 13px; font-weight: 600; color: var(--sb-text-primary); }

/* Chart */
.page-agent-discovery .ad-chart-container {
    position: relative;
    height: 260px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    padding: 16px;
}
.page-agent-discovery .ad-chart-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--sb-text-muted);
    gap: 8px;
}
.page-agent-discovery .ad-chart-empty .icon { font-size: 24px; }

/* Period Select */
.page-agent-discovery .ad-period-select {
    padding: 4px 8px;
    border: 1px solid var(--sb-border-color);
    border-radius: 6px;
    font-size: 13px;
    background: var(--sb-bg);
    color: var(--sb-text-primary);
}

/* Status badges */
.page-agent-discovery .ad-status {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
    text-transform: capitalize;
}
.page-agent-discovery .ad-status-active { background: rgba(0, 122, 255, 0.1); color: var(--sb-primary); }
.page-agent-discovery .ad-status-closed { background: rgba(52, 199, 89, 0.1); color: #34c759; }
.page-agent-discovery .ad-status-cancelled { background: rgba(255, 59, 48, 0.1); color: #ff3b30; }

/* Delegation badges */
.page-agent-discovery .ad-deleg-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 500;
    background: rgba(0, 122, 255, 0.1);
    color: var(--sb-primary);
}
.page-agent-discovery .ad-no-deleg {
    font-size: 11px;
    color: var(--sb-text-muted);
}

/* Placeholder card (pricing rules) */
/* Pricing Rules */
.page-agent-discovery .ad-pricing-empty {
    text-align: center;
    padding: 48px 24px;
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
}
.page-agent-discovery .ad-pricing-empty .icon { font-size: 40px; color: var(--sb-text-muted); margin-bottom: 16px; }
.page-agent-discovery .ad-pricing-empty h3 { margin: 0 0 8px; font-size: 18px; }
.page-agent-discovery .ad-pricing-empty p { color: var(--sb-text-secondary); font-size: 14px; margin-bottom: 20px; max-width: 400px; margin-left: auto; margin-right: auto; }
.page-agent-discovery .ad-pricing-rule-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border: 1px solid var(--sb-border-color);
    border-radius: 10px;
    margin-bottom: 8px;
    background: var(--sb-bg-card, #fff);
}
.page-agent-discovery .ad-pricing-rule-row:hover { background: var(--sb-row-hover, #f9fafb); }
.page-agent-discovery .ad-rule-actions { display: flex; gap: 6px; flex-shrink: 0; }
.page-agent-discovery .ad-rule-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    margin-left: 8px;
    vertical-align: middle;
}
.page-agent-discovery .ad-rule-active { background: rgba(52, 199, 89, 0.12); color: #34c759; }
.page-agent-discovery .ad-rule-inactive { background: rgba(142, 142, 147, 0.12); color: #8e8e93; }
.page-agent-discovery .ad-rule-type-label { color: var(--sb-text-muted); font-size: 12px; }
.page-agent-discovery .ad-form-group { margin-bottom: 16px; }
.page-agent-discovery .ad-form-label { display: block; font-size: 13px; font-weight: 600; color: var(--sb-text-secondary); margin-bottom: 6px; }
.page-agent-discovery .ad-form-input {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    font-size: 14px;
    background: var(--sb-bg-input, #fff);
    color: var(--sb-text-primary);
    box-sizing: border-box;
}
.page-agent-discovery .ad-form-input:focus { border-color: var(--sb-primary); outline: none; }
.page-agent-discovery .ad-form-select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    font-size: 14px;
    background: var(--sb-bg-input, #fff);
    color: var(--sb-text-primary);
    box-sizing: border-box;
}
.page-agent-discovery .ad-form-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }
.page-agent-discovery .ad-tier-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}
.page-agent-discovery .ad-tier-row .ad-form-input { width: 120px; flex: 0 0 auto; }
.page-agent-discovery .ad-tier-sep { font-size: 13px; color: var(--sb-text-muted); white-space: nowrap; }

/* Product actions */
.page-agent-discovery .ad-product-actions { display: flex; gap: 8px; }

/* Responsive */
@media (max-width: 640px) {
    .page-agent-discovery .ad-metrics-grid { grid-template-columns: 1fr 1fr; }
    .page-agent-discovery .ad-comparison-grid { grid-template-columns: 1fr; }
    .page-agent-discovery .ad-filter-bar { flex-direction: column; align-items: flex-start; }
    .page-agent-discovery .ad-search-input { width: 100%; }
    .page-agent-discovery .ad-tier-row { flex-wrap: wrap; }
    .page-agent-discovery .ad-tier-row .ad-form-input { width: 100px; }
}

/* ==========================================================================
   Help Panel & Contextual Help System
   ========================================================================== */

/* Help panel backdrop */
#help-panel-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: 13500;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}
.help-panel-open ~ #help-panel-backdrop,
.help-panel-active #help-panel-backdrop {
    opacity: 1;
    visibility: visible;
}

/* Help panel slide-over */
#help-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 420px;
    max-width: 100vw;
    background: var(--sb-bg-card, #fff);
    z-index: 13600;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    box-shadow: -2px 0 16px rgba(0, 0, 0, 0.1);
}
#help-panel.help-panel-open {
    transform: translateX(0);
}

/* Help panel header */
.help-panel-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--sb-border-color, #e3e8ee);
    flex-shrink: 0;
}
.help-panel-header-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: rgba(0, 113, 227, 0.1);
    color: var(--sb-primary, #0071e3);
    flex-shrink: 0;
}
.help-panel-header-icon .f7-icons { font-size: 18px; }
#help-panel-title {
    flex: 1;
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary, #1a1f36);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
#help-panel-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    color: var(--sb-text-muted, #697386);
    cursor: pointer;
    flex-shrink: 0;
    text-decoration: none;
}
#help-panel-close:hover { background: var(--sb-bg-hover, #f6f9fc); }
#help-panel-close .f7-icons { font-size: 16px; }
/* Minimum 44×44px touch target on mobile (Apple HIG / WCAG 2.5.5) */
@media (max-width: 768px) {
    #help-panel-close {
        min-width: 44px;
        min-height: 44px;
        border-radius: 8px;
    }
}

/* Help panel search */
.help-panel-search {
    padding: 12px 20px;
    border-bottom: 1px solid var(--sb-border-color, #e3e8ee);
    flex-shrink: 0;
}
.help-panel-search-list {
    margin: 0;
    background: transparent;
}
.help-panel-search-list ul {
    background: var(--sb-bg-hover, #f6f9fc);
    border-radius: 8px;
    border: 1px solid var(--sb-border-color, #e3e8ee);
}
.help-panel-search-list .item-content {
    padding: 8px 12px;
    min-height: auto;
}
.help-panel-search-list .item-media {
    min-width: auto;
    padding: 0;
    align-self: center;
}
.help-panel-search-list .item-media .f7-icons {
    font-size: 14px;
    color: var(--sb-text-muted, #697386);
}
.help-panel-search-list .item-inner {
    padding: 0 0 0 8px;
    min-height: auto;
}
.help-panel-search-list .item-inner::after { display: none; }
#help-search-input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 13px;
    color: var(--sb-text-primary, #1a1f36);
    outline: none;
}
#help-search-input::placeholder { color: var(--sb-text-muted, #697386); }

/* Search results */
#help-search-results {
    display: none;
    padding: 8px 20px;
    border-bottom: 1px solid var(--sb-border-color, #e3e8ee);
    max-height: 240px;
    overflow-y: auto;
    flex-shrink: 0;
}
.help-search-item {
    display: block;
    padding: 10px 12px;
    border-radius: 8px;
    text-decoration: none;
    color: var(--sb-text-primary, #1a1f36);
    transition: background 0.1s;
}
.help-search-item:hover { background: var(--sb-bg-hover, #f6f9fc); }
.help-search-item-title { font-size: 13px; font-weight: 600; }
.help-search-item-route { font-size: 11px; color: var(--sb-text-muted, #697386); margin-top: 2px; }
.help-search-empty {
    padding: 16px 12px;
    text-align: center;
    font-size: 13px;
    color: var(--sb-text-muted, #697386);
}

/* Help panel content area */
#help-panel-content {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    -webkit-overflow-scrolling: touch;
}

/* Loading state */
.help-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}
.help-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--sb-text-muted, #697386);
    font-size: 14px;
}

/* Rendered markdown styles inside help panel */
#help-panel-content h1 {
    font-size: 20px;
    font-weight: 700;
    color: var(--sb-text-primary, #1a1f36);
    margin: 0 0 16px 0;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--sb-border-color, #e3e8ee);
}
#help-panel-content h2 {
    font-size: 16px;
    font-weight: 600;
    color: var(--sb-text-primary, #1a1f36);
    margin: 24px 0 12px 0;
}
#help-panel-content h3 {
    font-size: 14px;
    font-weight: 600;
    color: var(--sb-text-primary, #1a1f36);
    margin: 20px 0 8px 0;
}
#help-panel-content h4 {
    font-size: 13px;
    font-weight: 600;
    color: var(--sb-text-secondary, #3c4257);
    margin: 16px 0 8px 0;
}
#help-panel-content p {
    font-size: 13px;
    line-height: 1.6;
    color: var(--sb-text-secondary, #3c4257);
    margin: 0 0 12px 0;
}
#help-panel-content ul, #help-panel-content ol {
    font-size: 13px;
    line-height: 1.6;
    color: var(--sb-text-secondary, #3c4257);
    margin: 0 0 12px 0;
    padding-left: 20px;
}
#help-panel-content li { margin-bottom: 4px; }
#help-panel-content code {
    font-family: 'SF Mono', 'Fira Code', 'Roboto Mono', monospace;
    font-size: 12px;
    background: var(--sb-bg-hover, #f6f9fc);
    padding: 2px 6px;
    border-radius: 4px;
    color: var(--sb-text-primary, #1a1f36);
}
#help-panel-content pre {
    background: #1e1e2e;
    color: #cdd6f4;
    padding: 12px 16px;
    border-radius: 8px;
    overflow-x: auto;
    margin: 0 0 12px 0;
    font-size: 12px;
    line-height: 1.5;
}
#help-panel-content pre code {
    background: transparent;
    padding: 0;
    color: inherit;
}
#help-panel-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 16px 0;
    font-size: 12px;
}
#help-panel-content th {
    text-align: left;
    padding: 8px 10px;
    background: var(--sb-bg-hover, #f6f9fc);
    border: 1px solid var(--sb-border-color, #e3e8ee);
    font-weight: 600;
    color: var(--sb-text-primary, #1a1f36);
    white-space: nowrap;
}
#help-panel-content td {
    padding: 8px 10px;
    border: 1px solid var(--sb-border-color, #e3e8ee);
    color: var(--sb-text-secondary, #3c4257);
    vertical-align: top;
}
#help-panel-content a {
    color: var(--sb-primary, #0071e3);
    text-decoration: none;
}
#help-panel-content a:hover { text-decoration: underline; }
#help-panel-content strong { font-weight: 600; color: var(--sb-text-primary, #1a1f36); }
#help-panel-content blockquote {
    margin: 0 0 12px 0;
    padding: 8px 16px;
    border-left: 3px solid var(--sb-primary, #0071e3);
    background: var(--sb-bg-hover, #f6f9fc);
    border-radius: 0 8px 8px 0;
}
#help-panel-content hr {
    border: none;
    border-top: 1px solid var(--sb-border-color, #e3e8ee);
    margin: 20px 0;
}

/* Help panel footer */
.help-panel-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    border-top: 1px solid var(--sb-border-color, #e3e8ee);
    flex-shrink: 0;
    background: var(--sb-bg-sidebar, #f5f7fa);
}

.help-panel-ask-ai-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    text-decoration: none;
    padding: 6px 12px;
    border-radius: 8px;
    background: var(--sb-primary, #0071e3);
    transition: background 0.15s;
}
.help-panel-ask-ai-btn:hover {
    background: var(--sb-primary-hover, #0076df);
    text-decoration: none;
}
.help-panel-ask-ai-btn .f7-icons { font-size: 14px; }

.help-panel-docs-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--sb-text-muted, #697386);
    text-decoration: none;
}
.help-panel-docs-link:hover { color: var(--sb-primary, #0071e3); text-decoration: none; }
.help-panel-docs-link .f7-icons { font-size: 12px; }

/* Responsive */
@media (max-width: 480px) {
    #help-panel { width: 100vw; }
}

/* On desktop the help panel is a non-modal side panel (420px).
   Hide the full-viewport backdrop so it does not dim/block the main
   dashboard content — the panel slides in alongside the page. */
@media (min-width: 481px) {
    #help-panel-backdrop { display: none !important; }
}

/* Field-level help tooltips */
[data-help] {
    cursor: help;
    border-bottom: 1px dotted var(--sb-text-muted, #697386);
}

.help-field-tooltip .tooltip-content {
    max-width: 280px;
    font-size: 13px;
    line-height: 1.4;
}

/* ─── Agent Workflows Dashboard ──────────────────────────────── */

.awf-section.hidden {
    display: none;
}

.awf-poll-indicator {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--sb-text-muted, #697386);
    animation: awf-pulse 2s ease-in-out infinite;
}

@keyframes awf-pulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
}

.awf-filter-row {
    display: flex;
    gap: 8px;
    align-items: center;
}

.awf-filter-select {
    padding: 6px 12px;
    border: 1px solid var(--sb-border-color, #e3e8ee);
    border-radius: 6px;
    font-size: 13px;
    background: var(--sb-bg-card, #fff);
    color: var(--sb-text-primary, #1a1f36);
}

/* Status Badges */
.awf-status-badge {
    display: inline-flex;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: capitalize;
}

.awf-status-planned {
    background: rgba(107, 114, 128, 0.12);
    color: #6b7280;
}

.awf-status-executing {
    background: rgba(59, 130, 246, 0.12);
    color: #3b82f6;
}

.awf-status-negotiating {
    background: rgba(245, 158, 11, 0.12);
    color: #f59e0b;
}

.awf-status-completed {
    background: rgba(16, 185, 129, 0.12);
    color: #059669;
}

.awf-status-failed {
    background: rgba(239, 68, 68, 0.12);
    color: #dc2626;
}

.awf-status-cancelled {
    background: rgba(107, 114, 128, 0.12);
    color: #6b7280;
}

.awf-status-degraded {
    background: rgba(245, 158, 11, 0.12);
    color: #d97706;
}

/* Workflow ID */
.awf-id {
    font-size: 12px;
    font-family: var(--sb-font-mono, 'SF Mono', 'Fira Code', monospace);
    color: var(--sb-text-secondary, #3c4257);
}

.awf-deleg-id {
    font-size: 12px;
    color: var(--sb-text-muted, #697386);
}

/* Row interactions */
.awf-row {
    cursor: pointer;
    transition: background 0.15s;
}

.awf-row:hover {
    background: var(--sb-bg-hover, #f6f9fc);
}

/* Cancel button */
.sb-btn-sm {
    padding: 4px 12px;
    font-size: 12px;
}

/* Detail Panel */
.awf-detail-panel {
    margin-top: 8px;
}

.awf-detail-actions {
    display: flex;
    gap: 12px;
    align-items: center;
}

.awf-danger-link {
    color: #dc2626 !important;
}

.awf-loading {
    display: flex;
    justify-content: center;
    padding: 32px 0;
}

.awf-error {
    text-align: center;
    padding: 16px;
    color: var(--sb-text-muted, #697386);
}

.awf-error-card {
    border-color: #ef4444;
    background: rgba(239, 68, 68, 0.04);
}

.awf-error-card .metric-title {
    color: #dc2626;
}

#awf-detail-error-msg {
    font-size: 13px;
    color: #dc2626;
    word-break: break-word;
}

/* Step Timeline */
.awf-timeline-step {
    display: flex;
    gap: 12px;
    position: relative;
}

.awf-timeline-connector {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    width: 20px;
}

.awf-timeline-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--sb-border-color, #e3e8ee);
    border: 2px solid var(--sb-bg-card, #fff);
    box-shadow: 0 0 0 2px var(--sb-border-color, #e3e8ee);
    flex-shrink: 0;
    margin-top: 4px;
}

.awf-timeline-line {
    width: 2px;
    flex-grow: 1;
    background: var(--sb-border-color, #e3e8ee);
    min-height: 24px;
}

.awf-step-completed .awf-timeline-dot {
    background: #059669;
    box-shadow: 0 0 0 2px #059669;
}

.awf-step-active .awf-timeline-dot {
    background: #3b82f6;
    box-shadow: 0 0 0 2px #3b82f6;
    animation: awf-pulse 1.5s ease-in-out infinite;
}

.awf-step-failed .awf-timeline-dot {
    background: #dc2626;
    box-shadow: 0 0 0 2px #dc2626;
}

.awf-timeline-content {
    flex-grow: 1;
    padding-bottom: 16px;
}

.awf-timeline-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}

.awf-timeline-label {
    font-weight: 600;
    font-size: 13px;
    color: var(--sb-text-primary, #1a1f36);
}

.awf-timeline-duration {
    font-size: 11px;
    color: var(--sb-text-muted, #697386);
    font-family: var(--sb-font-mono, 'SF Mono', 'Fira Code', monospace);
}

.awf-step-detail {
    display: block;
    font-size: 12px;
    color: var(--sb-text-secondary, #3c4257);
    margin-top: 2px;
}

.awf-timeline-time {
    font-size: 11px;
    color: var(--sb-text-muted, #697386);
    margin-top: 2px;
}

.awf-empty-timeline {
    text-align: center;
    padding: 24px 0;
    color: var(--sb-text-muted, #697386);
    font-size: 13px;
}

/* Budget Validation */
.awf-budget-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
    font-size: 13px;
}

.awf-budget-row .icon {
    font-size: 16px;
}

.awf-budget-ok .icon {
    color: #059669;
}

.awf-budget-fail .icon {
    color: #dc2626;
}

.awf-budget-label {
    flex-grow: 1;
    color: var(--sb-text-primary, #1a1f36);
}

.awf-budget-value {
    font-family: var(--sb-font-mono, 'SF Mono', 'Fira Code', monospace);
    font-size: 12px;
    color: var(--sb-text-secondary, #3c4257);
}

/* Constraints */
.awf-constraint-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 13px;
    border-bottom: 1px solid var(--sb-border-color, #e3e8ee);
}

.awf-constraint-row:last-child {
    border-bottom: none;
}

.awf-constraint-label {
    color: var(--sb-text-muted, #697386);
}

.awf-constraint-value {
    color: var(--sb-text-primary, #1a1f36);
    font-weight: 500;
}

/* Spending Cards */
.awf-spending-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.awf-spending-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 12px;
}

.awf-spending-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    color: var(--sb-text-muted, #697386);
    border-top: 1px solid var(--sb-border-color, #e3e8ee);
    padding-top: 8px;
}

.awf-spending-actions {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 70%;
}

/* Pagination */
.awf-pagination {
    padding: 16px 24px;
}

.awf-pagination-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
}

.awf-page-info {
    font-size: 13px;
    color: var(--sb-text-muted, #697386);
}

/* Agent Analytics — Issue #302 */
.awf-trend-up { color: #16a34a; font-size: 12px; font-weight: 600; }
.awf-trend-down { color: #ef4444; font-size: 12px; font-weight: 600; }
.awf-trend-flat { color: #6b7280; font-size: 12px; font-weight: 600; }

.awf-ceiling-group {
    margin: 8px 0;
    padding: 8px;
    background: var(--f7-block-bg-color, #f9fafb);
    border-radius: 8px;
}
.awf-ceiling-deleg {
    margin-bottom: 4px;
    font-size: 11px;
    color: var(--f7-text-color);
}
.awf-ceiling-bar-row {
    margin: 4px 0;
}
.awf-ceilings-section {
    margin-top: 8px;
    border-top: 1px solid var(--f7-list-border-color, #e5e7eb);
    padding-top: 8px;
}

.deleg-spending-fill.deleg-bar-warning {
    background: #f59e0b;
}

/* Anomaly Cards */
.awf-anomaly-label {
    font-weight: 600;
    font-size: 14px;
}
.awf-anomaly-agent {
    margin: 4px 0;
    font-size: 12px;
}
.awf-anomaly-details {
    margin: 8px 0;
    font-size: 13px;
}
.awf-anomaly-detail {
    margin: 2px 0;
}
.awf-anomaly-detail span {
    color: var(--f7-list-item-after-text-color, #6b7280);
}
.awf-anomaly-suggestion {
    margin-top: 8px;
    padding: 6px 10px;
    background: rgba(59, 130, 246, 0.06);
    border-radius: 6px;
    font-size: 12px;
    color: var(--f7-theme-color);
}
.awf-anomaly-suggestion .icon {
    font-size: 14px;
    margin-right: 4px;
}
.awf-anomaly-time {
    margin-top: 6px;
    font-size: 11px;
    color: var(--f7-list-item-after-text-color, #9ca3af);
}

/* Anomaly severity badges */
.awf-severity-low { background: #dbeafe; color: #2563eb; }
.awf-severity-medium { background: #fef3c7; color: #d97706; }
.awf-severity-high { background: #fee2e2; color: #dc2626; }
.awf-severity-critical { background: #ef4444; color: #fff; }

/* Approval Cards — Issue #657 */
.awf-approval-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    margin-left: 6px;
    border-radius: 9px;
    background: var(--f7-color-red);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    line-height: 1;
}

.awf-status-awaiting-approval {
    background: rgba(234, 179, 8, 0.12);
    color: #b45309;
    border: 1px solid rgba(234, 179, 8, 0.3);
}

.awf-approval-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.awf-approval-checkbox-label {
    flex-shrink: 0;
    cursor: pointer;
}

.awf-approval-card-id {
    flex-grow: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.awf-approval-value {
    font-size: 14px;
    font-weight: 600;
    color: #059669;
}

.awf-approval-intent {
    font-size: 13px;
    color: var(--sb-text-secondary, #697386);
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.awf-approval-meta {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: var(--sb-text-muted, #697386);
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.awf-approval-expires {
    font-size: 12px;
    color: #dc2626;
    margin-bottom: 8px;
}

.awf-approval-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

/* Bulk action toolbar */
.awf-bulk-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    background: var(--sb-bg-secondary, #f6f9fc);
    border: 1px solid var(--sb-border-color, rgba(0,0,0,.08));
    border-radius: 8px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.awf-bulk-bar.hidden {
    display: none;
}

.awf-bulk-select-all {
    flex-shrink: 0;
    cursor: pointer;
}

.awf-bulk-select-all-text {
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
}

.awf-bulk-count-label {
    font-size: 13px;
    color: var(--sb-text-muted, #697386);
    white-space: nowrap;
}

/* Spending items */
.awf-spending-item {
    padding: 4px 0;
}

.awf-spending-expiry {
    font-size: 12px;
    color: var(--sb-text-muted, #697386);
}

/* Responsive */
@media (max-width: 768px) {
    .awf-spending-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .awf-approval-actions {
        gap: 6px;
    }

    .awf-bulk-bar {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Deal Participants Section */
.deal-participant-item { display: flex; align-items: center; padding: 10px 16px; border-bottom: 1px solid var(--f7-list-item-border-color, rgba(0,0,0,.08)); }
.deal-participant-item:last-child { border-bottom: none; }
.deal-participant-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--f7-color-blue); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 14px; font-weight: 600; flex-shrink: 0; margin-right: 12px; }
.deal-participant-info { flex: 1; min-width: 0; }
.deal-participant-name { font-size: 14px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.deal-participant-meta { font-size: 12px; color: #888; margin-top: 2px; }
.deal-participant-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.deal-participant-share { font-size: 12px; color: var(--f7-color-green); font-weight: 500; }
.deal-participants-empty { padding: 24px 16px; text-align: center; color: #888; font-size: 14px; }

/* Deal View — Escrow Details */
.escrow-details { padding: 12px 16px; }
.escrow-row { display: flex; align-items: center; padding: 6px 0; border-bottom: 1px solid var(--f7-list-item-border-color, rgba(0,0,0,.08)); }
.escrow-row:last-child { border-bottom: none; }
.escrow-row-label { flex: 0 0 120px; font-size: 13px; color: var(--f7-list-item-subtitle-text-color, #888); }
.escrow-row-value { flex: 1; font-size: 14px; }
.escrow-auth-expiry { display: flex; align-items: center; gap: 6px; }
.escrow-auth-badge { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: #4cd964; }
.escrow-auth-badge[data-status="warning"] { background: #ff9500; }
.escrow-auth-badge[data-status="critical"] { background: #ff3b30; }
.escrow-days-remaining { font-size: 12px; color: #888; }

/* ─── Intelligence Action Bridge — Issue #814 ─────────────────── */

/* At-risk deals negotiation status cell */
.intel-neg-loading { color: #94a3b8; font-size: 12px; }
.intel-no-neg { color: #94a3b8; }
.intel-prob-lift { color: #15803d; font-weight: 600; }

/* Pipeline drill-down section */
.intel-drill-section {
    border-top: 2px solid var(--f7-theme-color, #0071e3);
    margin-top: 8px;
}
.intel-hbar-clickable {
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.15s;
}
.intel-hbar-clickable:hover {
    background: rgba(0, 113, 227, 0.06);
}
.intel-hbar-clickable:hover .intel-hbar-label {
    color: var(--f7-theme-color, #0071e3);
}

/* Bulk pricing suggestions section */
#intel-bulk-pricing-section {
    margin-top: 8px;
}

/* Deal score in negotiations table */
.neg-win-pct {
    display: block;
    font-size: 11px;
    color: #888;
    margin-top: 2px;
}
.neg-score-na {
    color: #94a3b8;
}

/* ─── Suggestions Page (#1991) ──────────────────────────────────── */

/* Layout */
.sug-page-wrapper { max-width: 1200px; margin: 0 auto; padding: 16px; }
.sug-list-filters { margin-bottom: 20px; }
.sug-counts { margin-bottom: 20px; }
.sug-count-card { cursor: pointer; }

/* Batch Toolbar */
.sug-batch-toolbar { margin-bottom: 16px; padding: 12px 16px; background: var(--sb-bg-card); border: 1px solid var(--sb-border-color); border-radius: 8px; }
.sug-batch-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.sug-batch-label { font-size: 13px; font-weight: 600; color: var(--sb-text-secondary); }
.sug-btn-danger { color: #ef4444; border-color: #ef4444; }
.sug-spacer { flex: 1; }
.sug-btn-icon { font-size: 14px; margin-right: 4px; }

/* Settings Panel */
.sug-settings-panel { margin-bottom: 20px; }
.sug-settings-card { padding: 20px; }
.sug-settings-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.sug-settings-title { font-size: 16px; font-weight: 600; margin: 0; }
.sug-settings-subtitle { font-size: 12px; color: var(--sb-text-muted); margin: 2px 0 0 0; }
.sug-link { font-size: 12px; color: var(--sb-primary); }
.sug-settings-empty { text-align: center; padding: 16px; color: var(--sb-text-muted); }
.sug-settings-grid { display: grid; gap: 16px; grid-template-columns: 1fr 1fr; }
.sug-label { font-size: 12px; font-weight: 600; color: var(--sb-text-secondary); display: block; margin-bottom: 6px; }
.sug-setting-value { font-size: 14px; color: var(--sb-text-primary); padding: 8px 0; }
.sug-chip-row { display: flex; flex-wrap: wrap; gap: 6px; }
.sug-field { margin-top: 16px; }
.sug-settings-section { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--sb-border-color); }
.sug-settings-section-title { font-size: 14px; font-weight: 600; color: var(--sb-text-primary); margin-bottom: 12px; }
.sug-hint { font-size: 11px; color: var(--sb-text-muted); margin-top: 4px; }
.sug-settings-actions { margin-top: 16px; display: flex; gap: 8px; }

/* Rollback Alert */
.sug-rollback-alert { margin-bottom: 16px; padding: 14px 16px; background: #fef2f2; border: 1px solid #fecaca; border-radius: 8px; border-left: 4px solid #ef4444; }
.sug-rollback-content { display: flex; align-items: center; gap: 10px; }
.sug-rollback-icon { font-size: 20px; color: #ef4444; }
.sug-rollback-text { flex: 1; }
.sug-rollback-title { font-size: 14px; font-weight: 600; color: #991b1b; }
.sug-rollback-desc { font-size: 13px; color: #991b1b; margin-top: 2px; }
.sug-rollback-cta { font-size: 13px; font-weight: 600; color: #ef4444; white-space: nowrap; }

/* Health Score */
.sug-health-score { margin-bottom: 16px; }
.sug-health-card { padding: 12px 16px; }
.sug-health-row { display: flex; align-items: center; gap: 16px; }
.sug-score-ring { position: relative; width: 56px; height: 56px; flex-shrink: 0; }
.sug-health-content { flex: 1; }
.sug-health-label { font-size: 14px; color: var(--sb-text-primary); margin-top: 2px; }
.sug-health-meta { text-align: right; font-size: 12px; color: var(--sb-text-muted); }

/* State Displays */
.sug-state-center { text-align: center; padding: 60px 0; color: var(--sb-text-muted); }
.sug-loading-text { margin-top: 12px; }
.sug-empty-state { text-align: center; padding: 60px 20px; }
.sug-no-results-state { text-align: center; padding: 40px 20px; }
.sug-empty-icon-lg { font-size: 48px; color: var(--sb-text-muted); margin-bottom: 12px; }
.sug-empty-icon { font-size: 36px; color: var(--sb-text-muted); margin-bottom: 8px; }
.sug-empty-title { color: var(--sb-text-secondary); margin-bottom: 8px; }
.sug-empty-desc { color: var(--sb-text-muted); font-size: 14px; }

/* Panel Sections */
.sug-section-panel { margin-bottom: 20px; }
.sug-section-header { margin-bottom: 12px; }
.sug-panel-title { font-size: 16px; margin: 0; }
.sug-panel-desc { margin: 2px 0 0 0; font-size: 12px; }
.sug-flex-row { display: flex; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.sug-sub-section { margin-bottom: 12px; }

/* Cumulative Impact */
.sug-cumulative-impact { margin-bottom: 16px; }
.sug-cumulative-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.sug-stat { text-align: center; min-width: 80px; }
.sug-stat-value { font-size: 22px; font-weight: 700; }
.sug-stat-label { font-size: 11px; color: var(--sb-text-muted); }
.sug-timeline-wrap { flex: 1; min-width: 100px; }
.sug-timeline { display: flex; align-items: flex-end; gap: 2px; height: 40px; }

/* Suggestion Card (JS-rendered) */
.sug-card { padding: 16px; margin-bottom: 12px; cursor: pointer; }
.sug-card-body { display: flex; align-items: flex-start; gap: 12px; }
.sug-card-icon { flex-shrink: 0; width: 36px; height: 36px; border-radius: 8px; background: var(--sb-empty-bg); display: flex; align-items: center; justify-content: center; }
.sug-card-icon .icon { font-size: 18px; color: var(--sb-primary); }
.sug-card-main { flex: 1; min-width: 0; }
.sug-card-title-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.sug-card-title { font-size: 15px; font-weight: 600; color: var(--sb-text-primary); }
.sug-badge-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px; }
.sug-badge { font-size: 10px; padding: 2px 8px; border-radius: 10px; }
.sug-badge-muted { background: var(--sb-empty-bg); color: var(--sb-text-secondary); }
.sug-badge-auto { background: #6366f122; color: #6366f1; font-weight: 600; }
.sug-badge-ab { background: #8b5cf622; color: #8b5cf6; font-weight: 600; }
.sug-badge-rollback { background: #fef2f222; color: #ef4444; font-weight: 600; border: 1px solid #fecaca; }
.sug-card-rationale { font-size: 13px; color: var(--sb-text-secondary); margin: 0 0 6px 0; line-height: 1.4; }
.sug-card-impact-note { font-size: 12px; color: var(--sb-text-muted); margin: 0; font-style: italic; }
.sug-actions { display: flex; gap: 8px; margin-top: 12px; align-items: center; }
.sug-reject-btn { color: #ef4444; border-color: #ef4444; }
.sug-dismiss-btn { font-size: 11px; color: var(--sb-text-muted); }
.sug-impact-span { font-size: 12px; font-weight: 600; margin-left: 8px; }
.sug-rollback-reason { font-size: 12px; color: #ef4444; margin-top: 6px; }
.sug-rollback-reason .icon { font-size: 11px; }
.sug-score-wrap { flex-shrink: 0; text-align: center; }
.sug-confidence-ring { width: 44px; height: 44px; border-radius: 50%; border: 3px solid; display: flex; align-items: center; justify-content: center; }
.sug-confidence-value { font-size: 13px; font-weight: 700; }
.sug-score-label { font-size: 10px; color: var(--sb-text-muted); margin-top: 2px; }

/* Insights — Category Rates */
.sug-insight-card { padding: 12px; }
.sug-insight-label { font-size: 12px; font-weight: 600; color: var(--sb-text-secondary); margin-bottom: 8px; }
.sug-cat-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.sug-cat-item { flex: 1; min-width: 100px; text-align: center; padding: 8px; background: var(--sb-empty-bg); border-radius: 6px; }
.sug-cat-item .icon { font-size: 14px; color: var(--sb-text-muted); }
.sug-cat-name { font-size: 11px; font-weight: 600; margin-top: 2px; }
.sug-cat-rate { font-size: 16px; font-weight: 700; }
.sug-cat-count { font-size: 10px; color: var(--sb-text-muted); }

/* Insights — Top Performing */
.sug-top-item { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--sb-border-color); }
.sug-top-item .icon { font-size: 14px; color: var(--sb-text-muted); }
.sug-top-item-title { flex: 1; font-size: 13px; }
.sug-top-impact { font-size: 13px; font-weight: 700; }

/* Impact Metrics (JS-rendered) */
.sug-metric-sm { flex: 1; min-width: 120px; padding: 12px; }
.sug-metric-title-sm { font-size: 12px; }
.sug-metric-value-sm { font-size: 22px; }
.sug-metric-sub-sm { font-size: 11px; }

/* Showing Count / Load More */
.sug-count-label { font-size: 13px; color: var(--sb-text-muted); margin-bottom: 8px; text-align: right; }
.sug-load-more { text-align: center; padding: 20px; }

/* Responsive */
@media (max-width: 600px) {
    .sug-settings-grid { grid-template-columns: 1fr; }
    .sug-cumulative-row { gap: 8px; }
    .sug-stat { min-width: 60px; }
    .sug-page-wrapper { padding: 12px; }
}
