/**
 * NexoraHR Design System v2
 * Navy #1A365D · Teal #38B2AC · Grey #718096
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
    --nx-navy: #1a365d;
    --nx-navy-mid: #2c5282;
    --nx-navy-light: #2c4b7c;
    --nx-teal: #38b2ac;
    --nx-teal-bright: #4fd1c5;
    --nx-teal-soft: rgba(56, 178, 172, 0.15);
    --nx-grey: #718096;
    --nx-grey-light: #a0aec0;
    --nx-danger: #e53e3e;
    --nx-danger-soft: rgba(229, 62, 62, 0.12);
    --nx-warning: #d69e2e;
    --nx-warning-soft: rgba(214, 158, 46, 0.14);
    --nx-success: #319795;
    --nx-success-soft: rgba(56, 178, 172, 0.18);

    --nx-primary: var(--nx-teal);
    --nx-primary-dark: #319795;
    --nx-primary-darker: var(--nx-navy);
    --nx-accent: var(--nx-teal-bright);
    --nx-accent-soft: var(--nx-teal-soft);

    --nx-surface: #f7fafc;
    --nx-surface-elevated: #ffffff;
    --nx-text: var(--nx-navy);
    --nx-text-muted: var(--nx-grey);
    --nx-border: #e2e8f0;
    --nx-sidebar: var(--nx-navy);
    --nx-sidebar-hover: #234876;
    --nx-sidebar-active: var(--nx-teal);

    --nx-gradient: linear-gradient(135deg, var(--nx-navy) 0%, var(--nx-navy-mid) 45%, var(--nx-teal) 100%);
    --nx-gradient-h: linear-gradient(90deg, var(--nx-navy) 0%, var(--nx-navy-mid) 55%, var(--nx-teal) 100%);

    --nx-radius: 0.75rem;
    --nx-radius-lg: 1rem;
    --nx-radius-xl: 1.25rem;
    --nx-shadow: 0 1px 3px rgba(26, 54, 93, 0.08);
    --nx-shadow-md: 0 4px 16px rgba(26, 54, 93, 0.1);
    --nx-shadow-lg: 0 12px 40px rgba(26, 54, 93, 0.14);

    --nx-font: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--nx-font);
    color: var(--nx-text);
    -webkit-font-smoothing: antialiased;
}

.nx-app-body {
    background: var(--nx-surface);
    min-height: 100vh;
    overflow-x: hidden;
}

/* ─── Bootstrap (public / auth) ─── */
.btn-primary {
    --bs-btn-bg: var(--nx-teal);
    --bs-btn-border-color: var(--nx-teal);
    --bs-btn-hover-bg: var(--nx-primary-dark);
    --bs-btn-hover-border-color: var(--nx-primary-dark);
    --bs-btn-active-bg: #2c7a7b;
    --bs-btn-active-border-color: #2c7a7b;
    --bs-btn-focus-shadow-rgb: 56, 178, 172;
    font-weight: 600;
    border-radius: var(--nx-radius);
}

.btn-secondary {
    --bs-btn-bg: var(--nx-navy);
    --bs-btn-border-color: var(--nx-navy);
    --bs-btn-hover-bg: var(--nx-navy-mid);
    --bs-btn-hover-border-color: var(--nx-navy-mid);
}

.btn-outline-primary {
    --bs-btn-color: var(--nx-teal);
    --bs-btn-border-color: var(--nx-teal);
    --bs-btn-hover-bg: var(--nx-teal);
    --bs-btn-hover-border-color: var(--nx-teal);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--nx-primary-dark);
    --bs-btn-active-border-color: var(--nx-primary-dark);
    --bs-btn-focus-shadow-rgb: 56, 178, 172;
    font-weight: 600;
    border-radius: var(--nx-radius);
}

.btn-outline-secondary {
    --bs-btn-color: var(--nx-navy);
    --bs-btn-border-color: var(--nx-border);
    --bs-btn-hover-bg: var(--nx-surface);
    --bs-btn-hover-border-color: var(--nx-grey-light);
    border-radius: var(--nx-radius);
}

