/* =================================================================
   GesDom — Couche de design moderne
   Surcouche par-dessus Material Dashboard 3 (ne remplace pas la base)
   ================================================================= */

/* ---------- 1. Variables de design ---------- */
:root {
    --gd-primary: #4f46e5;
    --gd-primary-soft: #eef2ff;
    --gd-primary-strong: #4338ca;
    --gd-accent: #06b6d4;
    --gd-success: #10b981;
    --gd-warning: #f59e0b;
    --gd-danger: #ef4444;
    --gd-info: #3b82f6;

    --gd-bg: #f5f6fa;
    --gd-surface: #ffffff;
    --gd-border: #e7eaf3;
    --gd-text: #1f2937;
    --gd-text-soft: #6b7280;
    --gd-text-muted: #9ca3af;

    --gd-radius-sm: 8px;
    --gd-radius-md: 14px;
    --gd-radius-lg: 18px;
    --gd-radius-xl: 22px;

    --gd-shadow-xs: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 1px rgba(15, 23, 42, 0.03);
    --gd-shadow-sm: 0 2px 6px rgba(15, 23, 42, 0.05), 0 1px 2px rgba(15, 23, 42, 0.04);
    --gd-shadow-md: 0 8px 24px rgba(15, 23, 42, 0.06), 0 2px 8px rgba(15, 23, 42, 0.04);
    --gd-shadow-lg: 0 18px 40px rgba(15, 23, 42, 0.10), 0 6px 14px rgba(15, 23, 42, 0.05);
    --gd-shadow-focus: 0 0 0 4px rgba(79, 70, 229, 0.18);

    --gd-transition: 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- 2. Fond et typographie ---------- */
body.g-sidenav-show,
body {
    background: linear-gradient(180deg, #f5f6fa 0%, #eef1f8 100%) !important;
    color: var(--gd-text);
    font-feature-settings: "cv11", "ss01", "ss03";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--gd-text);
    letter-spacing: -0.015em;
}

.text-sm { letter-spacing: -0.005em; }
.text-xs { letter-spacing: 0; }

/* ---------- 3. Sidenav ---------- */
.sidenav.navbar-vertical {
    border-radius: var(--gd-radius-lg) !important;
    box-shadow: var(--gd-shadow-md);
    border: 1px solid var(--gd-border);
}

.sidenav .navbar-brand {
    padding: 1rem 1.25rem !important;
    border-bottom: 1px solid var(--gd-border);
}

.sidenav .navbar-brand .material-symbols-rounded {
    color: var(--gd-primary);
    font-size: 1.6rem;
    vertical-align: middle;
}

.sidenav .navbar-brand span {
    font-weight: 700;
    letter-spacing: -0.01em;
    font-size: 1.05rem;
}

.sidenav .navbar-nav .nav-link {
    border-radius: var(--gd-radius-sm) !important;
    margin: 0.15rem 0.75rem;
    padding: 0.65rem 0.9rem !important;
    font-weight: 500;
    transition: background-color var(--gd-transition), color var(--gd-transition), transform var(--gd-transition);
}

.sidenav .navbar-nav .nav-link:not(.active):hover {
    background: var(--gd-primary-soft);
    color: var(--gd-primary-strong) !important;
    transform: translateX(2px);
}

.sidenav .navbar-nav .nav-link:not(.active):hover .material-symbols-rounded {
    color: var(--gd-primary);
    opacity: 1 !important;
}

.sidenav .navbar-nav .nav-link.active.bg-gradient-dark {
    background: linear-gradient(135deg, var(--gd-primary) 0%, var(--gd-primary-strong) 100%) !important;
    box-shadow: 0 6px 14px rgba(79, 70, 229, 0.28);
}

.sidenav .navbar-nav .nav-link.active .material-symbols-rounded {
    opacity: 1 !important;
    color: #ffffff;
}

.sidenav .navbar-nav .nav-item h6 {
    font-size: 0.68rem !important;
    letter-spacing: 0.08em;
    color: var(--gd-text-muted) !important;
}

/* ---------- 4. Navbar / Breadcrumb ---------- */
.navbar-main {
    background: transparent !important;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding-top: 0.75rem !important;
    padding-bottom: 0.75rem !important;
}

.navbar-main .breadcrumb {
    background: transparent !important;
    padding: 0 !important;
    font-size: 0.78rem;
}

.navbar-main .breadcrumb-item a {
    color: var(--gd-text-soft) !important;
    text-decoration: none;
    transition: color var(--gd-transition);
    opacity: 1 !important;
}

.navbar-main .breadcrumb-item a:hover {
    color: var(--gd-primary) !important;
}

.navbar-main .breadcrumb-item.active,
.navbar-main .breadcrumb-item:last-child {
    color: var(--gd-text) !important;
    font-weight: 600;
}

.navbar-main .breadcrumb-item + .breadcrumb-item::before {
    color: var(--gd-text-muted) !important;
    content: "›";
    font-size: 1rem;
    line-height: 1;
    opacity: 0.6;
}

.navbar-main h6.font-weight-bolder {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--gd-text) !important;
    margin-top: 0.15rem !important;
    letter-spacing: -0.02em;
}

