/* --- SYSTEM TOKENS --- */
        :root {
            --bg-app: #020617;
        --bg-sidebar: rgba(15, 23, 42, 0.8);
        --bg-panel: rgba(30, 41, 59, 0.3);
        --bg-card: rgba(30, 41, 59, 0.4);
        --bg-input: rgba(2, 6, 23, 0.5);
        --bg-deep: radial-gradient(circle at 20% 20%, rgba(99, 102, 241, 0.08), transparent 32%), radial-gradient(circle at 80% 0%, rgba(168, 85, 247, 0.08), transparent 30%), linear-gradient(145deg, #0b1220, #0f172a);

            --border-subtle: rgba(148, 163, 184, 0.08);
            --border-highlight: rgba(99, 102, 241, 0.3);

            --text-main: #f8fafc;
            --text-secondary: #94a3b8;
            --text-muted: #64748b;

            --brand-primary: #6366f1;
            --brand-hover: #4f46e5;
            --brand-glow: rgba(99, 102, 241, 0.25);

            --success: #10b981;
            --danger: #f43f5e;
            --warning: #f59e0b;
            --accent-amber: #fbbf24;
            --accent-amber-soft: rgba(251, 191, 36, 0.18);
            --accent-ink: #0b1224;

            --sidebar-width: 260px;
            --header-height: 70px;
            --radius-lg: 16px;
            --radius-md: 12px;
            --glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3);
        }

        [data-theme="light"] {
            --bg-app: #f8fafc;
            --bg-sidebar: #ffffff;
            --bg-panel: rgba(255, 255, 255, 0.8);
            --bg-card: #ffffff;
            --bg-input: #f1f5f9;

            --border-subtle: rgba(0, 0, 0, 0.06);
            --text-main: #0f172a;
            --text-secondary: #475569;
            --glass-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.05);
            --bg-deep: linear-gradient(150deg, rgba(247, 249, 253, 0.95) 0%, rgba(233, 236, 243, 0.9) 55%, rgba(204, 214, 255, 0.35) 100%);
            --accent-amber-soft: rgba(251, 191, 36, 0.22);
            --accent-ink: #0f172a;
        }

        /* --- RESET & BASE --- */
        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            outline: none;
        }

        body {
            font-family: 'Inter', sans-serif;
            background-color: var(--bg-app);
            color: var(--text-main);
            height: 100vh;
            overflow: hidden;
            /* App-like feel */
            display: flex;
            transition: background 0.3s;
        }

        h1, h2, h3, h4, h5 {
            font-family: 'Exo 2', 'Inter', sans-serif;
            letter-spacing: -0.01em;
        }

        /* UTILITÁRIOS */
        .hidden {
            display: none !important;
        }

        /* --- LAYOUT GRID --- */
        .app-layout {
            display: grid;
            grid-template-columns: var(--sidebar-width) 1fr;
            grid-template-rows: var(--header-height) 1fr;
            width: 100%;
            height: 100%;
        }

        /* --- BACKGROUND FX --- */
        .bg-decoration {
            position: fixed;
            inset: 0;
            z-index: -1;
            pointer-events: none;
        }

        .blob {
            position: absolute;
            border-radius: 50%;
            filter: blur(90px);
            opacity: 0.25;
        }

        .blob-1 {
            top: -20%;
            left: -10%;
            width: 600px;
            height: 600px;
            background: var(--brand-primary);
        }

        .blob-2 {
            bottom: -20%;
            right: -10%;
            width: 500px;
            height: 500px;
            background: #a855f7;
        }

        /* --- SIDEBAR --- */
        .sidebar {
            grid-row: 1 / -1;
            background: var(--bg-sidebar);
            border-right: 1px solid var(--border-subtle);
            backdrop-filter: blur(20px);
            display: flex;
            flex-direction: column;
            padding: 1.5rem;
            z-index: 20;
        }

        .logo-area {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            margin-bottom: 1.5rem;
            padding-left: 0.5rem;
            flex-shrink: 0;
        }

        .logo-icon {
            width: 32px;
            height: 32px;
            background: linear-gradient(135deg, var(--brand-primary), #a855f7);
            border-radius: 8px;
            display: grid;
            place-items: center;
            color: white;
            font-weight: bold;
        }

        .logo-text {
            font-size: 1.1rem;
            font-weight: 700;
            letter-spacing: -0.02em;
        }

        .nav-menu {
            list-style: none;
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
            flex: 1;
            min-height: 0;
            overflow-y: auto;
            overflow-x: hidden;
            margin-right: -0.5rem;
            padding-right: 0.5rem;
        }

        /* Thin scrollbar for sidebar nav */
        .nav-menu::-webkit-scrollbar {
            width: 4px;
        }
        .nav-menu::-webkit-scrollbar-track {
            background: transparent;
        }
        .nav-menu::-webkit-scrollbar-thumb {
            background: rgba(148, 163, 184, 0.15);
            border-radius: 4px;
        }
        .nav-menu::-webkit-scrollbar-thumb:hover {
            background: rgba(148, 163, 184, 0.3);
        }
        .nav-menu {
            scrollbar-width: thin;
            scrollbar-color: rgba(148, 163, 184, 0.15) transparent;
        }

        .nav-item {
            display: flex;
            align-items: center;
            gap: 0.85rem;
            padding: 0.75rem 1rem;
            border-radius: var(--radius-md);
            color: var(--text-secondary);
            cursor: pointer;
            transition: all 0.2s ease;
            font-weight: 500;
            font-size: 0.9rem;
            border: 1px solid transparent;
        }

        /* Hide permission-gated items until permissions are loaded (no flash) */
        body:not(.perms-loaded) .nav-item[data-view="observability"],
        body:not(.perms-loaded) .nav-item[data-view="insights"],
        body:not(.perms-loaded) .nav-item[data-view="alerts"],
        body:not(.perms-loaded) .nav-item[data-view="backlog"],
        body:not(.perms-loaded) .nav-item[data-view="chat"],
        body:not(.perms-loaded) .nav-item[data-view="metadata"],
        body:not(.perms-loaded) .nav-item[data-view="wizard"],
        body:not(.perms-loaded) .nav-item[data-view="whatsapp"],
        body:not(.perms-loaded) .nav-item[data-view="iam"],
        body:not(.perms-loaded) .nav-item[data-view="settings"] {
            display: none;
        }

        .nav-item:hover {
            background: var(--bg-panel);
            color: var(--text-main);
        }

        .nav-item.active {
            background: rgba(99, 102, 241, 0.1);
            color: var(--brand-primary);
            border-color: rgba(99, 102, 241, 0.2);
        }

        .nav-item i {
            font-size: 1.2rem;
        }

        .user-profile {
            margin-top: auto;
            padding-top: 0.75rem;
            border-top: 1px solid var(--border-subtle);
            display: flex;
            align-items: center;
            gap: 0.75rem;
            flex-shrink: 0;
        }

        .avatar {
            width: 36px;
            height: 36px;
            min-width: 36px;
            min-height: 36px;
            aspect-ratio: 1 / 1;
            flex-shrink: 0;
            border-radius: 50%;
            background: var(--brand-primary);
            color: white;
            display: grid;
            place-items: center;
            font-weight: 600;
            font-size: 0.85rem;
        }

        /* --- HEADER --- */
        .top-bar {
            grid-column: 2;
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0 2rem;
            border-bottom: 1px solid var(--border-subtle);
            backdrop-filter: blur(10px);
            z-index: 10;
        }

        .page-title {
            font-size: 1.1rem;
            font-weight: 600;
        }

        .top-actions {
            display: flex;
            gap: 1rem;
            align-items: center;
        }

        /* --- MAIN CONTENT AREA --- */
        .main-content {
            grid-column: 2;
            padding: 2rem;
            overflow-y: auto;
            position: relative;
        }

        /* --- VIEWS (SPA Logic) --- */
        .view {
            display: none;
            animation: fadeIn 0.3s ease;
        }

        .view.active {
            display: block;
        }

        @keyframes fadeIn {
            from {
                opacity: 0;
                transform: translateY(10px);
            }

            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* --- COMPONENTS --- */
        .glass-card {
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
            padding: 1.5rem;
        }

        .btn {
            cursor: pointer;
            border: none;
            font-family: inherit;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.5rem;
            padding: 0.6rem 1.2rem;
            border-radius: 8px;
            font-weight: 500;
            font-size: 0.9rem;
            transition: all 0.2s;
        }

        .btn-primary {
            background: var(--brand-primary);
            color: white;
            box-shadow: 0 2px 10px var(--brand-glow);
        }

        .btn-primary:hover {
            background: var(--brand-hover);
            transform: translateY(-1px);
        }

        .btn-ghost {
            background: transparent;
            color: var(--text-secondary);
            border: 1px solid var(--border-subtle);
        }

        .btn-ghost:hover {
            background: var(--bg-panel);
            color: var(--text-main);
        }

        .btn-active {
            background: var(--brand-primary);
            color: white;
            border-color: var(--brand-primary);
        }

        .btn-active:hover {
            background: var(--brand-hover);
            color: white;
        }

        .btn-danger {
            background: rgba(244, 63, 94, 0.1);
            color: var(--danger);
        }

        .btn-danger:hover {
            background: rgba(244, 63, 94, 0.2);
        }

        .btn-icon {
            padding: 0.5rem;
            border-radius: 50%;
            width: 32px;
            height: 32px;
        }

        .btn-small {
            padding: 0.4rem 0.75rem;
            font-size: 0.8rem;
        }

        .feedback {
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .feedback.hidden {
            display: none !important;
        }

        .input-pill {
            padding: 0.95rem 1.15rem;
            border-radius: 12px;
            border: 1px solid var(--border-subtle);
            background: var(--bg-input);
            color: var(--text-main);
            width: 100%;
            font-size: 0.95rem;
            transition: border 0.2s;
        }

        .input-pill:focus {
            border-color: var(--brand-primary);
        }

        .chat-textarea {
            min-height: 48px;
            resize: none;
            padding: 0.75rem 3.2rem 0.75rem 2.8rem;
            border: none;
            background: transparent;
            flex: 1;
        }
        .chat-textarea:focus {
            border: none;
            outline: none;
        }

        .chat-input-wrapper {
            display: flex;
            align-items: flex-end;
            border-radius: 16px;
            border: 1px solid var(--border-subtle);
            background: var(--bg-input);
            transition: border 0.2s;
            position: relative;
        }
        .chat-input-wrapper:focus-within {
            border-color: var(--brand-primary);
        }

        .chat-attach-btn {
            position: absolute;
            left: 8px;
            bottom: 8px;
            display: grid;
            place-items: center;
            width: 32px;
            height: 32px;
            border-radius: 8px;
            color: var(--text-muted);
            cursor: pointer;
            transition: color 0.15s, background 0.15s;
            font-size: 1.15rem;
            flex-shrink: 0;
        }
        .chat-attach-btn:hover {
            color: var(--brand-primary);
            background: var(--bg-panel);
        }
        .chat-attach-btn.has-files {
            color: var(--brand-primary);
        }

        .chat-send-btn {
            position: absolute;
            right: 8px;
            bottom: 8px;
        }
        .chat-btn-stop-wrap {
            position: relative;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }
        .chat-btn-stop-wrap .chat-stop-inner {
            position: absolute;
            font-size: 0.45em;
            opacity: 0.5;
        }
        .chat-send-btn.is-loading {
            cursor: pointer;
        }
        .chat-send-btn.is-loading:hover .chat-stop-inner {
            opacity: 1;
            color: var(--danger, #ef4444);
        }
        .chat-send-btn.is-loading:hover {
            background: rgba(239, 68, 68, 0.12);
        }

        .chat-input-meta {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            min-height: 0;
            flex-wrap: wrap;
            padding: 0 0.25rem;
        }
        .chat-input-meta:empty,
        .chat-input-meta:not(:has(*:not(.hidden):not(:empty))) {
            display: none;
        }
        .chat-ai-disclaimer {
            text-align: center;
            font-size: 0.75rem;
            color: var(--text-muted);
            margin: 0.25rem 0 0;
            opacity: 0.7;
        }
        .chat-docs-label {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            font-size: 0.8rem;
            color: var(--text-muted);
            padding: 0.2rem 0.5rem;
            background: var(--bg-panel);
            border-radius: 8px;
            max-width: 100%;
        }
        .chat-docs-label:empty {
            display: none;
        }
        .chat-docs-label i.ph-paperclip {
            color: var(--brand-primary);
            font-size: 0.85rem;
            flex-shrink: 0;
        }
        .chat-docs-remove {
            display: inline-grid;
            place-items: center;
            width: 18px;
            height: 18px;
            border: none;
            background: transparent;
            color: var(--text-muted);
            border-radius: 50%;
            cursor: pointer;
            font-size: 0.75rem;
            flex-shrink: 0;
            transition: background 0.15s, color 0.15s;
            padding: 0;
            margin-left: 0.15rem;
        }
        .chat-docs-remove:hover {
            background: rgba(239, 68, 68, 0.15);
            color: #ef4444;
        }

        .metadata-card {
            display: flex;
            flex-direction: column;
            gap: 1.25rem;
            background: var(--bg-card);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-subtle);
            padding: 1.5rem;
            box-shadow: var(--glass-shadow);
        }

        .catalog-toolbar {
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
            margin-bottom: 1.5rem;
        }

        .catalog-toolbar__row {
            display: flex;
            flex-wrap: wrap;
            gap: 0.75rem;
            align-items: center;
        }

        .catalog-toolbar__status {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
            align-items: center;
        }

        .catalog-layout {
            display: grid;
            grid-template-columns: minmax(0, 1fr) minmax(380px, 1.2fr);
            gap: 1.5rem;
            align-items: start;
        }

        .catalog-layout--hybrid {
            align-items: stretch;
        }

        .catalog-main {
            min-width: 0;
        }

        .catalog-table {
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-subtle);
            background: var(--bg-card);
            box-shadow: var(--glass-shadow);
            overflow: hidden;
        }

        .catalog-table__header {
            display: grid;
            grid-template-columns: 48px minmax(220px, 2fr) minmax(220px, 1.1fr) 90px;
            gap: 0.75rem;
            padding: 0.7rem 1rem;
            border-bottom: 1px solid var(--border-subtle);
            background: rgba(2, 6, 23, 0.35);
            font-size: 0.72rem;
            font-weight: 600;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            color: var(--text-muted);
        }

        [data-theme="light"] .catalog-table__header {
            background: rgba(15, 23, 42, 0.04);
        }

        .catalog-head {
            display: flex;
            align-items: center;
        }

        .catalog-head--select {
            justify-content: center;
        }

        .catalog-head--actions {
            justify-content: flex-end;
        }

        .catalog-table__body {
            display: flex;
            flex-direction: column;
        }

        .catalog-row {
            display: grid;
            grid-template-columns: 48px minmax(220px, 2fr) minmax(220px, 1.1fr) 90px;
            gap: 0.75rem;
            padding: 0.85rem 1rem;
            border-bottom: 1px solid var(--border-subtle);
            border-left: 3px solid transparent;
            background: rgba(15, 23, 42, 0.45);
            transition: background 0.2s ease, border-color 0.2s ease;
            cursor: pointer;
        }

        [data-theme="light"] .catalog-row {
            background: rgba(15, 23, 42, 0.03);
        }

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

        .catalog-row:hover {
            background: rgba(99, 102, 241, 0.08);
        }

        .catalog-row--selected {
            background: rgba(99, 102, 241, 0.14);
            border-left-color: var(--brand-primary);
        }

        .catalog-row--disabled {
            opacity: 0.75;
        }

        .catalog-cell {
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
            justify-content: center;
        }

        .catalog-cell--select {
            align-items: center;
            justify-content: center;
        }

        .catalog-cell--actions {
            align-items: flex-end;
        }

        .catalog-primary {
            display: flex;
            flex-wrap: wrap;
            gap: 0.4rem;
            align-items: center;
        }

        .catalog-table-name {
            font-size: 1rem;
            font-weight: 600;
            color: var(--text-main);
        }

        .catalog-secondary {
            font-size: 0.85rem;
            color: var(--text-secondary);
            display: -webkit-box;
            -webkit-line-clamp: 2;
            -webkit-box-orient: vertical;
            overflow: hidden;
        }

        .catalog-meta {
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
        }

        .catalog-meta-line {
            display: flex;
            flex-wrap: wrap;
            gap: 0.4rem;
        }

        .catalog-checkbox {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
        }

        .catalog-checkbox input {
            width: 16px;
            height: 16px;
            accent-color: var(--brand-primary);
        }

        .catalog-empty {
            padding: 1.2rem;
            text-align: center;
            color: var(--text-secondary);
        }

        .catalog-card__title {
            font-size: 1rem;
            font-weight: 600;
            color: var(--text-main);
        }

        .catalog-pagination {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 0.75rem;
            margin-top: 1rem;
        }

        .catalog-page-info {
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-drawer {
            background: var(--bg-card);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-subtle);
            padding: 1rem;
            box-shadow: var(--glass-shadow);
            display: flex;
            flex-direction: column;
            gap: 1rem;
            position: sticky;
            top: 1rem;
            max-height: calc(100vh - 2rem);
            overflow: auto;
        }

        .metadata-drawer__header {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            flex-wrap: wrap;
            align-items: flex-start;
        }

        .metadata-drawer__actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
            justify-content: flex-end;
        }

        .metadata-drawer__actions #metadata-drawer-close {
            display: none;
        }

        .metadata-detail-title {
            font-size: 1.1rem;
            font-weight: 600;
        }

        .metadata-detail-subtitle {
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-detail-badges {
            display: flex;
            gap: 0.4rem;
            flex-wrap: wrap;
            margin-top: 0.35rem;
        }

        .metadata-tabs {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
            border-bottom: 1px solid var(--border-subtle);
            padding-bottom: 0.5rem;
        }

        .metadata-columns-toolbar {
            margin-bottom: 0.75rem;
        }

        .metadata-tab {
            border-radius: 999px;
            border: 1px solid transparent;
            background: transparent;
            color: var(--text-secondary);
            padding: 0.35rem 0.85rem;
            font-size: 0.8rem;
            cursor: pointer;
            transition: all 0.2s ease;
        }

        .metadata-tab.is-active {
            border-color: var(--border-subtle);
            background: var(--bg-input);
            color: var(--text-main);
        }

        .metadata-detail-pane {
            display: none;
        }

        .metadata-detail-pane.is-active {
            display: block;
        }

        .metadata-history-list {
            display: flex;
            flex-direction: column;
            gap: 0.6rem;
        }

        .metadata-history-item {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 0.6rem 0.75rem;
            background: rgba(15, 23, 42, 0.4);
            display: flex;
            justify-content: space-between;
            gap: 0.75rem;
            align-items: center;
        }

        [data-theme="light"] .metadata-history-item {
            background: rgba(15, 23, 42, 0.03);
        }

        .metadata-history-preview {
            margin-top: 0.75rem;
            background: var(--bg-input);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-subtle);
            padding: 0.75rem;
            font-size: 0.78rem;
            color: var(--text-secondary);
            max-height: 240px;
            overflow: auto;
            white-space: pre-wrap;
        }

        .metadata-analysis-header {
            display: flex;
            justify-content: space-between;
            gap: 0.75rem;
            align-items: center;
        }

        .metadata-analysis-summary {
            margin-top: 0.75rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-analysis-table {
            margin-top: 0.75rem;
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }

        .metadata-analysis-row {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 0.6rem 0.75rem;
            background: rgba(15, 23, 42, 0.4);
            display: grid;
            grid-template-columns: minmax(120px, 1fr) minmax(80px, 0.5fr) minmax(80px, 0.5fr);
            gap: 0.5rem;
            align-items: center;
            font-size: 0.8rem;
        }

        [data-theme="light"] .metadata-analysis-row {
            background: rgba(15, 23, 42, 0.03);
        }

        .metadata-analysis-row span {
            color: var(--text-secondary);
        }

        .metadata-savebar {
            position: fixed;
            bottom: 0;
            right: 0;
            left: var(--sidebar-width);
            border-top: 1px solid var(--border-subtle);
            padding: 0.65rem 1.5rem;
            display: none;
            gap: 0.75rem;
            z-index: 50;
            transition: left 0.2s ease;
            align-items: center;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            background: var(--bg-card);
            backdrop-filter: blur(12px);
            box-shadow: 0 -4px 16px rgba(0,0,0,0.15);
        }

        .metadata-savebar.is-visible {
            display: flex;
        }

        .sidebar-collapsed .metadata-savebar {
            left: 64px;
        }

        .metadata-savebar__info {
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-savebar__info strong {
            color: var(--text-main);
            font-size: 0.9rem;
        }

        .metadata-savebar__actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

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

        @media (max-width: 980px) {
            .catalog-table__header {
                display: none;
            }

            .catalog-row {
                grid-template-columns: 44px 1fr;
            }

            .catalog-cell--meta,
            .catalog-cell--actions {
                grid-column: 2 / -1;
                align-items: flex-start;
            }

            .metadata-drawer {
                position: fixed;
                right: 1rem;
                left: 1rem;
                top: 1rem;
                bottom: 1rem;
                width: auto;
                max-height: calc(100vh - 2rem);
                overflow: auto;
                z-index: 30;
                display: none;
            }

            .metadata-drawer.is-open {
                display: flex;
            }

            .metadata-drawer__actions #metadata-drawer-close {
                display: inline-flex;
            }
        }

        @media (max-width: 720px) {
            .metadata-analysis-row {
                grid-template-columns: 1fr;
            }
        }

        /* --- Metadata section tabs (top-level: Catalogo | Templates | Perguntas) --- */
        .metadata-section-tabs {
            display: flex;
            gap: 0;
            border-bottom: 1px solid var(--border-subtle);
            margin-bottom: 1.25rem;
        }

        .metadata-section-tab {
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
            padding: 0.6rem 1.1rem;
            border: none;
            border-bottom: 2px solid transparent;
            background: transparent;
            color: var(--text-secondary);
            cursor: pointer;
            font-size: 0.9rem;
            font-weight: 500;
            transition: color 0.2s, border-color 0.2s;
        }

        .metadata-section-tab:hover {
            color: var(--text-main);
        }

        .metadata-section-tab.is-active {
            color: var(--brand-primary);
            border-bottom-color: var(--brand-primary);
        }

        .metadata-section-tab__count {
            font-size: 0.7rem;
            font-weight: 600;
            background: var(--brand-primary);
            color: #fff;
            border-radius: 999px;
            padding: 0.1rem 0.5rem;
            min-width: 1.4rem;
            text-align: center;
            line-height: 1.3;
        }

        .metadata-section-tab__count:empty {
            display: none;
        }

        .metadata-section-pane {
            display: none;
        }

        .metadata-section-pane.is-active {
            display: block;
        }

        /* --- Templates/Icebreakers panel styling (replaces aux-grid) --- */
        .metadata-section-pane[data-section-pane="templates"] .glass-card,
        .metadata-section-pane[data-section-pane="icebreakers"] .glass-card {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .metadata-section-pane[data-section-pane="templates"] .metadata-aux-header,
        .metadata-section-pane[data-section-pane="icebreakers"] .metadata-aux-header {
            flex-wrap: wrap;
        }

        .metadata-section-pane[data-section-pane="templates"] .metadata-aux-actions,
        .metadata-section-pane[data-section-pane="icebreakers"] .metadata-aux-actions {
            flex-wrap: wrap;
            align-items: center;
        }

        .metadata-section-pane .metadata-aux-list {
            max-height: none;
            overflow-y: visible;
        }

        /* --- DEPRECATED: metadata-aux-grid (replaced by section tabs) --- */
        .metadata-aux-grid {
            display: none;
        }

        .metadata-aux-card {
            flex: 1 1 340px;
            background: var(--bg-card);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-subtle);
            padding: 1.25rem;
            box-shadow: var(--glass-shadow);
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .metadata-aux-header {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            align-items: flex-start;
        }

        .metadata-aux-header h3 {
            font-size: 1rem;
            font-weight: 600;
            margin: 0;
        }

        .metadata-aux-header p {
            color: var(--text-secondary);
            font-size: 0.85rem;
            margin: 0.35rem 0 0;
        }

        .metadata-aux-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 0.45rem;
            justify-content: flex-end;
        }

        .metadata-aux-list {
            display: flex;
            flex-direction: column;
            gap: 0.85rem;
            max-height: 420px;
            overflow-y: auto;
            padding-right: 0.35rem;
        }

        .metadata-aux-item {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 1rem;
            background: rgba(15, 23, 42, 0.45);
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }

        [data-theme="light"] .metadata-aux-item {
            background: rgba(15, 23, 42, 0.03);
        }

        .metadata-aux-pre {
            margin: 0;
            background: rgba(255, 255, 255, 0.03);
            padding: 0.75rem;
            border-radius: 10px;
            font-size: 0.85rem;
            border: 1px solid var(--border-subtle);
            white-space: pre-wrap;
        }

        [data-theme="light"] .metadata-aux-pre {
            background: rgba(15, 23, 42, 0.04);
        }

        .metadata-aux-item input,
        .metadata-aux-item textarea,
        .metadata-aux-item select {
            width: 100%;
            border-radius: 10px;
            border: 1px solid var(--border-subtle);
            background: var(--bg-input);
            color: var(--text-main);
            padding: 0.45rem 0.6rem;
            font-size: 0.9rem;
        }

        .metadata-aux-item textarea {
            min-height: 60px;
            resize: vertical;
        }

        .metadata-aux-item__row {
            display: flex;
            gap: 0.75rem;
            flex-wrap: wrap;
        }

        .metadata-aux-item__row > * {
            flex: 1 1 150px;
        }

        .metadata-aux-item__row .checkbox-field {
            flex: 0 0 auto;
            display: flex;
            align-items: center;
            gap: 0.4rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-empty {
            padding: 1rem;
            border: 1px dashed var(--border-subtle);
            border-radius: var(--radius-md);
            text-align: center;
            color: var(--text-secondary);
            font-size: 0.85rem;
        }

        .metadata-empty-state {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 0.5rem;
            padding: 3rem 1rem;
            color: var(--text-secondary);
        }

        .metadata-empty-state i {
            font-size: 2.5rem;
            opacity: 0.4;
        }

        .metadata-empty-state h4 {
            margin: 0;
            font-size: 1rem;
            font-weight: 600;
            color: var(--text-main);
        }

        .metadata-empty-state p {
            margin: 0;
            font-size: 0.85rem;
        }

        .skeleton-row {
            height: 3.5rem;
            border-radius: var(--radius-md);
            background: linear-gradient(90deg, var(--border-subtle) 25%, transparent 50%, var(--border-subtle) 75%);
            background-size: 200% 100%;
            animation: skeleton-shimmer 1.5s infinite;
        }

        .skeleton-row + .skeleton-row {
            margin-top: 0.5rem;
        }

        @keyframes skeleton-shimmer {
            0% { background-position: 200% 0; }
            100% { background-position: -200% 0; }
        }

        /* ── Wizard: Card 1 — Header compacto ── */
        .wizard-header__top {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .wizard-header__title {
            display: flex;
            gap: 0.75rem;
            align-items: center;
        }

        .wizard-header__icon {
            width: 42px;
            height: 42px;
            border-radius: 12px;
            background: linear-gradient(135deg, var(--brand-primary), #a855f7);
            display: grid;
            place-items: center;
            color: white;
            font-size: 1.4rem;
            flex-shrink: 0;
            box-shadow: var(--glass-shadow);
        }

        .wizard-header__title h2 {
            margin: 0;
            font-size: 1.15rem;
            font-weight: 700;
        }

        .wizard-header__title p {
            margin: 0.2rem 0 0;
            color: var(--text-secondary);
            font-size: 0.85rem;
            max-width: 520px;
        }

        .wizard-header__actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
            align-items: center;
        }

        .wizard-header__actions .btn {
            padding: 0.55rem 1.1rem;
            font-size: 0.9rem;
        }

        /* ── Wizard: Card 2 — Configuracao colapsavel ── */
        .wizard-config {
            margin-bottom: 1.25rem;
        }

        .wizard-config__summary {
            display: flex;
            justify-content: space-between;
            align-items: center;
            cursor: pointer;
            font-weight: 600;
            font-size: 0.95rem;
            list-style: none;
            user-select: none;
        }

        .wizard-config__summary::-webkit-details-marker {
            display: none;
        }

        .wizard-config__summary-left {
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

        .wizard-config__caret {
            transition: transform 0.3s ease;
            color: var(--text-secondary);
        }

        details[open] > .wizard-config__summary .wizard-config__caret {
            transform: rotate(180deg);
        }

        .wizard-config__body {
            margin-top: 1rem;
        }

        .wizard-config__footer {
            display: flex;
            justify-content: flex-start;
            align-items: center;
            margin-top: 1rem;
            padding-top: 1rem;
            border-top: 1px solid var(--border-subtle);
        }

        .wizard-concurrency-control {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .wizard-concurrency-control input[type="range"] {
            width: 160px;
            accent-color: var(--brand-primary);
        }

        .wizard-concurrency-control span {
            font-weight: 600;
            min-width: 1.5rem;
            text-align: center;
        }

        /* ── Wizard: Card 2 — Table selector styles ── */
        .wizard-table-selector__header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1rem;
        }

        .wizard-table-selector__header h4 {
            margin: 0;
            font-weight: 600;
        }

        .wizard-table-filters {
            display: flex;
            gap: 1rem;
            margin-bottom: 1rem;
            flex-wrap: wrap;
            align-items: center;
        }

        .wizard-table-filters input[type="text"] {
            flex: 1;
            min-width: 200px;
            padding: 0.5rem 0.75rem;
            border-radius: 8px;
            border: 1px solid var(--border-subtle);
            background: var(--surface-secondary);
        }

        .wizard-table-filters select {
            min-width: 150px;
            padding: 0.5rem 0.75rem;
            border-radius: 8px;
            border: 1px solid var(--border-subtle);
            background: var(--surface-secondary);
        }

        .wizard-schema-checkboxes {
            display: flex;
            gap: 0.75rem;
            flex-wrap: wrap;
            margin-bottom: 0.75rem;
            padding: 0.5rem 0.75rem;
            border-radius: 8px;
            background: var(--surface-secondary);
            border: 1px solid var(--border-subtle);
        }

        .wizard-table-list {
            max-height: 400px;
            overflow-y: auto;
        }

        .wizard-table-pagination {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-top: 1rem;
            padding: 0.5rem 0;
        }

        .wizard-table-pagination__summary {
            color: var(--text-secondary);
            font-size: 0.9rem;
        }

        .wizard-table-pagination__nav {
            display: flex;
            gap: 0.5rem;
            align-items: center;
        }

        .wizard-table-pagination__info {
            font-size: 0.9rem;
        }

        /* ── Wizard: Card 3 — Resultados ── */
        .wizard-results__header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1.5rem;
            padding-bottom: 1rem;
            border-bottom: 1px solid var(--border-subtle);
        }

        .wizard-results__header h3 {
            font-weight: 600;
            font-size: 1.1rem;
            margin: 0;
        }

        .wizard-results__actions {
            display: flex;
            gap: 0.5rem;
        }

        .wizard-results__list {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        /* ── Wizard: Loading state ── */
        .wizard-loading {
            text-align: center;
            padding: 1.5rem;
            color: var(--text-secondary);
        }

        .wizard-loading i {
            font-size: 2rem;
            display: block;
            margin: 0 auto 0.75rem;
        }

        @media (max-width: 768px) {
            .wizard-header__top {
                flex-direction: column;
            }
            .wizard-header__actions {
                width: 100%;
                justify-content: flex-end;
            }
        }

        .wizard-banner {
            border-radius: var(--radius-md);
            border: 1px solid var(--border-highlight);
            background: rgba(99, 102, 241, 0.08);
            padding: 1rem;
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            align-items: center;
            transition: border-color 0.4s ease, box-shadow 0.4s ease;
        }

        .wizard-banner.is-running {
            border-color: var(--brand-primary);
            box-shadow: 0 0 12px rgba(99, 102, 241, 0.15);
            animation: wizard-glow 2.5s ease-in-out infinite;
        }

        .wizard-banner.is-completed {
            border-color: var(--success);
            background: rgba(34, 197, 94, 0.08);
        }

        .wizard-banner.is-failed {
            border-color: var(--danger);
            background: rgba(239, 68, 68, 0.08);
        }

        @keyframes wizard-glow {
            0%, 100% { box-shadow: 0 0 8px rgba(99, 102, 241, 0.1); }
            50% { box-shadow: 0 0 18px rgba(99, 102, 241, 0.25); }
        }

        .wizard-banner__content {
            flex: 1;
            min-width: 0;
            display: flex;
            flex-direction: column;
            gap: 0.6rem;
        }

        .wizard-banner__top {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .wizard-banner__status {
            font-size: 0.9rem;
            font-weight: 500;
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }

        .wizard-eta {
            font-size: 0.8rem;
            color: var(--text-secondary);
            white-space: nowrap;
            display: flex;
            align-items: center;
            gap: 0.35rem;
        }

        .wizard-progress-bar {
            width: 100%;
            height: 6px;
            background: rgba(148, 163, 184, 0.15);
            border-radius: 3px;
            overflow: hidden;
            position: relative;
        }

        .wizard-progress-fill {
            height: 100%;
            border-radius: 3px;
            background: linear-gradient(90deg, #6366f1, #818cf8);
            transition: width 0.6s ease;
            position: relative;
            min-width: 0;
        }

        .wizard-progress-fill.is-running::after {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: linear-gradient(
                90deg,
                transparent 0%,
                rgba(255, 255, 255, 0.3) 50%,
                transparent 100%
            );
            background-size: 200% 100%;
            animation: wizard-shimmer 1.8s ease-in-out infinite;
        }

        .wizard-progress-fill.is-completed {
            background: linear-gradient(90deg, #22c55e, #4ade80);
        }

        .wizard-progress-fill.is-failed {
            background: linear-gradient(90deg, #ef4444, #f87171);
        }

        .wizard-progress-fill.is-paused {
            background: linear-gradient(90deg, #f59e0b, #fbbf24);
        }

        @keyframes wizard-shimmer {
            0% { background-position: 200% 0; }
            100% { background-position: -200% 0; }
        }

        .wizard-fallback {
            font-size: 0.8rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: #fbbf24;
            display: inline-flex;
            align-items: center;
            gap: 0.3rem;
        }

        .wizard-extra-section {
            margin-top: 1.5rem;
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            background: var(--bg-card);
            overflow: hidden;
        }
        .wizard-extra-section > :not(summary) {
            padding-left: 1.25rem;
            padding-right: 1.25rem;
        }
        .wizard-extra-section > .wizard-extra-list {
            padding-bottom: 0.5rem;
        }
        .wizard-extra-section > .wizard-section-pagination {
            padding-bottom: 1rem;
        }

        .wizard-extra-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            font-weight: 600;
            padding: 1rem 1.25rem;
            cursor: pointer;
            user-select: none;
            list-style: none;
            border-bottom: 1px solid transparent;
            transition: border-color 0.2s;
        }
        .wizard-extra-header::-webkit-details-marker { display: none; }
        .wizard-extra-header::marker { display: none; content: ''; }
        details[open] > .wizard-extra-header {
            border-bottom-color: var(--border-subtle);
        }
        .wizard-extra-header:hover {
            background: rgba(255,255,255,0.03);
        }
        [data-theme="light"] .wizard-extra-header:hover {
            background: rgba(0,0,0,0.02);
        }
        .wizard-extra-header__title {
            display: flex;
            align-items: center;
            gap: 0.5rem;
        }
        .wizard-extra-header__right {
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }
        .wizard-extra-header__count {
            font-size: 0.85rem;
            font-weight: 400;
            color: var(--text-secondary);
        }
        .wizard-extra-header__caret {
            color: var(--text-secondary);
            transition: transform 0.2s;
        }
        details[open] > .wizard-extra-header .wizard-extra-header__caret {
            transform: rotate(180deg);
        }

        .wizard-extra-list {
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
            margin-top: 0.75rem;
        }

        .wizard-extra-item {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 0.75rem 1rem;
            background: rgba(15, 23, 42, 0.4);
            display: grid;
            grid-template-columns: 1.25rem 1fr;
            gap: 0 0.75rem;
            align-items: start;
            cursor: pointer;
        }
        .wizard-extra-item:hover {
            border-color: var(--accent-border);
        }
        .wizard-extra-item > input[type="checkbox"] {
            margin-top: 0.25rem;
            flex-shrink: 0;
        }

        [data-theme="light"] .wizard-extra-item {
            background: rgba(15, 23, 42, 0.03);
        }

        .wizard-extra-item__body {
            min-width: 0;
        }
        .wizard-extra-item__body h4 {
            margin: 0;
            font-size: 0.95rem;
            font-weight: 600;
        }
        .wizard-extra-item__desc {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin: 0.15rem 0 0.4rem;
        }
        .wizard-extra-item__badges {
            display: flex;
            flex-wrap: wrap;
            gap: 0.35rem;
            margin-bottom: 0.5rem;
        }
        .wizard-extra-item__sql {
            margin: 0;
            white-space: pre-wrap;
            word-break: break-all;
            font-size: 0.75rem;
            background: rgba(15, 23, 42, 0.6);
            border-radius: 8px;
            padding: 0.5rem 0.65rem;
            border: 1px solid var(--border-subtle);
            max-height: 5rem;
            overflow-y: auto;
        }
        [data-theme="light"] .wizard-extra-item__sql {
            background: rgba(15, 23, 42, 0.06);
        }

        /* ── Wizard: Section-level pagination ── */
        .wizard-section-pagination {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 0.75rem 0;
            border-top: 1px solid var(--border-subtle);
            margin-top: 0.75rem;
        }

        .wizard-section-pagination__summary {
            color: var(--text-secondary);
            font-size: 0.85rem;
        }

        .wizard-section-pagination__nav {
            display: flex;
            gap: 0.5rem;
            align-items: center;
        }

        .wizard-section-pagination__info {
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        /* ── Wizard: Unified table card ── */
        .wizard-unified-card {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            overflow: hidden;
            background: var(--bg-card);
        }

        .wizard-unified-card summary {
            padding: 0.85rem 1rem;
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            border-bottom: 1px solid var(--border-subtle);
        }

        .wizard-unified-card summary .wizard-card-title {
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .wizard-unified-card .wizard-card-desc {
            padding: 0.5rem 1rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
            border-bottom: 1px solid var(--border-subtle);
            background: rgba(99, 102, 241, 0.03);
        }

        .metadata-card__header {
            display: flex;
            justify-content: space-between;
            flex-wrap: wrap;
            gap: 1rem;
        }

        .metadata-card__title {
            display: flex;
            gap: 0.9rem;
            align-items: center;
        }

        .metadata-icon {
            width: 42px;
            height: 42px;
            border-radius: 12px;
            background: rgba(99, 102, 241, 0.18);
            color: var(--brand-primary);
            display: grid;
            place-items: center;
            font-size: 1.2rem;
        }

        [data-theme="light"] .metadata-icon {
            background: rgba(99, 102, 241, 0.12);
        }

        .metadata-name {
            font-size: 1.1rem;
            font-weight: 600;
            color: var(--text-main);
        }

        .metadata-subtitle {
            display: flex;
            flex-wrap: wrap;
            gap: 0.4rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .metadata-badge {
            font-size: 0.75rem;
            padding: 0.15rem 0.75rem;
            border-radius: 999px;
            background: var(--bg-input);
            border: 1px solid var(--border-subtle);
        }

        .metadata-toggle {
            display: inline-flex;
            align-items: center;
            gap: 0.4rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        /* Toggle switch inline (header do drawer) */
        .metadata-toggle-inline {
            position: relative;
            display: inline-flex;
            align-items: center;
            cursor: pointer;
            margin-left: 0.25rem;
        }
        .metadata-toggle-inline input {
            position: absolute;
            opacity: 0;
            width: 0;
            height: 0;
        }
        .metadata-toggle-slider {
            width: 32px;
            height: 18px;
            border-radius: 999px;
            background: var(--border-subtle);
            position: relative;
            transition: background 0.2s;
        }
        .metadata-toggle-slider::after {
            content: "";
            position: absolute;
            top: 2px;
            left: 2px;
            width: 14px;
            height: 14px;
            border-radius: 50%;
            background: var(--bg-card);
            transition: transform 0.2s;
            box-shadow: 0 1px 2px rgba(0,0,0,0.2);
        }
        .metadata-toggle-inline input:checked + .metadata-toggle-slider {
            background: var(--brand-primary);
        }
        .metadata-toggle-inline input:checked + .metadata-toggle-slider::after {
            transform: translateX(14px);
        }

        .metadata-fields {
            display: grid;
            gap: 1rem;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
        }

        .metadata-field {
            display: flex;
            flex-direction: column;
            gap: 0.4rem;
        }

        .metadata-field label {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-secondary);
        }

        .metadata-card input[type="text"],
        .metadata-card textarea {
            background: var(--bg-input);
            border: 1px solid var(--border-subtle);
            border-radius: 10px;
            color: var(--text-main);
            padding: 0.65rem 0.9rem;
            font-size: 0.9rem;
        }

        .metadata-card textarea {
            min-height: 72px;
            resize: vertical;
        }

        .metadata-table-wrapper {
            border: 1px solid var(--border-subtle);
            border-radius: 12px;
            overflow-x: auto;
            background: var(--bg-input);
        }

        .metadata-table {
            width: 100%;
            min-width: 580px;
            border-collapse: collapse;
            font-size: 0.85rem;
        }

        .metadata-table th {
            text-align: left;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-size: 0.7rem;
            padding: 0.6rem 0.6rem;
            color: var(--text-secondary);
            background: rgba(255, 255, 255, 0.02);
            border-bottom: 1px solid var(--border-subtle);
            white-space: nowrap;
        }

        [data-theme="light"] .metadata-table th {
            background: rgba(15, 23, 42, 0.04);
        }

        .metadata-table td {
            padding: 0.5rem 0.6rem;
            border-bottom: 1px solid var(--border-subtle);
        }

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

        .metadata-table input[type="text"] {
            padding: 0.4rem 0.55rem;
            font-size: 0.8rem;
            min-width: 0;
            width: 100%;
            box-sizing: border-box;
        }

        .metadata-table td:has(.metadata-description),
        .metadata-table td:has(.metadata-column-aliases),
        .metadata-table td:has(.metadata-column-tags) {
            min-width: 110px;
        }

        .metadata-semantic-cell {
            min-width: 160px;
        }

        .metadata-column-name {
            font-weight: 600;
            color: var(--text-main);
            white-space: nowrap;
            font-size: 0.8rem;
        }

        .metadata-column-flags {
            text-align: center;
        }

        .metadata-pii {
            width: 16px;
            height: 16px;
            accent-color: var(--brand-primary);
        }

        .metadata-semantic {
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
            font-size: 0.78rem;
            color: var(--text-secondary);
        }

        .semantic-role-row {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            flex-wrap: wrap;
            justify-content: space-between;
        }

        .semantic-role {
            font-size: 0.7rem;
            font-weight: 600;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            padding: 0.2rem 0.65rem;
            border-radius: 999px;
            border: 1px solid transparent;
            background: rgba(148, 163, 184, 0.15);
            color: var(--text-secondary);
        }

        .semantic-role-metric {
            background: rgba(16, 185, 129, 0.15);
            color: var(--success);
            border-color: rgba(16, 185, 129, 0.35);
        }

        .semantic-role-dimension {
            background: rgba(59, 130, 246, 0.15);
            color: #60a5fa;
            border-color: rgba(59, 130, 246, 0.35);
        }

        .semantic-role-date {
            background: rgba(249, 115, 22, 0.15);
            color: #fb923c;
            border-color: rgba(249, 115, 22, 0.35);
        }

        .semantic-line {
            font-size: 0.78rem;
            color: var(--text-main);
        }

        .semantic-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 0.35rem;
            align-items: center;
        }

        .semantic-label {
            font-weight: 600;
            font-size: 0.72rem;
            text-transform: uppercase;
            letter-spacing: 0.05em;
            color: var(--text-secondary);
        }

        .semantic-chip {
            background: rgba(148, 163, 184, 0.15);
            border-radius: 999px;
            padding: 0.1rem 0.45rem;
            font-size: 0.68rem;
            color: var(--text-secondary);
        }

        .semantic-confidence {
            font-size: 0.72rem;
            color: var(--text-secondary);
        }

        .semantic-placeholder {
            font-size: 0.72rem;
            color: var(--text-secondary);
            opacity: 0.8;
        }

        .session-card {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            align-items: center;
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 1rem 1.25rem;
            background: var(--bg-card);
        }

        .session-info {
            display: flex;
            gap: 0.75rem;
            align-items: center;
        }

        .session-icon {
            width: 36px;
            height: 36px;
            border-radius: 10px;
            background: rgba(16, 185, 129, 0.15);
            color: var(--success);
            display: grid;
            place-items: center;
            font-size: 1.1rem;
        }

        [data-theme="light"] .session-icon {
            background: rgba(16, 185, 129, 0.12);
        }

        .session-name {
            font-weight: 600;
            color: var(--text-main);
        }

        .session-status {
            font-size: 0.85rem;
            color: var(--text-secondary);
            text-transform: capitalize;
        }

        .session-status.success {
            color: var(--success);
        }

        .session-actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .qr-card {
            text-align: center;
        }

        .qr-placeholder {
            padding: 2rem;
            border: 2px dashed var(--border-subtle);
            border-radius: var(--radius-lg);
            color: var(--text-secondary);
        }

        .qr-output {
            padding: 1rem;
            background: var(--bg-input);
            border-radius: var(--radius-lg);
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 0.75rem;
        }

        .qr-caption {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin-bottom: 0.75rem;
        }

        .qr-code-img {
            width: 100%;
            max-width: 220px;
            border-radius: var(--radius-md);
            border: 1px solid var(--border-subtle);
            background: var(--bg-panel);
            padding: 0.5rem;
        }

        .empty-state {
            text-align: center;
            padding: 2rem;
            color: var(--text-secondary);
            border-radius: var(--radius-lg);
            border: 1px dashed var(--border-subtle);
            background: var(--bg-panel);
        }

        /* --- WHATSAPP BINDINGS --- */
        .binding-form-card {
            border: 1px solid var(--border-subtle);
            border-left: 3px solid var(--brand-primary);
            border-radius: var(--radius-md);
            padding: 1.25rem;
            margin-bottom: 1.25rem;
            background: var(--bg-panel);
        }

        .binding-form-row {
            display: flex;
            gap: 1rem;
            align-items: flex-end;
            flex-wrap: wrap;
        }

        .binding-otp-input {
            font-size: 1.4rem;
            font-weight: 600;
            letter-spacing: 0.35em;
            text-align: center;
        }

        .binding-card {
            display: flex;
            justify-content: space-between;
            gap: 1rem;
            align-items: center;
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 1rem 1.25rem;
            background: var(--bg-card);
        }

        .binding-info {
            display: flex;
            gap: 0.75rem;
            align-items: center;
        }

        .binding-icon {
            width: 36px;
            height: 36px;
            border-radius: 10px;
            background: rgba(99, 102, 241, 0.12);
            color: var(--brand-primary);
            display: grid;
            place-items: center;
            font-size: 1.1rem;
            flex-shrink: 0;
        }

        .binding-phone {
            font-weight: 600;
            color: var(--text-main);
        }

        .binding-meta {
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .binding-actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
            flex-shrink: 0;
        }

        @media (max-width: 768px) {
            .binding-form-row {
                flex-direction: column;
                align-items: stretch;
            }

            .binding-card {
                flex-direction: column;
                align-items: flex-start;
            }

            .binding-actions {
                width: 100%;
            }

            .binding-actions .btn {
                flex: 1;
            }
        }

        /* --- EMAIL BINDINGS --- */
        .email-binding-icon {
            background: rgba(16, 185, 129, 0.12);
            color: var(--success);
        }

        .email-verified-badge {
            color: var(--success);
            font-size: 0.85rem;
            font-weight: 600;
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
        }

        .email-pending-badge {
            color: var(--text-secondary);
            font-size: 0.85rem;
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
        }

        .email-disabled-badge {
            color: var(--danger);
            font-size: 0.85rem;
            font-weight: 600;
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
        }

        .email-disabled-reason {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin-left: 0.5rem;
            font-style: italic;
        }

        .email-binding-icon--disabled {
            background: rgba(244, 63, 94, 0.12);
            color: var(--danger);
        }

        .binding-card--disabled {
            opacity: 0.7;
            border-left: 3px solid var(--danger);
        }

        .binding-timestamps {
            display: flex;
            gap: 1rem;
            margin-top: 0.35rem;
            flex-wrap: wrap;
        }

        .binding-ts-item {
            font-size: 0.8rem;
            color: var(--text-muted);
            display: inline-flex;
            align-items: center;
            gap: 0.3rem;
        }

        .binding-ts-item i {
            font-size: 0.85rem;
        }

        .email-channel-active {
            font-size: 0.8rem;
            font-weight: 600;
            color: var(--success);
            display: inline-flex;
            align-items: center;
            gap: 0.3rem;
            padding: 0.2rem 0.6rem;
            border-radius: 20px;
            background: rgba(16, 185, 129, 0.1);
        }

        .email-channel-inactive {
            font-size: 0.8rem;
            font-weight: 600;
            color: var(--text-muted);
            display: inline-flex;
            align-items: center;
            gap: 0.3rem;
            padding: 0.2rem 0.6rem;
            border-radius: 20px;
            background: rgba(100, 116, 139, 0.1);
        }

        /* Email config settings */
        .email-config-block {
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: 12px;
            padding: 1.2rem;
        }

        .email-config-block h4 {
            font-size: 0.95rem;
            font-weight: 600;
            margin: 0 0 1rem;
            display: flex;
            align-items: center;
            gap: 0.4rem;
            color: var(--text-primary);
        }

        .email-config-field {
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
        }

        .email-config-field label {
            font-size: 0.8rem;
            color: var(--text-muted);
            font-weight: 500;
        }

        .email-config-value {
            font-size: 0.9rem;
            color: var(--text-primary);
            font-family: 'SF Mono', 'Fira Code', monospace;
            background: var(--bg-secondary);
            padding: 0.35rem 0.6rem;
            border-radius: 6px;
            word-break: break-all;
        }

        .email-config-metric {
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
            text-align: center;
            padding: 0.75rem;
            background: var(--bg-secondary);
            border-radius: 8px;
        }

        .email-config-metric-label {
            font-size: 0.8rem;
            color: var(--text-muted);
            font-weight: 500;
        }

        .email-config-metric-value {
            font-size: 0.9rem;
            font-weight: 600;
            color: var(--text-primary);
        }

        .email-config-metric-big {
            font-size: 1.5rem;
        }

        .ec-badge {
            font-size: 0.8rem;
            font-weight: 600;
            display: inline-flex;
            align-items: center;
            gap: 0.3rem;
            padding: 0.15rem 0.5rem;
            border-radius: 20px;
        }

        .ec-badge--ok {
            color: var(--success);
            background: rgba(16, 185, 129, 0.1);
        }

        .ec-badge--off {
            color: var(--danger);
            background: rgba(244, 63, 94, 0.1);
        }

        @keyframes spin {
            from {
                transform: rotate(0deg);
            }

            to {
                transform: rotate(360deg);
            }
        }

        .ph-spin {
            display: inline-block;
            animation: spin 1s linear infinite;
        }

        input,
        select,
        textarea {
            width: 100%;
            background: var(--bg-input);
            border: 1px solid var(--border-subtle);
            color: var(--text-main);
            padding: 0.7rem 1rem;
            border-radius: 8px;
            font-family: inherit;
            transition: border 0.2s;
            font-size: 0.9rem;
        }

        input:focus,
        select:focus,
        textarea:focus {
            border-color: var(--brand-primary);
        }

        /* --- DASHBOARD WIDGETS --- */
        .kpi-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: 1.5rem;
            margin-bottom: 2rem;
        }

        .metrics-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
            gap: 1.5rem;
            margin-bottom: 2rem;
        }

        .observability-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
            gap: 1.5rem;
        }

        .observability-full-row {
            grid-column: span 2;
        }

        .alert-kpi-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
            gap: 0.75rem;
        }

        .alert-kpi-item {
            padding: 0.65rem 0.75rem;
            border-radius: 12px;
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.4);
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
        }

        [data-theme="light"] .alert-kpi-item {
            background: rgba(255, 255, 255, 0.92);
            border-color: rgba(15, 23, 42, 0.06);
        }

        .alert-kpi-sub {
            font-size: 0.8rem;
            color: var(--text-secondary);
        }

        .chart-card {
            position: relative;
        }

        .span-full {
            grid-column: 1 / -1;
        }

        .chart-wrapper {
            position: relative;
            width: 100%;
            height: 260px;
        }

        .chart-card.compact .chart-wrapper {
            height: 200px;
        }

        .insights-summary {
            min-height: 110px;
            padding: 0.85rem 1rem;
            border-radius: 12px;
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.35);
            color: var(--text-secondary);
            font-size: 0.9rem;
            line-height: 1.5;
        }

        [data-theme="light"] .insights-summary {
            background: rgba(255, 255, 255, 0.92);
            color: #1f2937;
        }

        .chart-wrapper canvas {
            position: absolute;
            inset: 0;
            width: 100% !important;
            height: 100% !important;
        }

        .recent-activity {
            list-style: none;
            display: flex;
            flex-direction: column;
            gap: 1rem;
            margin: 0;
            padding: 0;
        }

        .activity-item {
            padding: 0.75rem;
            border-radius: 12px;
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.4);
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
        }

        [data-theme="light"] .activity-item {
            background: rgba(255, 255, 255, 0.92);
            border-color: rgba(15, 23, 42, 0.06);
            box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
            color: var(--text-main);
        }

        .pager {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .pager button {
            border: 1px solid var(--border-subtle);
            background: var(--bg-input);
            color: var(--text-main);
            padding: 0.35rem 0.65rem;
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .pager button:hover:not(:disabled) {
            background: rgba(99, 102, 241, 0.12);
            color: var(--text-main);
        }

        .pager button:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }

        .chart-legend {
            display: flex;
            gap: 1rem;
            flex-wrap: wrap;
            font-size: 0.8rem;
            color: var(--text-secondary);
        }

        .kpi-card {
            position: relative;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }

        .kpi-icon {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            display: grid;
            place-items: center;
            font-size: 1.2rem;
            margin-bottom: 0.5rem;
        }

        .kpi-label {
            font-size: 0.85rem;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.05em;
        }

        .kpi-value {
            font-size: 1.25rem;
            font-weight: 700;
            color: var(--text-main);
        }

        .kpi-status {
            font-size: 0.8rem;
            display: flex;
            align-items: center;
            gap: 0.4rem;
        }

        .status-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
        }

        /* --- CHAT INTERFACE --- */
        .chat-container {
            display: grid;
            grid-template-rows: 1fr auto;
            height: calc(100vh - 140px);
            gap: 1rem;
        }

        .chat-layout {
            display: flex;
            gap: 1.5rem;
            align-items: stretch;
            height: calc(100vh - 140px);
            overflow: hidden;
        }

        .chat-layout .chat-container {
            flex: 1;
            min-width: 320px;
            height: 100%;
        }

        .report-canvas {
            width: 38%;
            min-width: 320px;
            height: calc(100vh - 140px);
            display: flex;
            flex-direction: column;
            padding: 1.2rem;
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-subtle);
            background: linear-gradient(180deg, rgba(10, 14, 26, 0.88), rgba(3, 6, 18, 0.92));
            box-shadow: var(--glass-shadow);
            overflow-y: auto;
            gap: 1rem;
        }

        .report-canvas.hidden {
            display: none;
        }

        .report-header {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 0.75rem;
        }

        .report-title {
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--text-main);
        }

        .report-meta {
            display: flex;
            gap: 0.5rem;
            font-size: 0.75rem;
            color: var(--text-muted);
            margin-top: 0.15rem;
        }

        .report-status {
            padding: 0.15rem 0.6rem;
            border-radius: 999px;
            border: 1px solid rgba(59, 130, 246, 0.4);
            background: rgba(59, 130, 246, 0.12);
            color: #bfdbfe;
            font-weight: 600;
        }

        .report-version {
            padding: 0.15rem 0.55rem;
            border-radius: 999px;
            background: rgba(148, 163, 184, 0.16);
        }

        .report-actions {
            display: flex;
            gap: 0.5rem;
            align-items: center;
        }

        .report-progress {
            display: flex;
            flex-direction: column;
            gap: 0.35rem;
            font-size: 0.75rem;
            color: var(--text-muted);
        }

        .report-progress-item {
            display: flex;
            align-items: center;
            gap: 0.4rem;
        }

        .report-export-menu {
            position: absolute;
            top: 100%;
            right: 0;
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            box-shadow: var(--glass-shadow);
            z-index: 20;
            min-width: 140px;
            padding: 0.3rem 0;
        }
        .report-export-menu.hidden { display: none; }
        .report-export-option {
            display: flex;
            align-items: center;
            gap: 0.4rem;
            width: 100%;
            padding: 0.45rem 0.75rem;
            background: none;
            border: none;
            color: var(--text-main);
            font-size: 0.82rem;
            cursor: pointer;
            text-align: left;
        }
        .report-export-option:hover {
            background: rgba(59, 130, 246, 0.1);
        }

        .report-history {
            display: flex;
            flex-direction: column;
            gap: 0;
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            background: var(--bg-card);
            max-height: 320px;
            overflow-y: auto;
            margin-bottom: 0.5rem;
            flex-shrink: 0;
        }
        .report-history.hidden { display: none; }
        .report-history-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 0.6rem 0.75rem;
            border-bottom: 1px solid var(--border-subtle);
            position: sticky;
            top: 0;
            background: var(--bg-card);
            z-index: 1;
        }
        .report-history-item {
            padding: 0.6rem 0.75rem;
            border-bottom: 1px solid var(--border-subtle);
            cursor: pointer;
            transition: background 0.15s;
        }
        .report-history-item:hover {
            background: rgba(59, 130, 246, 0.08);
        }
        .report-history-item:last-child {
            border-bottom: none;
        }

        .report-body {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .report-empty {
            padding: 1.2rem;
            border: 1px dashed var(--border-subtle);
            border-radius: var(--radius-md);
            text-align: center;
            color: var(--text-muted);
        }

        .report-section {
            padding: 1rem;
            border-radius: var(--radius-md);
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.6);
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }

        .report-section h4 {
            font-size: 0.95rem;
            color: var(--text-main);
            margin: 0;
        }

        .report-section p,
        .report-section ul {
            margin: 0;
            color: var(--text-secondary);
            font-size: 0.85rem;
            line-height: 1.6;
        }

        .report-section ul {
            padding-left: 1.1rem;
        }

        .report-section ol {
            padding-left: 1.2rem;
        }

        .report-section li {
            margin-bottom: 0.35rem;
        }

        .report-section code {
            background: rgba(15, 23, 42, 0.5);
            border-radius: 6px;
            padding: 0.1rem 0.35rem;
            font-size: 0.78rem;
            color: var(--text-main);
        }

        .report-artifact {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 0.6rem;
            background: rgba(2, 6, 23, 0.6);
        }

        .report-artifact table {
            width: 100%;
            border-collapse: collapse;
            font-size: 0.78rem;
        }

        .report-artifact th,
        .report-artifact td {
            padding: 0.35rem 0.5rem;
            border-bottom: 1px solid rgba(148, 163, 184, 0.15);
            text-align: left;
        }

        .report-editor {
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }

        .report-editor textarea {
            min-height: 110px;
        }

        [data-theme="light"] .report-canvas {
            background: var(--bg-card);
        }

        [data-theme="light"] .report-section {
            background: var(--bg-input);
        }

        [data-theme="light"] .report-artifact {
            background: #ffffff;
        }

        [data-theme="light"] .report-title {
            color: var(--text-main);
        }

        [data-theme="light"] .report-meta {
            color: var(--text-secondary);
        }

        [data-theme="light"] .report-progress {
            color: var(--text-secondary);
        }

        [data-theme="light"] .report-empty {
            background: #ffffff;
            color: var(--text-secondary);
            border-color: rgba(15, 23, 42, 0.1);
        }

        [data-theme="light"] .report-status {
            border-color: rgba(59, 130, 246, 0.2);
            background: rgba(59, 130, 246, 0.08);
            color: #1d4ed8;
        }

        [data-theme="light"] .report-version {
            background: rgba(148, 163, 184, 0.18);
        }

        [data-theme="light"] .report-section p,
        [data-theme="light"] .report-section ul,
        [data-theme="light"] .report-section ol {
            color: var(--text-secondary);
        }

        [data-theme="light"] .report-section code {
            background: rgba(15, 23, 42, 0.08);
            color: var(--text-main);
        }

        [data-theme="light"] .report-artifact th,
        [data-theme="light"] .report-artifact td {
            border-bottom: 1px solid rgba(15, 23, 42, 0.08);
        }

        [data-theme="light"] .report-history {
            background: var(--bg-card);
            border-color: rgba(0, 0, 0, 0.1);
        }

        [data-theme="light"] .report-history-header {
            background: var(--bg-card);
            border-bottom-color: rgba(0, 0, 0, 0.08);
        }

        [data-theme="light"] .report-history-item {
            border-bottom-color: rgba(0, 0, 0, 0.06);
        }

        [data-theme="light"] .report-history-item:hover {
            background: rgba(59, 130, 246, 0.06);
        }

        [data-theme="light"] .report-editor label {
            color: var(--text-secondary);
        }

        @media (max-width: 980px) {
            .chat-layout {
                flex-direction: column;
                height: auto;
                overflow: visible;
            }

            .chat-layout .chat-container {
                height: calc(100vh - 140px);
            }

            .report-canvas {
                width: 100%;
                height: auto;
            }
        }

        .chat-history {
            overflow-y: auto;
            min-height: 0;
            padding: 0.5rem 0.75rem 0.85rem 0.75rem;
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            background: linear-gradient(180deg, rgba(15, 23, 42, 0.65), rgba(2, 6, 23, 0.8));
            box-shadow: var(--glass-shadow);
        }

        .chat-placeholder {
            text-align: center;
            color: var(--text-secondary);
            margin-top: 1.5rem;
            line-height: 1.6;
        }

        .chat-row {
            display: flex;
            gap: 0.6rem;
            align-items: flex-end;
            width: 100%;
            padding: 0 0.35rem;
        }

        .chat-row.user {
            flex-direction: row-reverse;
            justify-content: flex-end;
        }

        .chat-row.user .chat-bubble {
            margin-left: auto;
        }

        .chat-row.assistant .chat-bubble,
        .chat-row.error .chat-bubble {
            margin-right: auto;
        }

        .chat-row.thinking .chat-bubble {
            margin-right: auto;
        }

        .chat-avatar {
            width: 34px;
            height: 34px;
            border-radius: 10px;
            display: grid;
            place-items: center;
            font-weight: 700;
            font-size: 0.9rem;
            color: white;
            box-shadow: 0 6px 18px rgba(0, 0, 0, 0.3);
            border: 1px solid var(--border-subtle);
            background: var(--bg-panel);
        }

        .chat-avatar.user {
            background: linear-gradient(135deg, rgba(99, 102, 241, 0.15), rgba(99, 102, 241, 0.05));
            color: var(--text-main);
        }

        .chat-avatar.assistant {
            background: linear-gradient(135deg, var(--brand-primary), #a855f7);
        }

        .chat-avatar.error {
            background: linear-gradient(135deg, #f43f5e, #be123c);
        }

        .chat-avatar.thinking {
            background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(168, 85, 247, 0.3));
            color: var(--text-main);
        }

        .chat-bubble {
            position: relative;
            max-width: min(960px, calc(100% - 74px));
            padding: 1rem 1.1rem;
            border-radius: 14px;
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.7);
            box-shadow: 0 10px 26px rgba(0, 0, 0, 0.25);
            flex: 0 1 auto;
            width: auto;
        }
        .chat-bubble__copy {
            position: absolute;
            top: 0.5rem;
            right: 0.5rem;
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            padding: 0.25rem;
            border-radius: 6px;
            font-size: 0.9rem;
            line-height: 1;
            opacity: 0;
            transition: opacity 0.15s, background 0.15s, color 0.15s;
        }
        .chat-bubble:hover .chat-bubble__copy {
            opacity: 0.6;
        }
        .chat-bubble__copy:hover {
            opacity: 1 !important;
            background: rgba(99, 102, 241, 0.15);
            color: var(--text-primary);
        }

        .chat-row.user {
            justify-content: flex-end;
        }

        .chat-bubble.user {
            background: rgba(99, 102, 241, 0.08);
            border-color: rgba(99, 102, 241, 0.25);
        }

        .chat-bubble.assistant {
            background: rgba(30, 41, 59, 0.7);
            border-color: rgba(99, 102, 241, 0.3);
        }

        .chat-bubble.error {
            background: rgba(244, 63, 94, 0.08);
            border-color: rgba(244, 63, 94, 0.35);
        }

        .chat-bubble.thinking {
            background: rgba(30, 41, 59, 0.55);
            border-color: rgba(148, 163, 184, 0.35);
        }

        /* Light theme overrides */
        [data-theme="light"] .chat-history {
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(248, 250, 252, 0.92));
            border-color: rgba(0, 0, 0, 0.04);
            box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
        }

        [data-theme="light"] .chat-bubble {
            background: rgba(255, 255, 255, 0.95);
            border-color: rgba(0, 0, 0, 0.06);
            box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
        }

        [data-theme="light"] .chat-bubble.user {
            background: linear-gradient(135deg, rgba(99, 102, 241, 0.08), rgba(99, 102, 241, 0.02));
            border-color: rgba(99, 102, 241, 0.22);
        }

        [data-theme="light"] .chat-bubble.assistant {
            background: rgba(248, 250, 252, 0.98);
            border-color: rgba(148, 163, 184, 0.35);
        }

        [data-theme="light"] .chat-bubble.error {
            background: rgba(244, 63, 94, 0.08);
            border-color: rgba(244, 63, 94, 0.32);
        }

        [data-theme="light"] .chat-bubble.thinking {
            background: rgba(241, 245, 249, 0.95);
            border-color: rgba(148, 163, 184, 0.3);
        }

        [data-theme="light"] .chat-avatar {
            border-color: rgba(0, 0, 0, 0.06);
            box-shadow: 0 6px 12px rgba(15, 23, 42, 0.08);
        }

        [data-theme="light"] .chat-avatar.assistant {
            color: white;
            background: linear-gradient(135deg, #6366f1, #8b5cf6);
        }

        [data-theme="light"] .chat-avatar.user {
            background: linear-gradient(135deg, rgba(99, 102, 241, 0.2), rgba(99, 102, 241, 0.08));
            color: #111827;
        }

        [data-theme="light"] .chat-avatar.thinking {
            background: linear-gradient(135deg, rgba(99, 102, 241, 0.18), rgba(139, 92, 246, 0.22));
            color: #1e293b;
        }

        [data-theme="light"] .chat-render {
            background: rgba(255, 255, 255, 0.9);
            border-color: rgba(0, 0, 0, 0.06);
        }

        [data-theme="light"] .chat-render__table-wrapper {
            border-color: rgba(0, 0, 0, 0.08);
        }

        [data-theme="light"] .chat-render__label,
        [data-theme="light"] .chat-bubble__header {
            color: #475569;
        }

        [data-theme="light"] .chat-render__chart .chart-row__label {
            color: #334155;
        }

        [data-theme="light"] .render-table {
            border-color: rgba(15, 23, 42, 0.12);
        }

        [data-theme="light"] .render-table thead th {
            background: #f1f5f9;
            color: #334155;
            border-bottom-color: rgba(15, 23, 42, 0.15);
            border-right-color: rgba(15, 23, 42, 0.08);
        }

        [data-theme="light"] .render-table tbody td {
            color: #1e293b;
            border-bottom-color: rgba(15, 23, 42, 0.08);
            border-right-color: rgba(15, 23, 42, 0.05);
        }

        [data-theme="light"] .render-table tbody tr:nth-child(even) {
            background: rgba(15, 23, 42, 0.02);
        }

        [data-theme="light"] .render-table tbody tr:hover {
            background: rgba(59, 130, 246, 0.06);
        }

        [data-theme="light"] .report-artifact .render-table thead th {
            background: #ffffff;
        }

        [data-theme="light"] .chat-debug {
            border-color: rgba(0, 0, 0, 0.08);
            background: rgba(248, 250, 252, 0.96);
        }

        [data-theme="light"] .chat-debug__label {
            background: rgba(99, 102, 241, 0.08);
            border-bottom-color: rgba(0, 0, 0, 0.05);
            color: #475569;
        }

        [data-theme="light"] .chat-debug__body {
            color: #0f172a;
        }

        [data-theme="light"] .chat-progress {
            border-color: rgba(15, 23, 42, 0.08);
            background: rgba(248, 250, 252, 0.9);
        }

        [data-theme="light"] .chat-progress:not([open]) {
            border-color: transparent;
            background: transparent;
        }

        [data-theme="light"] .chat-progress__item {
            border-color: rgba(148, 163, 184, 0.25);
            background: rgba(255, 255, 255, 0.9);
        }

        [data-theme="light"] .chat-progress__item.is-error {
            border-color: rgba(248, 113, 113, 0.35);
            background: rgba(254, 242, 242, 0.9);
        }

        [data-theme="light"] .chat-progress__sql {
            border-color: rgba(148, 163, 184, 0.25);
            background: rgba(241, 245, 249, 0.95);
            color: #0f172a;
        }

        .chat-bubble__header {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 0.8rem;
            letter-spacing: 0.05em;
            text-transform: uppercase;
            color: var(--text-secondary);
            margin-bottom: 0.35rem;
        }

        .chat-bubble__header .chat-role {
            font-weight: 700;
        }

        .chat-bubble__header .chat-time {
            font-variant-numeric: tabular-nums;
            opacity: 0.7;
        }

        .chat-bubble__text {
            white-space: pre-wrap;
            color: var(--text-main);
            line-height: 1.6;
        }

        .chat-bubble__text--thinking {
            display: inline-flex;
            align-items: center;
            gap: 0.6rem;
            color: var(--text-secondary);
            font-weight: 500;
        }

        .chat-thinking__dots {
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
        }

        .chat-thinking__dots span {
            width: 6px;
            height: 6px;
            border-radius: 999px;
            background: var(--brand-primary);
            opacity: 0.4;
            animation: chatThinkingPulse 1.2s infinite ease-in-out;
        }

        .chat-thinking__dots span:nth-child(2) {
            animation-delay: 0.2s;
        }

        .chat-thinking__dots span:nth-child(3) {
            animation-delay: 0.4s;
        }

        @keyframes chatThinkingPulse {
            0%,
            80%,
            100% {
                transform: translateY(0);
                opacity: 0.35;
            }
            40% {
                transform: translateY(-3px);
                opacity: 1;
            }
        }

        .chat-row.user .chat-bubble__text {
            text-align: left;
        }

        .chat-row.assistant .chat-bubble__text,
        .chat-row.error .chat-bubble__text {
            text-align: left;
        }

        .chat-row.assistant .chat-bubble__text {
            white-space: normal;
        }

        .chat-row.assistant .chat-bubble__text p {
            margin: 0 0 0.4em 0;
        }

        .chat-row.assistant .chat-bubble__text p:last-child {
            margin-bottom: 0;
        }

        .chat-row.assistant .chat-bubble__text h4,
        .chat-row.assistant .chat-bubble__text h5,
        .chat-row.assistant .chat-bubble__text h6 {
            margin: 0.6em 0 0.3em 0;
            font-weight: 600;
            color: var(--text-main);
        }

        .chat-row.assistant .chat-bubble__text h4 { font-size: 0.95rem; }
        .chat-row.assistant .chat-bubble__text h5 { font-size: 0.9rem; }
        .chat-row.assistant .chat-bubble__text h6 { font-size: 0.85rem; }

        .chat-row.assistant .chat-bubble__text ul,
        .chat-row.assistant .chat-bubble__text ol {
            margin: 0.3em 0 0.5em 0;
            padding-left: 1.4em;
        }

        .chat-row.assistant .chat-bubble__text li {
            margin-bottom: 0.15em;
        }

        .chat-row.assistant .chat-bubble__text code {
            font-family: "SF Mono", "Fira Code", monospace;
            font-size: 0.85em;
            background: rgba(148, 163, 184, 0.15);
            padding: 0.1em 0.35em;
            border-radius: 4px;
        }

        .chat-row.assistant .chat-bubble__text a {
            color: var(--brand-primary);
            text-decoration: underline;
        }

        .chat-progress {
            margin-top: 0.85rem;
            border: 1px dashed rgba(148, 163, 184, 0.35);
            border-radius: 12px;
            background: rgba(15, 23, 42, 0.35);
            padding: 0.5rem 0.75rem;
            transition: border-color 0.2s ease, background 0.2s ease;
        }

        .chat-progress summary {
            cursor: pointer;
            font-size: 0.72rem;
            font-weight: 500;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.05em;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 0.5rem;
            padding: 0.15rem 0.1rem;
            list-style: none;
        }

        .chat-progress summary::after {
            content: "ver etapas";
            font-size: 0.7rem;
            text-transform: none;
            letter-spacing: 0;
            color: var(--text-muted);
        }

        .chat-progress[open] summary::after {
            content: "ocultar";
        }

        .chat-progress summary::-webkit-details-marker {
            display: none;
        }

        .chat-progress:not([open]) {
            border-color: transparent;
            background: transparent;
            padding: 0.15rem 0.25rem;
        }

        .chat-progress__list {
            margin-top: 0.6rem;
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }

        .chat-progress__item {
            padding: 0.55rem 0.7rem;
            border-radius: 10px;
            border: 1px solid rgba(148, 163, 184, 0.2);
            background: rgba(15, 23, 42, 0.5);
        }

        .chat-progress__item.is-error {
            border-color: rgba(248, 113, 113, 0.5);
            background: rgba(127, 29, 29, 0.2);
        }

        .chat-progress__header {
            display: flex;
            align-items: baseline;
            justify-content: space-between;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .chat-progress__label {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-main);
        }

        .chat-progress__attempt,
        .chat-progress__time {
            font-size: 0.75rem;
            color: var(--text-muted);
        }

        .chat-progress__meta {
            margin-top: 0.4rem;
            font-size: 0.78rem;
            color: var(--text-secondary);
        }

        .chat-progress__sql {
            margin-top: 0.35rem;
            padding: 0.5rem 0.6rem;
            border-radius: 8px;
            border: 1px solid rgba(148, 163, 184, 0.2);
            background: rgba(2, 6, 23, 0.6);
            color: var(--text-main);
            font-family: "JetBrains Mono", "Fira Code", monospace;
            font-size: 0.75rem;
            white-space: pre-wrap;
        }

        .chat-debug {
            margin-top: 0.85rem;
            border: 1px solid rgba(148, 163, 184, 0.2);
            border-radius: 12px;
            background: rgba(2, 6, 23, 0.5);
            overflow: hidden;
        }

        .chat-debug__label {
            display: flex;
            align-items: center;
            gap: 0.35rem;
            padding: 0.55rem 0.75rem;
            font-size: 0.8rem;
            letter-spacing: 0.05em;
            text-transform: uppercase;
            color: var(--text-secondary);
            border-bottom: 1px solid rgba(148, 163, 184, 0.15);
            background: rgba(148, 163, 184, 0.04);
        }

        .chat-debug__body {
            padding: 0.75rem;
            background: transparent;
            color: #cbd5f5;
            font-size: 11px;
            overflow-x: auto;
        }

        .chat-render {
            margin-top: 0.85rem;
            border: 1px solid rgba(255, 255, 255, 0.05);
            border-radius: 14px;
            padding: 0.85rem 1rem;
            background: rgba(8, 13, 30, 0.55);
        }

        .chat-render__label {
            font-size: 0.8rem;
            letter-spacing: 0.05em;
            text-transform: uppercase;
            color: var(--text-secondary);
            display: flex;
            align-items: center;
            gap: 0.35rem;
        }

        .chat-render__table-wrapper {
            overflow-x: auto;
            border: 1px solid rgba(255, 255, 255, 0.06);
            border-radius: 12px;
            margin-top: 0.75rem;
        }

        .render-table {
            width: 100%;
            border-collapse: collapse;
            font-size: 0.85rem;
            border: 1px solid rgba(255, 255, 255, 0.10);
            border-radius: 6px;
            overflow: hidden;
        }

        .render-table thead th {
            text-align: left;
            padding: 0.65rem 1rem;
            border-bottom: 2px solid rgba(255, 255, 255, 0.12);
            border-right: 1px solid rgba(255, 255, 255, 0.06);
            color: #cbd5f5;
            font-weight: 600;
            font-size: 0.78rem;
            letter-spacing: 0.03em;
            text-transform: uppercase;
            position: sticky;
            top: 0;
            background: rgba(8, 13, 30, 0.95);
            z-index: 1;
        }

        .render-table thead th:last-child {
            border-right: none;
        }

        .render-table tbody td {
            padding: 0.55rem 1rem;
            border-bottom: 1px solid rgba(255, 255, 255, 0.07);
            border-right: 1px solid rgba(255, 255, 255, 0.04);
            color: #f8fafc;
        }

        .render-table tbody td:last-child {
            border-right: none;
        }

        .render-table tbody td.is-numeric {
            text-align: right;
            font-variant-numeric: tabular-nums;
        }

        .render-table tbody tr:nth-child(even) {
            background: rgba(255, 255, 255, 0.02);
        }

        .render-table tbody tr:hover {
            background: rgba(59, 130, 246, 0.08);
            transition: background 0.15s ease;
        }

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

        .report-artifact .render-table {
            font-size: 0.78rem;
        }

        .report-artifact .render-table thead th {
            background: rgba(2, 6, 23, 0.8);
            padding: 0.5rem 0.75rem;
        }

        .report-artifact .render-table tbody td {
            padding: 0.4rem 0.75rem;
        }

        .chat-render__chart {
            margin-top: 0.75rem;
            position: relative;
            min-height: 180px;
        }

        .chat-render__chart canvas {
            width: 100%;
            height: 180px;
            display: block;
        }

        .chat-render__chart .empty-state {
            display: none;
            padding: 0.5rem 0;
        }

        .chat-render__chart.is-empty {
            min-height: auto;
        }

        .chat-render__chart.is-empty canvas {
            display: none;
        }

        .chat-render__chart.is-empty .empty-state {
            display: block;
        }

        .chart-row {
            display: grid;
            grid-template-columns: minmax(120px, 200px) 1fr 80px;
            gap: 0.65rem;
            align-items: center;
        }

        .chart-row__bar {
            height: 8px;
            border-radius: 999px;
            background: rgba(148, 163, 184, 0.15);
            overflow: hidden;
            position: relative;
        }

        .chart-row__bar span {
            display: block;
            height: 100%;
            border-radius: 999px;
            background: linear-gradient(90deg, #818cf8, #c084fc);
            box-shadow: 0 0 10px rgba(129, 140, 248, 0.45);
        }

        .chart-row__value {
            text-align: right;
            font-variant-numeric: tabular-nums;
            color: #e2e8f0;
        }

        .line-chart {
            margin-top: 1rem;
            width: 100%;
            overflow: hidden;
        }

        .line-chart svg {
            width: 100%;
            height: 220px;
        }

        /* --- BACKLOG --- */
        .backlog-layout {
            display: grid;
            grid-template-columns: 380px 1fr;
            gap: 1.25rem;
        }

        .backlog-list {
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }

        .backlog-item {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-md);
            padding: 1rem;
            background: rgba(15, 23, 42, 0.35);
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .backlog-item:hover {
            border-color: var(--border-highlight);
            transform: translateY(-1px);
        }

        .backlog-item.active {
            border-color: var(--brand-primary);
            background: rgba(99, 102, 241, 0.08);
            box-shadow: 0 4px 18px rgba(99, 102, 241, 0.15);
        }

        .backlog-meta {
            display: flex;
            gap: 0.4rem;
            flex-wrap: wrap;
            align-items: center;
            font-size: 0.8rem;
            color: var(--text-secondary);
        }

        .backlog-pill {
            padding: 0.15rem 0.65rem;
            border-radius: 999px;
            border: 1px solid var(--border-subtle);
            background: var(--bg-input);
            font-weight: 600;
            font-size: 0.8rem;
        }

        .backlog-priority {
            color: #fbbf24;
            border-color: rgba(251, 191, 36, 0.3);
            background: rgba(251, 191, 36, 0.08);
        }

        .backlog-priority[data-level="P1"] {
            color: #f43f5e;
            border-color: rgba(244, 63, 94, 0.35);
            background: rgba(244, 63, 94, 0.1);
        }

        .backlog-priority[data-level="P2"] {
            color: #fbbf24;
        }

        .backlog-priority[data-level="P3"] {
            color: #22c55e;
            border-color: rgba(34, 197, 94, 0.35);
            background: rgba(34, 197, 94, 0.08);
        }

        .backlog-tag {
            font-size: 0.78rem;
            padding: 0.15rem 0.55rem;
            border-radius: 999px;
            background: rgba(148, 163, 184, 0.15);
            border: 1px solid var(--border-subtle);
            color: var(--text-secondary);
        }

        .backlog-detail {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            padding: 1.5rem;
            background: var(--bg-card);
            min-height: 420px;
        }

        .backlog-detail h3 {
            margin: 0 0 0.35rem;
        }

        .backlog-detail p {
            color: var(--text-secondary);
            line-height: 1.6;
        }

        .backlog-acceptance {
            list-style: none;
            padding: 0;
            margin: 0.5rem 0 0;
            display: flex;
            flex-direction: column;
            gap: 0.45rem;
        }

        .backlog-acceptance li {
            display: flex;
            gap: 0.5rem;
            align-items: flex-start;
        }

        .backlog-acceptance i {
            color: var(--brand-primary);
            margin-top: 2px;
        }

        /* Alert wizard prototype */
        .alert-pattern {
            background: linear-gradient(150deg, rgba(18, 25, 44, 0.92) 0%, rgba(24, 32, 53, 0.88) 55%, rgba(63, 46, 110, 0.35) 100%);
            border-radius: 18px;
            border: 1px solid var(--border-subtle);
            box-shadow: var(--glass-shadow);
            position: relative;
            overflow: hidden;
        }

        [data-theme="light"] .alert-pattern {
            background: linear-gradient(150deg, rgba(248, 250, 252, 0.98) 0%, rgba(241, 245, 249, 0.95) 55%, rgba(236, 240, 245, 0.9) 100%);
        }

        .alert-wizard-grid {
            display: grid;
            grid-template-columns: 2fr 1fr;
            gap: 1.25rem;
        }

        @media (max-width: 1100px) {
            .alert-wizard-grid {
                grid-template-columns: 1fr;
            }
        }

        .alert-stepper {
            display: flex;
            flex-wrap: wrap;
            gap: 0.5rem;
            margin-bottom: 1rem;
            padding: 0.35rem;
            border-radius: 12px;
            background: rgba(255, 255, 255, 0.02);
        }

        .alert-step-chip {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            padding: 0.5rem 0.9rem;
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.04);
            border: 1px solid rgba(148, 163, 184, 0.22);
            color: var(--text-main);
            font-size: 0.85rem;
            position: relative;
            overflow: hidden;
            transition: transform 0.15s ease, box-shadow 0.2s ease, border-color 0.15s ease;
        }

        .alert-step-chip::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(90deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
            transform: translateX(-100%);
            transition: transform 0.35s ease;
        }

        .alert-step-chip:hover::after {
            transform: translateX(0%);
        }

        .alert-step-chip:hover {
            transform: translateY(-1px);
            box-shadow: 0 10px 26px rgba(99, 102, 241, 0.18);
            border-color: rgba(99, 102, 241, 0.6);
        }

        .alert-step-chip.active {
            background: rgba(99, 102, 241, 0.22);
            color: var(--text-main);
            border-color: var(--border-highlight);
        }

        .alert-step-chip.complete {
            background: rgba(16, 185, 129, 0.16);
            border-color: rgba(16, 185, 129, 0.55);
            color: rgba(16, 185, 129, 0.95);
        }

        .alert-step-chip.blocked {
            opacity: 0.5;
        }

        [data-theme="light"] .alert-step-chip {
            background: rgba(15, 23, 42, 0.04);
            border-color: rgba(148, 163, 184, 0.35);
            box-shadow: none;
        }

        [data-theme="light"] .alert-step-chip.active {
            background: rgba(99, 102, 241, 0.14);
            border-color: rgba(99, 102, 241, 0.45);
        }

        .input-pill.invalid {
            border-color: rgba(244, 63, 94, 0.65);
            box-shadow: 0 0 0 1px rgba(244, 63, 94, 0.25);
        }

        .alert-step-card {
            border: 1px solid var(--border-subtle);
            border-radius: 18px;
            padding: 1.1rem;
            background: linear-gradient(160deg, rgba(12, 19, 33, 0.9), rgba(21, 29, 46, 0.85));
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
            position: relative;
            overflow: hidden;
            box-shadow: 0 20px 50px rgba(0, 0, 0, 0.28);
        }

        [data-theme="light"] .alert-step-card {
            background: linear-gradient(175deg, rgba(250, 252, 253, 0.98), rgba(243, 246, 250, 0.96));
            box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
        }

        .alert-step-card h4 {
            margin: 0;
            font-size: 1rem;
        }

        .alert-step-card::before {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 92% 12%, rgba(99, 102, 241, 0.18), transparent 32%);
            opacity: 0.9;
            pointer-events: none;
        }

        [data-theme="light"] .alert-step-card::before {
            background: radial-gradient(circle at 92% 12%, rgba(99, 102, 241, 0.08), transparent 32%);
            opacity: 0.5;
        }

        .alert-form-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: 0.75rem;
        }

        .alert-preview {
            border: 1px dashed var(--border-subtle);
            border-radius: 12px;
            padding: 0.75rem 1rem;
            background: rgba(148, 163, 184, 0.06);
            font-size: 0.9rem;
            color: var(--text-secondary);
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
        }

        [data-theme="light"] .alert-preview {
            background: rgba(15, 23, 42, 0.03);
            box-shadow: inset 0 1px 0 rgba(15,23,42,0.05);
        }

        .alert-final-checklist {
            list-style: none;
            padding: 0;
            margin: 0;
            display: grid;
            gap: 0.5rem;
            font-size: 0.9rem;
        }

        .alert-final-checklist li {
            padding: 0.45rem 0.75rem;
            border-radius: 10px;
            background: rgba(148, 163, 184, 0.08);
            color: var(--text-secondary);
            border: 1px solid rgba(148, 163, 184, 0.18);
        }

        .alert-final-checklist li.complete {
            color: rgba(16, 185, 129, 0.95);
            border-color: rgba(16, 185, 129, 0.5);
            background: rgba(16, 185, 129, 0.12);
            font-weight: 600;
        }
        .alert-summary-card {
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            padding: 1.1rem;
            background: linear-gradient(145deg, rgba(99, 102, 241, 0.18), rgba(15, 23, 42, 0.6));
            box-shadow: var(--glass-shadow);
            position: relative;
            overflow: hidden;
            backdrop-filter: blur(10px);
        }

        [data-theme="light"] .alert-summary-card {
            background: linear-gradient(145deg, rgba(250, 252, 253, 0.98), rgba(241, 245, 249, 0.94));
            box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
        }

        .alert-summary-card::before {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 6px;
            background: linear-gradient(180deg, var(--brand-primary), #a855f7);
            opacity: 0.9;
        }

        [data-theme="light"] .alert-summary-card::before {
            background: linear-gradient(180deg, rgba(99, 102, 241, 0.6), rgba(168, 85, 247, 0.45));
            opacity: 0.7;
        }

        .alert-list {
            display: flex;
            flex-direction: column;
            gap: 0;
        }

        /* ── Alert Rule Cards ── */
        .alert-rule-card {
            display: flex;
            gap: 0.85rem;
            padding: 0.85rem 0;
            border-bottom: 1px solid var(--border-subtle);
            transition: background 0.15s;
        }
        .alert-rule-card:last-child { border-bottom: none; }
        .alert-rule-card:hover { background: var(--bg-hover, rgba(99,102,241,0.03)); border-radius: 8px; }
        .alert-rule-card__indicator {
            width: 4px;
            border-radius: 4px;
            flex-shrink: 0;
            min-height: 100%;
        }
        .alert-rule-card__body { flex: 1; min-width: 0; }
        .alert-rule-card__top {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 0.75rem;
            flex-wrap: wrap;
        }
        .alert-rule-card__badges {
            display: flex;
            align-items: center;
            gap: 0.4rem;
            flex-wrap: wrap;
        }
        .alert-rule-card__name {
            font-weight: 600;
            font-size: 0.9rem;
            color: var(--text-main);
        }
        .alert-rule-card__actions {
            display: flex;
            gap: 0.25rem;
            flex-shrink: 0;
        }
        .alert-rule-card__desc {
            margin: 0.3rem 0 0;
            font-size: 0.82rem;
            color: var(--text-secondary);
            line-height: 1.4;
        }
        .alert-rule-card__chip {
            display: inline-flex;
            align-items: center;
            gap: 0.25rem;
            padding: 0.15rem 0.5rem;
            border-radius: 5px;
            font-size: 0.75rem;
            font-weight: 500;
            background: var(--bg-body, rgba(107,114,128,0.08));
            color: var(--text-secondary);
            white-space: nowrap;
        }
        .alert-rule-card__sql {
            margin: 0.35rem 0 0;
            font-size: 0.78rem;
            color: var(--text-secondary);
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .alert-rule-card__sql code {
            font-family: monospace;
            font-size: 0.78rem;
        }

        .badge-prototype {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            padding: 0.35rem 0.65rem;
            border-radius: 10px;
            border: 1px solid var(--border-subtle);
            background: rgba(99, 102, 241, 0.18);
            color: var(--text-main);
            font-size: 0.8rem;
        }

        .alert-wizard-pills {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .alert-pill {
            padding: 0.35rem 0.65rem;
            background: rgba(148, 163, 184, 0.12);
            border: 1px solid var(--border-subtle);
            border-radius: 10px;
            font-size: 0.8rem;
            color: var(--text-secondary);
        }

        .btn-gradient {
            background: linear-gradient(135deg, #2563eb, #a855f7);
            color: white;
            border: none;
            box-shadow: 0 10px 30px rgba(79, 70, 229, 0.35);
        }

        .btn-gradient:hover {
            filter: brightness(1.05);
        }

        [data-theme="light"] .btn-gradient {
            box-shadow: 0 10px 24px rgba(37, 99, 235, 0.25);
        }

        .accent-amber {
            background: var(--accent-amber-soft);
            border: 1px solid rgba(251, 191, 36, 0.35);
            color: var(--accent-amber);
        }

        .shimmer {
            position: relative;
            overflow: hidden;
        }

        .shimmer::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(110deg, transparent 0%, rgba(255, 255, 255, 0.12) 40%, transparent 60%);
            transform: translateX(-120%);
            animation: shimmer 1.8s infinite;
        }

        @keyframes shimmer {
            100% {
                transform: translateX(120%);
            }
        }

        /* Backlog viewport control */
        #view-backlog .backlog-layout {
            height: calc(100vh - 260px);
            overflow: hidden;
        }

        #view-backlog .backlog-list,
        #view-backlog .backlog-detail {
            max-height: 100%;
            overflow-y: auto;
            padding-right: 0.35rem;
        }

        /* Modal */
        .modal {
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.6);
            display: grid;
            place-items: center;
            z-index: 200;
        }

        .modal.hidden {
            display: none;
        }

        .modal-content {
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            padding: 1.5rem;
            width: min(720px, 92vw);
            max-height: 90vh;
            overflow-y: auto;
            box-shadow: var(--glass-shadow);
        }

        /* --- CONFIRM MODAL --- */
        .confirm-modal {
            position: fixed;
            inset: 0;
            z-index: 300;
            display: flex;
            align-items: center;
            justify-content: center;
            animation: confirmFadeIn 0.18s ease;
        }

        .confirm-modal.hidden {
            display: none;
        }

        .confirm-modal.closing {
            animation: confirmFadeOut 0.15s ease forwards;
        }

        .confirm-modal__backdrop {
            position: absolute;
            inset: 0;
            background: rgba(0, 0, 0, 0.55);
            backdrop-filter: blur(4px);
        }

        .confirm-modal__dialog {
            position: relative;
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            padding: 1.75rem 1.5rem 1.25rem;
            width: min(380px, 90vw);
            text-align: center;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.05);
            animation: confirmSlideIn 0.2s ease;
        }

        .confirm-modal.closing .confirm-modal__dialog {
            animation: confirmSlideOut 0.15s ease forwards;
        }

        .confirm-modal__icon {
            width: 48px;
            height: 48px;
            border-radius: 50%;
            display: grid;
            place-items: center;
            margin: 0 auto 0.85rem;
            font-size: 1.4rem;
        }

        .confirm-modal__icon.danger {
            background: rgba(239, 68, 68, 0.12);
            color: #f87171;
            border: 1px solid rgba(239, 68, 68, 0.25);
        }

        .confirm-modal__icon.warning {
            background: rgba(245, 158, 11, 0.12);
            color: #fbbf24;
            border: 1px solid rgba(245, 158, 11, 0.25);
        }

        .confirm-modal__icon.info {
            background: rgba(59, 130, 246, 0.12);
            color: #60a5fa;
            border: 1px solid rgba(59, 130, 246, 0.25);
        }

        .confirm-modal__title {
            font-size: 1.05rem;
            font-weight: 700;
            color: var(--text-main);
            margin: 0 0 0.4rem;
        }

        .confirm-modal__message {
            font-size: 0.88rem;
            color: var(--text-secondary);
            margin: 0 0 1.25rem;
            line-height: 1.5;
        }

        .confirm-modal__actions {
            display: flex;
            gap: 0.6rem;
            justify-content: center;
        }

        .confirm-modal__actions .btn {
            min-width: 100px;
            padding: 0.55rem 1.1rem;
            font-size: 0.85rem;
            font-weight: 600;
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .confirm-modal__cancel {
            background: rgba(148, 163, 184, 0.1);
            border: 1px solid var(--border-subtle);
            color: var(--text-secondary);
        }

        .confirm-modal__cancel:hover {
            background: rgba(148, 163, 184, 0.18);
            color: var(--text-main);
        }

        .btn-danger {
            background: rgba(239, 68, 68, 0.15);
            border: 1px solid rgba(239, 68, 68, 0.35);
            color: #f87171;
        }

        .btn-danger:hover {
            background: rgba(239, 68, 68, 0.25);
            border-color: rgba(239, 68, 68, 0.5);
            color: #fca5a5;
        }

        .btn-warning {
            background: rgba(245, 158, 11, 0.15);
            border: 1px solid rgba(245, 158, 11, 0.35);
            color: #fbbf24;
        }

        .btn-warning:hover {
            background: rgba(245, 158, 11, 0.25);
            border-color: rgba(245, 158, 11, 0.5);
            color: #fde68a;
        }

        @keyframes confirmFadeIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }

        @keyframes confirmFadeOut {
            from { opacity: 1; }
            to { opacity: 0; }
        }

        @keyframes confirmSlideIn {
            from { opacity: 0; transform: scale(0.92) translateY(8px); }
            to { opacity: 1; transform: scale(1) translateY(0); }
        }

        @keyframes confirmSlideOut {
            from { opacity: 1; transform: scale(1) translateY(0); }
            to { opacity: 0; transform: scale(0.95) translateY(4px); }
        }

        /* Light theme */
        [data-theme="light"] .confirm-modal__backdrop {
            background: rgba(0, 0, 0, 0.35);
        }

        [data-theme="light"] .confirm-modal__dialog {
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
        }

        .form-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: 0.85rem;
        }

        .line-chart__labels {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
            gap: 0.35rem;
            margin-top: 0.5rem;
            font-size: 0.7rem;
            color: rgba(226, 232, 240, 0.75);
        }

        /* --- SETTINGS TABS --- */
        .settings-layout {
            display: grid;
            grid-template-columns: 240px 1fr;
            gap: 2rem;
        }

        .channel-pref-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: 1rem;
            margin-top: 0.5rem;
        }

        .channel-pref-card {
            border: 1px solid var(--border-subtle);
            border-radius: 14px;
            padding: 1rem;
            background: rgba(15, 23, 42, 0.35);
        }

        [data-theme="light"] .channel-pref-card {
            background: rgba(15, 23, 42, 0.03);
        }

        .channel-pref-card h4 {
            margin: 0 0 0.4rem;
            font-size: 0.95rem;
        }

        .channel-pref-card label {
            display: flex;
            align-items: center;
            gap: 0.45rem;
            font-size: 0.85rem;
            margin-top: 0.35rem;
        }

        .channel-pref-card input[type="number"] {
            width: 100%;
            margin-top: 0.4rem;
        }

        .settings-nav {
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
        }

        .settings-tab {
            text-align: left;
            padding: 0.75rem 1rem;
            border-radius: 8px;
            cursor: pointer;
            color: var(--text-secondary);
            font-size: 0.9rem;
            font-weight: 500;
        }

        .settings-tab:hover {
            background: var(--bg-panel);
            color: var(--text-main);
        }

        .settings-tab.active {
            background: var(--bg-card);
            color: var(--brand-primary);
            border-left: 3px solid var(--brand-primary);
        }

        .setting-section {
            display: none;
            animation: fadeIn 0.2s;
        }

        .setting-section.active {
            display: block;
        }

        /* --- IAM TABS --- */
        .iam-tabs {
            display: flex;
            flex-wrap: wrap;
            gap: 0.5rem;
            margin: 1rem 0 1.25rem;
        }

        .iam-tab {
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.35);
            color: var(--text-secondary);
            padding: 0.55rem 0.95rem;
            border-radius: 12px;
            cursor: pointer;
            font-size: 0.9rem;
            font-weight: 600;
        }

        [data-theme="light"] .iam-tab {
            background: rgba(15, 23, 42, 0.04);
        }

        .iam-tab:hover {
            color: var(--text-main);
            border-color: rgba(99, 102, 241, 0.4);
        }

        .iam-tab.active {
            color: var(--text-main);
            background: rgba(99, 102, 241, 0.12);
            border-color: var(--brand-primary);
        }

        .iam-tab-panel {
            display: none;
            animation: fadeIn 0.2s;
            width: 100%;
            flex-basis: 100%;
            clear: both;
        }

        .iam-tab-panel.active {
            display: block;
        }

        .iam-tab-panels {
            display: block;
            width: 100%;
        }

        .iam-kpi-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 1rem;
        }

        .iam-grid {
            display: grid;
            grid-template-columns: minmax(0, 1fr) 320px;
            gap: 1.2rem;
        }

        .iam-side-panel {
            display: flex;
            flex-direction: column;
            gap: 1rem;
        }

        .iam-panel-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            flex-wrap: wrap;
        }

        .iam-inline-actions {
            display: flex;
            gap: 0.5rem;
            flex-wrap: wrap;
        }

        .iam-search {
            position: relative;
            min-width: 220px;
            flex: 1 1 240px;
        }

        .iam-search input {
            width: 100%;
            padding-left: 2.5rem;
            background: var(--bg-input);
            border: 1px solid var(--border-subtle);
        }

        .iam-search i {
            position: absolute;
            left: 0.85rem;
            top: 50%;
            transform: translateY(-50%);
            color: var(--text-secondary);
            font-size: 1rem;
        }

        .iam-kpi-card {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            padding: 1.1rem 1.25rem;
            border-radius: 16px;
            border: 1px solid var(--border-subtle);
            background: rgba(15, 23, 42, 0.55);
            box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
            position: relative;
            overflow: hidden;
        }

        [data-theme="light"] .iam-kpi-card {
            background: #ffffff;
            box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
        }

        .iam-kpi-card::after {
            content: "";
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 80% 20%, rgba(99, 102, 241, 0.12), transparent 55%);
            opacity: 0.8;
            pointer-events: none;
        }

        [data-theme="light"] .iam-kpi-card::after {
            background: radial-gradient(circle at 80% 20%, rgba(99, 102, 241, 0.08), transparent 55%);
        }

        .iam-kpi-meta {
            display: flex;
            flex-direction: column;
            gap: 0.3rem;
            position: relative;
            z-index: 1;
        }

        .iam-kpi-label {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-secondary);
        }

        .iam-kpi-value {
            font-size: 1.45rem;
            font-weight: 700;
        }

        .iam-kpi-sub {
            font-size: 0.82rem;
            color: var(--text-secondary);
        }

        .iam-kpi-icon {
            width: 44px;
            height: 44px;
            border-radius: 14px;
            display: grid;
            place-items: center;
            background: rgba(99, 102, 241, 0.15);
            color: var(--brand-primary);
            border: 1px solid rgba(99, 102, 241, 0.35);
            font-size: 1.2rem;
            position: relative;
            z-index: 1;
        }

        .iam-table-card {
            border-radius: 18px;
            overflow: hidden;
            padding: 0;
        }

        .iam-table-card.menu-floating {
            overflow: visible;
        }

        .iam-card-section {
            padding: 1rem 1.25rem;
            border-bottom: 1px solid var(--border-subtle);
        }

        .iam-card-section:last-child {
            border-bottom: none;
        }

        .iam-table-header-compact {
            padding: 0.75rem 1.25rem;
        }

        .table-container {
            width: 100%;
            overflow-x: auto;
            overflow-y: visible;
        }

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

        .iam-table-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            padding: 1rem 1.25rem;
            border-bottom: 1px solid var(--border-subtle);
            background: linear-gradient(135deg, rgba(15, 23, 42, 0.85), rgba(99, 102, 241, 0.08));
        }

        [data-theme="light"] .iam-table-header {
            background: linear-gradient(135deg, rgba(248, 250, 252, 0.96), rgba(226, 232, 240, 0.85));
        }

        .iam-table-title {
            margin: 0;
            font-size: 1rem;
            font-weight: 600;
        }

        .iam-table-subtitle {
            margin: 0;
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .iam-table {
            width: 100%;
            border-collapse: collapse;
            table-layout: fixed;
            font-size: 0.88rem;
        }

        .iam-table th {
            text-align: left;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-size: 0.72rem;
            padding: 0.7rem 1.1rem;
            color: var(--text-secondary);
            background: rgba(15, 23, 42, 0.4);
            border-bottom: 1px solid var(--border-subtle);
        }

        [data-theme="light"] .iam-table th {
            background: rgba(15, 23, 42, 0.04);
            color: var(--text-muted);
        }

        .iam-table td {
            padding: 0.7rem 1.1rem;
            border-bottom: 1px solid var(--border-subtle);
            vertical-align: middle;
            line-height: 1.2;
            word-break: break-word;
        }

        .iam-table tbody tr:hover {
            background: rgba(99, 102, 241, 0.06);
        }

        .iam-user-cell {
            display: flex;
            align-items: center;
            gap: 0.75rem;
        }

        .iam-user-meta {
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
        }

        .iam-user-name {
            font-weight: 600;
            color: var(--text-main);
        }

        .iam-user-email {
            font-size: 0.8rem;
            color: var(--text-secondary);
        }

        .iam-avatar {
            width: 34px;
            height: 34px;
            border-radius: 50%;
            background: rgba(99, 102, 241, 0.16);
            border: 1px solid var(--border-subtle);
            color: var(--text-main);
            display: grid;
            place-items: center;
            font-weight: 700;
            font-size: 0.9rem;
        }

        .iam-menu {
            position: relative;
            display: inline-flex;
            align-items: center;
        }

        .iam-menu-button {
            width: 34px;
            height: 34px;
            padding: 0;
            justify-content: center;
        }

        .iam-menu-list {
            position: absolute;
            right: 0;
            top: calc(100% + 0.4rem);
            min-width: 160px;
            padding: 0.35rem;
            background: var(--bg-card);
            border: 1px solid var(--border-subtle);
            border-radius: 12px;
            box-shadow: 0 12px 24px rgba(0, 0, 0, 0.25);
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
            z-index: 40;
        }

        .iam-menu-item {
            background: transparent;
            border: none;
            padding: 0.45rem 0.65rem;
            border-radius: 8px;
            text-align: left;
            font-size: 0.85rem;
            color: var(--text-main);
            cursor: pointer;
        }

        .iam-menu-item:hover {
            background: rgba(99, 102, 241, 0.12);
        }

        .iam-menu-item.danger {
            color: var(--danger);
        }

        .iam-modal-content {
            background: rgba(8, 12, 24, 0.98);
            border-color: rgba(148, 163, 184, 0.25);
            box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
        }

        [data-theme="light"] .iam-modal-content {
            background: #ffffff;
        }

        .iam-role-table {
            border: 1px solid var(--border-subtle);
            border-radius: 12px;
            overflow: hidden;
            background: rgba(15, 23, 42, 0.35);
        }

        [data-theme="light"] .iam-role-table {
            background: rgba(248, 250, 252, 0.96);
        }

        .iam-role-row {
            display: grid;
            grid-template-columns: 1.2fr 0.8fr 0.8fr auto;
            gap: 0.75rem;
            align-items: center;
            padding: 0.6rem 0.9rem;
            border-bottom: 1px solid var(--border-subtle);
            font-size: 0.85rem;
        }

        .iam-role-row:last-child {
            border-bottom: none;
        }

        .iam-role-row.header {
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-size: 0.7rem;
            color: var(--text-secondary);
            background: rgba(15, 23, 42, 0.55);
        }

        [data-theme="light"] .iam-role-row.header {
            background: rgba(15, 23, 42, 0.05);
            color: var(--text-muted);
        }
        .iam-role-cell {
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .iam-grid-single {
            grid-template-columns: 1fr;
        }

        @media (max-width: 1024px) {
            .iam-grid {
                grid-template-columns: 1fr;
            }
        }

        /* --- TOAST NOTIFICATIONS --- */
        #toast-container {
            position: fixed;
            top: 20px;
            right: 20px;
            z-index: 1000;
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        .toast {
            background: var(--bg-sidebar);
            border: 1px solid var(--border-subtle);
            padding: 1rem;
            border-radius: 10px;
            width: 320px;
            box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
            display: flex;
            align-items: center;
            gap: 0.8rem;
            transform: translateX(120%);
            transition: transform 0.3s cubic-bezier(0.68, -0.55, 0.27, 1.55);
        }

        .toast.show {
            transform: translateX(0);
        }

        .toast-icon {
            font-size: 1.5rem;
        }

        .toast.success .toast-icon {
            color: var(--success);
        }

        .toast.error .toast-icon {
            color: var(--danger);
        }

        /* --- LOGIN OVERLAY --- */
        #login-card {
            position: fixed;
            inset: 0;
            z-index: 200;
            background: var(--bg-app);
            display: grid;
            place-items: center;
        }

        .login-box {
            width: 100%;
            max-width: 400px;
            padding: 3rem;
            text-align: center;
        }

        /* Mobile Menu Button */
        .mobile-menu-btn {
            display: none;
            background: transparent;
            border: none;
            color: var(--text-main);
            font-size: 1.5rem;
            cursor: pointer;
            padding: 0.5rem;
            border-radius: 8px;
            transition: background 0.2s;
        }

        .mobile-menu-btn:hover {
            background: var(--bg-panel);
        }

        /* Sidebar Overlay */
        .sidebar-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.5);
            backdrop-filter: blur(4px);
            z-index: 99;
            opacity: 0;
            transition: opacity 0.3s ease;
            pointer-events: none;
        }

        .sidebar-overlay.active {
            opacity: 1;
            pointer-events: auto;
        }

        /* --- WhatsApp sessions layout --- */
        .wa-sessions-grid {
            display: grid;
            grid-template-columns: 1fr 350px;
            gap: 2rem;
        }

        /* --- Tablet breakpoint (compact sidebar) --- */
        @media (max-width: 1024px) and (min-width: 769px) {
            :root {
                --sidebar-width: 220px;
            }

            .sidebar {
                padding: 1rem;
            }

            .logo-area {
                margin-bottom: 1rem;
            }

            .nav-item {
                padding: 0.6rem 0.75rem;
                font-size: 0.84rem;
                gap: 0.7rem;
            }

            .nav-item i {
                font-size: 1.1rem;
            }

            .main-content {
                padding: 1.25rem;
            }

            .top-bar {
                padding: 0 1.25rem;
            }
        }

        /* --- Mobile breakpoint (drawer sidebar) --- */
        @media (max-width: 768px) {
            .app-layout {
                grid-template-columns: 1fr;
            }

            .mobile-menu-btn {
                display: block;
            }

            .sidebar {
                position: fixed;
                top: 0;
                left: 0;
                bottom: 0;
                width: var(--sidebar-width);
                max-width: 85vw;
                z-index: 100;
                transform: translateX(-100%);
                transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
                box-shadow: 2px 0 20px rgba(0, 0, 0, 0.3);
                visibility: hidden;
                padding: 1rem;
            }

            .sidebar.mobile-open {
                transform: translateX(0);
                visibility: visible;
            }

            .sidebar-overlay {
                display: block;
            }

            .logo-area {
                margin-bottom: 1rem;
            }

            .nav-item {
                padding: 0.45rem 0.75rem;
                font-size: 0.84rem;
                gap: 0.65rem;
            }

            .top-bar {
                grid-column: 1;
                padding: 0 1rem;
            }

            .top-actions {
                gap: 0.5rem;
            }

            .main-content {
                grid-column: 1;
                padding: 1rem;
            }

            .settings-layout {
                grid-template-columns: 1fr;
            }

            .page-title {
                font-size: 1rem;
                max-width: 45vw;
                overflow: hidden;
                text-overflow: ellipsis;
                white-space: nowrap;
            }

            /* P0: Tabelas IAM — scroll horizontal */
            .iam-table {
                table-layout: auto;
                min-width: 600px;
            }

            .iam-table th,
            .iam-table td {
                white-space: nowrap;
                padding: 0.5rem 0.75rem;
            }

            .iam-table td {
                word-break: normal;
            }

            /* P1: WhatsApp — colapsar grid */
            .wa-sessions-grid {
                grid-template-columns: 1fr;
                gap: 1.25rem;
            }

            /* P1: Observabilidade — coluna única */
            .observability-grid {
                grid-template-columns: 1fr;
            }

            .observability-full-row {
                grid-column: span 1;
            }

            /* P1: Permissões — badges e pre */
            .metadata-badge {
                max-width: 100%;
                overflow: hidden;
                text-overflow: ellipsis;
                white-space: nowrap;
                font-size: 0.7rem;
                padding: 0.1rem 0.5rem;
            }

            .metadata-aux-pre {
                overflow-x: auto;
                max-width: calc(100vw - 3rem);
                font-size: 0.75rem;
            }
        }

        /* --- Small phone --- */
        @media (max-width: 480px) {
            :root {
                --header-height: 56px;
            }

            .main-content {
                padding: 0.75rem;
            }

            .top-bar {
                padding: 0 0.75rem;
            }

            .login-box {
                padding: 1.5rem;
            }

            .page-title {
                font-size: 0.9rem;
            }

            .top-actions a.btn-ghost {
                display: none;
            }
        }

        .chat-actions {
            display: flex;
            gap: 0.5rem;
            margin-top: 0.75rem;
            flex-wrap: wrap;
            justify-content: flex-start;
            align-items: center;
        }

        .chat-row.user .chat-actions {
            justify-content: flex-end;
        }

        .chat-attachments {
            display: flex;
            gap: 0.4rem;
            flex-wrap: wrap;
            margin-top: 0.6rem;
        }

        .chat-row.user .chat-attachments {
            justify-content: flex-end;
        }

        .chat-attachment {
            display: inline-flex;
            align-items: center;
            gap: 0.35rem;
            padding: 0.2rem 0.55rem;
            font-size: 0.75rem;
            border-radius: 999px;
            border: 1px dashed rgba(148, 163, 184, 0.35);
            background: rgba(15, 23, 42, 0.45);
            color: var(--text-secondary);
        }

        .chat-row.user .chat-attachment {
            border-color: rgba(99, 102, 241, 0.35);
            background: rgba(99, 102, 241, 0.12);
            color: var(--text-main);
        }

        [data-theme="light"] .chat-attachment {
            border-color: rgba(0, 0, 0, 0.12);
            background: rgba(255, 255, 255, 0.9);
            color: #1f2937;
        }

        [data-theme="light"] .chat-row.user .chat-attachment {
            border-color: rgba(99, 102, 241, 0.3);
            background: rgba(99, 102, 241, 0.1);
            color: #111827;
        }

        /* Light theme buttons and actions visibility */
        [data-theme="light"] .chat-action-btn {
            border-color: rgba(0, 0, 0, 0.08);
            background: rgba(255, 255, 255, 0.85);
            color: #1f2937;
        }

        [data-theme="light"] .chat-action-btn:hover {
            border-color: rgba(99, 102, 241, 0.35);
            color: #111827;
            background: rgba(99, 102, 241, 0.1);
        }

        [data-theme="light"] .chat-action-btn.positive:hover {
            background: rgba(16, 185, 129, 0.12);
            border-color: rgba(16, 185, 129, 0.4);
            color: #065f46;
        }

        [data-theme="light"] .chat-action-btn.negative:hover {
            background: rgba(244, 63, 94, 0.12);
            border-color: rgba(244, 63, 94, 0.45);
            color: #7f1d1d;
        }

        [data-theme="light"] .chip {
            border-color: rgba(0, 0, 0, 0.08);
            background: rgba(255, 255, 255, 0.9);
            color: #1f2937;
        }

        [data-theme="light"] .chip:hover {
            border-color: rgba(99, 102, 241, 0.35);
            background: rgba(99, 102, 241, 0.1);
        }

        .chat-action-btn {
            background: rgba(255, 255, 255, 0.05);
            border: 1px solid rgba(255, 255, 255, 0.1);
            border-radius: 0.5rem;
            padding: 0.25rem 0.6rem;
            font-size: 0.75rem;
            color: var(--text-secondary);
            cursor: pointer;
            transition: all 0.2s;
            display: flex;
            align-items: center;
            gap: 0.3rem;
        }

        .chat-action-btn:hover {
            background: rgba(255, 255, 255, 0.1);
            color: var(--text-primary);
            border-color: rgba(255, 255, 255, 0.2);
        }

        .chat-action-btn.positive:hover {
            background: rgba(16, 185, 129, 0.1);
            color: #34d399;
            border-color: #34d399;
        }

        .chat-action-btn.negative:hover {
            background: rgba(244, 63, 94, 0.1);
            color: #fb7185;
            border-color: #fb7185;
        }

        /* ===================================================================
           COLLAPSIBLE MAIN SIDEBAR
           =================================================================== */

        .sidebar-collapse-btn {
            margin-left: auto;
            opacity: 0.6;
            transition: opacity 0.2s;
        }
        .sidebar-collapse-btn:hover {
            opacity: 1;
        }

        .sidebar-collapsed .sidebar {
            width: 64px;
            padding: 1rem 0.5rem 0.75rem;
            align-items: center;
            overflow-x: hidden;
        }
        .sidebar-collapsed .sidebar .user-profile > div:not(.avatar) {
            display: none;
        }
        .sidebar-collapsed .sidebar .user-profile {
            flex-direction: column;
            align-items: center;
            gap: 0.25rem;
            padding-top: 0.5rem;
        }
        .sidebar-collapsed .sidebar .user-profile .btn {
            padding: 0.4rem;
            font-size: 1rem;
        }
        .sidebar-collapsed .sidebar .logo-area {
            flex-direction: column;
            align-items: center;
            gap: 0.25rem;
            padding-left: 0;
            margin-bottom: 1rem;
        }
        .sidebar-collapsed .sidebar .logo-text {
            display: none;
        }
        .sidebar-collapsed .sidebar .sidebar-collapse-btn {
            margin-left: 0;
            padding: 0.25rem;
            font-size: 0.9rem;
        }
        .sidebar-collapsed .sidebar .sidebar-collapse-btn i {
            transform: scaleX(-1);
            transition: transform 0.2s ease;
        }
        .sidebar-collapsed .sidebar .nav-label {
            display: none;
        }
        .sidebar-collapsed .sidebar .nav-item {
            justify-content: center;
            padding: 0.6rem;
        }
        .sidebar-collapsed .sidebar .nav-item i {
            margin-right: 0;
            font-size: 1.15rem;
        }
        .sidebar-collapsed.app-layout {
            grid-template-columns: 64px 1fr;
        }

        /* Tooltip on collapsed sidebar items */
        .sidebar-collapsed .sidebar .nav-item {
            position: relative;
        }
        .sidebar-collapsed .sidebar .nav-item:hover::after {
            content: attr(data-label);
            position: absolute;
            left: calc(100% + 8px);
            top: 50%;
            transform: translateY(-50%);
            background: var(--bg-card);
            color: var(--text-main);
            padding: 0.3rem 0.6rem;
            border-radius: 6px;
            font-size: 0.75rem;
            white-space: nowrap;
            z-index: 200;
            border: 1px solid var(--border-subtle);
            box-shadow: var(--glass-shadow);
            pointer-events: none;
        }

        /* ===================================================================
           CONVERSATION SIDEBAR (inside chat view)
           =================================================================== */

        .conv-sidebar {
            width: 280px;
            min-width: 240px;
            max-width: 320px;
            display: flex;
            flex-direction: column;
            background: var(--bg-sidebar);
            backdrop-filter: blur(12px);
            border: 1px solid var(--border-subtle);
            border-radius: var(--radius-lg);
            overflow: hidden;
            flex-shrink: 0;
        }

        .conv-sidebar__header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0.85rem 1rem;
            border-bottom: 1px solid var(--border-subtle);
            flex-shrink: 0;
        }

        .conv-sidebar__title {
            font-size: 0.9rem;
            font-weight: 600;
            color: var(--text-main);
            margin: 0;
        }

        .conv-sidebar__search {
            padding: 0.5rem 0.75rem;
            flex-shrink: 0;
        }

        .conv-sidebar__search .input-pill {
            width: 100%;
            font-size: 0.82rem;
            padding: 0.4rem 0.75rem;
        }

        .conv-sidebar__list {
            flex: 1;
            overflow-y: auto;
            padding: 0.25rem 0.5rem 0.5rem;
        }

        .conv-empty {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 2rem 1rem;
            text-align: center;
        }

        .conv-group-label {
            font-size: 0.7rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.05em;
            color: var(--text-muted);
            padding: 0.75rem 0.5rem 0.35rem;
        }

        .conv-item {
            padding: 0.6rem 0.75rem;
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: background 0.15s;
            border: 1px solid transparent;
            margin-bottom: 0.15rem;
            position: relative;
        }

        .conv-item:hover {
            background: var(--bg-panel);
        }

        .conv-item.active {
            background: rgba(99, 102, 241, 0.08);
            border-color: rgba(99, 102, 241, 0.25);
        }

        .conv-item__title {
            font-size: 0.85rem;
            font-weight: 500;
            color: var(--text-main);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            padding-right: 2.5rem;
        }

        .conv-item__meta {
            display: flex;
            gap: 0.5rem;
            font-size: 0.72rem;
            color: var(--text-muted);
            margin-top: 0.15rem;
        }

        .conv-item__actions {
            position: absolute;
            right: 0.4rem;
            top: 50%;
            transform: translateY(-50%);
            display: flex;
            gap: 0.1rem;
            opacity: 0;
            transition: opacity 0.15s;
        }

        .conv-item:hover .conv-item__actions {
            opacity: 1;
        }

        .conv-item__action-btn {
            background: none;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            padding: 0.25rem;
            font-size: 0.8rem;
            border-radius: 4px;
            transition: color 0.15s, background 0.15s;
            display: grid;
            place-items: center;
        }

        .conv-item__action-btn:hover {
            color: var(--brand-primary);
            background: rgba(99, 102, 241, 0.1);
        }

        .conv-item__action-btn--danger:hover {
            color: var(--danger);
            background: rgba(239, 68, 68, 0.1);
        }

        .conv-item__rename-input {
            width: 100%;
            font-size: 0.85rem;
            font-weight: 500;
            color: var(--text-main);
            background: var(--bg-input);
            border: 1px solid var(--brand-primary);
            border-radius: 6px;
            padding: 0.2rem 0.4rem;
            outline: none;
        }

        [data-theme="light"] .conv-sidebar {
            background: rgba(255, 255, 255, 0.95);
        }

        [data-theme="light"] .conv-item:hover {
            background: rgba(0, 0, 0, 0.03);
        }

        [data-theme="light"] .conv-item.active {
            background: rgba(99, 102, 241, 0.06);
            border-color: rgba(99, 102, 241, 0.2);
        }

        @media (max-width: 768px) {
            .conv-sidebar {
                display: none;
            }
            .conv-sidebar.mobile-open {
                display: flex;
                position: fixed;
                top: 0;
                left: 0;
                bottom: 0;
                width: 85vw;
                max-width: 320px;
                z-index: 100;
                border-radius: 0;
            }
        }

