/* ════════════════════════════════════════════════════════════════════════════════
   GENAPA FORGE PORTAL - DESIGN SYSTEM

   Lighthouse-inspired visual identity: Clarity, Trust, Illumination
   "A lighthouse in a sea of agents, helping guide agents towards better outcomes"

   Agent Identity:
   - Oracle (Beacon Blue): Synthesizer, steady guiding beam
   - Seeker (Teal): Expert searcher, sweeps the waters

   CSS MODULAR ARCHITECTURE
   ─────────────────────────────────────────────────────────────────────────────
   This file serves as the entry point, importing all CSS modules:
   - base/_variables.css     → All CSS custom properties
   - base/_typography.css    → Font definitions and text utilities
   - components/_badges.css  → Status, job type, and metric badges
   - components/_radzen-grid.css → Shared Radzen DataGrid theming
   - layouts/_layout.css     → Page layout and navigation
   ════════════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────────
   CSS MODULE IMPORTS
   ───────────────────────────────────────────────────────────────────────────── */
@import 'base/_variables.css';
@import 'base/_typography.css';
@import 'components/_badges.css';
@import 'components/_radzen-grid.css';
@import 'components/_submissions.css';
@import 'layouts/_layout.css';

/* ════════════════════════════════════════════════════════════════════════════════
   FLUENT UI DESIGN SYSTEM INTEGRATION
   ════════════════════════════════════════════════════════════════════════════════ */
fluent-design-system-provider {
    --base-layer-luminance: 0.08;
}

/* ════════════════════════════════════════════════════════════════════════════════
   GLOBAL STYLES
   ════════════════════════════════════════════════════════════════════════════════ */
html,
body {
    margin: 0;
    padding: 0;
    height: 100%;
    overflow-x: hidden;
    background-color: var(--genapa-bg-app);
    color: var(--genapa-text-primary);
    font-family: var(--genapa-font-family);
    font-size: var(--genapa-text-body-size);
    line-height: 1.5;
}

/* ════════════════════════════════════════════════════════════════════════════════
   DASHBOARD CARDS
   ════════════════════════════════════════════════════════════════════════════════ */
.dashboard-card {
    padding: var(--genapa-space-5);
    background: var(--genapa-bg-elevated);
    border: 1px solid var(--genapa-border-subtle);
    border-radius: var(--genapa-radius-lg);
    transition: all var(--genapa-transition-normal);
    min-height: 160px;
    display: flex;
    flex-direction: column;
}

.dashboard-card:hover {
    background: var(--genapa-bg-hover);
    border-color: var(--genapa-accent-primary);
    box-shadow: var(--genapa-glow-blue);
    transform: translateY(-2px);
}

.dashboard-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: var(--genapa-radius-lg);
    background: var(--genapa-badge-blue-bg);
    margin-bottom: var(--genapa-space-3);
}

.dashboard-card__icon--blue {
    background: var(--genapa-badge-blue-bg);
    box-shadow: var(--genapa-glow-blue);
}

.dashboard-card__icon--amber {
    background: var(--genapa-badge-amber-bg);
    box-shadow: var(--genapa-glow-amber);
}

.dashboard-card__title {
    font-size: var(--genapa-text-h3-size);
    font-weight: var(--genapa-weight-semibold);
    color: var(--genapa-text-emphasis);
    margin-bottom: var(--genapa-space-2);
}

.dashboard-card__description {
    font-size: var(--genapa-text-body-size);
    color: var(--genapa-text-secondary);
    flex: 1;
}

.dashboard-card__action {
    margin-top: var(--genapa-space-4);
}

/* ════════════════════════════════════════════════════════════════════════════════
   CARD STYLES (Generic)
   ════════════════════════════════════════════════════════════════════════════════ */
.genapa-card {
    background-color: var(--genapa-bg-card);
    border: 1px solid var(--genapa-border);
    border-radius: var(--genapa-radius-md);
    padding: var(--genapa-space-4);
}

