/**
 * Boknero Stylesheet
 * Modern, responsive design with smooth animations
 */

/* ===== ROOT VARIABLES ===== */
:root {
    /* Colors */
    --primary-color: #2563eb;
    --primary-dark: #1e40af;
    --primary-light: #3b82f6;
    --secondary-color: #10b981;
    --secondary-dark: #059669;
    --danger-color: #ef4444;
    --danger-dark: #dc2626;
    --warning-color: #f59e0b;
    --info-color: #3b82f6;
    --success-color: #10b981;
    
    /* Neutral colors */
    --bg-primary: #ffffff;
    --bg-secondary: #f9fafb;
    --bg-tertiary: #f3f4f6;
    --text-primary: #111827;
    --text-secondary: #6b7280;
    --text-light: #9ca3af;
    --border-color: #e5e7eb;
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    
    /* Spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-2xl: 3rem;
    
    /* Border radius */
    --radius-sm: 0.25rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    
    /* Transitions */
    --transition-fast: 150ms ease-in-out;
    --transition-base: 300ms ease-in-out;
    --transition-slow: 500ms ease-in-out;
    
    /* Fonts */
    --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
}

/* Dark mode variables (optional) */
@media (prefers-color-scheme: dark) {
    :root {
        --bg-primary: #111827;
        --bg-secondary: #1f2937;
        --bg-tertiary: #374151;
        --text-primary: #f9fafb;
        --text-secondary: #d1d5db;
        --text-light: #9ca3af;
        --border-color: #374151;
    }
}

/* ===== RESET & BASE ===== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-sans);
    font-size: 1rem;
    line-height: 1.5;
    color: var(--text-primary);
    background-color: var(--bg-secondary);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    color: var(--primary-color);
    text-decoration: none;
    transition: color var(--transition-fast);
}

a:hover {
    color: var(--primary-dark);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    outline: none;
}

input, select, textarea {
    font-family: inherit;
    font-size: 1rem;
}

/* ===== UTILITY CLASSES ===== */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.text-center { text-align: center; }
.text-right { text-align: right; }
.text-muted { color: var(--text-secondary); }
.text-small { font-size: 0.875rem; }
.text-large { font-size: 1.125rem; }

.mt-1 { margin-top: var(--spacing-md); }
.mt-2 { margin-top: var(--spacing-lg); }
.mt-3 { margin-top: var(--spacing-xl); }
.mb-1 { margin-bottom: var(--spacing-md); }
.mb-2 { margin-bottom: var(--spacing-lg); }
.mb-3 { margin-bottom: var(--spacing-xl); }

.d-flex { display: flex; }
.flex-column { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.align-center { align-items: center; }
.gap-1 { gap: var(--spacing-md); }
.gap-2 { gap: var(--spacing-lg); }

/* ===== FLASH MESSAGES ===== */
.flash-message {
    position: fixed;
    top: 20px;
    right: 20px;
    max-width: 400px;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    z-index: 9999;
    animation: slideInRight 0.3s ease-out, fadeOut 0.3s ease-out 4.7s forwards;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes fadeOut {
    to {
        opacity: 0;
        transform: translateX(100%);
    }
}

.flash-success {
    background-color: var(--success-color);
    color: white;
}

.flash-error {
    background-color: var(--danger-color);
    color: white;
}

.flash-warning {
    background-color: var(--warning-color);
    color: white;
}

.flash-info {
    background-color: var(--info-color);
    color: white;
}

.flash-content {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.flash-close {
    background: transparent;
    color: white;
    border: none;
    font-size: 1.2rem;
    opacity: 0.8;
    transition: opacity var(--transition-fast);
}

.flash-close:hover {
    opacity: 1;
}

/* ===== NAVBAR ===== */
.navbar {
    background-color: var(--bg-primary);
    border-bottom: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.navbar-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--spacing-md) var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-lg);
}

.navbar-brand a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--primary-color);
}

.navbar-toggle {
    display: none;
    background: transparent;
    color: var(--text-primary);
    font-size: 1.5rem;
}

.navbar-menu {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.navbar-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    transition: all var(--transition-fast);
}

.navbar-item:hover {
    background-color: var(--bg-secondary);
    color: var(--primary-color);
}

.navbar-item.active {
    background-color: var(--primary-color);
    color: white;
}

.navbar-user {
    margin-left: auto;
}

.user-dropdown {
    position: relative;
}

.user-button {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background-color: var(--bg-secondary);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    transition: all var(--transition-fast);
}

.user-button:hover {
    background-color: var(--bg-tertiary);
}

.user-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 250px;
    background-color: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all var(--transition-base);
}

.user-menu.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.user-info {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
}

.user-info strong {
    display: block;
    margin-bottom: var(--spacing-xs);
}

.user-info small {
    color: var(--text-secondary);
}

.user-menu a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    color: var(--text-primary);
    transition: background-color var(--transition-fast);
}

.user-menu a:hover {
    background-color: var(--bg-secondary);
}

/* ===== MAIN CONTENT ===== */
.main-content {
    min-height: calc(100vh - 140px);
    padding: var(--spacing-xl) 0;
}

/* ===== CARDS ===== */
.card {
    background-color: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: all var(--transition-base);
}

.card:hover {
    box-shadow: var(--shadow-md);
}

.card-header {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
    background-color: var(--bg-secondary);
}

.card-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
}

.card-body {
    padding: var(--spacing-lg);
}

.card-footer {
    padding: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-secondary);
}

/* Grid layout for cards */
.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

/* ===== FORMS ===== */
.form-group {
    margin-bottom: var(--spacing-lg);
}

.form-label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: 500;
    color: var(--text-primary);
}

