/**
 * CatBox - Revolutionary Design System
 * Built from zero with modern health app UX patterns
 * All rules use !important to override WordPress/GeneratePress
 */

/* ============================================
   RESET & BASE - Force override everything
   ============================================ */

body.page-template *,
body.page-template *::before,
body.page-template *::after {
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

/* Remove WordPress defaults */
body.page-template .site-header,
body.page-template .site-footer,
body.page-template .entry-header,
body.page-template .entry-content,
body.page-template .entry-footer,
body.page-template .page-header {
    display: none !important;
}

/* ============================================
   DESIGN TOKENS - Modern Health App System
   ============================================ */

:root {
    /* Colors - Health Status Driven */
    --health-success: #10b981 !important;
    --health-warning: #f59e0b !important;
    --health-danger: #ef4444 !important;
    --health-info: #3b82f6 !important;

    /* Neutrals - Modern gray scale */
    --gray-50: #fafafa !important;
    --gray-100: #f5f5f5 !important;
    --gray-200: #e5e5e5 !important;
    --gray-300: #d4d4d4 !important;
    --gray-400: #a3a3a3 !important;
    --gray-500: #737373 !important;
    --gray-600: #525252 !important;
    --gray-700: #404040 !important;
    --gray-800: #262626 !important;
    --gray-900: #171717 !important;

    /* Primary - Purple accent */
    --primary-50: #faf5ff !important;
    --primary-500: #8b5cf6 !important;
    --primary-600: #7c3aed !important;
    --primary-700: #6d28d9 !important;

    /* Spacing - 4px scale */
    --space-1: 0.25rem !important;  /* 4px */
    --space-2: 0.5rem !important;   /* 8px */
    --space-3: 0.75rem !important;  /* 12px */
    --space-4: 1rem !important;     /* 16px */
    --space-5: 1.25rem !important;  /* 20px */
    --space-6: 1.5rem !important;   /* 24px */
    --space-8: 2rem !important;     /* 32px */
    --space-10: 2.5rem !important;  /* 40px */
    --space-12: 3rem !important;    /* 48px */
    --space-16: 4rem !important;    /* 64px */
    --space-20: 5rem !important;    /* 80px */

    /* Typography - Fluid & Responsive */
    --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem) !important;
    --text-sm: clamp(0.875rem, 0.825rem + 0.25vw, 1rem) !important;
    --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.125rem) !important;
    --text-lg: clamp(1.125rem, 1.05rem + 0.375vw, 1.25rem) !important;
    --text-xl: clamp(1.25rem, 1.15rem + 0.5vw, 1.5rem) !important;
    --text-2xl: clamp(1.5rem, 1.35rem + 0.75vw, 1.875rem) !important;
    --text-3xl: clamp(1.875rem, 1.65rem + 1.125vw, 2.25rem) !important;

    /* Font weights */
    --font-normal: 400 !important;
    --font-medium: 500 !important;
    --font-semibold: 600 !important;
    --font-bold: 700 !important;

    /* Radius - Modern rounded corners */
    --radius-sm: 0.375rem !important;   /* 6px */
    --radius-md: 0.5rem !important;     /* 8px */
    --radius-lg: 0.75rem !important;    /* 12px */
    --radius-xl: 1rem !important;       /* 16px */
    --radius-2xl: 1.5rem !important;    /* 24px */
    --radius-full: 9999px !important;

    /* Shadows - Layered depth */
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05) !important;
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) !important;
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1) !important;
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1) !important;

    /* Transitions */
    --duration-150: 150ms !important;
    --duration-200: 200ms !important;
    --duration-300: 300ms !important;
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1) !important;

    /* Z-index scale */
    --z-base: 1 !important;
    --z-dropdown: 1000 !important;
    --z-sticky: 1020 !important;
    --z-fixed: 1030 !important;
    --z-modal-backdrop: 1040 !important;
    --z-modal: 1050 !important;
    --z-toast: 1060 !important;
}

/* ============================================
   GLOBAL LAYOUT - App Container
   ============================================ */

body.page-template {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    background: var(--gray-50) !important;
    color: var(--gray-900) !important;
    font-size: var(--text-base) !important;
    line-height: 1.5 !important;
    min-height: 100vh !important;
}

/* Main app wrapper */
.catbox-app {
    width: 100% !important;
    min-height: 100vh !important;
    display: flex !important;
    flex-direction: column !important;
    background: var(--gray-50) !important;
}