/* Autocomplete dropdown */
.autocomplete-dropdown {
    position: absolute; top: 100%; left: 0; right: 0; z-index: 10;
    background: var(--bg-card); border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md); max-height: 200px; overflow-y: auto;
    box-shadow: var(--glass-shadow);
}
.autocomplete-item {
    padding: 0.6rem 0.85rem; cursor: pointer; font-size: 0.85rem;
    transition: background 0.15s;
}
.autocomplete-item:hover { background: rgba(99, 102, 241, 0.08); }

/* Column pill checkbox */
.col-pill {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.3rem 0.65rem; border-radius: 999px;
    border: 1px solid var(--border-subtle); font-size: 0.82rem;
    cursor: pointer; background: var(--bg-input); transition: all 0.15s;
}
.col-pill:hover { border-color: var(--brand-primary); }
.col-pill.pii {
    border-color: rgba(244, 63, 94, 0.35);
    background: rgba(244, 63, 94, 0.08);
}
.col-pill.masked {
    border-color: rgba(245, 158, 11, 0.35);
    background: rgba(245, 158, 11, 0.08);
}
.col-pill input[type="checkbox"] { accent-color: var(--brand-primary); }
.col-pill.masked input[type="checkbox"] { accent-color: var(--warning); }

/* ===================================================================
   IAM REDESIGN — Permissions, IAM Management, Data Policies
   =================================================================== */