/* ---------- 5. Cartes ---------- */
.card {
    border: 1px solid var(--gd-border) !important;
    border-radius: var(--gd-radius-md) !important;
    box-shadow: var(--gd-shadow-sm) !important;
    background: var(--gd-surface);
    transition: box-shadow var(--gd-transition), transform var(--gd-transition), border-color var(--gd-transition);
}

.card:hover {
    box-shadow: var(--gd-shadow-md) !important;
}

.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--gd-border) !important;
    padding: 1rem 1.5rem !important;
}

.card-header h6,
.card-header .h6 {
    margin-bottom: 0;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.card-body {
    padding: 1.5rem !important;
}

/* Cartes statistiques du dashboard : effet de surélévation */
.card .bg-gradient-dark,
.card .bg-gradient-primary,
.card .bg-gradient-success,
.card .bg-gradient-info,
.card .bg-gradient-warning,
.card .bg-gradient-danger {
    border-radius: var(--gd-radius-sm) !important;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

/* ---------- 6. Boutons ---------- */
.btn {
    border-radius: var(--gd-radius-sm) !important;
    font-weight: 600;
    letter-spacing: 0.01em;
    padding: 0.55rem 1.1rem;
    transition: transform var(--gd-transition), box-shadow var(--gd-transition), background-color var(--gd-transition), border-color var(--gd-transition);
    text-transform: none !important;
    border-width: 1px;
}

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

.btn:active {
    transform: translateY(0);
}

.btn-sm {
    padding: 0.35rem 0.7rem !important;
    font-size: 0.78rem !important;
}

.btn-lg {
    padding: 0.75rem 1.5rem !important;
    font-size: 0.95rem !important;
}

.btn-primary,
.btn.bg-gradient-primary,
.btn.bg-gradient-dark {
    background: linear-gradient(135deg, var(--gd-primary) 0%, var(--gd-primary-strong) 100%) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(79, 70, 229, 0.20);
}

.btn-primary:hover,
.btn.bg-gradient-primary:hover,
.btn.bg-gradient-dark:hover {
    box-shadow: 0 10px 22px rgba(79, 70, 229, 0.30) !important;
    filter: brightness(1.04);
}

.btn-outline-primary {
    color: var(--gd-primary) !important;
    border-color: var(--gd-primary) !important;
}

.btn-outline-primary:hover {
    background: var(--gd-primary) !important;
    color: #fff !important;
}

.btn-outline-secondary {
    color: var(--gd-text-soft) !important;
    border-color: var(--gd-border) !important;
    background: var(--gd-surface) !important;
}

.btn-outline-secondary:hover {
    background: var(--gd-bg) !important;
    color: var(--gd-text) !important;
    border-color: var(--gd-text-soft) !important;
}

.btn-icon-only,
.btn.btn-icon {
    width: 36px;
    height: 36px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* ---------- 7. Formulaires ---------- */
.form-control,
.form-select,
textarea.form-control,
input.form-control {
    border-radius: var(--gd-radius-sm) !important;
    border: 1px solid var(--gd-border) !important;
    padding: 0.55rem 0.85rem !important;
    background: var(--gd-surface) !important;
    transition: border-color var(--gd-transition), box-shadow var(--gd-transition);
    font-size: 0.9rem;
    color: var(--gd-text);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--gd-primary) !important;
    box-shadow: var(--gd-shadow-focus) !important;
    outline: none !important;
}

.form-control::placeholder { color: var(--gd-text-muted); opacity: 1; }

.form-label,
label.form-label,
label {
    color: var(--gd-text-soft);
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.input-group-text {
    border-radius: var(--gd-radius-sm) !important;
    background: var(--gd-bg) !important;
    border: 1px solid var(--gd-border) !important;
    color: var(--gd-text-soft);
}

.form-check-input {
    border-radius: 4px;
    border: 1.5px solid var(--gd-border);
}

.form-check-input:checked {
    background-color: var(--gd-primary) !important;
    border-color: var(--gd-primary) !important;
}

.form-check-input:focus {
    box-shadow: var(--gd-shadow-focus) !important;
    border-color: var(--gd-primary) !important;
}

/* ---------- 8. Tableaux ---------- */
.table {
    color: var(--gd-text);
    margin-bottom: 0;
}

.table > thead > tr > th {
    background: var(--gd-bg) !important;
    color: var(--gd-text-soft) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase;
    padding: 0.85rem 1rem !important;
    border-bottom: 1px solid var(--gd-border) !important;
    border-top: none !important;
}

.table > tbody > tr {
    transition: background-color var(--gd-transition);
}

.table > tbody > tr:hover {
    background: var(--gd-primary-soft);
}

.table > tbody > tr > td {
    padding: 0.85rem 1rem !important;
    border-top: 1px solid var(--gd-border);
    vertical-align: middle;
    font-size: 0.86rem;
}

.table-responsive {
    border-radius: var(--gd-radius-md);
    background: var(--gd-surface);
}

/* ---------- 9. Badges et chips ---------- */
.badge {
    border-radius: 999px !important;
    padding: 0.35em 0.75em !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em;
    font-size: 0.7rem !important;
    text-transform: none !important;
    line-height: 1.2;
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
}

.badge.bg-success,
.badge.bg-gradient-success {
    background: rgba(16, 185, 129, 0.12) !important;
    color: #047857 !important;
}

.badge.bg-warning,
.badge.bg-gradient-warning {
    background: rgba(245, 158, 11, 0.14) !important;
    color: #b45309 !important;
}

.badge.bg-danger,
.badge.bg-gradient-danger {
    background: rgba(239, 68, 68, 0.12) !important;
    color: #b91c1c !important;
}

.badge.bg-info,
.badge.bg-gradient-info {
    background: rgba(59, 130, 246, 0.12) !important;
    color: #1d4ed8 !important;
}

.badge.bg-primary,
.badge.bg-gradient-primary {
    background: var(--gd-primary-soft) !important;
    color: var(--gd-primary-strong) !important;
}

.badge.bg-secondary,
.badge.bg-gradient-secondary {
    background: var(--gd-bg) !important;
    color: var(--gd-text-soft) !important;
}

.badge.bg-dark,
.badge.bg-gradient-dark {
    background: #111827 !important;
    color: #fff !important;
}

/* ---------- 10. Alertes ---------- */
.alert {
    border: 1px solid transparent;
    border-radius: var(--gd-radius-md) !important;
    padding: 0.85rem 1.1rem !important;
    box-shadow: var(--gd-shadow-xs);
    font-size: 0.88rem;
}

.alert-success {
    background: rgba(16, 185, 129, 0.08) !important;
    border-color: rgba(16, 185, 129, 0.25) !important;
    color: #065f46 !important;
}

.alert-danger {
    background: rgba(239, 68, 68, 0.08) !important;
    border-color: rgba(239, 68, 68, 0.25) !important;
    color: #991b1b !important;
}

.alert-warning {
    background: rgba(245, 158, 11, 0.08) !important;
    border-color: rgba(245, 158, 11, 0.30) !important;
    color: #92400e !important;
}

.alert-info {
    background: rgba(59, 130, 246, 0.08) !important;
    border-color: rgba(59, 130, 246, 0.25) !important;
    color: #1e3a8a !important;
}

/* ---------- 11. Modales ---------- */
.modal-content {
    border: 1px solid var(--gd-border) !important;
    border-radius: var(--gd-radius-lg) !important;
    box-shadow: var(--gd-shadow-lg) !important;
    overflow: hidden;
}

.modal-header {
    border-bottom: 1px solid var(--gd-border) !important;
    padding: 1.1rem 1.5rem !important;
}

.modal-title {
    font-weight: 700;
    letter-spacing: -0.01em;
}

.modal-body { padding: 1.5rem !important; }

.modal-footer {
    border-top: 1px solid var(--gd-border) !important;
    padding: 1rem 1.5rem !important;
    background: var(--gd-bg);
}

/* ---------- 12. Dropdowns ---------- */
.dropdown-menu {
    border: 1px solid var(--gd-border) !important;
    border-radius: var(--gd-radius-md) !important;
    box-shadow: var(--gd-shadow-md) !important;
    padding: 0.4rem !important;
}

.dropdown-item {
    border-radius: var(--gd-radius-sm) !important;
    padding: 0.5rem 0.75rem !important;
    font-size: 0.86rem !important;
    transition: background-color var(--gd-transition), color var(--gd-transition);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background: var(--gd-primary-soft) !important;
    color: var(--gd-primary-strong) !important;
}

/* ---------- 13. Onglets / Pills ---------- */
.nav-pills .nav-link {
    border-radius: var(--gd-radius-sm) !important;
    color: var(--gd-text-soft);
    font-weight: 600;
    padding: 0.5rem 1rem;
    transition: background-color var(--gd-transition), color var(--gd-transition);
}

.nav-pills .nav-link:hover {
    color: var(--gd-primary-strong);
    background: var(--gd-primary-soft);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: linear-gradient(135deg, var(--gd-primary) 0%, var(--gd-primary-strong) 100%) !important;
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(79, 70, 229, 0.25);
}

.nav-tabs {
    border-bottom: 1px solid var(--gd-border);
}

.nav-tabs .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--gd-text-soft);
    font-weight: 600;
    border-radius: 0 !important;
}

.nav-tabs .nav-link.active {
    color: var(--gd-primary-strong);
    border-bottom-color: var(--gd-primary);
    background: transparent;
}

/* ---------- 14. Pagination ---------- */
.pagination .page-link {
    border: 1px solid var(--gd-border);
    color: var(--gd-text-soft);
    border-radius: var(--gd-radius-sm) !important;
    margin: 0 2px;
    padding: 0.45rem 0.8rem;
    transition: all var(--gd-transition);
}

.pagination .page-link:hover {
    background: var(--gd-primary-soft);
    color: var(--gd-primary-strong);
    border-color: var(--gd-primary-soft);
}

.pagination .page-item.active .page-link {
    background: linear-gradient(135deg, var(--gd-primary) 0%, var(--gd-primary-strong) 100%);
    border-color: var(--gd-primary);
    color: #fff;
    box-shadow: 0 4px 10px rgba(79, 70, 229, 0.25);
}

.pagination .page-item.disabled .page-link {
    color: var(--gd-text-muted);
    background: #fafbff;
    border-color: var(--gd-border);
    opacity: 0.6;
    cursor: not-allowed;
}

.docs-pagination {
    border-top: 1px solid var(--gd-border);
    margin-top: 4px;
}

.docs-per-page {
    width: auto;
    min-width: 72px;
    padding: 0.3rem 1.8rem 0.3rem 0.7rem;
    border-radius: var(--gd-radius-sm);
    border: 1px solid var(--gd-border);
    background-color: #fff;
    font-size: 0.8rem;
}

/* ---------- 15. Scrollbar ---------- */
* { scrollbar-width: thin; scrollbar-color: #c7cbd6 transparent; }

*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
    background: #c7cbd6;
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: content-box;
}
*::-webkit-scrollbar-thumb:hover { background: #9aa1b2; background-clip: content-box; border: 2px solid transparent; }

/* ---------- 16. Footer ---------- */
.footer { color: var(--gd-text-muted); }

/* ---------- 17. Liens ---------- */
a:not(.btn):not(.nav-link):not(.dropdown-item):not(.breadcrumb-item a):not(.page-link) {
    color: var(--gd-primary);
    text-decoration: none;
    transition: color var(--gd-transition);
}

a:not(.btn):not(.nav-link):not(.dropdown-item):not(.page-link):hover {
    color: var(--gd-primary-strong);
}

/* ---------- 18. Composants thématiques GesDom ---------- */

/* Cartes d'information (icône + label + valeur) */
.info-tile {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.85rem 1rem;
    background: var(--gd-surface);
    border: 1px solid var(--gd-border);
    border-radius: var(--gd-radius-md);
    transition: all var(--gd-transition);
}

.info-tile:hover {
    border-color: var(--gd-primary);
    box-shadow: var(--gd-shadow-sm);
    transform: translateY(-1px);
}

.info-tile .info-icon {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--gd-radius-sm);
    background: var(--gd-primary-soft);
    color: var(--gd-primary);
    flex-shrink: 0;
}

.info-tile .info-icon .material-symbols-rounded { font-size: 1.25rem; }

.info-tile .info-label {
    font-size: 0.72rem;
    color: var(--gd-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    display: block;
    margin-bottom: 0.1rem;
}

.info-tile .info-value {
    font-size: 0.95rem;
    color: var(--gd-text);
    font-weight: 600;
    line-height: 1.2;
}

/* Avatars / pastilles d'initiales */
.avatar-circle {
    width: 36px; height: 36px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--gd-primary) 0%, var(--gd-primary-strong) 100%);
    color: #fff;
    font-weight: 700;
    font-size: 0.78rem;
    border-radius: 999px;
    letter-spacing: 0.02em;
    flex-shrink: 0;
    box-shadow: 0 4px 8px rgba(79, 70, 229, 0.18);
}