fluent-card {
    --card-background-color: var(--genapa-bg-elevated);
    border: 1px solid var(--genapa-border-subtle);
    border-radius: var(--genapa-radius-lg);
}

/* ════════════════════════════════════════════════════════════════════════════════
   AGENT IDENTITY STYLES
   ════════════════════════════════════════════════════════════════════════════════ */
.agent-oracle {
    --agent-color: var(--genapa-blue-600);
    --agent-glow: var(--genapa-glow-blue);
    --agent-bg: var(--genapa-badge-blue-bg);
}

.agent-seeker {
    --agent-color: var(--genapa-teal-600);
    --agent-glow: var(--genapa-glow-teal);
    --agent-bg: var(--genapa-badge-teal-bg);
}

.agent-indicator {
    width: 8px;
    height: 8px;
    border-radius: var(--genapa-radius-full);
    background: var(--agent-color);
    box-shadow: var(--agent-glow);
    animation: agent-pulse 2s ease-in-out infinite;
}

@keyframes agent-pulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.7;
        transform: scale(1.1);
    }
}

.activity-entry {
    display: flex;
    gap: var(--genapa-space-3);
    padding: var(--genapa-space-3);
    border-left: 3px solid var(--agent-color);
    background: var(--genapa-bg-elevated);
    margin-bottom: var(--genapa-space-2);
    border-radius: 0 var(--genapa-radius-sm) var(--genapa-radius-sm) 0;
}

/* ════════════════════════════════════════════════════════════════════════════════
   DATA GRID STYLING (Fluent)
   ════════════════════════════════════════════════════════════════════════════════ */
fluent-data-grid {
    --data-grid-border-color: var(--genapa-border-subtle);
    --data-grid-row-background: var(--genapa-bg-elevated);
    --data-grid-row-hover-background: var(--genapa-bg-hover);
    --data-grid-header-background: var(--genapa-bg-secondary);
}

.data-grid-container {
    border: 1px solid var(--genapa-border-subtle);
    border-radius: var(--genapa-radius-lg);
    overflow: hidden;
}

/* ════════════════════════════════════════════════════════════════════════════════
   CUSTOM SCROLLBAR - Dark Theme
   ════════════════════════════════════════════════════════════════════════════════ */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--genapa-bg-secondary);
}

::-webkit-scrollbar-thumb {
    background: var(--genapa-neutral-600);
    border-radius: var(--genapa-radius-sm);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--genapa-neutral-500);
}

/* ════════════════════════════════════════════════════════════════════════════════
   LINKS AND BUTTONS
   ════════════════════════════════════════════════════════════════════════════════ */
a,
.btn-link {
    color: var(--genapa-accent-blue);
    transition: color var(--genapa-transition-fast);
}

a:hover,
.btn-link:hover {
    color: var(--genapa-blue-400);
}

/* Focus States */
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 0.1rem var(--genapa-bg-app), 0 0 0 0.25rem var(--genapa-accent-blue);
}

h1:focus {
    outline: none;
}

/* ════════════════════════════════════════════════════════════════════════════════
   FORM VALIDATION
   ════════════════════════════════════════════════════════════════════════════════ */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--genapa-success-500);
}

.invalid {
    outline: 1px solid var(--genapa-error-500);
}

.validation-message {
    color: var(--genapa-error-500);
    font-size: var(--genapa-text-small-size);
}

/* ════════════════════════════════════════════════════════════════════════════════
   BLAZOR ERROR UI
   ════════════════════════════════════════════════════════════════════════════════ */
#blazor-error-ui {
    background: var(--genapa-error-700);
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: var(--genapa-space-3) var(--genapa-space-5);
    position: fixed;
    width: 100%;
    z-index: 1000;
    color: white;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: var(--genapa-space-3);
    top: var(--genapa-space-2);
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, var(--genapa-bg-secondary);
    padding: var(--genapa-space-4) var(--genapa-space-4) var(--genapa-space-4) 3.7rem;
    color: var(--genapa-text-primary);
    border-radius: var(--genapa-radius-md);
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