/* Container with max-width */
.catbox-container {
    width: 100% !important;
    max-width: 1400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--space-4) !important;
    padding-right: var(--space-4) !important;
}

@media (min-width: 768px) {
    .catbox-container {
        padding-left: var(--space-6) !important;
        padding-right: var(--space-6) !important;
    }
}

@media (min-width: 1024px) {
    .catbox-container {
        padding-left: var(--space-8) !important;
        padding-right: var(--space-8) !important;
    }
}

/* ============================================
   HEADER - Sticky navigation
   ============================================ */

.catbox-header {
    position: sticky !important;
    top: 0 !important;
    z-index: var(--z-sticky) !important;
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(12px) !important;
    border-bottom: 1px solid var(--gray-200) !important;
    padding-top: var(--space-4) !important;
    padding-bottom: var(--space-4) !important;
}

.catbox-header-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: var(--space-4) !important;
}

.catbox-header-title {
    display: flex !important;
    align-items: center !important;
    gap: var(--space-3) !important;
}

.catbox-header h1 {
    font-size: var(--text-2xl) !important;
    font-weight: var(--font-bold) !important;
    color: var(--gray-900) !important;
    line-height: 1.2 !important;
}

.catbox-header-subtitle {
    font-size: var(--text-sm) !important;
    color: var(--gray-500) !important;
    margin-top: var(--space-1) !important;
}

.catbox-header-actions {
    display: flex !important;
    align-items: center !important;
    gap: var(--space-3) !important;
    flex-wrap: wrap !important;
}

/* ============================================
   BUTTONS - Touch-friendly (48px min)
   ============================================ */

.catbox-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--space-2) !important;
    padding: var(--space-3) var(--space-5) !important;
    min-height: 48px !important;
    font-size: var(--text-base) !important;
    font-weight: var(--font-medium) !important;
    line-height: 1 !important;
    border: none !important;
    border-radius: var(--radius-lg) !important;
    cursor: pointer !important;
    transition: all var(--duration-150) var(--ease-in-out) !important;
    text-decoration: none !important;
    white-space: nowrap !important;
}

.catbox-btn-primary {
    background: var(--primary-600) !important;
    color: white !important;
}

.catbox-btn-primary:hover {
    background: var(--primary-700) !important;
    transform: translateY(-1px) !important;
    box-shadow: var(--shadow-md) !important;
}

.catbox-btn-secondary {
    background: white !important;
    color: var(--gray-700) !important;
    border: 1px solid var(--gray-300) !important;
}

.catbox-btn-secondary:hover {
    background: var(--gray-50) !important;
    border-color: var(--gray-400) !important;
}

.catbox-btn-success {
    background: var(--health-success) !important;
    color: white !important;
}

.catbox-btn-danger {
    background: var(--health-danger) !important;
    color: white !important;
}

.catbox-btn-ghost {
    background: transparent !important;
    color: var(--gray-700) !important;
}

.catbox-btn-ghost:hover {
    background: var(--gray-100) !important;
}

/* Icon in button */
.catbox-btn svg {
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
}

/* ============================================
   CARDS - Modern health app style
   ============================================ */

.catbox-card {
    background: white !important;
    border: 1px solid var(--gray-200) !important;
    border-radius: var(--radius-xl) !important;
    padding: var(--space-6) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--duration-200) var(--ease-in-out) !important;
}

.catbox-card:hover {
    box-shadow: var(--shadow-md) !important;
    border-color: var(--gray-300) !important;
}

.catbox-card-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: var(--space-4) !important;
    margin-bottom: var(--space-4) !important;
}

.catbox-card-title {
    font-size: var(--text-lg) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
}

.catbox-card-body {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-3) !important;
}

/* ============================================
   DASHBOARD - Cat cards grid
   ============================================ */

.catbox-dashboard {
    padding-top: var(--space-6) !important;
    padding-bottom: var(--space-12) !important;
}

.catbox-cats-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--space-4) !important;
    margin-top: var(--space-6) !important;
}

@media (min-width: 640px) {
    .catbox-cats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--space-5) !important;
    }
}

@media (min-width: 1024px) {
    .catbox-cats-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: var(--space-6) !important;
    }
}

/* Cat card - clickable */
.catbox-cat-card {
    display: flex !important;
    flex-direction: column !important;
    background: white !important;
    border: 1px solid var(--gray-200) !important;
    border-radius: var(--radius-xl) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--duration-200) var(--ease-in-out) !important;
    cursor: pointer !important;
    text-decoration: none !important;
}