/* Timeline (déjà utilisé sur /historiques — coexiste avec les styles existants) */
.timeline-icon { box-shadow: 0 4px 10px rgba(15, 23, 42, 0.08); }

/* États vides */
.empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--gd-text-muted);
}

.empty-state .material-symbols-rounded {
    font-size: 3.5rem;
    color: var(--gd-text-muted);
    opacity: 0.5;
    margin-bottom: 0.75rem;
}

/* Cartes statistiques avec mini-icône colorée */
.stat-card .stat-icon {
    width: 48px; height: 48px;
    border-radius: var(--gd-radius-md);
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff;
}

/* ---------- 19. Apparitions douces ---------- */
@keyframes gdFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

main .container-fluid > .row,
main .container-fluid > .card,
main .container-fluid > div > .card {
    animation: gdFadeIn 0.35s ease-out both;
}

/* ---------- 20. Bandeau partenaire (dashboard) ---------- */
.dashboard-partner-img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 220px;
    object-fit: contain;
    padding: 12px 18px;
    background: #ffffff;
    border-radius: var(--gd-radius-md);
    box-shadow: var(--gd-shadow-sm);
    border: 1px solid var(--gd-border);
}

/* ---------- 21. Responsivité — petits ajustements ---------- */
@media (max-width: 991.98px) {
    .navbar-main h6.font-weight-bolder { font-size: 1.15rem !important; }
    .card-body { padding: 1.15rem !important; }
    .dashboard-partner-img { max-height: 160px; padding: 10px 14px; }
}