/* --- Animations --- */
@keyframes fadeSlideUp {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* --- Permissions Hero --- */
.perm-hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    flex-wrap: wrap;
}
.perm-hero-avatar {
    width: 48px; height: 48px;
    border-radius: 14px;
    display: grid; place-items: center;
    font-size: 1.25rem; font-weight: 700;
    color: #fff;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--brand-primary), #818cf8);
}
.perm-hero-avatar.role-owner {
    background: linear-gradient(135deg, #f59e0b, #d97706);
}
.perm-hero-avatar.role-admin {
    background: linear-gradient(135deg, #a855f7, #7c3aed);
}
.perm-hero-avatar.role-analyst {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
}
.perm-hero-avatar.role-viewer {
    background: linear-gradient(135deg, #6b7280, #4b5563);
}
.perm-hero-info {
    flex: 1; min-width: 200px;
}
.perm-hero-name {
    font-size: 1.15rem; font-weight: 700; margin: 0;
}
.perm-hero-detail {
    font-size: 0.85rem; color: var(--text-secondary); margin: 0.15rem 0 0;
}
.perm-hero-roles {
    display: flex; gap: 0.4rem; flex-wrap: wrap; margin-top: 0.35rem;
}

/* --- Permission Action Chips --- */
.perm-action-chip {
    display: inline-flex; align-items: center; gap: 0.3rem;
    padding: 0.2rem 0.6rem; border-radius: 999px;
    font-size: 0.78rem; font-weight: 500;
    border: 1px solid var(--border-subtle);
    background: rgba(100, 116, 139, 0.08);
    color: var(--text-secondary);
}
.perm-action-chip.read {
    background: rgba(100, 116, 139, 0.1);
    border-color: rgba(100, 116, 139, 0.25);
    color: var(--text-secondary);
}
.perm-action-chip.write {
    background: rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.3);
    color: var(--brand-primary);
}
.perm-action-chip.danger {
    background: rgba(244, 63, 94, 0.08);
    border-color: rgba(244, 63, 94, 0.25);
    color: var(--danger);
}

/* --- Permission Resource Card --- */
.perm-resource-card {
    border: 1px solid var(--border-subtle);
    border-radius: 14px;
    padding: 1rem 1.25rem;
    background: rgba(15, 23, 42, 0.3);
    animation: fadeSlideUp 0.2s ease;
}
[data-theme="light"] .perm-resource-card {
    background: rgba(255, 255, 255, 0.6);
}
.perm-resource-header {
    display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.6rem;
}
.perm-resource-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    display: grid; place-items: center;
    font-size: 1rem;
    background: rgba(99, 102, 241, 0.1);
    color: var(--brand-primary);
    border: 1px solid rgba(99, 102, 241, 0.2);
}
.perm-resource-name {
    font-size: 0.92rem; font-weight: 600; margin: 0;
}
.perm-resource-count {
    margin-left: auto;
    font-size: 0.78rem; color: var(--text-secondary);
    background: rgba(99, 102, 241, 0.08);
    padding: 0.15rem 0.5rem; border-radius: 999px;
}
.perm-resource-actions {
    display: flex; flex-wrap: wrap; gap: 0.35rem;
}

/* --- Permission Limits --- */
.perm-limit-card {
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 0.85rem 1rem;
    display: flex; align-items: center; gap: 0.65rem;
    background: rgba(15, 23, 42, 0.25);
}
[data-theme="light"] .perm-limit-card {
    background: rgba(255, 255, 255, 0.5);
}
.perm-limit-card.allowed {
    border-left: 3px solid var(--success);
}
.perm-limit-card.blocked {
    border-left: 3px solid var(--warning);
}
.perm-limit-icon {
    font-size: 1.15rem; color: var(--text-secondary);
}
.perm-limit-label {
    font-size: 0.82rem; color: var(--text-secondary);
}
.perm-limit-value {
    font-size: 0.95rem; font-weight: 600;
}

/* --- Empty state hero --- */
.perm-empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--text-secondary);
}
.perm-empty-state i {
    font-size: 3.5rem; opacity: 0.2; display: block; margin-bottom: 1rem;
}
.perm-empty-state h3 {
    color: var(--text-main); margin: 0 0 0.5rem; font-size: 1.1rem;
}
.perm-empty-state p {
    font-size: 0.88rem; max-width: 440px; margin: 0 auto 1.25rem;
}