.catbox-cat-card:hover {
    box-shadow: var(--shadow-lg) !important;
    transform: translateY(-4px) !important;
    border-color: var(--primary-500) !important;
}

.catbox-cat-photo {
    width: 100% !important;
    height: 240px !important;
    background: var(--gray-100) !important;
    position: relative !important;
    overflow: hidden !important;
}

.catbox-cat-photo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.catbox-cat-body {
    padding: var(--space-5) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-4) !important;
}

.catbox-cat-body h3 {
    font-size: var(--text-xl) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
    margin: 0 !important;
}

.catbox-cat-meta {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-2) !important;
}

.catbox-cat-meta-item {
    display: flex !important;
    align-items: center !important;
    gap: var(--space-2) !important;
    font-size: var(--text-sm) !important;
    color: var(--gray-600) !important;
}

.catbox-cat-meta-item svg {
    width: 16px !important;
    height: 16px !important;
    color: var(--gray-400) !important;
    flex-shrink: 0 !important;
}

/* Health status badge on cat card */
.catbox-health-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: var(--space-2) !important;
    padding: var(--space-2) var(--space-3) !important;
    border-radius: var(--radius-full) !important;
    font-size: var(--text-xs) !important;
    font-weight: var(--font-medium) !important;
    margin-top: var(--space-2) !important;
}

.catbox-health-badge.success {
    background: rgba(16, 185, 129, 0.1) !important;
    color: var(--health-success) !important;
}

.catbox-health-badge.warning {
    background: rgba(245, 158, 11, 0.1) !important;
    color: var(--health-warning) !important;
}

.catbox-health-badge.danger {
    background: rgba(239, 68, 68, 0.1) !important;
    color: var(--health-danger) !important;
}

/* Empty state */
.catbox-empty {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--space-16) var(--space-4) !important;
    text-align: center !important;
}

.catbox-empty-icon {
    width: 120px !important;
    height: 120px !important;
    margin-bottom: var(--space-6) !important;
    opacity: 0.4 !important;
}

.catbox-empty h3 {
    font-size: var(--text-xl) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
    margin-bottom: var(--space-2) !important;
}

.catbox-empty p {
    font-size: var(--text-base) !important;
    color: var(--gray-500) !important;
    margin-bottom: var(--space-6) !important;
}

/* ============================================
   CAT PROFILE - Tab-based interface
   ============================================ */

.catbox-profile {
    padding-top: var(--space-6) !important;
    padding-bottom: var(--space-12) !important;
}

/* Profile hero - Photo + key info */
.catbox-profile-hero {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-6) !important;
    background: white !important;
    border: 1px solid var(--gray-200) !important;
    border-radius: var(--radius-2xl) !important;
    padding: var(--space-6) !important;
    margin-bottom: var(--space-6) !important;
    box-shadow: var(--shadow-sm) !important;
}

@media (min-width: 768px) {
    .catbox-profile-hero {
        flex-direction: row !important;
        align-items: flex-start !important;
    }
}

.catbox-profile-photo-container {
    flex-shrink: 0 !important;
    width: 100% !important;
    max-width: 200px !important;
}

.catbox-profile-photo-container img {
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    object-fit: cover !important;
    border-radius: var(--radius-xl) !important;
    display: block !important;
}

.catbox-profile-info {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-4) !important;
}

.catbox-profile-name-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: var(--space-4) !important;
    flex-wrap: wrap !important;
}

.catbox-profile-name {
    font-size: var(--text-3xl) !important;
    font-weight: var(--font-bold) !important;
    color: var(--gray-900) !important;
}

.catbox-profile-stats {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)) !important;
    gap: var(--space-4) !important;
    margin-top: var(--space-2) !important;
}

.catbox-stat {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-1) !important;
}

