@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
       
    --fp-primary: #4f46e5;
    --fp-primary-hover: #4338ca;
    --fp-primary-text: #3730a3;
    --fp-primary-surface: #eef2ff;
    --fp-primary-border: #c7d2fe;

    --danger-text: #dc2626;
    --danger-surface: #fef2f2;
    --danger-border: #fecaca;

    --success-text: #059669;
    --success-surface: #ecfdf5;
    --success-border: #a7f3d0;

    --warning-text: #d97706;
    --warning-surface: #fffbeb;
    --warning-border: #fde68a;

    --bg-body: #f8fafc;
    --surface: #ffffff;
    --surface-secondary: #f1f5f9;
    --surface-tertiary: #e2e8f0;    

    --text-main: #0f172a;
    --text-secondary: #475569;
    --text-muted: #64748b; 

    --border-color: #e2e8f0;
    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 16px;
    
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-hover: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    
    --glass-bg: rgba(255, 255, 255, 1);
    --glass-border: rgba(255, 255, 255, 0.5);
    --backdrop-blur: blur(16px);

    --muted-surface: #f1f5f9;
    --border-badge: #e2e8f0;
}

[data-theme="dark"] {
    --danger-text: #f87171; 
    --danger-surface: rgba(220, 38, 38, 0.15); 
    --danger-border: rgba(248, 113, 113, 0.25);

    --success-text: #34d399;
    --success-surface: rgba(5, 150, 105, 0.15);
    --success-border: rgba(52, 211, 153, 0.25);

    --warning-text: #fbbf24;
    --warning-surface: rgba(217, 119, 6, 0.15);
    --warning-border: rgba(251, 191, 36, 0.25);

    --bg-body: #0a0a0a;
    --surface: #171717;
    --surface-secondary: #262626;
    --surface-tertiary: #404040;

    --text-main: #f1f5f9;
    --text-secondary: #cbd5e1;
    --text-muted: #94a3b8;
    
    --border-color: #262626;

    --glass-bg: rgba(23, 23, 23, 0.8); 
    --glass-border: rgba(255, 255, 255, 0.05);

    --muted-surface: rgba(148, 163, 184, 0.12);

}
body {
    background-color: var(--bg-body);
    color: var(--text-main);
    
    font-family: 'Plus Jakarta Sans', 'Inter', system-ui, -apple-system, sans-serif;
    line-height: 1.6;
    
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    
    transition: background-color 0.3s ease, color 0.3s ease;
    overflow-x: hidden;
}
a { text-decoration: none; transition: all 0.2s ease; }
ul { list-style: none; padding: 0; margin: 0; }