.form-label.required::after {
    content: ' *';
    color: var(--danger-color);
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    background-color: var(--bg-primary);
    color: var(--text-primary);
    font-size: 1rem;
    transition: all var(--transition-fast);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.form-input.error,
.form-select.error,
.form-textarea.error {
    border-color: var(--danger-color);
}

.form-textarea {
    min-height: 100px;
    resize: vertical;
}

.form-error {
    display: block;
    margin-top: var(--spacing-xs);
    color: var(--danger-color);
    font-size: 0.875rem;
}

.form-help {
    display: block;
    margin-top: var(--spacing-xs);
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.form-check {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 1.25rem;
    height: 1.25rem;
    cursor: pointer;
}

/* ===== BUTTONS ===== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-lg);
    border: none;
    border-radius: var(--radius-md);
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-decoration: none;
}

.btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.btn-primary {
    background-color: var(--primary-color);
    color: white;
}

.btn-primary:hover:not(:disabled) {
    background-color: var(--primary-dark);
    color: white;
}

.btn-secondary {
    background-color: var(--secondary-color);
    color: white;
}

.btn-secondary:hover:not(:disabled) {
    background-color: var(--secondary-dark);
}

.btn-danger {
    background-color: var(--danger-color);
    color: white;
}

.btn-danger:hover:not(:disabled) {
    background-color: var(--danger-dark);
}

.btn-success {
    background-color: var(--success-color);
    color: white;
}

.btn-success:hover:not(:disabled) {
    background-color: #059669;
    color: white;
}

.btn-outline {
    background-color: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

.btn-outline:hover:not(:disabled) {
    background-color: var(--bg-secondary);
}

.btn-sm {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: 0.875rem;
}

.btn-lg {
    padding: var(--spacing-md) var(--spacing-xl);
    font-size: 1.125rem;
}

.btn-block {
    width: 100%;
}

/* ===== TABLES ===== */
.table-container {
    overflow-x: auto;
}

.table {
    width: 100%;
    border-collapse: collapse;
}

.table thead {
    background-color: var(--bg-secondary);
}

.table th {
    padding: var(--spacing-md);
    text-align: left;
    font-weight: 600;
    color: var(--text-primary);
    border-bottom: 2px solid var(--border-color);
}

.table td {
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
}

.table td i:not(.fa-edit, .fa-trash, .fa-stop-circle) {
    margin-right: 5px;
}

.table tbody tr {
    transition: background-color var(--transition-fast);
}

.table tbody tr:hover {
    background-color: var(--bg-secondary);
}

/* ===== BADGES ===== */
.badge {
    display: inline-flex;
    align-items: center;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-right: 5px;
}

.badge-success {
    background-color: #d1fae5;
    color: #065f46;
}

.badge-danger {
    background-color: #fee2e2;
    color: #991b1b;
}

.badge-warning {
    background-color: #fef3c7;
    color: #92400e;
}

.badge-info {
    background-color: #dbeafe;
    color: #1e40af;
}

/* ===== STATS CARDS ===== */
.stat-card {
    position: relative;
    overflow: hidden;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--primary-color), var(--primary-light));
}

.stat-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--spacing-xs);
}

.stat-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.stat-change {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-sm);
    font-size: 0.875rem;
}

.stat-change.positive {
    color: var(--success-color);
}

.stat-change.negative {
    color: var(--danger-color);
}

/* ===== MODAL ===== */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-base);
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal {
    background-color: var(--bg-primary);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    transform: scale(0.9);
    transition: transform var(--transition-base);
}

.modal-overlay.active .modal {
    transform: scale(1);
}

.modal-header {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.modal-title {
    font-size: 1.5rem;
    font-weight: 600;
}

.modal-close {
    background: transparent;
    color: var(--text-secondary);
    font-size: 1.5rem;
    transition: color var(--transition-fast);
}

.modal-close:hover {
    color: var(--text-primary);
}

.modal-body {
    padding: var(--spacing-lg);
}

.modal-footer {
    padding: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
    display: flex;
    gap: var(--spacing-md);
    justify-content: flex-end;
}

/* ===== FILTERS ===== */
.filters {
    background-color: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.filter-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-md);
}

/* ===== LOGIN PAGE ===== */

/* Star background wrapper */
.login-bg {
    position: fixed;
    inset: 0;
    background: radial-gradient(ellipse at bottom, #1b2735 0%, #090a0f 100%);
    overflow: hidden;
    z-index: 0;
}

/* Centering layer sits above stars */
.login-container {
    position: relative;
    z-index: 10;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
}

.login-card {
    width: 100%;
    max-width: 450px;
    padding: var(--spacing-2xl);
    background: rgba(255, 255, 255, 0.07);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    color: #f0f4ff;
}

.login-card .form-label,
.login-card h1,
.login-card p,
.login-card .text-muted {
    color: rgba(255, 255, 255, 0.85);
}

.login-card .form-input {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.login-card .form-input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.login-card .form-input:focus {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.5);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1);
}