.catbox-stat-label {
    font-size: var(--text-xs) !important;
    font-weight: var(--font-medium) !important;
    color: var(--gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.catbox-stat-value {
    font-size: var(--text-lg) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
}

/* Tab navigation */
.catbox-tabs {
    display: flex !important;
    gap: var(--space-2) !important;
    border-bottom: 2px solid var(--gray-200) !important;
    margin-bottom: var(--space-6) !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

.catbox-tab {
    padding: var(--space-3) var(--space-5) !important;
    font-size: var(--text-base) !important;
    font-weight: var(--font-medium) !important;
    color: var(--gray-600) !important;
    background: transparent !important;
    border: none !important;
    border-bottom: 2px solid transparent !important;
    margin-bottom: -2px !important;
    cursor: pointer !important;
    transition: all var(--duration-150) var(--ease-in-out) !important;
    white-space: nowrap !important;
    min-height: 48px !important;
}

.catbox-tab:hover {
    color: var(--gray-900) !important;
}

.catbox-tab.active {
    color: var(--primary-600) !important;
    border-bottom-color: var(--primary-600) !important;
}

/* Tab content */
.catbox-tab-content {
    display: none !important;
}

.catbox-tab-content.active {
    display: block !important;
    animation: fadeIn var(--duration-300) var(--ease-in-out) !important;
}

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

/* ============================================
   TIMELINE - Medical history cards
   ============================================ */

.catbox-timeline {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-4) !important;
}

.catbox-timeline-item {
    display: flex !important;
    gap: var(--space-4) !important;
    background: white !important;
    border: 1px solid var(--gray-200) !important;
    border-radius: var(--radius-xl) !important;
    padding: var(--space-5) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: all var(--duration-200) var(--ease-in-out) !important;
}

.catbox-timeline-item:hover {
    box-shadow: var(--shadow-md) !important;
    border-color: var(--gray-300) !important;
}

/* Timeline icon */
.catbox-timeline-icon {
    flex-shrink: 0 !important;
    width: 48px !important;
    height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--radius-full) !important;
}

.catbox-timeline-icon.success {
    background: rgba(16, 185, 129, 0.1) !important;
    color: var(--health-success) !important;
}

.catbox-timeline-icon.warning {
    background: rgba(245, 158, 11, 0.1) !important;
    color: var(--health-warning) !important;
}

.catbox-timeline-icon.danger {
    background: rgba(239, 68, 68, 0.1) !important;
    color: var(--health-danger) !important;
}

.catbox-timeline-icon.info {
    background: rgba(59, 130, 246, 0.1) !important;
    color: var(--health-info) !important;
}

.catbox-timeline-icon svg {
    width: 24px !important;
    height: 24px !important;
}

/* Timeline content */
.catbox-timeline-content {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-2) !important;
}

.catbox-timeline-header {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: var(--space-4) !important;
}

.catbox-timeline-title {
    font-size: var(--text-base) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
}

.catbox-timeline-date {
    font-size: var(--text-sm) !important;
    color: var(--gray-500) !important;
    white-space: nowrap !important;
}

.catbox-timeline-body {
    font-size: var(--text-sm) !important;
    color: var(--gray-600) !important;
}

.catbox-timeline-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--space-2) !important;
    margin-top: var(--space-2) !important;
}

.catbox-timeline-tag {
    display: inline-flex !important;
    padding: var(--space-1) var(--space-2) !important;
    font-size: var(--text-xs) !important;
    font-weight: var(--font-medium) !important;
    background: var(--gray-100) !important;
    color: var(--gray-600) !important;
    border-radius: var(--radius-sm) !important;
}

/* ============================================
   FORMS - Modern input design
   ============================================ */

.catbox-form {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-5) !important;
}

.catbox-form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-2) !important;
}

.catbox-form-group label {
    font-size: var(--text-sm) !important;
    font-weight: var(--font-medium) !important;
    color: var(--gray-700) !important;
}

.catbox-form-group .required {
    color: var(--health-danger) !important;
}

.catbox-form-group input[type="text"],
.catbox-form-group input[type="email"],
.catbox-form-group input[type="date"],
.catbox-form-group input[type="number"],
.catbox-form-group select,
.catbox-form-group textarea {
    width: 100% !important;
    padding: var(--space-3) var(--space-4) !important;
    min-height: 48px !important;
    font-size: var(--text-base) !important;
    color: var(--gray-900) !important;
    background: white !important;
    border: 1px solid var(--gray-300) !important;
    border-radius: var(--radius-lg) !important;
    transition: all var(--duration-150) var(--ease-in-out) !important;
}

.catbox-form-group input:focus,
.catbox-form-group select:focus,
.catbox-form-group textarea:focus {
    outline: none !important;
    border-color: var(--primary-500) !important;
    box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.1) !important;
}

.catbox-form-group textarea {
    min-height: 120px !important;
    resize: vertical !important;
}

.catbox-form-group small {
    font-size: var(--text-xs) !important;
    color: var(--gray-500) !important;
}

.catbox-form-actions {
    display: flex !important;
    gap: var(--space-3) !important;
    justify-content: flex-end !important;
    margin-top: var(--space-4) !important;
}

