/* Theme unifie pour index/services/projects/partenaires */

:root {
    --ui-radius-sm: 12px;
    --ui-radius-md: 16px;
    --ui-radius-lg: 22px;
    --ui-radius-xl: 28px;
    --ui-gap: 24px;
    --ui-shadow-soft: 0 14px 36px rgba(2, 6, 23, 0.28);
    --ui-shadow-strong: 0 22px 54px rgba(2, 6, 23, 0.45);
    --ui-anim-fast: 0.2s;
    --ui-anim-med: 0.35s;
}

body {
    color: var(--text-main) !important;
    animation: fadeInBody 0.6s ease-out;
}

h1, h2, h3, h4 {
    font-family: 'Space Grotesk', sans-serif !important;
    color: #f3f7ff !important;
    letter-spacing: -0.02em;
}

p, li, span {
    color: var(--text-dim);
}

.sidebar {
    backdrop-filter: blur(20px) !important;
    animation: slideInSidebar 0.45s ease-out;
}

.nav-menu {
    gap: 10px !important;
}

.nav-link {
    min-height: 44px;
    border-radius: var(--ui-radius-sm) !important;
    transition: transform var(--ui-anim-fast) ease, background-color var(--ui-anim-fast) ease, border-color var(--ui-anim-fast) ease !important;
}

.nav-link i {
    transition: transform var(--ui-anim-fast) ease;
}

.nav-link:hover i {
    transform: translateX(2px);
}

.main-content {
    min-height: 100vh !important;
}

.hero-card,
.service-card,
.project-card,
.feature-card,
.auth-card-login,
.modal-content,
.user-card-container,
.user-block {
    border-radius: var(--ui-radius-lg) !important;
    box-shadow: var(--ui-shadow-soft) !important;
    border: 1px solid var(--border) !important;
    animation: riseIn 0.45s ease-out both;
}

.header-section,
.hero-section,
.content-padding {
    max-width: 1400px;
}

.grid-content,
.grid-projects,
.grid-services,
.feature-grid,
.footer-grid,
.footer-content {
    gap: var(--ui-gap) !important;
}

.btn-primary,
.btn-order,
.btn-discord,
.btn-secondary,
.btn-logout,
.btn-logout-full {
    min-height: 44px;
    border-radius: var(--ui-radius-sm) !important;
    font-weight: 700 !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease !important;
}

.btn-primary:hover,
.btn-order:hover,
.btn-discord:hover,
.btn-secondary:hover,
.btn-logout:hover,
.btn-logout-full:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 24px rgba(79, 140, 255, 0.22) !important;
}

.status-badge,
.partner-badge {
    border-radius: 999px !important;
    font-weight: 700 !important;
}

.site-footer,
.main-footer {
    margin-top: auto;
}

.form-input {
    border-radius: var(--ui-radius-sm) !important;
    min-height: 44px;
    transition: border-color var(--ui-anim-fast) ease, box-shadow var(--ui-anim-fast) ease, transform var(--ui-anim-fast) ease !important;
}

.form-input:focus {
    transform: translateY(-1px);
}

textarea.form-input {
    min-height: 120px;
}

.pricing-table-container,
.modal-content {
    border-radius: var(--ui-radius-md) !important;
    box-shadow: var(--ui-shadow-strong) !important;
}

.modal-content {
    animation: popIn var(--ui-anim-med) ease-out;
}

.feature-icon,
.icon-box,
.service-icon-box {
    transition: transform var(--ui-anim-fast) ease, box-shadow var(--ui-anim-fast) ease !important;
}

.service-card:hover .feature-icon,
.service-card:hover .icon-box,
.service-card:hover .service-icon-box,
.feature-card:hover .feature-icon,
.project-card:hover .icon-box {
    transform: translateY(-3px) scale(1.03);
}

/* Animations legeres */
@keyframes fadeInBody {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideInSidebar {
    from { opacity: 0; transform: translateX(10px); }
    to { opacity: 1; transform: translateX(0); }
}

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

@keyframes popIn {
    from { opacity: 0; transform: scale(0.98); }
    to { opacity: 1; transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
    }
}

@media (max-width: 1024px) {
    .hero-card,
    .service-card,
    .project-card,
    .feature-card,
    .auth-card-login,
    .modal-content {
        border-radius: var(--ui-radius-md) !important;
    }

    .main-content {
        padding: 32px 24px !important;
    }

    .sidebar-toggle {
        top: 22px !important;
        right: 20px !important;
    }
}

@media (max-width: 768px) {
    .sidebar {
        width: 100% !important;
        max-width: 100% !important;
        height: 100vh !important;
        top: 0 !important;
        right: 0 !important;
        left: auto !important;
        border-radius: 0 !important;
        padding: 24px 18px !important;
        overflow-y: auto !important;
    }

    body.sidebar-collapsed .sidebar,
    .sidebar.hidden {
        right: -100% !important;
    }

    .main-content {
        margin-right: 0 !important;
        width: 100% !important;
        padding: 24px 18px !important;
    }

    .sidebar-toggle {
        top: 18px !important;
        right: 18px !important;
        width: 40px !important;
        height: 40px !important;
    }

    .nav-menu {
        gap: 14px !important;
    }

    .grid-content,
    .grid-projects,
    .grid-services,
    .feature-grid,
    .footer-grid,
    .footer-content {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        gap: var(--ui-gap) !important;
    }

    .btn-primary,
    .btn-order,
    .btn-discord,
    .btn-secondary,
    .btn-logout,
    .btn-logout-full {
        width: 100% !important;
    }

    .form-input,
    textarea.form-input {
        min-height: 50px !important;
    }

    img,
    video,
    iframe,
    embed {
        max-width: 100% !important;
        height: auto !important;
    }
}

@media (max-width: 480px) {
    :root {
        --ui-gap: 16px;
    }

    .main-content {
        padding: 20px 14px !important;
    }

    .sidebar {
        padding: 18px 14px !important;
    }

    .nav-menu {
        gap: 10px !important;
    }

    .nav-link {
        padding: 10px 14px !important;
    }

    .hero-card h1,
    .hero-card h2,
    .hero-card h3 {
        font-size: clamp(1.8rem, 4vw, 2.4rem) !important;
    }

    .btn-primary,
    .btn-order,
    .btn-discord,
    .btn-secondary,
    .btn-logout,
    .btn-logout-full {
        padding: 0.85rem 1rem !important;
    }
}