/* Checkbox Border */
.darker-border-checkbox.form-check-input {
    border-color: var(--genapa-border-strong);
}

/* ════════════════════════════════════════════════════════════════════════════════
   SPACING UTILITIES
   ════════════════════════════════════════════════════════════════════════════════ */

/* Padding utilities */
.p-0 {
    padding: var(--genapa-space-0);
}

.p-1 {
    padding: var(--genapa-space-1);
}

.p-2 {
    padding: var(--genapa-space-2);
}

.p-3 {
    padding: var(--genapa-space-3);
}

.p-4 {
    padding: var(--genapa-space-4);
}

.p-5 {
    padding: var(--genapa-space-5);
}

.p-6 {
    padding: var(--genapa-space-6);
}

.p-8 {
    padding: var(--genapa-space-8);
}

/* Margin bottom utilities */
.mb-0 {
    margin-bottom: var(--genapa-space-0);
}

.mb-1 {
    margin-bottom: var(--genapa-space-1);
}

.mb-2 {
    margin-bottom: var(--genapa-space-2);
}

.mb-3 {
    margin-bottom: var(--genapa-space-3);
}

.mb-4 {
    margin-bottom: var(--genapa-space-4);
}

.mb-5 {
    margin-bottom: var(--genapa-space-5);
}

.mb-6 {
    margin-bottom: var(--genapa-space-6);
}

.mb-8 {
    margin-bottom: var(--genapa-space-8);
}

/* Margin top utilities */
.mt-0 {
    margin-top: var(--genapa-space-0);
}

.mt-1 {
    margin-top: var(--genapa-space-1);
}

.mt-2 {
    margin-top: var(--genapa-space-2);
}

.mt-3 {
    margin-top: var(--genapa-space-3);
}

.mt-4 {
    margin-top: var(--genapa-space-4);
}

/* Gap utilities */
.gap-1 {
    gap: var(--genapa-space-1);
}

.gap-2 {
    gap: var(--genapa-space-2);
}

.gap-3 {
    gap: var(--genapa-space-3);
}

.gap-4 {
    gap: var(--genapa-space-4);
}

.gap-6 {
    gap: var(--genapa-space-6);
}

/* Width utilities */
.w-full {
    width: 100%;
}

.w-half {
    width: 50%;
}

/* ════════════════════════════════════════════════════════════════════════════════
   CONNECTION INDICATOR
   ════════════════════════════════════════════════════════════════════════════════ */
.connection-indicator {
    display: flex;
    align-items: center;
    gap: var(--genapa-space-2);
}

.connection-indicator__dot {
    width: 8px;
    height: 8px;
    border-radius: var(--genapa-radius-full);
}

.connection-indicator__dot--connected {
    background: var(--genapa-success-500);
    box-shadow: var(--genapa-glow-success);
}

.connection-indicator__dot--disconnected {
    background: var(--genapa-error-500);
}

.connection-indicator__dot--connecting {
    background: var(--genapa-warning-500);
    animation: agent-pulse 1s ease-in-out infinite;
}

/* ════════════════════════════════════════════════════════════════════════════════
   FLUENT SELECT / DROPDOWN STYLING (Dark Theme)
   ════════════════════════════════════════════════════════════════════════════════ */
fluent-select {
    --neutral-fill-input-rest: var(--genapa-bg-elevated);
    --neutral-fill-input-hover: var(--genapa-bg-hover);
    background: var(--genapa-bg-elevated);
    border-color: var(--genapa-border-subtle);
}