/* --- Sticky Tabs --- */
.iam-tabs-sticky {
    position: sticky;
    top: 0;
    z-index: 10;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg, 16px);
    padding: 0.6rem 1rem;
    margin-bottom: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
[data-theme="light"] .iam-tabs-sticky {
    background: rgba(255, 255, 255, 0.95);
}

/* --- IAM Role Cards (for roles tab) --- */
.iam-roles-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
    gap: 1rem;
}
.iam-role-card {
    display: flex; flex-direction: column; gap: 0.75rem;
    padding: 1.25rem;
    border-radius: 16px;
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.4);
    animation: fadeSlideUp 0.2s ease;
    transition: border-color 0.2s;
}
[data-theme="light"] .iam-role-card {
    background: rgba(255, 255, 255, 0.7);
}
.iam-role-card:hover {
    border-color: rgba(99, 102, 241, 0.35);
}
.iam-role-card.system {
    border-color: rgba(245, 158, 11, 0.25);
}
.iam-role-card.custom {
    border-color: rgba(99, 102, 241, 0.25);
}
.iam-role-card-header {
    display: flex; justify-content: space-between; align-items: flex-start; gap: 0.75rem;
}
.iam-role-card-header .metadata-badge {
    white-space: nowrap; flex-shrink: 0;
}
.iam-role-card-name {
    font-size: 1rem; font-weight: 700; margin: 0;
}
.iam-role-card-desc {
    font-size: 0.82rem; color: var(--text-secondary); margin: 0;
}
.iam-role-card-perms {
    display: flex; flex-wrap: wrap; gap: 0.3rem;
}
.iam-role-card-actions {
    display: flex; gap: 0.35rem; margin-top: auto;
}