/* ============================================
   MODALS - Backdrop blur
   ============================================ */

.catbox-modal-wrapper {
    position: fixed !important;
    inset: 0 !important;
    z-index: var(--z-modal) !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--space-4) !important;
}

.catbox-modal-wrapper.show {
    display: flex !important;
}

.catbox-modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    backdrop-filter: blur(8px) !important;
    z-index: var(--z-modal-backdrop) !important;
}

.catbox-modal {
    position: relative !important;
    z-index: var(--z-modal) !important;
    width: 100% !important;
    max-width: 500px !important;
    max-height: 90vh !important;
    background: white !important;
    border-radius: var(--radius-2xl) !important;
    box-shadow: var(--shadow-xl) !important;
    display: flex !important;
    flex-direction: column !important;
    animation: modalEnter var(--duration-300) var(--ease-in-out) !important;
}

@keyframes modalEnter {
    from {
        opacity: 0 !important;
        transform: scale(0.95) translateY(20px) !important;
    }
    to {
        opacity: 1 !important;
        transform: scale(1) translateY(0) !important;
    }
}

.catbox-modal-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: var(--space-4) !important;
    padding: var(--space-6) !important;
    border-bottom: 1px solid var(--gray-200) !important;
}

.catbox-modal-header h3 {
    font-size: var(--text-xl) !important;
    font-weight: var(--font-semibold) !important;
    color: var(--gray-900) !important;
}

.catbox-modal-close {
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: none !important;
    background: transparent !important;
    color: var(--gray-500) !important;
    cursor: pointer !important;
    border-radius: var(--radius-md) !important;
    font-size: 24px !important;
    line-height: 1 !important;
    transition: all var(--duration-150) var(--ease-in-out) !important;
}

.catbox-modal-close:hover {
    background: var(--gray-100) !important;
    color: var(--gray-900) !important;
}

.catbox-modal-body {
    padding: var(--space-6) !important;
    overflow-y: auto !important;
}

.catbox-modal-footer {
    padding: var(--space-6) !important;
    border-top: 1px solid var(--gray-200) !important;
    display: flex !important;
    gap: var(--space-3) !important;
    justify-content: flex-end !important;
}

/* ============================================
   TOAST NOTIFICATIONS
   ============================================ */

.catbox-toast-container {
    position: fixed !important;
    bottom: var(--space-6) !important;
    right: var(--space-6) !important;
    z-index: var(--z-toast) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: var(--space-3) !important;
    max-width: 400px !important;
}

@media (max-width: 640px) {
    .catbox-toast-container {
        left: var(--space-4) !important;
        right: var(--space-4) !important;
        bottom: var(--space-4) !important;
    }
}

.catbox-toast {
    display: flex !important;
    align-items: flex-start !important;
    gap: var(--space-3) !important;
    padding: var(--space-4) !important;
    background: white !important;
    border: 1px solid var(--gray-200) !important;
    border-radius: var(--radius-xl) !important;
    box-shadow: var(--shadow-xl) !important;
    animation: toastEnter var(--duration-300) var(--ease-in-out) !important;
}

@keyframes toastEnter {
    from {
        opacity: 0 !important;
        transform: translateX(100%) !important;
    }
    to {
        opacity: 1 !important;
        transform: translateX(0) !important;
    }
}

.catbox-toast.success {
    border-left: 4px solid var(--health-success) !important;
}

.catbox-toast.error {
    border-left: 4px solid var(--health-danger) !important;
}

.catbox-toast.warning {
    border-left: 4px solid var(--health-warning) !important;
}

.catbox-toast.info {
    border-left: 4px solid var(--health-info) !important;
}

.catbox-toast-icon {
    flex-shrink: 0 !important;
    width: 24px !important;
    height: 24px !important;
}

.catbox-toast-content {
    flex: 1 !important;
    font-size: var(--text-sm) !important;
    color: var(--gray-900) !important;
}

/* ============================================
   FOOTER
   ============================================ */

.catbox-footer {
    margin-top: auto !important;
    padding: var(--space-8) var(--space-4) !important;
    background: white !important;
    border-top: 1px solid var(--gray-200) !important;
}

.catbox-footer-container {
    max-width: 1400px !important;
    margin: 0 auto !important;
    text-align: center !important;
}

.catbox-footer p {
    font-size: var(--text-sm) !important;
    color: var(--gray-500) !important;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.text-muted {
    color: var(--gray-500) !important;
}

.text-center {
    text-align: center !important;
}

.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border-width: 0 !important;
}