/* =================================================================
   PAGES D'AUTHENTIFICATION (login / register)
   ================================================================= */

.auth-page {
    min-height: 100vh;
    margin: 0;
    font-family: 'Inter', sans-serif;
    background:
        radial-gradient(circle at 18% 22%, rgba(79, 70, 229, 0.55) 0%, transparent 45%),
        radial-gradient(circle at 82% 78%, rgba(139, 92, 246, 0.55) 0%, transparent 45%),
        linear-gradient(135deg, #312e81 0%, #4f46e5 45%, #7c3aed 100%);
    display: flex;
    flex-direction: column;
    position: relative;
    color: var(--gd-text);
}

.auth-page::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px);
    background-size: 26px 26px;
    pointer-events: none;
}

.auth-shell {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
    position: relative;
    z-index: 1;
}

.auth-card {
    width: 100%;
    max-width: 960px;
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 30px 80px rgba(15, 23, 42, 0.35), 0 8px 24px rgba(15, 23, 42, 0.15);
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr 1fr;
    animation: authIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
    min-height: 560px;
}

.auth-card.auth-card-wide { max-width: 1040px; }

@keyframes authIn {
    from { opacity: 0; transform: translateY(18px) scale(0.985); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.auth-brand {
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 50%, #8b5cf6 100%);
    color: #fff;
    padding: 52px 44px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    overflow: hidden;
}

.auth-brand::before,
.auth-brand::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}

.auth-brand::before {
    top: -110px; right: -110px;
    width: 320px; height: 320px;
    background: radial-gradient(circle, rgba(255,255,255,0.16) 0%, transparent 70%);
}

.auth-brand::after {
    bottom: -90px; left: -90px;
    width: 260px; height: 260px;
    background: radial-gradient(circle, rgba(255,255,255,0.10) 0%, transparent 70%);
}

.auth-brand > * { position: relative; z-index: 1; }

.brand-logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.brand-logo .material-symbols-rounded {
    background: rgba(255, 255, 255, 0.16);
    padding: 10px;
    border-radius: 12px;
    font-size: 26px;
    backdrop-filter: blur(8px);
}

.brand-partner {
    margin: 24px 0;
    padding: 16px 18px;
    background: rgba(255, 255, 255, 0.96);
    border-radius: 14px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-partner-img {
    max-width: 100%;
    height: auto;
    max-height: 110px;
    display: block;
}

@media (max-width: 860px) {
    .brand-partner { margin: 14px 0; padding: 10px 12px; }
    .brand-partner-img { max-height: 70px; }
}

.brand-headline {
    font-size: 30px;
    font-weight: 700;
    line-height: 1.2;
    margin: 28px 0 14px;
    letter-spacing: -0.025em;
}

.brand-tagline {
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.88);
    margin-bottom: 24px;
}

.brand-features {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.brand-feature {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.94);
}

.brand-feature .material-symbols-rounded {
    background: rgba(255, 255, 255, 0.18);
    padding: 6px;
    border-radius: 8px;
    font-size: 18px;
}

.auth-form-wrap {
    padding: 52px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: #fff;
}

.auth-form h1 {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.025em;
    color: #0f172a;
    margin: 0 0 6px;
}

.auth-form .auth-sub {
    color: #64748b;
    font-size: 14px;
    margin: 0 0 24px;
}

.auth-group { margin-bottom: 16px; }

.auth-group > label {
    display: block;
    font-size: 11.5px;
    font-weight: 600;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 7px;
}

.auth-input { position: relative; }

.auth-input > .material-symbols-rounded {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    font-size: 20px;
    pointer-events: none;
    transition: color var(--gd-transition);
}

.auth-page input[type="text"],
.auth-page input[type="email"],
.auth-page input[type="tel"],
.auth-page input[type="password"] {
    width: 100%;
    padding: 12px 16px !important;
    border: 1px solid #e2e8f0 !important;
    background: #f8fafc !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    transition: border-color var(--gd-transition), background-color var(--gd-transition), box-shadow var(--gd-transition);
    color: #0f172a !important;
    box-sizing: border-box;
    font-family: inherit;
}

.auth-input input[type="text"],
.auth-input input[type="email"],
.auth-input input[type="tel"],
.auth-input input[type="password"] { padding-left: 46px !important; }

.auth-page input:focus {
    border-color: #4f46e5 !important;
    background: #fff !important;
    box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.15) !important;
    outline: none !important;
}