/* --- IAM Policy Visual Cards --- */
.iam-policy-cards-grid {
    display: flex; flex-direction: column; gap: 0.75rem;
}
.iam-policy-visual-card {
    border: 1px solid var(--border-subtle);
    border-radius: 14px;
    padding: 1.15rem 1.25rem;
    background: rgba(15, 23, 42, 0.3);
    animation: fadeSlideUp 0.2s ease;
}
[data-theme="light"] .iam-policy-visual-card {
    background: rgba(255, 255, 255, 0.6);
}
.iam-policy-visual-header {
    display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.85rem;
    flex-wrap: wrap;
}
.iam-policy-field-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.65rem;
}
.iam-policy-field {
    display: flex; align-items: center; gap: 0.5rem;
    padding: 0.55rem 0.75rem;
    border-radius: 10px;
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.2);
    font-size: 0.85rem;
}
[data-theme="light"] .iam-policy-field {
    background: rgba(0, 0, 0, 0.02);
}
.iam-policy-field i {
    font-size: 1rem; color: var(--text-secondary);
}
.iam-policy-field-label {
    font-size: 0.75rem; color: var(--text-secondary);
}
.iam-policy-field-value {
    font-weight: 600; font-size: 0.85rem;
}
.iam-policy-visual-footer {
    display: flex; gap: 0.35rem; margin-top: 0.85rem; justify-content: flex-end;
}