fluent-select::part(listbox) {
    background: var(--genapa-neutral-800);
    border: 1px solid var(--genapa-border-default);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

fluent-option {
    background: transparent;
    color: var(--genapa-text-primary);
}

fluent-option:hover,
fluent-option[aria-selected="true"] {
    background: var(--genapa-bg-hover);
}

fluent-option[aria-selected="true"] {
    color: var(--genapa-accent-primary);
    font-weight: var(--genapa-weight-medium);
}

/* Environment Switcher Dropdown */
.env-switcher {
    min-width: 90px;
    --height: 32px;
}

.env-switcher::part(control) {
    background: var(--genapa-badge-blue-bg);
    border: 1px solid var(--genapa-border-subtle);
    border-radius: var(--genapa-radius-sm);
    font-size: var(--genapa-text-tiny-size);
    font-weight: var(--genapa-weight-medium);
    text-transform: uppercase;
    padding: var(--genapa-space-1) var(--genapa-space-2);
}

.env-switcher::part(listbox) {
    min-width: 90px;
}

/* ════════════════════════════════════════════════════════════════════════════════
   REUSABLE TAB SYSTEM
   Professional, polished tabs for consistent UI throughout the application.
   Design: Clean underline-style tabs with accent indicators and subtle animations.
   ════════════════════════════════════════════════════════════════════════════════ */

/* Container wraps both tabs and content - takes full width */
.genapa-tabs {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    width: 100%;
}

/* Tab strip at top - horizontal list of tab buttons */
.genapa-tabs__strip {
    display: flex;
    align-items: stretch;
    position: relative;
    width: 100%;
    background: var(--genapa-bg-elevated);
    border-bottom: 2px solid var(--genapa-border-subtle);
    gap: 0;
    padding: 0 var(--genapa-space-2);
}

/* Individual tab button */
.genapa-tabs__tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--genapa-space-2);
    padding: var(--genapa-space-3) var(--genapa-space-5);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    color: var(--genapa-text-secondary);
    font-size: var(--genapa-text-body-size);
    font-weight: var(--genapa-weight-medium);
    cursor: pointer;
    transition: all var(--genapa-transition-fast);
    white-space: nowrap;
    position: relative;
}

.genapa-tabs__tab:hover:not(.genapa-tabs__tab--active) {
    color: var(--genapa-text-primary);
    background: var(--genapa-bg-hover);
    border-bottom-color: var(--genapa-border-emphasis);
}

/* Active tab - accent underline indicator */
.genapa-tabs__tab--active {
    color: var(--genapa-accent-primary);
    background: transparent;
    border-bottom: 2px solid var(--genapa-accent-primary);
    font-weight: var(--genapa-weight-semibold);
}

/* Active tab glow effect */
.genapa-tabs__tab--active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--genapa-accent-primary);
    box-shadow: 0 0 8px var(--genapa-accent-primary);
}

/* Tab icon container */
.genapa-tabs__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    font-size: var(--genapa-text-body-size);
    line-height: 1;
    flex-shrink: 0;
}

/* Icon color inherits from tab */
.genapa-tabs__tab .genapa-tabs__icon {
    color: inherit;
}

/* Pulse animation for live/active indicator */
.genapa-tabs__icon--pulse {
    color: var(--genapa-success-500) !important;
    animation: genapa-pulse 2s ease-in-out infinite;
}

/* Tab label */
.genapa-tabs__label {
    font-weight: inherit;
    letter-spacing: 0.01em;
}

/* Tab badge - pill-style count indicator */
.genapa-tabs__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 var(--genapa-space-2);
    background: var(--genapa-neutral-700);
    color: var(--genapa-text-secondary);
    border-radius: var(--genapa-radius-full);
    font-size: var(--genapa-text-small-size);
    font-weight: var(--genapa-weight-semibold);
    margin-left: var(--genapa-space-1);
    transition: all var(--genapa-transition-fast);
}

/* Badge variants */
.genapa-tabs__badge--success {
    background: var(--genapa-badge-success-bg);
    color: var(--genapa-success-500);
}

.genapa-tabs__badge--warning {
    background: var(--genapa-badge-warning-bg);
    color: var(--genapa-warning-500);
}

.genapa-tabs__badge--error {
    background: var(--genapa-badge-error-bg);
    color: var(--genapa-error-500);
}

.genapa-tabs__badge--info {
    background: var(--genapa-badge-blue-bg);
    color: var(--genapa-blue-500);
}