.login-logo {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.login-logo i {
    font-size: 4rem;
    color: var(--primary-color);
}

.login-logo h1 {
    margin-top: var(--spacing-md);
    font-size: 2rem;
    color: #fff;
    letter-spacing: 2px;
}

/* ── Star layers ─────────────────────────────────────────────────────────── */
#stars {
    width: 1px;
    height: 1px;
    background: transparent;
    box-shadow:
        501px 811px #fff, 1450px 1324px #fff, 1093px 1780px #fff, 1469px 678px #fff,
        904px 741px #fff, 1160px 781px #fff, 1841px 1962px #fff, 1630px 1667px #fff,
        1788px 676px #fff, 367px 1734px #fff, 1343px 156px #fff, 1283px 1142px #fff,
        1062px 378px #fff, 1395px 467px #fff, 1017px 1891px #fff, 137px 1114px #fff,
        1767px 1403px #fff, 1543px 11px #fff, 1078px 181px #fff, 1189px 1574px #fff,
        1697px 1551px #fff, 439px 472px #fff, 1491px 677px #fff, 1364px 599px #fff,
        34px 382px #fff, 1221px 1584px #fff, 1266px 1499px #fff, 169px 1907px #fff,
        1219px 1125px #fff, 659px 18px #fff, 1731px 1959px #fff, 332px 1216px #fff,
        1913px 788px #fff, 80px 712px #fff, 326px 1605px #fff, 574px 1502px #fff,
        473px 1653px #fff, 404px 975px #fff, 322px 1797px #fff, 425px 1321px #fff,
        1121px 1797px #fff, 731px 647px #fff, 891px 1584px #fff, 1523px 109px #fff,
        1379px 244px #fff, 865px 1064px #fff, 493px 956px #fff, 624px 1380px #fff,
        440px 619px #fff, 1630px 767px #fff, 955px 1196px #fff, 62px 729px #fff,
        126px 946px #fff, 1256px 896px #fff, 1444px 256px #fff, 661px 1628px #fff,
        1078px 1716px #fff, 300px 737px #fff, 1734px 413px #fff, 1296px 129px #fff,
        1771px 1678px #fff, 977px 1764px #fff, 1879px 549px #fff, 665px 1531px #fff,
        89px 701px #fff, 1084px 1183px #fff, 1597px 1576px #fff, 1354px 1774px #fff,
        554px 1471px #fff, 1469px 287px #fff, 887px 106px #fff, 1962px 766px #fff,
        638px 805px #fff, 1651px 741px #fff, 1517px 1826px #fff, 24px 1152px #fff,
        507px 558px #fff, 1262px 652px #fff, 246px 1048px #fff, 1077px 421px #fff,
        1866px 1847px #fff, 1986px 1561px #fff, 704px 632px #fff, 1991px 1875px #fff,
        1227px 395px #fff, 45px 1116px #fff, 247px 786px #fff, 890px 607px #fff,
        787px 1235px #fff, 557px 524px #fff, 1582px 1285px #fff, 1725px 1366px #fff,
        952px 747px #fff, 251px 458px #fff, 1500px 1250px #fff, 1999px 1734px #fff,
        1336px 1955px #fff, 1705px 1464px #fff, 728px 697px #fff, 594px 510px #fff,
        1345px 1990px #fff, 1919px 1803px #fff, 1117px 966px #fff, 1629px 97px #fff,
        1046px 1196px #fff, 810px 1092px #fff, 722px 976px #fff, 406px 18px #fff,
        1665px 1860px #fff, 1758px 1628px #fff, 1183px 463px #fff, 564px 239px #fff,
        13px 1767px #fff, 1482px 1472px #fff, 1700px 347px #fff, 1362px 244px #fff,
        1141px 1708px #fff, 22px 885px #fff, 374px 1309px #fff, 1034px 1037px #fff,
        1725px 1086px #fff, 1343px 1921px #fff, 596px 903px #fff, 1061px 478px #fff,
        18px 1409px #fff, 729px 1364px #fff, 264px 911px #fff, 677px 1442px #fff,
        123px 33px #fff, 1303px 646px #fff, 1945px 792px #fff, 1305px 938px #fff,
        918px 1536px #fff, 620px 948px #fff, 183px 646px #fff, 695px 687px #fff,
        881px 272px #fff, 1521px 1212px #fff, 1423px 1022px #fff, 1545px 1271px #fff,
        1393px 348px #fff, 685px 1910px #fff, 1446px 856px #fff, 73px 1201px #fff,
        736px 999px #fff, 673px 796px #fff, 469px 850px #fff, 1912px 142px #fff,
        1278px 664px #fff, 184px 1990px #fff, 1173px 1312px #fff, 782px 1879px #fff,
        323px 1035px #fff, 611px 908px #fff, 565px 1449px #fff, 748px 1713px #fff,
        1047px 490px #fff, 1040px 1872px #fff, 1818px 1659px #fff, 1806px 1327px #fff,
        386px 575px #fff, 1550px 463px #fff, 148px 687px #fff, 651px 1683px #fff,
        1588px 1194px #fff, 1831px 2px #fff, 581px 876px #fff, 1396px 1743px #fff,
        1212px 1810px #fff, 421px 1920px #fff, 658px 1461px #fff, 1859px 1809px #fff,
        1456px 388px #fff, 186px 1627px #fff, 1528px 1145px #fff, 171px 97px #fff,
        674px 1072px #fff, 676px 1052px #fff, 1165px 1131px #fff, 1088px 781px #fff,
        1231px 948px #fff, 330px 257px #fff, 426px 1046px #fff, 549px 652px #fff,
        1338px 74px #fff, 1749px 364px #fff, 931px 369px #fff, 383px 1428px #fff,
        1558px 389px #fff, 927px 133px #fff, 234px 1888px #fff, 1785px 1617px #fff,
        556px 643px #fff, 401px 275px #fff, 406px 1644px #fff, 1253px 1852px #fff,
        1599px 883px #fff, 744px 1721px #fff, 524px 1297px #fff, 1226px 1177px #fff,
        1679px 55px #fff, 874px 1811px #fff, 838px 790px #fff, 1241px 430px #fff,
        1676px 652px #fff, 1191px 568px #fff, 53px 1990px #fff, 1163px 237px #fff,
        61px 223px #fff, 592px 456px #fff, 1844px 271px #fff, 1324px 1488px #fff,
        1373px 717px #fff, 1822px 709px #fff, 1464px 941px #fff, 1445px 1118px #fff,
        991px 1414px #fff, 1964px 1076px #fff, 108px 172px #fff, 641px 1722px #fff,
        1539px 427px #fff, 1697px 45px #fff, 1301px 1353px #fff, 1060px 329px #fff,
        967px 1396px #fff, 493px 301px #fff, 1228px 1406px #fff, 1211px 1653px #fff,
        444px 1822px #fff, 1746px 353px #fff, 1449px 381px #fff, 671px 887px #fff,
        650px 138px #fff, 30px 1839px #fff, 1094px 1405px #fff, 273px 796px #fff,
        1618px 1964px #fff, 1045px 1849px #fff, 1472px 1155px #fff, 1529px 1312px #fff,
        728px 448px #fff, 44px 1908px #fff, 691px 818px #fff, 254px 293px #fff,
        1981px 1133px #fff, 1307px 375px #fff, 196px 316px #fff, 1241px 1975px #fff,
        1138px 1706px #fff, 1769px 463px #fff, 1768px 1428px #fff, 1730px 590px #fff,
        1780px 523px #fff, 1862px 1526px #fff, 1613px 909px #fff, 1266px 1781px #fff,
        470px 352px #fff, 699px 1682px #fff, 1002px 614px #fff, 1209px 133px #fff,
        1842px 518px #fff, 1422px 1836px #fff, 1720px 1901px #fff, 470px 1788px #fff,
        1355px 1387px #fff, 146px 1162px #fff, 933px 80px #fff, 681px 1063px #fff,
        313px 1341px #fff, 740px 1498px #fff, 168px 1014px #fff, 345px 1355px #fff,
        1498px 1562px #fff, 1626px 1358px #fff, 890px 403px #fff, 663px 562px #fff,
        1481px 168px #fff, 22px 719px #fff, 774px 1041px #fff, 1899px 829px #fff,
        430px 158px #fff, 430px 361px #fff, 1592px 1334px #fff, 224px 323px #fff,
        1639px 1131px #fff, 7px 271px #fff, 1646px 1514px #fff, 1605px 1444px #fff,
        1820px 1665px #fff, 1549px 1641px #fff, 1609px 1377px #fff, 486px 1098px #fff,
        229px 613px #fff, 542px 1694px #fff, 318px 256px #fff, 1861px 918px #fff,
        889px 892px #fff, 442px 1524px #fff, 19px 422px #fff, 1935px 1908px #fff,
        828px 109px #fff, 862px 1248px #fff, 1275px 560px #fff, 906px 63px #fff,
        337px 1605px #fff, 1691px 918px #fff, 1414px 679px #fff, 1726px 749px #fff,
        1540px 1149px #fff, 1337px 1466px #fff, 446px 430px #fff, 676px 1616px #fff,
        840px 326px #fff, 976px 977px #fff, 1840px 642px #fff, 1273px 804px #fff,
        1071px 928px #fff, 1292px 1675px #fff, 29px 1148px #fff, 1585px 135px #fff,
        1007px 563px #fff, 1035px 78px #fff, 1174px 574px #fff, 120px 1304px #fff,
        845px 1292px #fff, 861px 540px #fff, 234px 232px #fff, 1940px 1367px #fff,
        759px 639px #fff, 1775px 1381px #fff, 906px 372px #fff, 1104px 1165px #fff,
        1524px 911px #fff, 1882px 330px #fff, 1389px 700px #fff, 300px 1629px #fff,
        220px 1614px #fff, 563px 140px #fff, 1611px 1586px #fff, 793px 1316px #fff,
        325px 1070px #fff, 1722px 1462px #fff, 1406px 1120px #fff, 1169px 1768px #fff,
        1956px 1053px #fff, 959px 1587px #fff, 585px 1566px #fff, 370px 204px #fff,
        1606px 1416px #fff, 443px 1606px #fff, 1499px 1102px #fff, 1943px 105px #fff,
        1121px 1594px #fff, 1512px 32px #fff, 871px 1425px #fff, 433px 100px #fff,
        294px 1471px #fff, 1688px 1755px #fff, 1666px 591px #fff, 1034px 300px #fff,
        734px 1178px #fff, 1342px 313px #fff, 1616px 1590px #fff, 1763px 1472px #fff,
        632px 1935px #fff, 1708px 872px #fff, 1871px 915px #fff, 1829px 1020px #fff,
        1599px 578px #fff, 42px 585px #fff, 1163px 1382px #fff, 1744px 1272px #fff,
        984px 1426px #fff, 1786px 1584px #fff, 1813px 379px #fff, 1867px 1127px #fff,
        97px 567px #fff, 626px 988px #fff, 1178px 79px #fff, 1703px 211px #fff,
        961px 1785px #fff, 110px 975px #fff, 953px 1941px #fff, 1027px 1790px #fff,
        1665px 107px #fff, 11px 964px #fff, 1718px 1147px #fff, 21px 1728px #fff,
        1358px 1922px #fff, 872px 65px #fff, 1191px 1635px #fff, 762px 681px #fff,
        1519px 1033px #fff, 906px 566px #fff, 1074px 657px #fff, 1093px 415px #fff,
        51px 198px #fff, 1075px 1418px #fff, 1547px 1070px #fff, 225px 920px #fff,
        850px 1974px #fff, 981px 595px #fff, 1425px 131px #fff, 460px 917px #fff,
        56px 495px #fff, 714px 428px #fff, 920px 493px #fff, 470px 1521px #fff,
        532px 821px #fff, 1905px 71px #fff, 883px 1501px #fff, 294px 196px #fff,
        381px 1999px #fff, 332px 793px #fff, 1246px 408px #fff, 233px 149px #fff,
        315px 231px #fff, 1594px 1302px #fff, 696px 1585px #fff, 791px 136px #fff,
        479px 199px #fff, 1627px 1413px #fff, 1824px 924px #fff, 1631px 342px #fff,
        1251px 1151px #fff, 284px 1781px #fff, 497px 1052px #fff, 204px 1161px #fff,
        646px 1499px #fff, 1762px 558px #fff, 854px 1833px #fff, 883px 945px #fff,
        44px 982px #fff, 1101px 834px #fff, 515px 1748px #fff, 1578px 1435px #fff,
        819px 1258px #fff, 776px 670px #fff, 115px 385px #fff, 1478px 434px #fff,
        885px 20px #fff, 192px 1513px #fff, 78px 1129px #fff, 1774px 1105px #fff,
        955px 1149px #fff, 1817px 1929px #fff, 1106px 1832px #fff, 1107px 1997px #fff,
        94px 23px #fff, 243px 982px #fff, 43px 1972px #fff, 1798px 673px #fff,
        1131px 1589px #fff, 841px 14px #fff, 826px 345px #fff, 687px 56px #fff,
        1084px 32px #fff, 1887px 1878px #fff, 153px 526px #fff, 1828px 253px #fff,
        1947px 1105px #fff, 886px 700px #fff, 1307px 1723px #fff, 1274px 651px #fff,
        1530px 837px #fff, 1699px 1637px #fff, 1703px 1331px #fff, 1929px 1557px #fff,
        1763px 737px #fff, 1118px 1680px #fff, 1545px 692px #fff, 1462px 1092px #fff,
        208px 1667px #fff, 1393px 859px #fff, 186px 1794px #fff, 351px 1199px #fff,
        642px 1995px #fff, 1061px 1726px #fff, 1708px 115px #fff, 1233px 1305px #fff,
        637px 1786px #fff, 1730px 603px #fff, 75px 1240px #fff, 1704px 1326px #fff,
        584px 346px #fff, 438px 1554px #fff, 561px 513px #fff, 1382px 225px #fff,
        467px 1674px #fff, 1403px 815px #fff, 1546px 1835px #fff, 127px 1119px #fff,
        276px 591px #fff, 688px 1458px #fff, 765px 646px #fff, 474px 984px #fff,
        171px 361px #fff, 94px 1480px #fff, 1962px 1666px #fff, 909px 1037px #fff,
        1725px 222px #fff, 253px 1355px #fff, 1892px 1901px #fff, 275px 1847px #fff,
        28px 1184px #fff, 1725px 1382px #fff, 882px 647px #fff, 1935px 1046px #fff,
        10px 344px #fff, 292px 1328px #fff, 127px 1352px #fff, 752px 929px #fff,
        1589px 384px #fff, 284px 1829px #fff, 381px 820px #fff, 1229px 1125px #fff,
        777px 429px #fff, 1811px 1499px #fff, 1573px 287px #fff, 295px 756px #fff,
        389px 616px #fff, 781px 41px #fff, 1092px 333px #fff, 794px 1588px #fff,
        386px 1847px #fff, 1802px 710px #fff, 662px 60px #fff, 640px 264px #fff,
        463px 746px #fff, 1859px 799px #fff, 763px 37px #fff, 639px 396px #fff,
        357px 1071px #fff, 1190px 1430px #fff, 1814px 257px #fff, 1382px 235px #fff,
        606px 1304px #fff, 1939px 1470px #fff, 1124px 349px #fff, 307px 1567px #fff,
        310px 1323px #fff, 1145px 922px #fff, 1196px 1922px #fff, 1647px 544px #fff,
        788px 1337px #fff, 257px 632px #fff, 1413px 414px #fff, 590px 620px #fff,
        582px 794px #fff, 1702px 1481px #fff, 1055px 53px #fff, 157px 346px #fff,
        50px 1901px #fff, 1038px 1369px #fff, 796px 1941px #fff, 215px 194px #fff,
        1567px 1538px #fff, 367px 800px #fff, 1044px 489px #fff, 1109px 1712px #fff,
        524px 327px #fff, 525px 1252px #fff, 1475px 1240px #fff, 529px 436px #fff,
        795px 834px #fff, 122px 1371px #fff, 79px 482px #fff, 520px 1249px #fff,
        336px 1878px #fff, 188px 944px #fff, 325px 1259px #fff, 1491px 1942px #fff,
        620px 1054px #fff, 1606px 1153px #fff, 1448px 502px #fff, 53px 1381px #fff,
        107px 1670px #fff, 1380px 618px #fff, 967px 1557px #fff, 1116px 1722px #fff,
        1174px 1044px #fff, 1805px 717px #fff, 663px 394px #fff, 1848px 1007px #fff,
        389px 802px #fff, 49px 392px #fff, 1650px 852px #fff, 1678px 1012px #fff,
        335px 1009px #fff, 1818px 1631px #fff, 1568px 742px #fff, 1162px 1991px #fff,
        52px 1190px #fff, 1401px 928px #fff, 119px 1549px #fff, 537px 1529px #fff,
        2px 1709px #fff, 122px 387px #fff, 543px 2px #fff, 27px 1971px #fff,
        507px 1377px #fff, 1362px 1080px #fff, 1031px 1544px #fff, 1631px 1174px #fff,
        1603px 312px #fff, 1626px 1422px #fff, 1430px 615px #fff, 1958px 1431px #fff,
        1946px 1412px #fff, 1848px 247px #fff, 984px 1808px #fff, 1396px 225px #fff,
        319px 717px #fff, 1252px 875px #fff, 1619px 156px #fff, 951px 1971px #fff,
        386px 355px #fff, 1406px 1151px #fff, 273px 1538px #fff, 844px 1570px #fff,
        947px 151px #fff, 1363px 525px #fff, 209px 307px #fff, 1923px 1718px #fff,
        993px 1741px #fff, 1513px 353px #fff, 1353px 61px #fff, 664px 352px #fff,
        1382px 359px #fff, 1487px 1707px #fff, 657px 1045px #fff, 1107px 490px #fff,
        1834px 1176px #fff, 837px 1438px #fff, 1947px 448px #fff, 1196px 333px #fff,
        151px 555px #fff, 18px 992px #fff, 458px 748px #fff, 1801px 890px #fff,
        1093px 1012px #fff, 315px 1101px #fff, 194px 323px #fff, 754px 292px #fff,
        1737px 7px #fff, 40px 840px #fff, 1170px 805px #fff, 176px 1753px #fff,
        805px 1148px #fff, 1578px 1271px #fff, 367px 1494px #fff, 363px 1111px #fff,
        1955px 243px #fff, 1451px 1093px #fff, 375px 617px #fff, 1223px 720px #fff,
        1178px 13px #fff, 1456px 865px #fff, 1440px 49px #fff, 186px 1569px #fff,
        320px 1853px #fff, 300px 539px #fff, 1559px 509px #fff, 1985px 1108px #fff,
        1588px 828px #fff, 525px 1432px #fff, 831px 363px #fff, 141px 281px #fff,
        1319px 402px #fff, 40px 456px #fff, 1955px 478px #fff, 1758px 818px #fff,
        1924px 688px #fff, 1030px 953px #fff, 1982px 210px #fff, 917px 1401px #fff,
        1051px 1837px #fff, 1045px 463px #fff, 1744px 573px #fff, 529px 1530px #fff,
        542px 469px #fff, 1982px 324px #fff, 1902px 1422px #fff, 1968px 782px #fff,
        1666px 1561px #fff, 955px 304px #fff, 323px 778px #fff, 272px 443px #fff,
        485px 581px #fff, 1353px 1058px #fff, 1257px 131px #fff, 434px 98px #fff,
        1587px 1953px #fff, 1749px 68px #fff, 1984px 839px #fff, 1518px 183px #fff,
        1071px 855px #fff, 1662px 1994px #fff, 1111px 106px #fff, 1954px 838px #fff;
    animation: animStar 50s linear infinite;
}
#stars::after {
    content: ' ';
    position: absolute;
    top: 2000px;
    width: 1px;
    height: 1px;
    background: transparent;
    box-shadow: inherit;
}