.auth-page input:focus + .material-symbols-rounded,
.auth-input:focus-within > .material-symbols-rounded { color: #4f46e5; }

.auth-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.auth-options {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 8px 0 22px;
    flex-wrap: wrap;
    gap: 10px;
}

.auth-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #475569;
    font-size: 13px;
    cursor: pointer;
    user-select: none;
    margin: 0;
}

.auth-check input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: #4f46e5;
    cursor: pointer;
    margin: 0;
}

.auth-check a { color: #4f46e5; font-weight: 600; text-decoration: none; }
.auth-check a:hover { text-decoration: underline; }

.auth-submit {
    width: 100%;
    padding: 13px;
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: transform var(--gd-transition), box-shadow var(--gd-transition), filter var(--gd-transition);
    box-shadow: 0 8px 20px rgba(79, 70, 229, 0.35);
    font-family: inherit;
    letter-spacing: 0.01em;
}

.auth-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 28px rgba(79, 70, 229, 0.45);
    filter: brightness(1.06);
}

.auth-submit:active { transform: translateY(0); }

.auth-divider {
    margin: 24px 0 14px;
    position: relative;
    text-align: center;
}

.auth-divider::before {
    content: '';
    position: absolute;
    top: 50%; left: 0; right: 0;
    height: 1px;
    background: #e2e8f0;
}