.alert-primary {
    --bs-alert-color: var(--nx-navy);
    --bs-alert-bg: var(--nx-teal-soft);
    --bs-alert-border-color: rgba(56, 178, 172, 0.35);
}

.bg-primary-subtle { background-color: var(--nx-teal-soft) !important; color: var(--nx-navy) !important; }
.link-primary { color: var(--nx-teal) !important; }
.link-primary:hover { color: var(--nx-primary-dark) !important; }
.text-primary { color: var(--nx-teal) !important; }
.bg-primary { background-color: var(--nx-teal) !important; }
.border-primary { border-color: var(--nx-teal) !important; }

.nx-auth-bg .form-control,
.nx-auth-bg .form-select {
    border-radius: var(--nx-radius);
    border-color: var(--nx-border);
    padding: 0.625rem 0.875rem;
    font-size: 0.9375rem;
}

.nx-auth-bg .form-control:focus,
.nx-auth-bg .form-select:focus {
    border-color: var(--nx-teal);
    box-shadow: 0 0 0 3px rgba(56, 178, 172, 0.2);
}

.nx-auth-bg .form-label { color: var(--nx-navy); }
.nx-auth-bg a:not(.btn) { color: var(--nx-teal); }
.nx-auth-bg a:not(.btn):hover { color: var(--nx-primary-dark); }

/* ─── Public marketing ─── */
.navbar-nexora {
    background: #ffffff !important;
    border-bottom: 1px solid var(--nx-border);
    box-shadow: var(--nx-shadow);
}

.navbar-nexora .nav-link {
    color: var(--nx-navy) !important;
    font-weight: 500;
}

.navbar-nexora .nav-link:hover,
.navbar-nexora .nav-link.active {
    color: var(--nx-teal) !important;
}

.navbar-nexora .navbar-toggler {
    border-color: var(--nx-border) !important;
    padding: 0.35rem 0.55rem;
}

/* Navbar CTA — must stay visible on white background */
.navbar-nexora .btn-primary,
.navbar-nexora .btn-nexora {
    background: var(--nx-teal) !important;
    border-color: var(--nx-teal) !important;
    color: #ffffff !important;
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(26, 54, 93, 0.12);
}

.navbar-nexora .btn-primary:hover,
.navbar-nexora .btn-nexora:hover {
    background: var(--nx-primary-dark) !important;
    border-color: var(--nx-primary-dark) !important;
    color: #ffffff !important;
}

.navbar-nexora .btn-outline-primary {
    color: var(--nx-teal) !important;
    border-color: var(--nx-teal) !important;
    background: transparent !important;
}

.navbar-nexora .btn-outline-primary:hover {
    background: var(--nx-teal) !important;
    color: #ffffff !important;
}

.btn-nexora {
    background: var(--nx-teal);
    border: 1px solid var(--nx-teal);
    color: #fff !important;
}

.btn-nexora:hover {
    background: var(--nx-primary-dark);
    border-color: var(--nx-primary-dark);
    color: #fff !important;
}

.hero-section {
    background: var(--nx-gradient) !important;
    color: #ffffff !important;
}

.hero-section h1, .hero-section h2, .hero-section h3,
.hero-section .display-4, .hero-section .lead,
.hero-section p, .hero-section .hero-stat-value { color: #ffffff !important; }

.hero-section .hero-tagline {
    color: rgba(255, 255, 255, 0.88) !important;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.hero-section .text-muted-hero { color: rgba(255, 255, 255, 0.82) !important; }

.hero-section .hero-badge {
    background: rgba(255, 255, 255, 0.16) !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.28);
}

.hero-section .hero-card {
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
    backdrop-filter: blur(8px);
    color: #ffffff;
}

.hero-section .btn-light {
    color: var(--nx-navy) !important;
    background: #ffffff !important;
    border-color: #ffffff !important;
    font-weight: 600;
}

.hero-section .btn-outline-light {
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.9) !important;
    background: transparent !important;
}