/* Tab content panel */
.genapa-tabs__content {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    width: 100%;
    background: var(--genapa-bg-secondary);
    border: 1px solid var(--genapa-border-subtle);
    border-top: none;
    border-radius: 0 0 var(--genapa-radius-lg) var(--genapa-radius-lg);
    padding: var(--genapa-space-5);
    overflow: auto;
}

/* Pulse animation for active indicators */
@keyframes genapa-pulse {

    0%,
    100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.6;
        transform: scale(1.1);
    }
}

/* ─────────────────────────────────────────────────────────────────────────────
   Tab Variant: Folder-style (optional modifier)
   Use .genapa-tabs--folder on the container for traditional folder tabs
   ───────────────────────────────────────────────────────────────────────────── */
.genapa-tabs--folder .genapa-tabs__strip {
    background: transparent;
    border-bottom: 1px solid var(--genapa-border-default);
    gap: var(--genapa-space-1);
    padding: 0;
}

.genapa-tabs--folder .genapa-tabs__tab {
    background: var(--genapa-bg-tertiary);
    border: 1px solid var(--genapa-border-default);
    border-bottom: 1px solid var(--genapa-border-default);
    border-radius: var(--genapa-radius-md) var(--genapa-radius-md) 0 0;
    margin-bottom: -1px;
    padding: var(--genapa-space-2) var(--genapa-space-4);
}

.genapa-tabs--folder .genapa-tabs__tab--active {
    background: var(--genapa-bg-secondary);
    border-color: var(--genapa-border-default);
    border-bottom-color: var(--genapa-bg-secondary);
}

.genapa-tabs--folder .genapa-tabs__tab--active::after {
    display: none;
}

/* ════════════════════════════════════════════════════════════════════════════════
   REUSABLE EMPTY TABLE STATE
   Shows table headers with a centered empty message
   ════════════════════════════════════════════════════════════════════════════════ */

.genapa-empty-table {
    width: 100%;
    border: 1px solid var(--genapa-border-default);
    border-radius: var(--genapa-radius-md);
    overflow: hidden;
}

.genapa-empty-table__header {
    display: flex;
    background: var(--genapa-bg-tertiary);
    border-bottom: 1px solid var(--genapa-border-default);
}

.genapa-empty-table__cell {
    flex: 1;
    padding: var(--genapa-space-3) var(--genapa-space-3);
    font-size: var(--genapa-text-small-size);
    font-weight: var(--genapa-weight-semibold);
    color: var(--genapa-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.genapa-empty-table__body {
    background: var(--genapa-bg-secondary);
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.genapa-empty-table__message {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--genapa-space-2);
    padding: var(--genapa-space-6);
    color: var(--genapa-text-muted);
}

.genapa-empty-table__icon {
    font-size: 2rem;
    color: var(--genapa-success-500);
}

.genapa-empty-table__text {
    font-size: var(--genapa-text-body-size);
    color: var(--genapa-text-secondary);
}

/* ════════════════════════════════════════════════════════════════════════════════
   REUSABLE EMPTY STATE
   Generic empty state for any container
   ════════════════════════════════════════════════════════════════════════════════ */

.genapa-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--genapa-space-3);
    padding: var(--genapa-space-8);
    background: var(--genapa-bg-secondary);
    border-radius: var(--genapa-radius-lg);
    border: 1px dashed var(--genapa-border-default);
}

.genapa-empty-state__icon {
    font-size: 2.5rem;
    color: var(--genapa-text-muted);
}

.genapa-empty-state__icon--success {
    color: var(--genapa-success-500);
}

.genapa-empty-state__title {
    font-size: var(--genapa-text-h3-size);
    font-weight: var(--genapa-weight-semibold);
    color: var(--genapa-text-primary);
}

.genapa-empty-state__description {
    font-size: var(--genapa-text-body-size);
    color: var(--genapa-text-secondary);
    text-align: center;
    max-width: 300px;
}
