/**
 * 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);
    
    /* 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: #635bff;
    --sb-primary-hover: #5851ea;
    --sb-primary-gradient: #8b5cf6;
    --sb-primary-tint: rgba(99, 91, 255, 0.08);
    --sb-primary-subtle: rgba(99, 91, 255, 0.02);
    --sb-row-hover: #f9fafb;
    --sb-empty-bg: #f6f9fc;
}

.ios {
    
    --f7-tabbar-link-inactive-color: #8b8d98;
    --f7-tabbar-link-active-color: #000;
    --f7-ios-primary-shade: #5851ea;
    --f7-ios-primary-tint: #7c75ff;
    --f7-ios-primary-rgb: 99, 91, 255;
    --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: #7c75ff;
    --sb-primary-hover: #8f89ff;
    --sb-primary-gradient: #a78bfa;
    --sb-primary-tint: rgba(124, 117, 255, 0.15);
    --sb-primary-subtle: rgba(124, 117, 255, 0.05);
    --sb-row-hover: #232329;
    --sb-empty-bg: #1a1a1f;

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

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

.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);
}

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

/* App mode: animate global toolbar visibility based on page transitions */
body.layout-app .global-toolbar {
    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: #f3e8ff;
    color: #9333ea;
}

.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 toolbar 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,
body.layout-app .view-main:not(.router-transition-forward):not(.router-transition-backward):has(.page-current.page-dashboard) .global-toolbar {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
}

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

/* App mode: During backward transition - show only if going back TO a list/dashboard page */
body.layout-app .view-main.router-transition-backward:has(.page-previous.page-list) .global-toolbar,
body.layout-app .view-main.router-transition-backward:has(.page-previous.page-dashboard) .global-toolbar {
    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;
}

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

@media (min-width: 960px) {
    .view-main .navbar-inner .left {
        display: none;
    }
}

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

.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(99, 91, 255, 0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(147, 51, 234, 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: center;
}

.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: 14px;
    color: var(--auth-primary);
    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;
}

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

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

.page.auth-page .auth-divider span {
    padding: 0 16px;
    font-size: 12px;
    font-weight: 500;
    color: var(--auth-text-muted);
    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) {

    .global-searchbar {
        max-width: calc(70vw - 1.5rem);
        margin-left: 1rem;
    }
    .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(99, 91, 255, 0.1);
}

.dark .page.auth-page .tenant-item:hover {
    box-shadow: 0 2px 8px rgba(124, 117, 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;
    justify-content: space-between;
    align-items: center;
    padding: 24px 24px 16px;
}

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

.catalogue-header-right {
    display: flex;
    gap: 8px;
}

.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 (Card Style) */
.catalogue-filter-tabs {
    display: flex;
    gap: 8px;
    padding: 16px 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.filter-tab {
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 400;
    color: var(--sb-text-secondary);
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
    min-width: 80px;
}

.filter-tab:hover {
    border-color: var(--sb-border-hover);
}

.filter-tab.active {
    border-color: var(--sb-primary);
    background: var(--sb-primary-subtle);
    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 24px;
    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;
}

.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-tint);
    border-color: var(--sb-primary);
    color: var(--sb-primary);
}

.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 24px;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: none;
}

.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-secondary) !important;
    text-align: left;
    text-transform: capitalize;
    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:hover {
    background: var(--sb-row-hover);
    cursor: pointer;
}

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

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

.catalogue-table tbody td:before, .catalogue-table tbody th:before {
    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);
}

.row-actions-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    color: var(--sb-text-muted);
}

.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);
}

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

/* Empty State - InfrastructureLike Style */
.catalogue-empty-state {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding: 80px 24px;
    text-align: left;
    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;
    gap: 12px;
    justify-content: center;
    margin-top: 4px;
}

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

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

    .catalogue-filter-tabs {
        padding: 12px 16px;
    }

    .filter-tab {
        padding: 10px 16px;
        font-size: 13px;
    }

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

    .catalogue-table {
        margin: 0 16px;
        overflow-x: auto;
    }

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

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

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

/* =============================================
   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%, #8b5cf6 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(99, 102, 241, 0.25);
}

.dashboard-assistant-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 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;
}

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

.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: 24px;
    height: 24px;
    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: 20px;
}

.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-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);
}

/* 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: 1fr;
    }

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

/* =============================================
   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: 36px !important;
}

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

.popover-menu .item-inner {
    padding: 0 !important;
    min-height: 36px !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 .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;
}

/* 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: 14px;
    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:hover {
    background-color: var(--sb-bg-hover);
}

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

/* 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(99, 91, 255, 0.1);
}

.sb-card-row-icon-stripe .icon {
    color: #635bff;
}

.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 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);
}

/* 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: #22c55e;
}

/* 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: #22c55e;
}

.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: #22c55e; }
.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;
    }
}

/* ============================================
   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, #635bff);
    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-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(99, 91, 255, 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: 8px;
    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-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);
}

/* 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);
}

/* 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%;
    }
}

/* ============================================
   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);
}

/* ============================================
   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;
}

.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;
    padding-top: 8px;
    padding-bottom: 8px;
    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: vertical;
    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;
}

/* 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(99, 102, 241, 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: #22c55e;
}

.file-write-card-status.failed {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
}

.file-write-card-status.pending {
    background: rgba(99, 102, 241, 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 {
    width: 32px;
    height: 32px;
    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);
}

/* 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: 10px;
    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: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.api-status.active {
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
}

.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
   ======================================== */

.marketplace-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px 48px;
}

/* Hero Section */
.marketplace-hero {
    padding: 48px 0 32px;
    text-align: center;
}

.marketplace-hero h1 {
    font-size: 32px;
    font-weight: 700;
    color: var(--sb-text-primary);
    margin: 0 0 8px;
    letter-spacing: -0.5px;
}

.marketplace-hero p {
    font-size: 16px;
    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;
}

.plugin-card-inner {
    background: var(--sb-bg-card);
    border: 1px solid var(--sb-border-color);
    border-radius: 12px;
    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 6px 12px -2px rgba(50, 50, 93, 0.08), 0 3px 7px -3px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.plugin-card.is-installed .plugin-card-inner {
    border-color: #9ae6b4;
    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-badge {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 600;
    color: #0d6832;
    background: #d4edda;
    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: 4px 10px;
    border-radius: 4px;
}

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

/* Plugin Buttons */
.plugin-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 6px;
    border: none;
    cursor: pointer;
    transition: all 0.15s ease;
}

.plugin-btn i {
    font-size: 14px;
}

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

.plugin-btn-install:hover {
    background: var(--sb-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(99, 91, 255, 0.3);
}

.plugin-btn-install:active {
    transform: translateY(0);
}

.plugin-btn-installed {
    background: #d4edda;
    color: #0d6832;
}

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

.plugin-btn-uninstall:hover {
    background: #fef2f2;
    color: #dc2626;
    border-color: #fecaca;
}

.plugin-btn-disabled {
    background: var(--sb-bg-hover);
    color: var(--sb-text-muted);
    cursor: not-allowed;
}

/* Empty State */
.marketplace-empty {
    text-align: center;
    padding: 80px 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: 32px 0 24px;
    }

    .marketplace-hero h1 {
        font-size: 26px;
    }

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