.hero-section .btn-outline-light:hover {
    background: rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
    border-color: #ffffff !important;
}

.feature-icon {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: var(--nx-teal-soft);
    color: var(--nx-teal);
    font-size: 1.5rem;
}

.public-page .card {
    border-radius: var(--nx-radius-lg);
    border-color: var(--nx-border);
}

.nx-footer { background: var(--nx-gradient-h); }

.nx-auth-bg {
    background: linear-gradient(160deg, #edfdfd 0%, #e6fffa 35%, #f7fafc 100%);
    min-height: 100vh;
}

.nx-auth-bg .auth-card {
    border: 1px solid var(--nx-border);
    border-radius: var(--nx-radius-lg);
    box-shadow: var(--nx-shadow-lg);
    background: #fff;
}

.nx-auth-heading { color: var(--nx-navy); }

/* ─── Logo ─── */
.brand-logo {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    text-decoration: none;
    color: inherit;
    line-height: 1.1;
}

.brand-logo__mark {
    display: block;
    overflow: hidden;
    line-height: 0;
}

.brand-logo img,
.brand-logo__svg {
    display: block;
    object-fit: contain;
    max-width: 100%;
    width: auto;
    height: auto;
    background: transparent;
}

/* SVG logo — navy text + readable tagline on light surfaces */
.brand-logo--on-light-surface {
    color: var(--nx-navy);
}

.brand-logo--on-light-surface .brand-logo__svg {
    height: auto;
}

.brand-logo--sm .brand-logo__svg,
.brand-logo--sm .brand-logo__mark img { max-height: 44px; }
.brand-logo--md .brand-logo__svg,
.brand-logo--md .brand-logo__mark img { max-height: 54px; }
.brand-logo--lg .brand-logo__svg,
.brand-logo--lg .brand-logo__mark img { max-height: 64px; }
.brand-logo--xl .brand-logo__svg,
.brand-logo--xl .brand-logo__mark img { max-height: 82px; }

.brand-logo--sm .brand-logo__mark { max-height: 40px; }
.brand-logo--md .brand-logo__mark { max-height: 48px; }
.brand-logo--lg .brand-logo__mark { max-height: 52px; }
.brand-logo--xl .brand-logo__mark { max-height: 64px; }

.brand-logo--with-tagline {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
}

.brand-logo__tagline {
    display: block;
    font-size: 0.625rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #4a5568;
    line-height: 1.2;
    padding-left: 2px;
}

/* PNG on dark surfaces — crop baked-in tagline, show HTML tagline */
.brand-logo--center { margin-left: auto; margin-right: auto; }

.navbar-nexora .brand-logo--lg .brand-logo__svg { width: 220px; max-height: none; height: 52px; }

.brand-logo--on-dark-surface {
    color: #ffffff;
}

.brand-logo--on-dark-surface .brand-logo__svg {
    filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.35));
}

.nx-sidebar .brand-logo--on-dark-surface .brand-logo__svg {
    width: 200px;
    height: 46px;
}

.brand-logo__text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    font-weight: 700;
    color: var(--nx-navy);
}

.brand-logo__text small {
    font-weight: 500;
    font-size: 0.65rem;
    color: var(--nx-grey);
    letter-spacing: 0.02em;
}

.brand-logo--on-dark-surface .brand-logo__text {
    color: #fff;
}

.brand-logo--on-dark-surface .brand-logo__text small {
    color: rgba(255, 255, 255, 0.78);
}

/* ─── App shell ─── */
.nx-sidebar {
    background: var(--nx-sidebar);
    color: #fff;
}

.nx-sidebar .border-slate-800,
.nx-sidebar .border-white\/10 { border-color: rgba(255,255,255,0.12) !important; }

.nx-sidebar a.bg-slate-800,
.nx-sidebar .bg-slate-800 {
    background-color: var(--nx-sidebar-hover) !important;
    box-shadow: inset 3px 0 0 var(--nx-teal);
}

