/**
 * GMod4Life Staff — Thème v2
 * Moderne · énergique · glass morphism
 */

/* ── Fond vivant ── */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(ellipse 90% 60% at 15% -10%, rgba(255, 77, 90, 0.22), transparent 55%),
        radial-gradient(ellipse 70% 50% at 95% 5%, rgba(167, 139, 250, 0.16), transparent 50%),
        radial-gradient(ellipse 60% 45% at 50% 110%, rgba(56, 189, 248, 0.1), transparent 55%),
        linear-gradient(180deg, #0a0c12 0%, var(--bg) 40%, #06070b 100%);
    pointer-events: none;
}

body::after {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    opacity: 0.35;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 85% 75% at 50% 30%, black 15%, transparent 72%);
    pointer-events: none;
}

@keyframes theme-aurora {
    0%, 100% { opacity: 0.55; transform: translate(0, 0) scale(1); }
    50% { opacity: 0.85; transform: translate(2%, -1%) scale(1.03); }
}

@media (prefers-reduced-motion: no-preference) {
    body::before {
        animation: theme-aurora 18s ease-in-out infinite;
    }
}

/* ── Typo ── */
h1, h2, h3,
.brand-name,
.page-header h1,
.modal-title,
.fmt-hero-text h1,
.login-brand h1,
.users-admin-hero-text h1,
.dash-hero-text h1 {
    font-family: var(--font-display);
    letter-spacing: -0.03em;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.2); background-clip: padding-box; }

/* ── Navbar glass ── */
.navbar {
    background: rgba(10, 12, 18, 0.78);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border-bottom: 1px solid var(--glass-border);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 0.04),
        0 8px 32px rgba(0, 0, 0, 0.35);
}

.navbar::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 77, 90, 0.45), rgba(167, 139, 250, 0.35), transparent);
    opacity: 0.7;
    pointer-events: none;
}

.brand-name { font-weight: 800; }
.brand-staff {
    background: linear-gradient(135deg, var(--accent) 0%, #ff9a7b 45%, var(--violet) 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

.nav-link {
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.84rem;
}

.nav-link:hover {
    background: rgba(255, 255, 255, 0.07);
    color: var(--text);
    transform: translateY(-1px);
}

.nav-link.active {
    background: linear-gradient(135deg, var(--accent-soft), rgba(167, 139, 250, 0.1));
    color: var(--text);
    box-shadow: inset 0 0 0 1px rgba(255, 77, 90, 0.25);
}

.nav-link.active::after {
    width: 24px;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent), var(--violet));
    box-shadow: 0 0 12px var(--accent-glow);
}

.nav-dropdown-link.active {
    background: var(--accent-soft);
    color: var(--text);
    box-shadow: inset 3px 0 0 var(--accent);
}

.nav-user-trigger {
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(8px);
}

.nav-user-trigger:hover {
    border-color: rgba(255, 77, 90, 0.35);
    box-shadow: 0 0 0 3px rgba(255, 77, 90, 0.1);
}