/* --- IAM Channel Group Accordion --- */
.iam-channel-group {
    border: 1px solid var(--border-subtle);
    border-radius: 14px;
    margin-bottom: 0.75rem;
    overflow: hidden;
}
.iam-channel-group summary {
    padding: 0.85rem 1.15rem;
    cursor: pointer;
    display: flex; align-items: center; gap: 0.6rem;
    font-weight: 600; font-size: 0.92rem;
    background: rgba(15, 23, 42, 0.2);
    border-bottom: 1px solid transparent;
}
[data-theme="light"] .iam-channel-group summary {
    background: rgba(0, 0, 0, 0.02);
}
.iam-channel-group[open] summary {
    border-bottom-color: var(--border-subtle);
}
.iam-channel-group-content {
    padding: 0.75rem 1.15rem;
    display: flex; flex-direction: column; gap: 0.65rem;
}

/* --- IAM User Cell improved --- */
.iam-user-cell-v2 {
    display: flex; align-items: center; gap: 0.6rem;
}
.iam-user-cell-v2 .iam-avatar {
    width: 32px; height: 32px; font-size: 0.75rem;
}

/* --- WhatsApp Chips (IAM Modal) --- */
.wa-chips-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    min-height: 32px;
    align-items: center;
}
.wa-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: rgba(37, 211, 102, 0.12);
    color: var(--text-main);
    border: 1px solid rgba(37, 211, 102, 0.3);
    border-radius: 20px;
    padding: 0.25rem 0.6rem;
    font-size: 0.82rem;
    font-family: monospace;
}
.wa-chip-remove {
    background: none;
    border: none;
    color: var(--danger);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    padding: 0 0.15rem;
    font-weight: 700;
}
.wa-chip-remove:hover {
    color: #e11d48;
}