.nx-sidebar button:hover,
.nx-sidebar a:hover { background-color: var(--nx-sidebar-hover); }

.nx-topbar {
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--nx-border);
}

.nx-topbar-title { color: var(--nx-navy); font-weight: 600; }
.nx-topbar-subtitle { color: var(--nx-grey); }

.nx-topbar-link {
    color: var(--nx-grey);
    border-radius: var(--nx-radius);
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    transition: background 0.15s, color 0.15s;
    text-decoration: none;
}

.nx-topbar-link:hover {
    background: var(--nx-teal-soft);
    color: var(--nx-navy);
}

.nx-topbar-btn {
    background: var(--nx-teal);
    color: #fff;
    border: none;
    border-radius: var(--nx-radius);
    font-weight: 600;
    min-height: 2.5rem;
    min-width: 2.5rem;
}

.nx-topbar-btn:hover { background: var(--nx-primary-dark); color: #fff; }

.nx-icon-btn {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--nx-radius);
    border: 1px solid var(--nx-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--nx-grey);
    background: #fff;
    transition: background 0.15s, color 0.15s;
}

.nx-icon-btn:hover {
    background: var(--nx-teal-soft);
    color: var(--nx-teal);
}

/* ─── Buttons ─── */
.nx-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    font-weight: 600;
    border-radius: var(--nx-radius);
    border: 1px solid transparent;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s, box-shadow 0.15s;
    white-space: nowrap;
}

.nx-btn-md { padding: 0.5rem 1rem; font-size: 0.875rem; min-height: 2.5rem; }
.nx-btn-sm { padding: 0.25rem 0.75rem; font-size: 0.75rem; border-radius: 9999px; min-height: 1.75rem; }