#stars2 {
    width: 2px;
    height: 2px;
    background: transparent;
    box-shadow:
        1925px 1320px #fff, 693px 1778px #fff, 1016px 711px #fff, 1171px 563px #fff,
        661px 1919px #fff, 1610px 44px #fff, 1275px 140px #fff, 1208px 1802px #fff,
        1473px 1587px #fff, 11px 1117px #fff, 853px 1757px #fff, 1149px 937px #fff,
        1353px 428px #fff, 270px 279px #fff, 258px 1404px #fff, 417px 1188px #fff,
        286px 561px #fff, 393px 1765px #fff, 147px 881px #fff, 666px 1097px #fff,
        1425px 1278px #fff, 806px 156px #fff, 1252px 561px #fff, 218px 52px #fff,
        1371px 1980px #fff, 171px 745px #fff, 1424px 89px #fff, 137px 244px #fff,
        939px 1922px #fff, 137px 1080px #fff, 1757px 50px #fff, 904px 536px #fff,
        1938px 1001px #fff, 1172px 440px #fff, 72px 1475px #fff, 102px 121px #fff,
        804px 1671px #fff, 1314px 270px #fff, 440px 1341px #fff, 1216px 511px #fff,
        1061px 1523px #fff, 97px 274px #fff, 704px 1318px #fff, 52px 1872px #fff,
        1962px 296px #fff, 111px 289px #fff, 1157px 1236px #fff, 1347px 1451px #fff,
        820px 286px #fff, 1389px 1169px #fff, 644px 841px #fff, 1286px 522px #fff,
        955px 659px #fff, 428px 1805px #fff, 237px 557px #fff, 1689px 1058px #fff,
        636px 1882px #fff, 1349px 1664px #fff, 1548px 432px #fff, 1841px 504px #fff,
        302px 252px #fff, 827px 1765px #fff, 620px 123px #fff, 207px 748px #fff,
        1454px 1234px #fff, 1967px 1790px #fff, 542px 33px #fff, 742px 1214px #fff,
        255px 1402px #fff, 74px 1772px #fff, 699px 475px #fff, 980px 1253px #fff,
        534px 1676px #fff, 909px 202px #fff, 1498px 1251px #fff, 1796px 120px #fff,
        1409px 1263px #fff, 1627px 995px #fff, 969px 710px #fff, 1674px 676px #fff,
        1832px 759px #fff, 1623px 563px #fff, 251px 1790px #fff, 96px 1688px #fff,
        886px 239px #fff, 778px 150px #fff, 1767px 430px #fff, 765px 1259px #fff,
        1189px 877px #fff, 444px 1629px #fff, 1560px 324px #fff, 1952px 1097px #fff,
        712px 1173px #fff, 541px 911px #fff, 827px 1420px #fff, 1233px 285px #fff,
        784px 546px #fff, 645px 285px #fff, 1273px 1255px #fff, 1821px 174px #fff,
        221px 1795px #fff, 1004px 456px #fff, 1298px 941px #fff, 274px 387px #fff,
        174px 376px #fff, 1491px 258px #fff, 1489px 1946px #fff, 1134px 1382px #fff,
        1289px 1145px #fff, 464px 358px #fff, 1249px 1842px #fff, 1665px 831px #fff,
        1982px 84px #fff, 541px 774px #fff, 1994px 523px #fff, 762px 1644px #fff,
        1730px 867px #fff, 1951px 1287px #fff, 911px 1691px #fff, 1454px 725px #fff,
        1287px 1940px #fff, 70px 564px #fff, 1980px 638px #fff, 1674px 1774px #fff,
        1720px 116px #fff, 1747px 182px #fff, 1040px 450px #fff, 1795px 375px #fff,
        857px 1471px #fff, 1326px 1730px #fff, 915px 274px #fff, 1224px 358px #fff,
        1808px 60px #fff, 43px 1870px #fff, 1810px 1536px #fff, 1564px 1719px #fff,
        731px 1388px #fff, 1953px 1967px #fff, 1744px 1119px #fff, 794px 1384px #fff,
        959px 714px #fff, 18px 1932px #fff, 1358px 1437px #fff, 355px 939px #fff,
        1355px 1648px #fff, 608px 719px #fff, 383px 758px #fff, 1164px 1681px #fff,
        1045px 253px #fff, 424px 1279px #fff, 1899px 359px #fff, 379px 488px #fff,
        214px 465px #fff, 179px 905px #fff, 830px 1993px #fff, 448px 1077px #fff,
        1880px 1354px #fff, 1973px 347px #fff, 745px 1025px #fff, 788px 1007px #fff,
        1377px 883px #fff, 6px 290px #fff, 1312px 407px #fff, 1398px 622px #fff,
        1405px 339px #fff, 1198px 1709px #fff, 988px 1226px #fff, 87px 1459px #fff,
        1113px 1698px #fff, 997px 732px #fff, 708px 331px #fff, 1876px 1112px #fff,
        1729px 1797px #fff, 719px 703px #fff, 1295px 522px #fff, 758px 1061px #fff,
        1309px 1014px #fff, 1327px 1365px #fff, 854px 1317px #fff, 531px 1001px #fff,
        1751px 1040px #fff, 1354px 190px #fff, 800px 1538px #fff, 88px 1455px #fff,
        668px 39px #fff, 1379px 41px #fff, 892px 524px #fff, 54px 649px #fff,
        1289px 730px #fff, 727px 488px #fff, 181px 842px #fff, 1230px 64px #fff,
        3px 857px #fff, 292px 1201px #fff, 1343px 673px #fff, 1096px 1412px #fff,
        1520px 292px #fff, 104px 1683px #fff, 934px 1387px #fff, 314px 739px #fff;
    animation: animStar 100s linear infinite;
}
#stars2::after {
    content: ' ';
    position: absolute;
    top: 2000px;
    width: 2px;
    height: 2px;
    background: transparent;
    box-shadow: inherit;
}