/* --- Semantic Role Badges (colored) --- */
.semantic-role-badge {
    display: inline-flex; align-items: center; gap: 0.25rem;
    padding: 0.2rem 0.6rem; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.03em;
}
.semantic-role-badge.owner {
    background: rgba(245, 158, 11, 0.12); color: #f59e0b;
    border: 1px solid rgba(245, 158, 11, 0.3);
}
.semantic-role-badge.admin {
    background: rgba(168, 85, 247, 0.12); color: #a855f7;
    border: 1px solid rgba(168, 85, 247, 0.3);
}
.semantic-role-badge.analyst {
    background: rgba(59, 130, 246, 0.12); color: #3b82f6;
    border: 1px solid rgba(59, 130, 246, 0.3);
}
.semantic-role-badge.whatsapp_ops {
    background: rgba(34, 197, 94, 0.12); color: #22c55e;
    border: 1px solid rgba(34, 197, 94, 0.3);
}
.semantic-role-badge.viewer {
    background: rgba(100, 116, 139, 0.12); color: #94a3b8;
    border: 1px solid rgba(100, 116, 139, 0.3);
}
.semantic-role-badge.user {
    background: rgba(99, 102, 241, 0.1); color: var(--brand-primary);
    border: 1px solid rgba(99, 102, 241, 0.25);
}

/* --- Audit action badges --- */
.audit-action-badge {
    display: inline-flex; align-items: center; gap: 0.3rem;
    padding: 0.2rem 0.55rem; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600;
}
.audit-action-badge.create {
    background: rgba(34, 197, 94, 0.1); color: var(--success);
    border: 1px solid rgba(34, 197, 94, 0.25);
}
.audit-action-badge.update {
    background: rgba(59, 130, 246, 0.1); color: #3b82f6;
    border: 1px solid rgba(59, 130, 246, 0.25);
}
.audit-action-badge.delete {
    background: rgba(239, 68, 68, 0.1); color: var(--danger);
    border: 1px solid rgba(239, 68, 68, 0.25);
}
.audit-action-badge.accept {
    background: rgba(6, 182, 212, 0.1); color: #06b6d4;
    border: 1px solid rgba(6, 182, 212, 0.25);
}

/* --- Assignment Cards --- */
.iam-assignment-card {
    display: flex; align-items: center; gap: 0.75rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.2);
    animation: fadeSlideUp 0.2s ease;
    flex-wrap: wrap;
}
[data-theme="light"] .iam-assignment-card {
    background: rgba(255, 255, 255, 0.5);
}
.iam-assignment-arrow {
    color: var(--text-muted); font-size: 1.1rem;
}

/* --- Data Access Policy Cards --- */
/* ── Data Policy Tabs ── */
.dap-tabs-bar {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--border-subtle);
}
.dap-tab {
    padding: 0.65rem 1.2rem;
    border: none;
    background: none;
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    transition: color 0.2s, border-color 0.2s;
}
.dap-tab:hover { color: var(--text-main); }
.dap-tab.active {
    color: var(--brand-primary);
    border-bottom-color: var(--brand-primary);
    font-weight: 600;
}

/* ── Policy Cards (Table view) ── */
.dap-policy-card {
    display: flex;
    gap: 0.85rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--border-subtle);
    transition: background 0.15s;
}
.dap-policy-card:last-child { border-bottom: none; }
.dap-policy-card:hover { background: var(--bg-hover, rgba(99,102,241,0.03)); border-radius: 8px; }

.dap-policy-card__indicator {
    width: 4px;
    border-radius: 4px;
    flex-shrink: 0;
    min-height: 100%;
}
.dap-policy-card__body { flex: 1; min-width: 0; }
.dap-policy-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}
.dap-policy-card__title-row {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    min-width: 0;
    flex-wrap: wrap;
}
.dap-policy-card__name {
    font-size: 0.9rem;
    color: var(--text-main);
}
.dap-policy-card__sep {
    color: var(--text-muted);
    font-size: 0.8rem;
}
.dap-policy-card__table {
    font-size: 0.88rem;
    font-family: monospace;
    color: var(--text-main);
}
.dap-policy-card__status {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-style: italic;
}
.dap-policy-card__summary {
    margin: 0.25rem 0 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
    line-height: 1.4;
}
.dap-policy-card__desc {
    margin: 0.15rem 0 0;
    font-size: 0.78rem;
    color: var(--text-muted);
    font-style: italic;
}
.dap-policy-card__actions {
    display: flex;
    gap: 0.2rem;
    flex-shrink: 0;
}

/* ── By-Role view ── */
.dap-role-group {
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 0.75rem;
}
.dap-role-group__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem 1rem;
    cursor: pointer;
    transition: background 0.15s;
    gap: 0.75rem;
}
.dap-role-group__header:hover { background: var(--bg-hover, rgba(99,102,241,0.03)); }
.dap-role-group__left {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}
.dap-role-group__meta {
    font-size: 0.82rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.dap-role-group__caret {
    font-size: 0.75rem;
    color: var(--text-secondary);
    transition: transform 0.2s;
}
.dap-role-group[open] .dap-role-group__caret { transform: rotate(90deg); }
.dap-role-group__body {
    padding: 0 1rem 0.85rem;
    border-top: 1px solid var(--border-subtle);
    display: flex;
    flex-direction: column;
    gap: 0;
}
.dap-role-group__badge-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ── Matrix view ── */
.dap-matrix-wrap {
    overflow-x: auto;
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
}
.dap-matrix-wrap table {
    width: 100%;
    border-collapse: collapse;
}
.dap-matrix-wrap th {
    padding: 0.65rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-subtle);
    background: var(--bg-body, rgba(0,0,0,0.02));
}
.dap-matrix-wrap td {
    padding: 0.4rem;
    text-align: center;
    border-bottom: 1px solid var(--border-subtle);
}
.dap-matrix-wrap tr:last-child td { border-bottom: none; }
.dap-matrix-wrap td:first-child {
    text-align: left;
    padding-left: 1rem;
    font-weight: 500;
    font-size: 0.85rem;
}
.dap-matrix-cell {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s;
    font-size: 1.1rem;
}
.dap-matrix-cell:hover { transform: scale(1.1); }
.dap-matrix-cell.full { background: rgba(34,197,94,0.12); color: var(--success); }
.dap-matrix-cell.filtered { background: rgba(99,102,241,0.12); color: var(--primary,#6366f1); }
.dap-matrix-cell.masked-cell { background: rgba(245,158,11,0.12); color: var(--warning); }
.dap-matrix-cell.denied-cell { background: rgba(239,68,68,0.1); color: var(--danger); }
.dap-matrix-cell.create {
    background: none;
    border: 1px dashed var(--border-subtle);
    color: var(--text-muted);
    opacity: 0.4;
}
.dap-matrix-cell.create:hover { opacity: 1; border-color: var(--primary,#6366f1); color: var(--primary,#6366f1); transform: scale(1.1); }

.dap-matrix-legend {
    display: flex; gap: 1rem; font-size: 0.78rem;
    color: var(--text-secondary); margin-bottom: 0.75rem;
    flex-wrap: wrap;
    padding: 0.5rem 0.75rem;
    background: var(--bg-body, rgba(0,0,0,0.02));
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
}
.dap-matrix-legend span {
    display: inline-flex; align-items: center; gap: 0.3rem;
}

/* --- Data Policy Form components --- */
.dap-form-card {
    margin-bottom: 1.25rem;
}
.dap-col-mode-group {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
}
.dap-col-mode-option {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-card);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    font-size: 0.85rem;
}
.dap-col-mode-option:hover {
    border-color: var(--primary, #6366f1);
}
.dap-col-mode-option input[type="radio"] {
    accent-color: var(--primary, #6366f1);
}
.dap-col-mode-option:has(input:checked) {
    border-color: var(--primary, #6366f1);
    background: rgba(99, 102, 241, 0.06);
}
.dap-col-mode-label {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-weight: 500;
}
.dap-pills-area {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-height: 2rem;
}
.dap-rls-row {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}
.dap-rls-prefix {
    padding: 0.5rem 0.5rem;
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 600;
    flex-shrink: 0;
    background: var(--bg-body, rgba(0,0,0,0.02));
    border-radius: 6px;
}
.dap-filter-feedback {
    font-size: 0.78rem;
    margin-top: 0.3rem;
    display: block;
}

/* --- IAM Status Badges --- */
.status-badge {
    display: inline-flex; align-items: center; gap: 0.3rem;
    padding: 0.2rem 0.55rem; border-radius: 999px;
    font-size: 0.75rem; font-weight: 600;
}
.status-badge.active {
    background: rgba(34, 197, 94, 0.1); color: var(--success);
    border: 1px solid rgba(34, 197, 94, 0.25);
}
.status-badge.pending {
    background: rgba(245, 158, 11, 0.1); color: var(--warning);
    border: 1px solid rgba(245, 158, 11, 0.25);
}
.status-badge.disabled {
    background: rgba(239, 68, 68, 0.08); color: var(--danger);
    border: 1px solid rgba(239, 68, 68, 0.2);
}

/* --- Responsive for new IAM components --- */
@media (max-width: 768px) {
    .perm-hero { flex-direction: column; text-align: center; }
    .perm-hero-roles { justify-content: center; }
    .iam-roles-grid { grid-template-columns: 1fr; }
    .iam-policy-field-grid { grid-template-columns: 1fr 1fr; }
    .dap-matrix-cell { min-width: 70px; min-height: 44px; font-size: 0.95rem; }
    .iam-tabs-sticky { padding: 0.5rem 0; }
}

/* ── Insights V2 ── */
.insights-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid var(--border-subtle);
}
.insights-tab {
    padding: 0.65rem 1.2rem;
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: color 0.2s, border-color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}
.insights-tab:hover { color: var(--text-main); }
.insights-tab.active { color: var(--brand-primary); border-bottom-color: var(--brand-primary); }

.insights-pane { display: none; }
.insights-pane.active { display: block; }

.insights-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1rem;
}
.insights-card {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    padding: 1rem 1.15rem;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}
.insights-card:hover {
    border-color: var(--brand-primary);
    box-shadow: 0 4px 16px rgba(99, 102, 241, 0.08);
}
.insights-card.expanded {
    border-color: var(--brand-primary);
    box-shadow: 0 4px 20px rgba(99, 102, 241, 0.15);
}

.insights-card__header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8rem;
}
.insights-card__severity {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.insights-card__severity--critical { background: var(--danger); }
.insights-card__severity--high { background: #f97316; }
.insights-card__severity--medium { background: var(--warning); }
.insights-card__severity--low { background: var(--brand-primary); }
.insights-card__severity--info { background: var(--text-muted); }

.insights-card__category {
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}
.insights-card__score {
    margin-left: auto;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    background: var(--bg-deep);
    padding: 0.15rem 0.45rem;
    border-radius: 6px;
}
.insights-card__title {
    font-weight: 600;
    font-size: 0.92rem;
    line-height: 1.35;
    color: var(--text-main);
}
.insights-card__body {
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.insights-card__sparkline {
    height: 48px;
    width: 100%;
}
.insights-card__footer {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--text-muted);
}

.insights-filters {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
    margin-bottom: 1rem;
}
.insights-filter-field {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}
.insights-filter-field__label {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    padding-left: 0.1rem;
}
.insights-filter-field__wrapper {
    position: relative;
    display: flex;
    align-items: center;
}
.insights-filter-field__icon {
    position: absolute;
    left: 0.65rem;
    font-size: 0.9rem;
    color: var(--text-secondary);
    pointer-events: none;
    z-index: 1;
}
.insights-filter-field__select {
    width: 100%;
    padding: 0.5rem 2rem 0.5rem 2.1rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-main);
    font-size: 0.85rem;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.insights-filter-field__select:focus {
    outline: none;
    border-color: var(--primary, #6366f1);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.insights-filter-field__select:hover {
    border-color: var(--primary, #6366f1);
}

/* ── Searchable Select Component ── */
.searchable-select {
    position: relative;
    width: 100%;
}
.searchable-select__input {
    width: 100%;
    padding: 0.5rem 2rem 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-main);
    font-size: 0.85rem;
    box-sizing: border-box;
    transition: border-color 0.2s;
}
.searchable-select__input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.searchable-select__input:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
.searchable-select__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    max-height: 220px;
    overflow-y: auto;
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    z-index: 50;
}
.searchable-select__dropdown.open {
    display: block;
}
.searchable-select__option {
    padding: 0.45rem 0.75rem;
    font-size: 0.85rem;
    color: var(--text-main);
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.searchable-select__option:hover,
.searchable-select__option.active {
    background: var(--bg-hover, rgba(99, 102, 241, 0.08));
}
.searchable-select__option--highlight {
    font-weight: 600;
}
.searchable-select__option--empty {
    color: var(--text-secondary);
    font-style: italic;
    cursor: default;
}

.insights-config-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: var(--bg-card);
    margin-bottom: 0.5rem;
}
.insights-config-row__name {
    font-weight: 500;
    flex: 1;
}
.insights-config-row__meta {
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.insights-config-row__actions {
    display: flex;
    gap: 0.35rem;
}

/* ── Configs Pagination ── */
.configs-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 0.25rem 0;
    margin-top: 0.5rem;
    border-top: 1px solid var(--border-subtle);
}
.configs-pagination__info {
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.configs-pagination__controls {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}
.configs-pagination__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 0.4rem;
    border: 1px solid var(--border-subtle);
    border-radius: 6px;
    background: var(--bg-card);
    color: var(--text-main);
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.15s;
}
.configs-pagination__btn:hover:not(:disabled):not(.active) {
    border-color: var(--primary, #6366f1);
    color: var(--primary, #6366f1);
    background: rgba(99, 102, 241, 0.06);
}
.configs-pagination__btn.active {
    background: var(--primary, #6366f1);
    color: white;
    border-color: var(--primary, #6366f1);
    font-weight: 600;
}
.configs-pagination__btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}
.configs-pagination__ellipsis {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 32px;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

/* ── Config Form (Add/Edit Table) ── */
.config-form__header {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-subtle);
}
.config-form__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(16,185,129,0.15), rgba(6,182,212,0.15));
    color: var(--success, #10b981);
    font-size: 1.2rem;
    flex-shrink: 0;
}
.config-form__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
}
.config-form__subtitle {
    margin: 0.2rem 0 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.config-form__section {
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    margin: 0 0 1rem;
    background: var(--bg-body, rgba(0,0,0,0.02));
}
.config-form__legend {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    padding: 0 0.35rem;
}
.config-form__grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.config-form__grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.config-form__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.config-form__label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-secondary);
}
.config-form__input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-main);
    font-size: 0.85rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}
.config-form__input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.config-form__metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-height: 2rem;
}
.config-form__footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding-top: 0.5rem;
}

/* ── Domain Picker ── */
.domain-picker {
    position: relative;
    width: 100%;
}
.domain-picker__selected {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-main);
    font-size: 0.85rem;
    cursor: pointer;
    transition: border-color 0.2s;
}
.domain-picker__selected:hover {
    border-color: var(--primary, #6366f1);
}
.domain-picker__selected span {
    flex: 1;
}
.domain-picker__caret {
    font-size: 0.75rem;
    color: var(--text-secondary);
    transition: transform 0.2s;
}
.domain-picker.open .domain-picker__caret {
    transform: rotate(180deg);
}
.domain-picker__dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    z-index: 50;
    overflow: hidden;
}
.domain-picker__search-box {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-secondary);
}
.domain-picker__search-box i { font-size: 0.9rem; flex-shrink: 0; }
.domain-picker__search {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--text-main);
    font-size: 0.85rem;
    outline: none;
}
.domain-picker__list {
    max-height: 240px;
    overflow-y: auto;
    padding: 0.35rem 0;
}
.domain-picker__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background 0.15s;
    font-size: 0.85rem;
}
.domain-picker__item:hover {
    background: var(--bg-hover, rgba(99, 102, 241, 0.08));
}
.domain-picker__item.active {
    background: rgba(99, 102, 241, 0.1);
    font-weight: 600;
}
.domain-picker__item-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    font-size: 0.85rem;
    flex-shrink: 0;
}
.domain-picker__item-info {
    flex: 1;
    min-width: 0;
}
.domain-picker__item-name {
    font-weight: 500;
    color: var(--text-main);
}
.domain-picker__item-desc {
    font-size: 0.75rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.domain-picker__item-badge {
    font-size: 0.65rem;
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    background: rgba(99, 102, 241, 0.1);
    color: var(--primary, #6366f1);
    font-weight: 600;
    text-transform: uppercase;
    flex-shrink: 0;
}
.domain-picker__section-label {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    padding: 0.5rem 0.75rem 0.25rem;
}
.domain-picker__create {
    border-top: 1px solid var(--border-subtle);
    padding: 0.35rem;
}
.domain-picker__create-btn {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    width: 100%;
    padding: 0.5rem 0.65rem;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--primary, #6366f1);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s;
}
.domain-picker__create-btn:hover {
    background: rgba(99, 102, 241, 0.08);
}

/* Phase 8/9 — Ask insights input */
.insights-ask__answer { white-space: pre-wrap; line-height: 1.6; }

/* Phase 8 — Health badge */
.health-badge { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.15rem 0.5rem; border-radius: 4px; font-size: 0.75rem; font-weight: 600; color: white; }

/* Phase 8 — Goal progress */
.goal-progress { margin-top: 0.5rem; }
.goal-progress__bar { height: 8px; border-radius: 6px; transition: width 0.3s; }

/* Phase 8 — Create alert button in drilldown */
.insights-drilldown__actions { margin-top: 1rem; padding-top: 0.75rem; border-top: 1px solid var(--border-subtle); }

/* ── Notification Preferences ── */
.notif-prefs__header {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-subtle);
}
.notif-prefs__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(99,102,241,0.15), rgba(139,92,246,0.15));
    color: var(--brand-primary);
    font-size: 1.2rem;
    flex-shrink: 0;
}
.notif-prefs__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
}
.notif-prefs__subtitle {
    margin: 0.2rem 0 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.notif-prefs__form {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}
.notif-prefs__section {
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    margin: 0;
    background: var(--bg-body, rgba(0,0,0,0.02));
}
.notif-prefs__legend {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-secondary);
    padding: 0 0.35rem;
}
.notif-prefs__grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.notif-prefs__grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}
.notif-prefs__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.notif-prefs__label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-secondary);
}
.notif-prefs__select {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-main);
    font-size: 0.85rem;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.notif-prefs__select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

/* Toggle switches */
.notif-prefs__toggle {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.65rem 0.85rem;
    border-radius: 8px;
    border: 1px solid var(--border-subtle);
    background: var(--bg-card);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    position: relative;
}
.notif-prefs__toggle:hover {
    border-color: var(--primary, #6366f1);
}
.notif-prefs__toggle input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.notif-prefs__toggle-track {
    width: 36px;
    height: 20px;
    border-radius: 12px;
    background: var(--border-subtle, #d1d5db);
    flex-shrink: 0;
    position: relative;
    transition: background 0.25s;
}
.notif-prefs__toggle-track::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: white;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
    transition: transform 0.25s;
}
.notif-prefs__toggle input:checked ~ .notif-prefs__toggle-track {
    background: var(--brand-primary, #6366f1);
}
.notif-prefs__toggle input:checked ~ .notif-prefs__toggle-track::after {
    transform: translateX(16px);
}
.notif-prefs__toggle-content {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-main);
}
.notif-prefs__footer {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding-top: 0.5rem;
}

/* ── History Timeline ── */
.history-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-subtle);
}
.history-header__left {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}
.history-header__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(99,102,241,0.15), rgba(168,85,247,0.15));
    color: var(--primary, #6366f1);
    font-size: 1.2rem;
    flex-shrink: 0;
}
.history-header__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
}
.history-header__subtitle {
    margin: 0.2rem 0 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
}
.history-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.history-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 2.5rem 1rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}
.history-empty p { margin: 0; }
.history-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 2rem;
    color: var(--text-secondary);
    font-size: 0.9rem;
}
@keyframes history-spin { to { transform: rotate(360deg); } }
.history-spin { animation: history-spin 1s linear infinite; }

.history-run {
    display: flex;
    gap: 0.85rem;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--border-subtle);
    transition: background 0.15s;
}
.history-run:last-child { border-bottom: none; }
.history-run:hover { background: var(--bg-hover, rgba(99,102,241,0.03)); border-radius: 8px; }

.history-run__indicator {
    width: 4px;
    border-radius: 4px;
    flex-shrink: 0;
    min-height: 100%;
}
.history-run__content {
    flex: 1;
    min-width: 0;
}
.history-run__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}
.history-run__badges {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}
.history-run__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.55rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
}
.history-run__badge--neutral {
    background: var(--bg-body, rgba(107,114,128,0.08));
    color: var(--text-secondary);
}
.history-run__time {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.78rem;
    color: var(--text-secondary);
    flex-shrink: 0;
    white-space: nowrap;
}
.history-run__summary {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
    color: var(--text-secondary);
    line-height: 1.4;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.history-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 0.25rem 0;
    margin-top: 0.5rem;
    border-top: 1px solid var(--border-subtle);
}

@media (max-width: 768px) {
    .insights-cards-grid { grid-template-columns: 1fr; }
    .insights-filters { grid-template-columns: 1fr; }
    .insights-config-row { flex-wrap: wrap; }
    .insights-config-row__meta { width: 100%; }
    .insights-ask { flex-direction: column; }
    .notif-prefs__grid-2 { grid-template-columns: 1fr; }
    .notif-prefs__grid-3 { grid-template-columns: 1fr; }
    .config-form__grid-2 { grid-template-columns: 1fr; }
    .config-form__grid-3 { grid-template-columns: 1fr; }
    .history-run__top { flex-direction: column; align-items: flex-start; }
}