.auth-divider span {
    background: #fff;
    padding: 0 14px;
    color: #64748b;
    font-size: 12.5px;
    position: relative;
}

.auth-alt-link {
    text-align: center;
    font-size: 14px;
    color: #475569;
}

.auth-alt-link a {
    color: #4f46e5;
    font-weight: 600;
    text-decoration: none;
}

.auth-alt-link a:hover { text-decoration: underline; }

.auth-alert {
    padding: 12px 14px;
    border-radius: 12px;
    font-size: 13.5px;
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    border: 1px solid transparent;
    line-height: 1.45;
}

.auth-alert .material-symbols-rounded { font-size: 20px; flex-shrink: 0; }

.auth-alert.danger { background: rgba(239,68,68,0.08); color: #991b1b; border-color: rgba(239,68,68,0.25); }
.auth-alert.success { background: rgba(16,185,129,0.08); color: #065f46; border-color: rgba(16,185,129,0.25); }
.auth-alert.info { background: rgba(59,130,246,0.10); color: #1e40af; border-color: rgba(59,130,246,0.28); }
.auth-alert.warning { background: rgba(245,158,11,0.12); color: #92400e; border-color: rgba(245,158,11,0.30); }

.auth-footer {
    text-align: center;
    color: rgba(255,255,255,0.8);
    font-size: 13px;
    padding: 18px;
    position: relative;
    z-index: 1;
    letter-spacing: 0.02em;
}

@media (max-width: 860px) {
    .auth-card {
        grid-template-columns: 1fr;
        min-height: auto;
        max-width: 460px;
    }
    .auth-brand { padding: 32px 28px; }
    .auth-brand .brand-features { display: none; }
    .auth-brand .brand-headline { font-size: 22px; margin: 16px 0 8px; }
    .auth-brand .brand-tagline { margin-bottom: 0; font-size: 14px; }
    .auth-form-wrap { padding: 32px 28px; }
    .auth-row { grid-template-columns: 1fr; gap: 0; }
}

/* =================================================================
   STYLES WORKFLOW (existants — conservés)
   ================================================================= */

.cursor-pointer { cursor: pointer; }

.step-icon {
    transition: transform 0.3s ease;
    display: inline-block;
}

.step-header .step-icon { transform: rotate(0deg); }

.step-content.collapse { transition: all 0.3s ease; }

.step-header { user-select: none; }

.step-name {
    border: none !important;
    background: transparent !important;
    font-weight: 600 !important;
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
}

.step-name:focus {
    outline: none !important;
    box-shadow: none !important;
}

.workflow-step {
    border: 1px solid var(--gd-border) !important;
    border-radius: var(--gd-radius-md) !important;
    transition: all var(--gd-transition);
    background: var(--gd-surface);
}

.workflow-step:hover {
    border-color: var(--gd-primary) !important;
    box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.08), var(--gd-shadow-sm);
}