#stars3 {
    width: 3px;
    height: 3px;
    background: transparent;
    box-shadow:
        200px 981px #fff, 1731px 521px #fff, 132px 1039px #fff, 1888px 1547px #fff,
        899px 1226px #fff, 1887px 580px #fff, 1548px 1092px #fff, 1626px 689px #fff,
        254px 1072px #fff, 1684px 1211px #fff, 672px 1267px #fff, 939px 668px #fff,
        1969px 645px #fff, 1126px 983px #fff, 457px 568px #fff, 476px 876px #fff,
        829px 1896px #fff, 1364px 1846px #fff, 1507px 1120px #fff, 936px 1948px #fff,
        1833px 832px #fff, 1424px 285px #fff, 1377px 1596px #fff, 432px 153px #fff,
        1348px 1410px #fff, 1529px 954px #fff, 1102px 387px #fff, 264px 297px #fff,
        811px 977px #fff, 1931px 673px #fff, 1734px 978px #fff, 1772px 1567px #fff,
        1197px 1400px #fff, 764px 282px #fff, 1103px 822px #fff, 872px 1803px #fff,
        1057px 1763px #fff, 52px 1299px #fff, 1312px 1236px #fff, 235px 1082px #fff,
        299px 1086px #fff, 1017px 1602px #fff, 1950px 626px #fff, 1306px 132px #fff,
        1358px 1618px #fff, 1873px 1718px #fff, 1447px 940px #fff, 1888px 1195px #fff,
        1704px 1765px #fff, 872px 1357px #fff, 1555px 1120px #fff, 250px 1415px #fff,
        450px 415px #fff, 492px 901px #fff, 170px 1641px #fff, 56px 1129px #fff,
        627px 1514px #fff, 1221px 500px #fff, 324px 1895px #fff, 1397px 1775px #fff,
        1966px 598px #fff, 1550px 763px #fff, 326px 1605px #fff, 261px 969px #fff,
        890px 281px #fff, 736px 544px #fff, 589px 1262px #fff, 1581px 368px #fff,
        1900px 1132px #fff, 1914px 585px #fff, 1864px 1517px #fff, 241px 217px #fff,
        859px 787px #fff, 996px 1729px #fff, 741px 121px #fff, 418px 414px #fff,
        142px 967px #fff, 387px 896px #fff, 703px 562px #fff, 968px 1136px #fff,
        1682px 332px #fff, 1287px 846px #fff, 256px 1427px #fff, 1885px 432px #fff,
        1739px 1458px #fff, 345px 1769px #fff, 1140px 1612px #fff, 192px 1921px #fff,
        920px 471px #fff, 834px 881px #fff, 917px 1803px #fff, 466px 1266px #fff,
        483px 1108px #fff, 689px 986px #fff, 1279px 786px #fff, 458px 910px #fff,
        1250px 870px #fff, 785px 1654px #fff, 1543px 1757px #fff, 287px 1272px #fff;
    animation: animStar 150s linear infinite;
}
#stars3::after {
    content: ' ';
    position: absolute;
    top: 2000px;
    width: 3px;
    height: 3px;
    background: transparent;
    box-shadow: inherit;
}