.text-primary { color: var(--fp-primary) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-main { color: var(--text-main) !important; }
.text-sm { font-size: 0.8rem !important}
.text-md { font-size: 1rem !important}
.text-danger { color: var(--danger-text) !important}
.bg-surface { background-color: var(--surface) !important; }
.bg-surface-secondary { background-color: var(--surface-secondary) !important; }
.bg-primary { background-color: var(--fp-primary) !important }
.bg-danger { background-color: var(--danger-surface) !important}
.border-danger { border-color: var(--danger-border) !important}
.border-normal { border-color: var(--border-color) !important }

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.btn-fp-primary {
    background-color: var(--fp-primary);
    color: white;
    border: none;
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    letter-spacing: 0.5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.btn-fp-primary:hover {
    background-color: var(--fp-primary);
    transform: translateY(-2px);
    color: white;
    text-decoration: none !important;
}
.btn-fp-primary:active {
    background-color: var(--fp-primary) !important;
    color: white !important;
    transform: scale(0.98);
    text-decoration: none !important;
}

.btn-fp-primary--dark {
    background-color: var(--fp-primary);
    border: none;
    color: white
}
.btn-fp-primary--dark:hover, .btn-fp-primary--dark:active {
    background-color: var(--fp-primary) !important;
    color: white !important;
    text-decoration: none !important;
}

.btn-fp-outline {
    background: transparent;
    border: 1px solid var(--fp-primary);
    color: var(--fp-primary);
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    transition: all 0.3s ease;
    cursor: pointer;
    display: inline-block;
}

.btn-fp-outline--sm {
    padding: 0.5rem 1rem;
}

.btn-fp-outline--danger {
    border: 1px solid var(--danger-text);
    color: var(--danger-text);
}

.btn-fp-outline--warning {
    border: 1px solid var(--warning-text);
    color: var(--warning-text);
}

.btn-fp-outline--third {
    border: 1px solid var(--text-muted);
    color: var(--text-muted);
}

.btn-fp-outline--success {
    border: 1px solid var(--success-text);
    color: var(--success-text);
}

.btn-fp-outline:hover, 
.btn-fp-outline:focus-visible {
    background-color: var(--fp-primary);
    color: white;
    border-color: var(--fp-primary);
    outline: none;
    text-decoration: none !important;
}

.btn-fp-outline--danger:hover, 
.btn-fp-outline--danger:focus-visible {
    background-color: var(--danger-text);
    color: white;
    border-color: var(--danger-text);
    outline: none;
    text-decoration: none !important;
}

.btn-fp-outline--warning:hover, 
.btn-fp-outline--warning:focus-visible {
    background-color: var(--warning-text);
    color: white;
    border-color: var(--warning-text);
    outline: none;
    text-decoration: none !important;
}


.btn-fp-outline--third:hover, 
.btn-fp-outline--third:focus-visible {
    background-color: var(--text-muted);
    color: white;
    border-color: var(--text-muted);
    outline: none;
    text-decoration: none !important;
}

.btn-fp-outline--success:hover, 
.btn-fp-outline--success:focus-visible {
    background-color: var(--success-text);
    color: white;
    border-color: var(--success-text);
    outline: none;
    text-decoration: none !important;
}

.btn-fp-outline:active {
    transform: scale(0.98);
    background: transparent;
    border-color: var(--fp-primary) !important;
    color: var(--fp-primary) !important;
    text-decoration: none !important;
}

.btn-fp-outline--danger:active {
    transform: scale(0.98);
    background: transparent;
    border-color: var(--danger-text) !important;
    color: var(--danger-text) !important;
    text-decoration: none !important;
}

.btn-fp-outline--warning:active {
    transform: scale(0.98);
    background: transparent;
    border-color: var(--warning-text) !important;
    color: var(--warning-text) !important;
    text-decoration: none !important;
}

.btn-fp-outline--third:active {
    transform: scale(0.98);
    background: transparent;
    border-color: var(--text-muted) !important;
    color: var(--text-muted) !important;
    text-decoration: none !important;
}

.btn-fp-outline--success:active {
    transform: scale(0.98);
    background: transparent;
    border-color: var(--success-text) !important;
    color: var(--success-text) !important;
    text-decoration: none !important;
}


.btn-fp-transparent, .btn-fp-transparent--dark {
    background: transparent;
    border: 1px solid white;
    color: white;
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    transition: all 0.3s ease;
    cursor: pointer;
    display: inline-block;
    text-decoration: none !important;
}
.btn-fp-transparent:hover, 
.btn-fp-transparent:focus-visible {
    color: var(--fp-primary);
    border-color: var(--fp-primary);
    outline: none;
}

.btn-fp-transparent--dark:hover, 
.btn-fp-transparent--dark:focus-visible {
    color: var(--fp-primary);
    border-color: var(--fp-primary);
    outline: none;
}

.fp-border-color {
    border-color: var(--border-color) !important;
}
 
.logo-img {
    height: 35px;
    width: auto;
}

.fade-in-up { animation: fadeInUp 0.8s ease-out; }
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

 .background-glass {
    background-color: var(--glass-bg);
 }

 
.card-img-wrapper.square-ratio {
    height: auto;
    aspect-ratio: 1 / 1;
    position: relative;
    overflow: hidden;
}

@media (max-width: 768px) {
    .mt-md-only-4 {
        margin-top: 1.5rem;
    }
}
@media (min-width: 768px) {
    .mt-lg-only-4 {
        margin-top: 1.5rem;
    }
}

.border-bottom-fp {
    border-bottom: 1px solid var(--border-color) !important;
}


.user-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background-color: var(--surface-secondary);
    color: var(--fp-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    border: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.2s ease;
}

.user-avatar:hover {
    background-color: var(--fp-primary);
    color: white;
    border-color: var(--fp-primary);
}

/* Ajustes del Dropdown de Bootstrap/Tabler para coincidir con tu tema */
.dropdown-menu-fp {
    background-color: var(--surface);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
    border-radius: var(--radius-md);
    padding: 0.5rem 0;
    margin-top: 0.5rem !important; /* Separación del header */
    min-width: 220px;
}

.dropdown-item-fp {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    color: var(--text-main);
    text-decoration: none !important;
    transition: background-color 0.2s;
    border: none;
    background: transparent;
    width: 100%;
    text-align: left;
    font-size: 0.9rem;
}

.dropdown-item-fp:hover {
    background-color: var(--surface-secondary);
}

.dropdown-header-fp {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 0.5rem;
}

.user-name {
    font-weight: 600;
    color: var(--text-main);
    display: block;
    line-height: 1.2;
}

.user-email {
    font-size: 0.75rem;
    color: var(--text-muted);
    display: block;
    margin-top: 2px;
}

.mobile-user-card {
    background-color: var(--surface-secondary);
    border-radius: var(--radius-sm);
    padding: 1rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}

@media (min-width: 768px) {
    .w-md-80 {
        width: 80% !important;
    }
}

@media (min-width: 992px) {
    .w-lg-60 {
        width: 60% !important;
    }
}

.alert-danger-fp {
  --tblr-alert-color: var(--danger-text);
  --tblr-alert-bg: transparent;
  --tblr-alert-border-color: var(--danger-border);
  --tblr-alert-link-color: var(--tblr-danger-text-emphasis);
}

.ti-chevron-fp {
    color: var(--text-muted);
}

.page-link-fp:hover .ti-chevron-fp {
    color: var(--fp-primary);
}

.page-link-fp {
    text-decoration: none;
}

.page-link-fp:hover {
    text-decoration: none;
}

.page-link-fp.disabled .ti-chevron-fp {
    color: var(--text-muted);
    cursor: default;
}