/* ── Vue site bar ── */
.site-view-bar {
    background: rgba(10, 12, 18, 0.88);
    backdrop-filter: blur(16px);
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

.site-view-bar--preview {
    background: linear-gradient(90deg, rgba(251, 191, 36, 0.1), rgba(10, 12, 18, 0.92) 45%);
}

.site-view-bar-tab.is-active {
    box-shadow:
        inset 0 0 0 1px color-mix(in srgb, var(--site-view-color, #60a5fa) 40%, transparent),
        0 4px 16px color-mix(in srgb, var(--site-view-color, #60a5fa) 20%, transparent);
}

/* ── Cartes glass ── */
.card {
    background: var(--glass);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
}

.card:hover {
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: var(--shadow-sm), 0 0 0 1px rgba(255, 77, 90, 0.06);
    transform: translateY(-2px);
}

.card-header .card-title {
    font-family: var(--font-display);
    font-weight: 700;
}

/* ── Stats motivantes ── */
.stat-card-v2 {
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
    backdrop-filter: blur(10px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.stat-card-v2::before {
    height: 4px;
    opacity: 1;
    box-shadow: 0 0 20px color-mix(in srgb, var(--stat-color, var(--accent)) 50%, transparent);
}

.stat-card-v2:hover {
    transform: translateY(-4px) scale(1.01);
    border-color: color-mix(in srgb, var(--stat-color, var(--accent)) 35%, var(--border));
    box-shadow:
        var(--shadow-sm),
        0 12px 40px color-mix(in srgb, var(--stat-color, var(--accent)) 18%, transparent);
}

.stat-card-v2-num {
    font-family: var(--font-display);
    font-size: 1.9rem;
}

.stat-card-v2-icon {
    border-radius: 12px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.stat-card {
    background: var(--glass);
    backdrop-filter: blur(10px);
}

/* ── Headers de page ── */
.page-header h1 {
    font-family: var(--font-display);
    font-weight: 800;
    background: linear-gradient(135deg, var(--text) 30%, var(--text2) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.page-header.page-toolbar {
    background: linear-gradient(135deg, rgba(255, 77, 90, 0.1), rgba(167, 139, 250, 0.06));
    border: 1px solid rgba(255, 77, 90, 0.2);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}

/* ── Boutons énergiques ── */
.btn {
    font-family: var(--font-display);
    font-weight: 700;
    border-radius: var(--radius-sm);
    position: relative;
    overflow: hidden;
}

.btn-primary {
    background: linear-gradient(135deg, #ff4d5a 0%, #ff6b4a 50%, #ff8a65 100%);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow:
        0 4px 20px var(--accent-glow),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.btn-primary::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.22) 50%, transparent 60%);
    transform: translateX(-120%);
    transition: transform 0.5s ease;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow:
        0 8px 28px var(--accent-glow),
        0 0 0 1px rgba(255, 77, 90, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.btn-primary:hover::after {
    transform: translateX(120%);
}

.btn-secondary {
    background: rgba(255, 255, 255, 0.06);
    backdrop-filter: blur(8px);
    border: 1px solid var(--glass-border);
}

.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.18);
    transform: translateY(-1px);
}

.btn-success {
    background: linear-gradient(135deg, #059669, var(--success));
    box-shadow: 0 4px 20px rgba(52, 211, 153, 0.3);
}

.btn-info {
    background: linear-gradient(135deg, #2563eb, var(--info));
    box-shadow: 0 4px 20px rgba(96, 165, 250, 0.28);
}

/* ── Formulaires ── */
.form-group input,
.form-group select,
.form-group textarea,
.login-input-wrap input,
.media-picker-filter,
.media-picker-upload-fields input[type="text"] {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    transition: border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus,
.login-input-wrap input:focus {
    border-color: rgba(255, 77, 90, 0.45);
    box-shadow: 0 0 0 3px rgba(255, 77, 90, 0.12);
    background: rgba(0, 0, 0, 0.35);
    outline: none;
}

/* ── Alertes ── */
.alert {
    border-radius: var(--radius-sm);
    border-left-width: 4px;
    backdrop-filter: blur(8px);
}

.alert-success {
    background: rgba(52, 211, 153, 0.1);
    border-color: rgba(52, 211, 153, 0.35);
    border-left-color: var(--success);
}

.alert-danger {
    background: rgba(251, 113, 133, 0.1);
    border-color: rgba(251, 113, 133, 0.3);
    border-left-color: var(--danger);
}

.alert-warning {
    background: rgba(251, 191, 36, 0.1);
    border-color: rgba(251, 191, 36, 0.3);
    border-left-color: var(--warning);
}

.alert-info {
    background: rgba(96, 165, 250, 0.1);
    border-color: rgba(96, 165, 250, 0.3);
    border-left-color: var(--info);
}

/* ── Modales ── */
.modal-overlay {
    background: rgba(4, 5, 8, 0.72);
    backdrop-filter: blur(8px);
}

.modal {
    background: linear-gradient(160deg, rgba(22, 26, 36, 0.98), rgba(14, 17, 24, 0.98));
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow), 0 0 60px rgba(255, 77, 90, 0.06);
}

/* ── Filtres / chips ── */
.filtre-btn.active,
.filter-btn.active {
    background: linear-gradient(135deg, var(--accent-soft), rgba(167, 139, 250, 0.12));
    border-color: rgba(255, 77, 90, 0.4);
    color: var(--text);
    box-shadow: 0 4px 16px rgba(255, 77, 90, 0.15);
}

.chip-success { background: rgba(52, 211, 153, 0.15); color: var(--success); }
.chip-danger { background: rgba(251, 113, 133, 0.15); color: var(--danger); }
.chip-warning { background: rgba(251, 191, 36, 0.15); color: var(--warning); }
.chip-info { background: rgba(96, 165, 250, 0.15); color: var(--info); }

.badge-success { background: rgba(52, 211, 153, 0.18); color: #6ee7b7; }
.badge-info { background: rgba(96, 165, 250, 0.18); color: #93c5fd; }
.badge-warning { background: rgba(251, 191, 36, 0.18); color: #fcd34d; }

/* ── Login ── */
.login-bg {
    background: radial-gradient(ellipse at 40% 0%, #1a1028 0%, var(--bg) 60%);
}

.login-bg-glow-1 {
    background: rgba(255, 77, 90, 0.4);
    opacity: 0.55;
}

.login-bg-glow-2 {
    background: rgba(167, 139, 250, 0.35);
}

.login-mark {
    border-radius: 18px;
    background: linear-gradient(135deg, var(--accent), #ff8a65, var(--violet));
    box-shadow: 0 12px 40px var(--accent-glow), 0 0 60px var(--violet-glow);
}

.login-box-v2 {
    background: var(--glass);
    backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
}

.login-submit {
    background: linear-gradient(135deg, #ff4d5a, #ff6b4a) !important;
    box-shadow: 0 8px 28px var(--accent-glow) !important;
}

/* ── Dashboard & héros ── */
.fmt-hero-icon,
.users-admin-hero-icon {
    box-shadow:
        0 8px 32px rgba(96, 165, 250, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.fmt-card,
.dash-widget {
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.fmt-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-sm), 0 12px 36px rgba(96, 165, 250, 0.08);
}

.dash-patch-item:hover {
    background: rgba(255, 77, 90, 0.04);
}

.dash-patch-accent {
    background: linear-gradient(180deg, var(--accent), var(--violet));
}

/* ── Tables ── */
table thead th {
    font-family: var(--font-display);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text2);
}

/* ── Footer ── */
.site-footer {
    border-top: 1px solid var(--glass-border);
    background: rgba(8, 10, 14, 0.6);
    backdrop-filter: blur(12px);
}

/* ── Quota bar / progression ── */
.quota-bar {
    border-radius: 999px;
    box-shadow: 0 0 12px currentColor;
}

/* ── Empty states ── */
.page-empty,
.fmt-empty {
    border: 1px dashed rgba(255, 255, 255, 0.12);
    border-radius: var(--radius-lg);
    background: rgba(255, 255, 255, 0.02);
}

/* ── Dashboard inline (priorité sur styles page) ── */
.dash-hero,
.spotlight-meeting,
.quota-bar-card {
    backdrop-filter: blur(12px);
}

.quota-fill {
    background: linear-gradient(90deg, #059669, var(--success));
    box-shadow: 0 0 16px rgba(52, 211, 153, 0.35);
}

.quick-btn {
    border-radius: 999px;
    font-family: var(--font-display);
    font-weight: 700;
}

.dash-event-day { color: var(--accent); }

/* ── Sélection texte ── */
::selection {
    background: rgba(255, 77, 90, 0.35);
    color: #fff;
}