@keyframes animStar {
    from { transform: translateY(0px); }
    to   { transform: translateY(-2000px); }
}

/* ===== FOOTER ===== */
.footer {
    background-color: var(--bg-primary);
    border-top: 1px solid var(--border-color);
    padding: var(--spacing-lg) 0;
    margin-top: var(--spacing-2xl);
}

.footer-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
}

.footer p,
.footer a {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
    .navbar-toggle {
        display: block;
    }

    .navbar-menu {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background-color: var(--bg-primary);
        border-top: 1px solid var(--border-color);
        flex-direction: column;
        align-items: stretch;
        max-height: 0;
        overflow: hidden;
        transition: max-height var(--transition-base);
    }

    .navbar-menu.active {
        max-height: 400px;
        box-shadow: var(--shadow-md);
    }

    .navbar-item {
        padding: var(--spacing-md) var(--spacing-lg);
        border-radius: 0;
    }

    .cards-grid {
        grid-template-columns: 1fr;
    }

    .filter-row {
        grid-template-columns: 1fr;
    }

    .footer-container {
        flex-direction: column;
        text-align: center;
    }

    .modal {
        width: 95%;
    }
}

/* ===== ANIMATIONS ===== */
@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes slideUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.fade-in {
    animation: fadeIn var(--transition-base);
}