/* ── Insights Drill-Down Tabs (V3) ── */
.insights-drilldown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.insights-drilldown-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:1rem}
.insights-drilldown-tab{background:none;border:none;color:var(--text-secondary);padding:.5rem 1rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-size:.9rem}
.insights-drilldown-tab:hover{color:var(--text-primary)}
.insights-drilldown-tab.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}
.insights-dd-pane{display:none;animation:ddFadeIn .2s ease}
.insights-dd-pane.active{display:block}
@keyframes ddFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.dd-skeleton{padding:1rem 0}
.skeleton-line{height:1rem;background:rgba(255,255,255,.06);border-radius:4px;margin-bottom:.75rem;animation:ddPulse 1.5s infinite}
.skeleton-line.short{width:60%}
@keyframes ddPulse{0%,100%{opacity:.4}50%{opacity:.8}}
.dd-hypothesis{background:rgba(255,255,255,.04);border-radius:8px;padding:1rem;margin-bottom:.75rem;border-left:3px solid var(--text-secondary)}
.dd-hypothesis[data-plausibility="high"]{border-left-color:var(--success)}
.dd-hypothesis[data-plausibility="medium"]{border-left-color:var(--warning)}
.dd-hypothesis[data-plausibility="low"]{border-left-color:var(--danger)}
.dd-hypothesis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.dd-plausibility-badge{font-size:.75rem;padding:2px 8px;border-radius:12px;font-weight:600}
.dd-plausibility-badge.high{background:rgba(16,185,129,.15);color:var(--success)}
.dd-plausibility-badge.medium{background:rgba(245,158,11,.15);color:var(--warning)}
.dd-plausibility-badge.low{background:rgba(244,63,94,.15);color:var(--danger)}
.dd-confirming{margin-top:.5rem;font-size:.85rem;color:var(--text-secondary)}
.dd-disclaimer{margin-top:1rem;padding:.75rem;background:rgba(255,255,255,.03);border-radius:6px;font-size:.8rem;color:var(--text-secondary);font-style:italic}
.dd-actions-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.dd-action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:.85rem}
.dd-action-btn:hover{background:rgba(99,102,241,.15);border-color:var(--brand-primary)}

/* ── Domain Badge & Knowledge Hints ── */
.dd-domain-badge{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;margin-bottom:1rem;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);border-radius:8px;font-size:.85rem;color:var(--text-primary);flex-wrap:wrap}
.dd-domain-badge i{font-size:1.1rem;color:var(--brand-primary)}
.dd-domain-toggle{background:none;border:none;color:var(--brand-primary);cursor:pointer;font-size:.8rem;padding:0 .3rem;opacity:.7;transition:opacity .2s}
.dd-domain-toggle:hover{opacity:1}
.dd-domain-hints{display:none;width:100%;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}
.dd-domain-hints.open{display:block}
.dd-domain-hints ul{margin:0;padding:0 0 0 1.2rem;font-size:.8rem;color:var(--text-secondary);line-height:1.6}

/* ── Action button states ── */
.dd-action-btn:disabled{opacity:.5;cursor:wait}
.dd-action-btn .ph-spin{animation:ddSpin 1s linear infinite}
@keyframes ddSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── Assistant Drawer ── */
.assistant-fab{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--primary,#6366f1);color:white;border:none;cursor:pointer;z-index:149;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 4px 12px rgba(99,102,241,0.3);transition:transform 0.2s,box-shadow 0.2s}
.assistant-fab:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(99,102,241,0.4)}
.assistant-fab.hidden{display:none}

.assistant-drawer{position:fixed;top:0;right:0;width:380px;height:100vh;background:var(--bg-card);border-left:1px solid var(--border-subtle);z-index:150;display:flex;flex-direction:column;transform:translateX(100%);transition:transform 0.25s ease;box-shadow:-4px 0 24px rgba(0,0,0,0.1)}
.assistant-drawer.open{transform:translateX(0)}

.assistant-drawer__header{display:flex;align-items:center;gap:0.5rem;padding:0.75rem 1rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}
.assistant-drawer__title{display:flex;align-items:center;gap:0.4rem;font-weight:600;font-size:0.95rem;color:var(--text-main)}
.assistant-drawer__badge{margin-left:auto;font-size:0.72rem;padding:0.15rem 0.5rem;border-radius:4px;background:var(--bg-body,rgba(99,102,241,0.08));color:var(--text-secondary);font-weight:500}
.assistant-drawer__close{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:1.1rem;padding:0.25rem}

.assistant-drawer__messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:0.75rem}

/* Bubbles */
.assistant-msg{display:flex;max-width:85%}
.assistant-msg--user{align-self:flex-end}
.assistant-msg--assistant{align-self:flex-start}
.assistant-msg__bubble{padding:0.6rem 0.85rem;border-radius:12px;font-size:0.85rem;line-height:1.5;word-break:break-word}
.assistant-msg--user .assistant-msg__bubble{background:var(--primary,#6366f1);color:white;border-bottom-right-radius:4px}
.assistant-msg--assistant .assistant-msg__bubble{background:var(--bg-body,#f1f5f9);border:1px solid var(--border-subtle);color:var(--text-main);border-bottom-left-radius:4px}
.assistant-msg--assistant .assistant-msg__bubble p{margin:0 0 0.5rem}
.assistant-msg--assistant .assistant-msg__bubble p:last-child{margin-bottom:0}
.assistant-msg--assistant .assistant-msg__bubble strong{color:var(--text-main);font-weight:600}
.assistant-msg--assistant .assistant-msg__bubble .drawer-h2{display:block;font-size:0.9rem;margin:0.6rem 0 0.3rem;color:var(--text-main)}
.assistant-msg--assistant .assistant-msg__bubble .drawer-h3{display:block;font-size:0.85rem;margin:0.5rem 0 0.2rem;color:var(--text-main)}
.assistant-msg--assistant .assistant-msg__bubble ul{margin:0.3rem 0;padding-left:1.2rem}
.assistant-msg--assistant .assistant-msg__bubble li{margin-bottom:0.2rem}
.assistant-msg--assistant .assistant-msg__bubble code{background:rgba(99,102,241,0.08);padding:0.1rem 0.35rem;border-radius:4px;font-size:0.8rem;font-family:monospace}
.assistant-msg--error .assistant-msg__bubble{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);color:var(--danger)}

/* Typing indicator */
.assistant-typing{display:flex;gap:4px;padding:0.6rem 0.85rem}
.assistant-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:assistantBounce 1.4s infinite}
.assistant-typing span:nth-child(2){animation-delay:0.2s}
.assistant-typing span:nth-child(3){animation-delay:0.4s}
@keyframes assistantBounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-6px)}}

/* Suggestions */
.assistant-drawer__suggestions{display:flex;flex-wrap:wrap;gap:0.4rem;padding:0.5rem 1rem;border-top:1px solid var(--border-subtle)}
.assistant-chip{padding:0.3rem 0.65rem;border-radius:16px;border:1px solid var(--border-subtle);background:var(--bg-card);color:var(--text-secondary);font-size:0.78rem;cursor:pointer;transition:border-color 0.15s,color 0.15s;white-space:nowrap}
.assistant-chip:hover{border-color:var(--primary,#6366f1);color:var(--primary,#6366f1)}

/* Input */
.assistant-drawer__input-row{display:flex;gap:0.5rem;padding:0.65rem 1rem 0;align-items:flex-end}
.assistant-drawer__input{flex:1;resize:none;border:1px solid var(--border-subtle);border-radius:8px;padding:0.5rem 0.75rem;background:var(--bg-input);color:var(--text-main);font-size:0.85rem;max-height:100px;overflow-y:auto;font-family:inherit}
.assistant-drawer__input:focus{outline:none;border-color:var(--primary,#6366f1)}
.assistant-drawer__send{width:36px;height:36px;border-radius:8px;border:none;background:var(--primary,#6366f1);color:white;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity 0.15s}
.assistant-drawer__send:disabled{opacity:0.4;cursor:not-allowed}

.assistant-drawer__footer{padding:0.35rem 1rem 0.65rem}
.assistant-drawer__new-conv{background:none;border:none;color:var(--text-muted);font-size:0.78rem;cursor:pointer;padding:0.2rem 0;display:flex;align-items:center;gap:0.3rem}
.assistant-drawer__new-conv:hover{color:var(--text-main)}

/* Action buttons inside bubbles */
.assistant-action-btn{display:flex;align-items:center;gap:0.25rem;margin-top:0.5rem;padding:0.3rem 0.6rem;border-radius:6px;border:1px solid var(--border-subtle);background:var(--bg-card);color:var(--text-secondary);font-size:0.78rem;cursor:pointer;width:fit-content}
.assistant-action-btn:hover{border-color:var(--primary);color:var(--primary)}

/* Backdrop (mobile) */
.assistant-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:148}

/* Welcome state */
.assistant-welcome{text-align:center;padding:2rem 1rem;color:var(--text-secondary)}
.assistant-welcome i{font-size:2rem;color:var(--primary,#6366f1);margin-bottom:0.5rem;display:block}
.assistant-welcome p{margin:0.25rem 0 0;font-size:0.85rem}

@media(max-width:768px){
.assistant-drawer{width:100vw}
.assistant-drawer.open~.assistant-backdrop{display:block}
}

/* ── Insights D4 Visual ── */
.insights-confidence{display:inline-flex;align-items:center;padding:0.15rem 0.45rem;border-radius:4px;font-size:0.7rem;font-weight:600;margin-left:0.35rem}
.confidence--high{background:rgba(16,185,129,0.12);color:var(--success)}
.confidence--mid{background:rgba(245,158,11,0.12);color:var(--warning)}
.confidence--low{background:rgba(239,68,68,0.1);color:var(--danger)}
.insights-method-badge{display:inline-flex;align-items:center;padding:0.15rem 0.45rem;border-radius:4px;font-size:0.65rem;font-weight:500;margin-left:0.25rem;background:rgba(99,102,241,0.08);color:var(--primary,#6366f1)}
.insights-drift-badge{display:inline-flex;align-items:center;padding:0.15rem 0.45rem;border-radius:4px;font-size:0.65rem;font-weight:500;margin-left:0.25rem;background:rgba(245,158,11,0.08);color:var(--warning)}
.insights-card--stale{border-left:3px solid var(--warning) !important}
.insights-card--drift{border-left:3px solid var(--primary,#6366f1) !important}

/* Stat hint tooltip (i) */
.stat-hint{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--bg-body,rgba(99,102,241,0.08));color:var(--text-secondary);font-size:0.65rem;cursor:help;margin-left:0.3rem;position:relative;vertical-align:middle;flex-shrink:0}
.stat-hint:hover{background:var(--primary,#6366f1);color:white}
.stat-hint[title]{position:relative}
.stat-hint::after{content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--bg-card,#1e293b);color:var(--text-main);border:1px solid var(--border-subtle);border-radius:8px;padding:0.45rem 0.65rem;font-size:0.75rem;line-height:1.4;white-space:normal;width:220px;text-align:left;box-shadow:0 4px 12px rgba(0,0,0,0.15);pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:100;font-weight:400}
.stat-hint:hover::after{opacity:1}

/* ── Delivery 5: Intelligent Dashboard ── */

/* Heatmap */
.insights-heatmap{width:100%;border-collapse:collapse;font-size:0.82rem}
.insights-heatmap th{padding:0.5rem 0.65rem;font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.03em;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);background:var(--bg-body,rgba(0,0,0,0.02));white-space:nowrap}
.insights-heatmap td{padding:0.35rem;text-align:center;border-bottom:1px solid var(--border-subtle)}
.insights-heatmap tr:last-child td{border-bottom:none}
.insights-heatmap td:first-child{text-align:left;padding-left:0.75rem;font-weight:500;font-size:0.82rem;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}
.heatmap-cell{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;cursor:pointer;transition:transform 0.15s;font-size:0.75rem;font-weight:600}
.heatmap-cell:hover{transform:scale(1.15)}
.heatmap-cell--none{background:var(--bg-body,rgba(107,114,128,0.05));color:var(--text-muted)}
.heatmap-cell--info{background:rgba(99,102,241,0.08);color:var(--primary,#6366f1)}
.heatmap-cell--low{background:rgba(59,130,246,0.1);color:#3b82f6}
.heatmap-cell--medium{background:rgba(245,158,11,0.12);color:var(--warning)}
.heatmap-cell--high{background:rgba(249,115,22,0.15);color:#f97316}
.heatmap-cell--critical{background:rgba(239,68,68,0.15);color:var(--danger)}

/* Executive */
.insights-executive{line-height:1.7;font-size:0.9rem;color:var(--text-main)}
.insights-executive h2,.insights-executive h3{margin:1.25rem 0 0.5rem;font-size:1rem;font-weight:600;color:var(--text-main)}
.insights-executive h2:first-child,.insights-executive h3:first-child{margin-top:0}
.insights-executive p{margin:0 0 0.75rem}
.insights-executive ul{margin:0.25rem 0 0.75rem;padding-left:1.4rem}
.insights-executive li{margin-bottom:0.3rem}
.insights-executive strong{color:var(--text-main)}
.insights-executive code{background:rgba(99,102,241,0.08);padding:0.1rem 0.3rem;border-radius:4px;font-size:0.82rem}

/* Skeleton loading */
.insights-executive-skeleton{display:flex;flex-direction:column;gap:1.5rem;padding:0.5rem 0}
.skeleton-block{display:flex;flex-direction:column;gap:0.5rem}
.skeleton-title{width:40%;height:18px;border-radius:6px;background:var(--border-subtle);animation:skeletonPulse 1.5s ease infinite}
.skeleton-line{width:100%;height:12px;border-radius:4px;background:var(--border-subtle);animation:skeletonPulse 1.5s ease infinite}
.skeleton-line.short{width:65%}
@keyframes skeletonPulse{0%,100%{opacity:0.4}50%{opacity:0.8}}

/* Health KPI color */
.health-grade-a{color:var(--success) !important}
.health-grade-b{color:#3b82f6 !important}
.health-grade-c{color:var(--warning) !important}
.health-grade-d{color:#f97316 !important}
.health-grade-f{color:var(--danger) !important}

/* ── Delivery 6: Timeline + History + Domain Context ── */
.insights-timeline{display:flex;flex-direction:column;gap:0}
.timeline-date-group{border-left:2px solid var(--border-subtle);padding-left:1rem;margin-bottom:1.25rem;position:relative}
.timeline-date-group::before{content:'';position:absolute;left:-5px;top:0;width:8px;height:8px;border-radius:50%;background:var(--primary,#6366f1)}
.timeline-date-label{font-size:0.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:0.5rem;text-transform:uppercase;letter-spacing:0.03em}
.timeline-item{display:flex;align-items:flex-start;gap:0.65rem;padding:0.45rem 0;cursor:pointer;border-radius:6px;transition:background 0.15s}
.timeline-item:hover{background:var(--bg-hover,rgba(99,102,241,0.03))}
.timeline-item__sev{width:6px;height:6px;border-radius:50%;margin-top:0.45rem;flex-shrink:0}
.timeline-item__sev--critical{background:var(--danger)}
.timeline-item__sev--high{background:#f97316}
.timeline-item__sev--medium{background:var(--warning)}
.timeline-item__sev--low{background:#3b82f6}
.timeline-item__sev--info{background:var(--text-muted)}
.timeline-item__body{flex:1;min-width:0}
.timeline-item__title{font-size:0.82rem;font-weight:500;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.timeline-item__meta{font-size:0.72rem;color:var(--text-secondary)}
.timeline-item__score{font-size:0.75rem;font-weight:600;color:var(--text-secondary);flex-shrink:0}

/* History mini-timeline in drilldown */
.dd-history-item{display:flex;align-items:center;gap:0.5rem;padding:0.35rem 0;border-bottom:1px solid var(--border-subtle);font-size:0.82rem}
.dd-history-item:last-child{border-bottom:none}
.dd-history-item__score{font-weight:600;min-width:28px;text-align:right}
.dd-history-item__date{color:var(--text-secondary);min-width:100px}
.dd-history-item__title{color:var(--text-main);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Domain context form */
.domain-ctx-list{display:flex;flex-direction:column;gap:0.5rem}
.domain-ctx-row{display:flex;gap:0.5rem;align-items:center}
.domain-ctx-row input,.domain-ctx-row .config-form__input{flex:1}
.domain-ctx-row .btn-remove{flex-shrink:0;color:var(--danger);background:none;border:none;cursor:pointer;padding:0.3rem;font-size:1rem}
.domain-ctx-row .btn-remove:hover{opacity:0.7}
.domain-ctx-event-row{display:flex;gap:0.5rem;align-items:center}
.domain-ctx-event-row input:first-child{max-width:130px}

/* Domain list items */
.domain-ctx-item{display:flex;align-items:center;gap:0.65rem;padding:0.65rem 0;border-bottom:1px solid var(--border-subtle);transition:background 0.15s}
.domain-ctx-item:last-child{border-bottom:none}
.domain-ctx-item:hover{background:var(--bg-hover,rgba(99,102,241,0.03));border-radius:6px}
.domain-ctx-item__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--bg-body,rgba(0,0,0,0.02));font-size:1.1rem;flex-shrink:0}
.domain-ctx-item__info{flex:1;min-width:0}
.domain-ctx-item__name{font-weight:500;font-size:0.88rem;color:var(--text-main)}
.domain-ctx-item__meta{display:flex;gap:0.35rem;margin-top:0.15rem}
.domain-ctx-item__badge{font-size:0.65rem;padding:0.1rem 0.4rem;border-radius:4px;font-weight:500}
.domain-ctx-item__badge--system{background:rgba(99,102,241,0.08);color:var(--primary,#6366f1)}
.domain-ctx-item__badge--custom{background:rgba(245,158,11,0.08);color:#f59e0b}

/* ── Delivery 7: Enhanced Descriptions ── */
.enhanced-desc-table{width:100%;border-collapse:collapse;margin-top:0.5rem;font-size:0.82rem}
.enhanced-desc-table th{text-align:left;padding:0.35rem 0.5rem;border-bottom:1px solid var(--border-subtle);font-weight:600;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.03em;color:var(--text-secondary)}
.enhanced-desc-table td{padding:0.3rem 0.5rem;border-bottom:1px solid var(--border-subtle)}
.enhanced-desc-table tr:last-child td{border-bottom:none}
.enhanced-desc-range{margin-top:0.4rem;font-size:0.8rem;color:var(--text-secondary);font-style:italic}

.enhanced-comparison{display:flex;align-items:center;gap:1rem;margin-top:0.75rem;padding:0.75rem;background:var(--bg-body);border-radius:8px;border:1px solid var(--border-subtle)}
.enhanced-comparison__period{text-align:center;flex:1}
.enhanced-comparison__label{font-size:0.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.03em;margin-bottom:0.2rem}
.enhanced-comparison__value{font-size:1.2rem;font-weight:700;color:var(--text-main)}
.enhanced-comparison__sub{font-size:0.7rem;color:var(--text-muted)}
.enhanced-comparison__delta{font-size:1.5rem;font-weight:700;flex-shrink:0}

.enhanced-freshness{display:flex;align-items:center;gap:0.75rem;margin-top:0.5rem;padding:0.75rem;background:var(--bg-body);border-radius:8px;border:1px solid var(--border-subtle)}
.enhanced-freshness__gap{font-size:2rem;font-weight:700;line-height:1}
.enhanced-freshness__gap small{font-size:0.8rem;font-weight:500}
.enhanced-freshness__text{font-size:0.9rem;color:var(--text-secondary)}

/* ── Delivery 7: Run History Enhancements ── */
.history-run{cursor:pointer;transition:background 0.15s}
.history-run:hover{background:var(--bg-hover,rgba(99,102,241,0.03))}
.history-run--expanded{background:var(--bg-hover,rgba(99,102,241,0.03));border-left-width:3px}
.history-run__check{display:flex;align-items:center;margin-right:0.35rem;cursor:pointer}
.history-run__check input{cursor:pointer;accent-color:var(--primary,#6366f1)}
.history-run__detail{padding:0.5rem 0 0.25rem;border-top:1px dashed var(--border-subtle);margin-top:0.5rem}

/* ── Delivery 7: Correlation Matrix Cell Hover ── */
.corr-matrix-cell:hover{outline:2px solid var(--primary,#6366f1);outline-offset:-1px;border-radius:2px}
.corr-edge{transition:opacity 0.15s}
.corr-edge:hover{opacity:1!important;stroke-width:4px!important}

/* ── D7: Enhanced descriptions (anomaly table, comparison card) ── */
.enhanced-desc-table{width:100%;border-collapse:collapse;margin-top:0.5rem;font-size:0.82rem}
.enhanced-desc-table th{text-align:left;padding:0.35rem 0.5rem;border-bottom:1px solid var(--border-subtle);font-weight:600;font-size:0.75rem;text-transform:uppercase;letter-spacing:0.03em;color:var(--text-secondary)}
.enhanced-desc-table td{padding:0.3rem 0.5rem;border-bottom:1px solid var(--border-subtle)}
.enhanced-desc-table tr:last-child td{border-bottom:none}
.enhanced-desc-range{margin-top:0.4rem;font-size:0.8rem;color:var(--text-secondary);font-style:italic}
.enhanced-comparison{display:flex;align-items:center;gap:1rem;margin-top:0.75rem;padding:0.75rem;background:var(--bg-body);border-radius:8px;border:1px solid var(--border-subtle)}
.enhanced-comparison__period{text-align:center;flex:1}
.enhanced-comparison__label{font-size:0.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.03em;margin-bottom:0.2rem}
.enhanced-comparison__value{font-size:1.2rem;font-weight:700;color:var(--text-main)}
.enhanced-comparison__sub{font-size:0.7rem;color:var(--text-muted)}
.enhanced-comparison__delta{font-size:1.5rem;font-weight:700;flex-shrink:0}