.nx-btn-primary { background: var(--nx-teal); color: #fff; }
.nx-btn-primary:hover { background: var(--nx-primary-dark); color: #fff; }

.nx-btn-secondary { background: var(--nx-navy); color: #fff; }
.nx-btn-secondary:hover { background: var(--nx-navy-mid); color: #fff; }

.nx-btn-outline {
    background: #fff;
    color: var(--nx-navy);
    border-color: var(--nx-border);
}
.nx-btn-outline:hover { background: var(--nx-surface); border-color: var(--nx-grey-light); color: var(--nx-navy); }

.nx-btn-ghost { background: #edf2f7; color: var(--nx-navy); }
.nx-btn-ghost:hover { background: #e2e8f0; color: var(--nx-navy); }

.nx-btn-danger { background: var(--nx-danger-soft); color: var(--nx-danger); }
.nx-btn-danger:hover { background: rgba(229, 62, 62, 0.22); color: #c53030; }

.nx-btn-success { background: var(--nx-success-soft); color: var(--nx-success); }
.nx-btn-success:hover { background: rgba(49, 151, 149, 0.28); color: #2c7a7b; }

.nx-btn-accent { background: rgba(49, 151, 149, 0.12); color: var(--nx-teal); }
.nx-btn-accent:hover { background: rgba(49, 151, 149, 0.22); color: var(--nx-primary-dark); }

/* ─── Cards & tables ─── */
.nx-card {
    background: var(--nx-surface-elevated);
    border-radius: var(--nx-radius-xl);
    border: 1px solid var(--nx-border);
    box-shadow: var(--nx-shadow);
    overflow: hidden;
}

.nx-card-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--nx-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.nx-card-body { padding: 1.25rem; }
.nx-card-footer { padding: 1rem 1.25rem; border-top: 1px solid var(--nx-border); }

.nx-module-toolbar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.nx-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.nx-table {
    width: 100%;
    min-width: 640px;
    font-size: 0.875rem;
    border-collapse: collapse;
}

.nx-table thead {
    background: var(--nx-surface);
    color: var(--nx-grey);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.nx-table th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-weight: 600;
}

.nx-table td {
    padding: 0.875rem 1rem;
    border-top: 1px solid #f1f5f9;
    vertical-align: middle;
}

.nx-table tbody tr:hover { background: #fafbfc; }

.nx-empty {
    padding: 2.5rem 1rem;
    text-align: center;
    color: var(--nx-grey);
}

/* ─── Stat cards (dashboard) ─── */
.nx-stat-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 768px) { .nx-stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1280px) { .nx-stat-grid--4 { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 768px) { .nx-stat-grid--3 { grid-template-columns: repeat(3, 1fr); } }

.nx-stat-card {
    background: #fff;
    border-radius: var(--nx-radius-xl);
    border: 1px solid var(--nx-border);
    box-shadow: var(--nx-shadow);
    padding: 1rem 1.125rem;
}

.nx-stat-card__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.nx-stat-card__label { font-size: 0.75rem; color: var(--nx-grey); }
.nx-stat-card__value { font-size: 1.5rem; font-weight: 700; color: var(--nx-navy); line-height: 1.2; }
.nx-stat-card__hint { font-size: 0.75rem; color: var(--nx-grey); margin-top: 0.75rem; }
.nx-stat-card__link { font-size: 0.75rem; color: var(--nx-teal); margin-top: 0.75rem; display: inline-block; text-decoration: none; }
.nx-stat-card__link:hover { color: var(--nx-primary-dark); text-decoration: underline; }

.nx-stat-icon {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: var(--nx-radius-lg);
    background: var(--nx-teal-soft);
    color: var(--nx-teal);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1.125rem;
}

/* ─── Badges ─── */
.nx-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.5rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.nx-badge-success { background: var(--nx-success-soft); color: var(--nx-success); }
.nx-badge-warning { background: var(--nx-warning-soft); color: #b7791f; }
.nx-badge-danger { background: var(--nx-danger-soft); color: var(--nx-danger); }
.nx-badge-neutral { background: #edf2f7; color: var(--nx-grey); }

/* ─── Forms (app) ─── */
.nx-app main input[type="text"],
.nx-app main input[type="email"],
.nx-app main input[type="password"],
.nx-app main input[type="number"],
.nx-app main input[type="date"],
.nx-app main input[type="url"],
.nx-app main input[type="file"],
.nx-app main select,
.nx-app main textarea {
    border-radius: var(--nx-radius);
    border: 1px solid var(--nx-border);
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    width: 100%;
    background: #fff;
    color: var(--nx-navy);
}

.nx-app main input:focus,
.nx-app main select:focus,
.nx-app main textarea:focus {
    outline: none;
    border-color: var(--nx-teal);
    box-shadow: 0 0 0 3px rgba(56, 178, 172, 0.18);
}

.nx-form-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--nx-grey);
    display: block;
    margin-bottom: 0.25rem;
}

.nx-panel {
    background: #fff;
    border-radius: var(--nx-radius-xl);
    border: 1px solid var(--nx-border);
    box-shadow: var(--nx-shadow);
    padding: 1.25rem;
    max-width: 48rem;
}

/* ─── Flash alerts ─── */
.nx-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    border-radius: var(--nx-radius);
    margin-bottom: 1rem;
    font-size: 0.875rem;
}

.nx-alert-success { background: var(--nx-teal-soft); border: 1px solid rgba(56,178,172,0.35); color: var(--nx-navy); }
.nx-alert-error { background: var(--nx-danger-soft); border: 1px solid rgba(229,62,62,0.25); color: #c53030; }
.nx-alert-warning { background: var(--nx-warning-soft); border: 1px solid rgba(214,158,46,0.3); color: #975a16; }

/* ─── Announcements grid ─── */
.nx-announcement-card {
    display: block;
    background: #fff;
    border-radius: var(--nx-radius-xl);
    border: 1px solid var(--nx-border);
    padding: 1.25rem;
    text-decoration: none;
    color: inherit;
    box-shadow: var(--nx-shadow);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.nx-announcement-card:hover {
    border-color: rgba(56, 178, 172, 0.45);
    box-shadow: var(--nx-shadow-md);
}

.nx-announcement-card__icon { color: var(--nx-teal); font-size: 1.25rem; }

/* ─── Legacy Tailwind color harmonization ─── */
.bg-emerald-600, .bg-blue-600, .bg-blue-500, .bg-indigo-600, .bg-indigo-500,
.bg-sky-600, .bg-purple-600, .bg-purple-500, .bg-amber-600, .bg-amber-500 {
    background-color: var(--nx-teal) !important;
    color: #fff !important;
}

.hover\:bg-emerald-500:hover, .hover\:bg-blue-500:hover, .hover\:bg-blue-600:hover,
.hover\:bg-indigo-500:hover, .hover\:bg-indigo-600:hover, .hover\:bg-purple-500:hover,
.hover\:bg-amber-500:hover, .hover\:bg-slate-800:hover {
    background-color: var(--nx-primary-dark) !important;
}

.bg-slate-900.text-white, button.bg-slate-900, a.bg-slate-900 {
    background-color: var(--nx-teal) !important;
    color: #fff !important;
}

.bg-emerald-50, .bg-blue-50, .bg-indigo-50, .bg-sky-50, .bg-purple-50,
.bg-violet-50, .bg-orange-50, .bg-teal-50 {
    background-color: var(--nx-teal-soft) !important;
}

.text-emerald-600, .text-blue-600, .text-indigo-600, .text-sky-600,
.text-purple-600, .text-violet-600, .text-orange-600, .text-teal-600 {
    color: var(--nx-teal) !important;
}

.bg-emerald-100, .bg-blue-100, .bg-indigo-100, .bg-sky-100, .bg-teal-100 {
    background-color: var(--nx-success-soft) !important;
}

.text-emerald-700, .text-blue-700, .text-indigo-700, .text-teal-700 {
    color: var(--nx-success) !important;
}

/* Dashboard stat icons — unified */
.nx-app main .w-11.h-11.rounded-2xl {
    background: var(--nx-teal-soft) !important;
    color: var(--nx-teal) !important;
}

.nx-app main a.text-xs.text-indigo-600,
.nx-app main a.text-xs.text-teal-600,
.nx-app main a.text-xs.text-violet-600,
.nx-app main a.text-xs.text-orange-600,
.nx-app main a.text-xs.text-blue-600 {
    color: var(--nx-teal) !important;
}

.hover\:border-purple-200:hover { border-color: rgba(56, 178, 172, 0.45) !important; }

/* Action pills in legacy tables */
.nx-app main a.rounded-full.bg-sky-100,
.nx-app main button.rounded-full.bg-sky-100 {
    background: rgba(49, 151, 149, 0.12) !important;
    color: var(--nx-teal) !important;
}

.nx-app main a.rounded-full.bg-emerald-100,
.nx-app main button.rounded-full.bg-emerald-100 {
    background: var(--nx-success-soft) !important;
    color: var(--nx-success) !important;
}

/* Pagination */
.nx-app .pagination { gap: 0.25rem; }
.nx-app .page-link { border-radius: 0.5rem; color: var(--nx-navy); }
.nx-app .page-item.active .page-link { background: var(--nx-teal); border-color: var(--nx-teal); }

[x-cloak] { display: none !important; }

.fade-in { animation: nxFadeIn 0.35s ease-in-out; }
@keyframes nxFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ─── Responsive ─── */
@media (max-width: 767px) {
    .nx-topbar-user-text { display: none; }
    .nx-hide-mobile { display: none !important; }

    .nx-module-toolbar .nx-btn-md {
        width: 100%;
        justify-content: center;
    }

    .nx-table { min-width: 560px; }

    .brand-logo--lg .brand-logo__svg { width: 200px; height: 46px; }
    .navbar-nexora .brand-logo--lg .brand-logo__svg { width: 220px; height: 52px; }
}

@media (min-width: 768px) {
    .nx-show-mobile-only { display: none !important; }
}

.sidebar-panel { max-height: calc(100vh - 8rem); }

.table-responsive-wrap,
.nx-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