.slide-up {
    animation: slideUp var(--transition-base);
}

/* ===== LOADING SPINNER ===== */
.loading-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: white;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* ===== CHARTS ===== */
.chart-container {
    position: relative;
    height: 300px;
    margin: var(--spacing-lg) 0;
}

/* ===== CATEGORY ICON ===== */
.category-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: white;
}

/* ===== TRANSACTION LIST ===== */
.transaction-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
    transition: background-color var(--transition-fast);
}

.transaction-item:hover {
    background-color: var(--bg-secondary);
}

.transaction-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.transaction-details h4 {
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
}

.transaction-details p {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.transaction-amount {
    font-size: 1.125rem;
    font-weight: 600;
}

.transaction-amount.income {
    color: var(--success-color);
}

.transaction-amount.expense {
    color: var(--danger-color);
}

/* ===== EMPTY STATE ===== */
.empty-state {
    text-align: center;
    padding: var(--spacing-2xl);
    color: var(--text-secondary);
}

.empty-state i {
    font-size: 4rem;
    margin-bottom: var(--spacing-lg);
    opacity: 0.3;
}

.empty-state h3 {
    margin-bottom: var(--spacing-sm);
    color: var(--text-primary);
}

/* ===== NAVBAR SEARCH ===== */
.navbar-search {
    position: relative;
    flex: 1;
    max-width: 360px;
    min-width: 0;
}

.search-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.search-icon {
    position: absolute;
    left: var(--spacing-md);
    color: var(--text-light);
    pointer-events: none;
    z-index: 1;
    font-size: 0.875rem;
}

.search-input {
    width: 100%;
    padding: 0.5rem var(--spacing-xl) 0.5rem 2.25rem;
    border: 1px solid var(--border-color);
    border-radius: 9999px;
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    font-size: 0.875rem;
    transition: all var(--transition-fast);
}

.search-input:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
    background-color: var(--bg-primary);
}

.search-clear {
    position: absolute;
    right: var(--spacing-md);
    background: transparent;
    color: var(--text-light);
    font-size: 0.8rem;
    line-height: 1;
    padding: 2px;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-fast);
    border-radius: 50%;
}

.search-clear.visible {
    opacity: 1;
    pointer-events: auto;
}

.search-clear:hover {
    color: var(--text-secondary);
}

.search-results {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    background-color: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    z-index: 2000;
    max-height: 380px;
    overflow-y: auto;
    display: none;
    animation: slideUp var(--transition-fast);
}

.search-results.open {
    display: block;
}

.search-result-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    cursor: pointer;
    transition: background-color var(--transition-fast);
    text-decoration: none;
    color: var(--text-primary);
    border-radius: 0;
}

.search-results .search-result-item:first-child { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.search-results .search-result-item:last-child  { border-radius: 0 0 var(--radius-lg) var(--radius-lg); }
.search-results .search-result-item:only-child  { border-radius: var(--radius-lg); }

.search-result-item:hover,
.search-result-item.focused {
    background-color: var(--bg-secondary);
}

.search-result-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    color: white;
    flex-shrink: 0;
}

.search-result-text {
    flex: 1;
    min-width: 0;
}

.search-result-label {
    font-size: 0.875rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-result-sublabel {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.search-no-results,
.search-loading {
    padding: var(--spacing-lg) var(--spacing-md);
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* ===== TAG CHIPS ===== */
.tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px var(--spacing-sm);
    border-radius: 9999px;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.2px;
    cursor: pointer;
    transition: opacity var(--transition-fast), transform var(--transition-fast);
    text-decoration: none;
}

.tag-chip:hover {
    opacity: 0.8;
    transform: translateY(-1px);
}

.tag-chip-sm {
    display: inline-flex;
    align-items: center;
    padding: 1px 6px;
    border-radius: 9999px;
    font-size: 0.68rem;
    font-weight: 600;
    margin-left: 4px;
    vertical-align: middle;
}

.tag-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-sm);
}

/* ===== DASHBOARD LAYOUT ===== */
.dashboard-page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-xl);
    gap: var(--spacing-md);
}

.dashboard-widget {
    transition: box-shadow var(--transition-base), opacity var(--transition-base), transform var(--transition-fast);
    margin-bottom: var(--spacing-lg);
}

.dashboard-widget.mb-2 {
    margin-bottom: var(--spacing-lg);
}

.widget-hidden > .widget-content {
    display: none;
}

.widget-hidden {
    opacity: 0.5;
}

/* Customize active mode */
body.customize-active .drag-handle {
    display: flex !important;
    cursor: grab;
}

body.customize-active .drag-handle:active {
    cursor: grabbing;
}

body.customize-active .widget-controls {
    display: flex !important;
}

body.customize-active .dashboard-widget {
    user-select: none;
}

body.customize-active .dashboard-widget:hover {
    box-shadow: var(--shadow-md);
}

body.customize-active .dashboard-widget.dragging {
    opacity: 0.35;
    transform: scale(0.985);
    box-shadow: var(--shadow-xl);
}

body.customize-active .dashboard-widget.drag-over {
    outline: 2px dashed var(--primary-color);
    outline-offset: 2px;
    background-color: rgba(37, 99, 235, 0.03);
}

/* Widget header */
.widget-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: nowrap;
}

.drag-handle {
    display: none;
    align-items: center;
    justify-content: center;
    color: var(--text-light);
    padding: 4px;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
    transition: color var(--transition-fast);
    font-size: 0.875rem;
}

.drag-handle:hover {
    color: var(--text-secondary);
}

.widget-header .card-title {
    flex: 1;
    min-width: 0;
}

.widget-view-all {
    flex-shrink: 0;
    font-size: 0.8rem;
}

.widget-controls {
    display: none;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

.widget-toggle-btn,
.widget-move-btn {
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    transition: all var(--transition-fast);
    cursor: pointer;
}

.widget-toggle-btn:hover,
.widget-move-btn:hover {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
    border-color: var(--text-light);
}

.widget-move-btns {
    display: flex;
    gap: 2px;
}

/* Customize bar — slides up from bottom */
.customize-bar {
    position: fixed;
    bottom: -90px;
    left: 0;
    right: 0;
    background-color: var(--bg-primary);
    border-top: 2px solid var(--primary-color);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.12);
    z-index: 1500;
    transition: bottom var(--transition-base);
    padding: var(--spacing-md) var(--spacing-lg);
}

.customize-bar.open {
    bottom: 0;
}

.customize-bar-content {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-md);
    flex-wrap: wrap;
}

.customize-bar-hint {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 0.8rem;
    color: var(--text-secondary);
}

/* ===== DASHBOARD STATS INLINE ===== */
.stats-grid-inline {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-md);
}

.stat-inline {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    background-color: var(--bg-secondary);
    transition: background-color var(--transition-fast);
}

.stat-inline:hover {
    background-color: var(--bg-tertiary);
}

.stat-inline-icon {
    width: 46px;
    height: 46px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    flex-shrink: 0;
}

.stat-inline .stat-value {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 2px;
}

.stat-inline .stat-label {
    font-size: 0.75rem;
    margin-top: 0;
}

.stat-green { color: var(--success-color); }
.stat-red   { color: var(--danger-color); }

/* ===== BUDGET PROGRESS BARS ===== */
.budget-row {
    margin-bottom: var(--spacing-lg);
}

.budget-row:last-child {
    margin-bottom: 0;
}

.progress-bar-track {
    background-color: var(--bg-tertiary);
    height: 8px;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 4px;
}

.progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary-color), var(--primary-light));
    border-radius: 4px;
    transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.progress-bar-fill.exceeded {
    background: linear-gradient(90deg, var(--danger-color), #f87171);
}

/* ===== QUICK ACTIONS GRID ===== */
.quick-actions-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.quick-action-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-lg);
    background-color: var(--bg-secondary);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    text-decoration: none;
    transition: all var(--transition-fast);
    border: 1px solid transparent;
}

.quick-action-btn:hover {
    background-color: rgba(37, 99, 235, 0.08);
    color: var(--primary-color);
    border-color: rgba(37, 99, 235, 0.3);
    transform: translateY(-2px);
}

.quick-action-btn i {
    font-size: 1.5rem;
}

.quick-action-btn span {
    font-size: 0.8rem;
    font-weight: 500;
    text-align: center;
}

/* ===== REPORTS TAG BREAKDOWN ===== */
.tag-breakdown-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-xl);
}

/* ===== RESPONSIVE ADDITIONS ===== */
@media (max-width: 1024px) {
    .navbar-search {
        max-width: 260px;
    }
}

@media (max-width: 768px) {
    .navbar-container {
        flex-wrap: wrap;
    }

    .navbar-search {
        order: 5;
        max-width: 100%;
        width: 100%;
        padding: var(--spacing-sm) 0 var(--spacing-xs);
    }

    .search-results {
        left: 0;
        right: 0;
    }

    .stats-grid-inline {
        grid-template-columns: repeat(2, 1fr);
    }

    .quick-actions-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .customize-bar-hint {
        display: none;
    }

    .tag-breakdown-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-page-header {
        flex-direction: column;
        gap: var(--spacing-sm);
    }

    .widget-move-btns {
        display: none;
    }

    /* Reports 2-col grids → 1 col on mobile */
    .card > div[style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
    }
}
