/* =========================================================
   AZUR — Espace client (shortcode [azur_account])
   Layout : Sidebar 280px fixe + Topbar sticky + 6 sous-pages switchables
   ========================================================= */

/* Defensive : annule la container WP autour du shortcode */
body:has(.azur-account) .entry-content,
body:has(.azur-account) .entry-content-wrap,
body:has(.azur-account) .single-content,
body:has(.azur-account) article.azur-page {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}
body:has(.azur-account) .azur-main { padding: 0 !important; }

.azur-account {
    display: flex;
    background: var(--bg);
    min-height: 100vh;
    font-family: var(--font-sans);
}

@media (max-width: 900px) {
    .azur-account { flex-direction: column; }
}

/* =========================================================
   SIDEBAR
   ========================================================= */
.azur-account__sidebar {
    width: 280px;
    background: var(--white);
    border-right: 1px solid var(--line);
    padding: 26px 0;
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
    flex-shrink: 0;
}
@media (max-width: 900px) {
    .azur-account__sidebar {
        width: 100%;
        height: auto;
        position: relative;
        border-right: 0;
        border-bottom: 1px solid var(--line);
    }
}

.azur-account__brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 24px 26px;
    border-bottom: 1px solid var(--line);
    text-decoration: none;
}
.azur-account__brand-mark {
    width: 38px;
    height: 38px;
    border-radius: var(--r-md);
    background: linear-gradient(135deg, var(--majorelle), var(--majorelle-deep));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.azur-account__brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}
.azur-account__brand-name {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 18px;
    color: var(--ink);
    letter-spacing: -0.035em;
}
.azur-account__brand-name em {
    font-style: italic;
    font-weight: var(--fw-medium);
    color: var(--gold);
}
.azur-account__brand-tagline {
    font-size: 9px;
    color: var(--muted);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    margin-top: 3px;
    font-weight: var(--fw-bold);
}

.azur-account__nav {
    padding: 20px 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}
.azur-account__nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: transparent;
    color: var(--ink-soft);
    border: 0;
    border-radius: var(--r-md);
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: var(--fw-semibold);
    cursor: pointer;
    text-align: left;
    transition: background var(--t-fast), color var(--t-fast);
}
.azur-account__nav-item:hover {
    background: var(--bg);
    color: var(--ink);
}
.azur-account__nav-item.is-active {
    background: var(--ink);
    color: var(--gold);
    font-weight: var(--fw-bold);
}
.azur-account__nav-item.is-active .azur-account__nav-icon { color: var(--gold); }
.azur-account__nav-icon {
    display: inline-flex;
    color: inherit;
}

.azur-account__sidebar-foot {
    padding: 16px 16px 0;
    border-top: 1px solid var(--line);
}
.azur-account__user {
    padding: 12px 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.azur-account__user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--majorelle), var(--gold));
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--fw-extra);
}
.azur-account__user-info {
    flex: 1;
    min-width: 0;
}
.azur-account__user-name {
    font-size: 13px;
    font-weight: var(--fw-bold);
    color: var(--ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.azur-account__user-email {
    font-size: 11px;
    color: var(--muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.azur-account__logout {
    width: 32px;
    height: 32px;
    border-radius: var(--r-sm);
    background: transparent;
    border: 0;
    color: var(--muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}
.azur-account__logout:hover { color: var(--ink); }

/* =========================================================
   NAV MOBILE — onglets horizontaux scrollables (<= 900px)
   Remplace la sidebar verticale qui poussait le contenu vers le bas.
   La barre colle en haut au scroll ; le logout reste accessible à droite.
   ========================================================= */
@media (max-width: 900px) {
    .azur-account__sidebar {
        flex-direction: row;
        align-items: center;
        position: sticky;
        top: 0;
        z-index: 40;
        padding: 0 4px;
        gap: 2px;
        background: var(--white);
        box-shadow: 0 1px 4px rgba(15, 23, 42, 0.06);
    }
    /* Brand masqué sur mobile : le header de page affiche déjà le titre */
    .azur-account__brand { display: none; }

    /* Nav : rangée horizontale qui défile au doigt */
    .azur-account__nav {
        flex-direction: row;
        flex: 1;
        overflow-x: auto;
        gap: 6px;
        padding: 9px 8px;
        scrollbar-width: none;              /* Firefox */
        -ms-overflow-style: none;           /* IE/Edge */
        -webkit-overflow-scrolling: touch;  /* momentum iOS */
        scroll-padding-inline: 8px;
    }
    .azur-account__nav::-webkit-scrollbar { display: none; } /* Chrome/Safari */

    .azur-account__nav-item {
        flex-shrink: 0;
        white-space: nowrap;
        padding: 9px 14px;
        min-height: 42px;               /* cible tactile confortable */
        font-size: 13px;
    }

    /* Foot : on ne garde que le logout (compact, à droite de la barre) */
    .azur-account__sidebar-foot {
        border-top: 0;
        padding: 0;
        flex-shrink: 0;
    }
    .azur-account__user { padding: 4px; gap: 0; }
    .azur-account__user-avatar,
    .azur-account__user-info { display: none; }
    .azur-account__logout {
        width: 42px;
        height: 42px;
    }
}

/* =========================================================
   MAIN + TOPBAR
   ========================================================= */
.azur-account__main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.azur-account__topbar {
    background: var(--white);
    border-bottom: 1px solid var(--line);
    padding: 20px 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: var(--font-sans);
    position: sticky;
    top: 0;
    z-index: 10;
}
@media (max-width: 720px) { .azur-account__topbar { padding: 16px 20px; } }

.azur-account__topbar-breadcrumb {
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-weight: var(--fw-bold);
    margin-bottom: 4px;
}
.azur-account__topbar-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 28px;
    color: var(--ink);
    margin: 0;
    letter-spacing: -0.03em;
    white-space: nowrap;
}
@media (max-width: 720px) { .azur-account__topbar-title { font-size: 22px; } }

.azur-account__topbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.azur-account__topbar-cta {
    padding: 10px 16px;
    border-radius: var(--r-md);
    font-size: 13px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    transition: transform var(--t-base);
}
.azur-account__topbar-cta--ghost {
    background: var(--bg);
    color: var(--ink);
    border: 1px solid var(--line);
    font-weight: var(--fw-bold);
}
.azur-account__topbar-cta--ghost:hover { background: var(--bg-soft); color: var(--ink); }
.azur-account__topbar-cta--primary {
    background: var(--ink);
    color: var(--gold);
    font-weight: var(--fw-extra);
}
.azur-account__topbar-cta--primary:hover {
    color: var(--gold);
    transform: translateY(-1px);
}
@media (max-width: 720px) {
    .azur-account__topbar-cta--ghost { display: none; }
}

/* =========================================================
   PAGE WRAPPER
   ========================================================= */
.azur-account__pages { flex: 1; }
.azur-account__page {
    padding: 32px 36px 60px;
}
.azur-account__page[hidden] { display: none; }
@media (max-width: 720px) {
    .azur-account__page { padding: 24px 20px 40px; }
}

/* =========================================================
   1. DASHBOARD
   ========================================================= */
.azur-account__welcome {
    background: linear-gradient(135deg, var(--ink) 0%, var(--majorelle-deep) 100%);
    border-radius: var(--r-xl);
    padding: 32px 36px;
    color: var(--white);
    position: relative;
    overflow: hidden;
    margin-bottom: 28px;
}
.azur-account__welcome-glow {
    position: absolute;
    top: -100px;
    right: -100px;
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 213, 74, 0.20), transparent 60%);
    filter: blur(40px);
    pointer-events: none;
}
.azur-account__welcome-grid {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 28px;
    flex-wrap: wrap;
}
.azur-account__welcome-eyebrow {
    font-size: 11px;
    color: var(--gold);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: var(--fw-extra);
    margin-bottom: 8px;
}
.azur-account__welcome-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: clamp(28px, 4vw, 36px);
    color: var(--white);
    margin: 0;
    letter-spacing: -0.03em;
}
.azur-account__welcome-title i {
    color: var(--gold);
    font-style: italic;
    font-weight: var(--fw-medium);
}
.azur-account__welcome-sub {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.70);
    margin-top: 8px;
}
.azur-account__welcome-ctas {
    display: flex;
    gap: 10px;
}
.azur-account__welcome-cta {
    padding: 12px 18px;
    border-radius: var(--r-md);
    border: 0;
    font-weight: var(--fw-bold);
    font-size: 13px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    text-decoration: none;
    transition: transform var(--t-base);
}
.azur-account__welcome-cta--ghost {
    background: rgba(255, 255, 255, 0.12);
    color: var(--white);
    border: 1px solid rgba(255, 255, 255, 0.22);
}
.azur-account__welcome-cta--ghost:hover { background: rgba(255, 255, 255, 0.20); color: var(--white); }
.azur-account__welcome-cta--gold {
    background: var(--gold);
    color: var(--ink);
    font-weight: var(--fw-extra);
}
.azur-account__welcome-cta--gold:hover { color: var(--ink); transform: translateY(-1px); }

/* Stats grid */
.azur-account__stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin-bottom: 28px;
}
@media (max-width: 980px) { .azur-account__stats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .azur-account__stats { grid-template-columns: 1fr; } }
.azur-account__stat {
    background: var(--white);
    border-radius: var(--r-lg);
    padding: 22px 24px;
    border: 1px solid var(--line);
}
.azur-account__stat-label {
    font-size: 12px;
    color: var(--muted);
    font-weight: var(--fw-semibold);
    margin-bottom: 12px;
}
.azur-account__stat-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}
.azur-account__stat-value {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 36px;
    color: var(--ink);
    letter-spacing: -0.03em;
    line-height: 1;
    white-space: nowrap;
}
.azur-account__stat-change {
    font-size: 11px;
    color: var(--success);
    font-weight: var(--fw-bold);
    white-space: nowrap;
}

/* Split: subscription + activity */
.azur-account__split {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 18px;
}
@media (max-width: 980px) { .azur-account__split { grid-template-columns: 1fr; } }

/* Variante "single" : quand l'activité récente est cachée (pas de données réelles),
   la carte abonnement occupe toute la largeur. En multi-dossiers, le grid
   bascule en colonnes auto pour répartir les cartes (2 par ligne si large). */
.azur-account__split--single {
    grid-template-columns: 1fr;
}
.azur-account__split--single:has(> .azur-account__sub-card + .azur-account__sub-card) {
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
}

/* Bandeau MULTI-ABONNEMENTS — affiché quand un user a 2+ dossiers actifs.
   Très visible (gold doux + icone grid) pour que l'admin sache d'un coup d'oeil. */
.azur-account__multi-banner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.08), rgba(245, 158, 11, 0.02));
    border: 1px solid rgba(245, 158, 11, 0.35);
    margin: 12px 0 18px;
}
.azur-account__multi-banner-ico {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(245, 158, 11, 0.15);
    color: #B45309;
}
.azur-account__multi-banner-body {
    flex: 1;
    min-width: 0;
}
.azur-account__multi-banner-title {
    font-family: var(--font-display, system-ui);
    font-size: 15px;
    color: var(--ink);
    line-height: 1.3;
}
.azur-account__multi-banner-title strong {
    color: #92400E;
    font-weight: 700;
}
.azur-account__multi-banner-meta {
    font-size: 12px;
    color: var(--ink-muted);
    margin-top: 2px;
}
.azur-account__multi-banner-cta {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 8px;
    border: 1px solid rgba(245, 158, 11, 0.4);
    background: #fff;
    color: #92400E;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms, transform 120ms;
}
.azur-account__multi-banner-cta:hover {
    background: rgba(245, 158, 11, 0.08);
    transform: translateX(2px);
}
@media (max-width: 640px) {
    .azur-account__multi-banner {
        flex-direction: column;
        align-items: flex-start;
    }
    .azur-account__multi-banner-cta {
        width: 100%;
        justify-content: center;
    }
}

/* Bandeau ABONNEMENT EN COURS — paiement à valider / activation en cours.
   Affiché sur le dashboard quand le client a DÉJÀ des identifiants ET une
   nouvelle commande pas encore débloquée. Ton bleu (info) volontairement
   distinct du bandeau multi-abonnements (ambre) pour éviter la confusion. */
.azur-account__pending-banner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(0, 63, 163, 0.07), rgba(0, 63, 163, 0.02));
    border: 1px solid rgba(0, 63, 163, 0.28);
    margin: 12px 0 18px;
}
.azur-account__pending-banner-ico {
    position: relative;
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(0, 63, 163, 0.12);
    color: #003FA3;
}
.azur-account__pending-banner-ico::after {
    content: "";
    position: absolute;
    top: 6px;
    right: 6px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #F59E0B;
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.25);
    animation: azurAccountPendingPulse 1.5s ease-in-out infinite;
}
@keyframes azurAccountPendingPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.35; }
}
@media (prefers-reduced-motion: reduce) {
    .azur-account__pending-banner-ico::after { animation: none; }
}
.azur-account__pending-banner-body {
    flex: 1;
    min-width: 0;
}
.azur-account__pending-banner-title {
    font-family: var(--font-display, system-ui);
    font-size: 15px;
    font-weight: 700;
    color: var(--ink);
    line-height: 1.3;
}
.azur-account__pending-banner-text {
    font-size: 12.5px;
    color: var(--ink-muted);
    margin-top: 3px;
    line-height: 1.55;
}
@media (max-width: 640px) {
    .azur-account__pending-banner {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* Variante "expired" / "expiring" des status pills (sur les sub-cards) */
.azur-account__status-pill--expired {
    background: rgba(198, 72, 58, 0.12);
    color: var(--danger, #C6483A);
}
.azur-account__status-pill--expired .azur-account__status-dot {
    background: var(--danger, #C6483A);
}
.azur-account__status-pill--expiring {
    background: rgba(245, 158, 11, 0.12);
    color: #B45309;
}
.azur-account__status-pill--expiring .azur-account__status-dot {
    background: #F59E0B;
}

.azur-account__card {
    background: var(--white);
    border-radius: var(--r-lg);
    padding: 26px 28px;
    border: 1px solid var(--line);
}
.azur-account__card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
    gap: 16px;
}
.azur-account__card-eyebrow {
    font-size: 11px;
    color: var(--majorelle);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: var(--fw-extra);
}
.azur-account__card-title-big {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 28px;
    color: var(--ink);
    margin-top: 6px;
    letter-spacing: -0.025em;
}
.azur-account__card-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 20px;
    color: var(--ink);
    letter-spacing: -0.02em;
}
.azur-account__see-all {
    font-size: 12px;
    color: var(--majorelle);
    font-weight: var(--fw-bold);
    cursor: pointer;
    text-decoration: none;
}
.azur-account__see-all:hover { color: var(--majorelle-deep); }

.azur-account__status-pill {
    padding: 5px 11px;
    background: rgba(31, 157, 85, 0.13);
    color: var(--success);
    border-radius: var(--r-pill);
    font-size: 11px;
    font-weight: var(--fw-extra);
    letter-spacing: 0.10em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.azur-account__status-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--success);
}

.azur-account__sub-row {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    color: var(--ink-soft);
    margin-bottom: 10px;
    flex-wrap: wrap;
    gap: 8px;
}
.azur-account__sub-row b { color: var(--ink); font-weight: var(--fw-bold); }
.azur-account__sub-days b { color: var(--majorelle); }
.azur-account__progress-bar {
    height: 8px;
    background: var(--bg);
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--line);
}
.azur-account__progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--majorelle), var(--gold));
    transition: width var(--t-slow);
}

.azur-account__sub-foot {
    margin-top: 24px;
    padding: 16px 18px;
    background: var(--bg);
    border-radius: var(--r-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.azur-account__sub-foot-label {
    font-size: 11px;
    color: var(--muted);
    font-weight: var(--fw-semibold);
}
.azur-account__sub-foot-value {
    font-size: 14px;
    color: var(--ink);
    font-weight: var(--fw-bold);
    margin-top: 2px;
}
.azur-account__sub-renew {
    padding: 10px 16px;
    border-radius: var(--r-md);
    background: var(--ink);
    color: var(--gold);
    text-decoration: none;
    font-weight: var(--fw-extra);
    font-size: 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
    transition: transform var(--t-base);
}
.azur-account__sub-renew:hover { color: var(--gold); transform: translateY(-1px); }

/* Activity */
.azur-account__activity {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.azur-account__activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--line-soft);
}
.azur-account__activity-item:last-child { border-bottom: 0; }
.azur-account__activity-ico {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: var(--bg);
    color: var(--majorelle);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.azur-account__activity-body { flex: 1; min-width: 0; }
.azur-account__activity-channel {
    font-size: 13px;
    color: var(--ink);
    font-weight: var(--fw-semibold);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.azur-account__activity-meta {
    font-size: 11px;
    color: var(--muted);
    margin-top: 2px;
}
.azur-account__activity-when {
    font-size: 11px;
    color: var(--muted);
    white-space: nowrap;
}

/* =========================================================
   2. CREDENTIALS
   ========================================================= */
.azur-account__warn {
    background: linear-gradient(135deg, var(--ink), var(--majorelle-deep));
    color: var(--white);
    border-radius: var(--r-lg);
    padding: 22px 26px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 14px;
}
.azur-account__warn--pending {
    background: linear-gradient(135deg, #2b2c4d, #3a3f6b);
    border-left: 4px solid var(--gold);
}

/* ============= Alert "URL mise à jour" (apparaît si maj < 7j) ============= */
.azur-account__alert {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 18px 22px;
    border-radius: var(--r-lg);
    margin-bottom: 16px;
    font-family: var(--font-sans);
    animation: azur-alert-slide-in .4s cubic-bezier(.16,1,.3,1);
}
@keyframes azur-alert-slide-in {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.azur-account__alert--update {
    background: linear-gradient(135deg, rgba(31,157,85,.12), rgba(31,157,85,.04));
    border: 1px solid rgba(31,157,85,.30);
    color: var(--ink);
}
.azur-account__alert-icon {
    font-size: 22px; line-height: 1; flex-shrink: 0;
    width: 44px; height: 44px; border-radius: 12px;
    background: rgba(31,157,85,.18);
    display: flex; align-items: center; justify-content: center;
}
.azur-account__alert-title {
    font-family: var(--font-display);
    font-weight: 800; font-size: 17px;
    color: var(--success);
    letter-spacing: -0.02em;
    margin-bottom: 4px;
}
.azur-account__alert-meta {
    font-size: 13px; line-height: 1.55;
    color: var(--ink-muted);
}
.azur-account__alert-meta strong { color: var(--ink); }

/* ============= Info banner permanente (rassurance bookmark) ============= */
.azur-account__info-banner {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 16px 22px;
    background: linear-gradient(135deg, rgba(0,63,163,.06), rgba(255,213,74,.04));
    border: 1px solid rgba(0,63,163,.18);
    border-radius: var(--r-lg);
    margin-bottom: 16px;
    font-family: var(--font-sans);
    font-size: 13px; line-height: 1.6;
    color: var(--ink-soft);
}
.azur-account__info-banner-icon {
    font-size: 20px; line-height: 1; flex-shrink: 0;
    width: 38px; height: 38px; border-radius: 10px;
    background: rgba(255,213,74,.18);
    display: flex; align-items: center; justify-content: center;
}
.azur-account__info-banner strong { color: var(--ink); font-weight: 700; }
.azur-account__info-banner-tip {
    display: block;
    margin-top: 6px;
    color: var(--majorelle);
    font-weight: 700;
}

/* ============================================================
   MULTI-DOSSIERS (user avec 2+ abonnements actifs)
   ============================================================ */
.azur-multi-creds { font-family: var(--font-sans); }

.azur-multi-creds__head {
    display: flex; justify-content: space-between; align-items: center;
    gap: 16px; flex-wrap: wrap;
    margin-bottom: 16px;
}
.azur-multi-creds__title {
    font-family: var(--font-display);
    font-weight: 800; font-size: 24px;
    color: var(--ink); margin: 0;
    letter-spacing: -0.025em;
}
.azur-multi-creds__meta {
    font-size: 13px; color: var(--ink-muted);
    margin: 4px 0 0;
}
.azur-multi-creds__meta strong { color: var(--ink); }
.azur-multi-creds .t-success { color: var(--success); font-weight: 700; }
.azur-multi-creds .t-danger  { color: var(--danger);  font-weight: 700; }

.azur-multi-creds__search {
    position: relative;
    display: flex; align-items: center; gap: 8px;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 8px 14px;
    min-width: 240px;
    transition: border-color .15s, box-shadow .15s;
}
.azur-multi-creds__search:focus-within {
    border-color: var(--majorelle);
    box-shadow: 0 0 0 3px rgba(0,63,163,.12);
}
.azur-multi-creds__search svg { color: var(--muted); flex-shrink: 0; }
.azur-multi-creds__search input {
    border: none; background: transparent; outline: none;
    font-family: var(--font-sans); font-size: 13px;
    color: var(--ink); width: 100%;
}

.azur-multi-creds__filters {
    display: flex; gap: 8px; flex-wrap: wrap;
    margin-bottom: 18px;
}
.azur-multi-creds__filter {
    padding: 8px 16px; border-radius: 999px;
    background: var(--white); border: 1px solid var(--line);
    color: var(--ink-soft); font-weight: 700; font-size: 12px;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}
.azur-multi-creds__filter:hover { border-color: var(--majorelle); color: var(--ink); }
.azur-multi-creds__filter.is-active {
    background: var(--ink); color: var(--gold); border-color: var(--ink);
}

.azur-multi-creds__list {
    display: flex; flex-direction: column; gap: 10px;
}
.azur-multi-creds__item {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    overflow: hidden;
    transition: border-color .15s, box-shadow .15s;
}
.azur-multi-creds__item[open] {
    border-color: rgba(0,63,163,.35);
    box-shadow: 0 10px 24px -16px rgba(0,67,163,.18);
}
.azur-multi-creds__item[hidden] { display: none; }

.azur-multi-creds__item-head {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 14px; align-items: center;
    padding: 14px 18px;
    cursor: pointer;
    list-style: none;
}
.azur-multi-creds__item-head::-webkit-details-marker { display: none; }
.azur-multi-creds__item-num {
    font-family: monospace; font-size: 11px;
    color: var(--muted); font-weight: 700;
    background: var(--bg); padding: 4px 8px; border-radius: 6px;
}
.azur-multi-creds__item-titles { min-width: 0; }
.azur-multi-creds__item-formule {
    display: block;
    font-family: var(--font-display); font-size: 16px; font-weight: 800;
    color: var(--ink); letter-spacing: -0.02em;
    line-height: 1.2;
}
.azur-multi-creds__item-sub {
    display: block;
    font-size: 12px; color: var(--muted); margin-top: 2px;
}
.azur-multi-creds__item-badge {
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 800; letter-spacing: .04em;
    white-space: nowrap;
}
.azur-multi-creds__item-badge--active   { background: rgba(31,157,85,.15);  color: var(--success); }
.azur-multi-creds__item-badge--expiring { background: rgba(245,197,24,.18); color: var(--gold-deep); }
.azur-multi-creds__item-badge--expired  { background: rgba(198,72,58,.15);  color: var(--danger); }

.azur-multi-creds__item-chevron {
    color: var(--muted); flex-shrink: 0;
    transition: transform .2s;
}
.azur-multi-creds__item[open] .azur-multi-creds__item-chevron { transform: rotate(180deg); }

.azur-multi-creds__item-body {
    padding: 18px;
    border-top: 1px solid var(--line);
    background: var(--bg);
}

.azur-multi-creds__empty {
    text-align: center; padding: 60px 20px; color: var(--muted);
    background: var(--white); border: 1px dashed var(--line); border-radius: var(--r-lg);
}
.azur-multi-creds__empty svg { color: var(--muted); margin: 0 auto 12px; display: block; }
.azur-multi-creds__empty p { margin: 0; font-size: 14px; }

/* Responsive */
@media (max-width: 720px) {
    .azur-multi-creds__head { flex-direction: column; align-items: stretch; }
    .azur-multi-creds__search { min-width: 0; width: 100%; }
    .azur-multi-creds__item-head {
        grid-template-columns: auto 1fr auto;
        gap: 10px; padding: 12px 14px;
    }
    .azur-multi-creds__item-chevron { display: none; }
    .azur-multi-creds__item-formule { font-size: 15px; }
    .azur-multi-creds__item-sub { font-size: 11px; }
    .azur-multi-creds__item-body { padding: 14px; }
}

/* ============= LOGIN PROMPT (user not logged in) ============= */
.azur-account--login {
    grid-template-columns: 1fr;
    min-height: 70vh;
    align-items: center;
    justify-items: center;
    padding: 60px 24px;
    background: var(--bg);
}
.azur-account__login {
    width: 100%;
    max-width: 560px;
}
.azur-account__login-card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 24px;
    padding: 48px 44px;
    text-align: center;
    box-shadow: 0 30px 60px -25px rgba(13, 18, 48, .15);
    font-family: var(--font-sans);
}
.azur-account__login-eyebrow {
    font-size: var(--fs-eyebrow);
    color: var(--majorelle);
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 800;
    margin-bottom: 14px;
}
.azur-account__login-title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 38px;
    color: var(--ink);
    margin: 0 0 16px;
    letter-spacing: -0.035em;
    line-height: 1.05;
}
.azur-account__login-lead {
    font-size: 16px;
    color: var(--ink-muted);
    line-height: 1.6;
    margin: 0 0 28px;
}
.azur-account__login-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.azur-account__login-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 24px;
    border-radius: 12px;
    font-weight: 800;
    font-size: 15px;
    text-decoration: none;
    transition: transform .15s, box-shadow .15s;
}
.azur-account__login-btn--primary {
    background: var(--ink);
    color: var(--gold);
    box-shadow: 0 14px 30px rgba(13, 18, 48, .25);
}
.azur-account__login-btn--primary:hover { transform: translateY(-1px); }
.azur-account__login-btn--ghost {
    background: var(--bg);
    color: var(--ink-soft);
    border: 1px solid var(--line);
}
.azur-account__login-btn--ghost:hover { border-color: var(--majorelle); color: var(--ink); }
.azur-account__login-help {
    margin: 22px 0 0;
    font-size: 13px;
    color: var(--muted);
}
.azur-account__login-help a { color: var(--majorelle); }

/* ============================================================
   WELCOME PAGE — user inscrit SANS abonnement
   ============================================================ */
.azur-welcome {
    background: var(--bg);
    min-height: 70vh;
    font-family: var(--font-sans);
    padding-bottom: 60px;
}

.azur-welcome .t-gold     { color: var(--gold); }
.azur-welcome .t-accent   { color: var(--majorelle); }

/* Hero — gradient ink+majorelle avec blooms */
.azur-welcome__hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--ink) 0%, var(--majorelle-deep) 100%);
    color: var(--white);
    padding: 72px 32px 56px;
    text-align: center;
}
.azur-welcome__hero-bloom {
    position: absolute;
    border-radius: 50%;
    filter: blur(50px);
    pointer-events: none;
}
.azur-welcome__hero-bloom--gold      { top: -160px; right: -120px; width: 480px; height: 480px; background: radial-gradient(circle, rgba(255, 213, 74, .3), transparent 60%); }
.azur-welcome__hero-bloom--majorelle { bottom: -140px; left: -120px; width: 440px; height: 440px; background: radial-gradient(circle, rgba(42, 102, 196, .4), transparent 60%); }
.azur-welcome__hero-inner {
    position: relative;
    max-width: 760px;
    margin: 0 auto;
}

.azur-welcome__avatar {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--gold-deep));
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 24px;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 40px;
    letter-spacing: -0.04em;
    box-shadow: 0 20px 50px rgba(255, 213, 74, .35), 0 0 0 8px rgba(255, 213, 74, .12);
    animation: azur-welcome-pulse 2.5s ease-in-out infinite;
}
@keyframes azur-welcome-pulse {
    0%, 100% { transform: scale(1); box-shadow: 0 20px 50px rgba(255, 213, 74, .35), 0 0 0 8px rgba(255, 213, 74, .12); }
    50%      { transform: scale(1.04); box-shadow: 0 22px 56px rgba(255, 213, 74, .45), 0 0 0 12px rgba(255, 213, 74, .15); }
}

.azur-welcome__eyebrow {
    font-size: var(--fs-eyebrow);
    color: var(--gold);
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 800;
    margin-bottom: 12px;
}
.azur-welcome__title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(36px, 5vw, 56px);
    color: var(--white);
    margin: 0;
    line-height: 1.02;
    letter-spacing: -0.04em;
}
.azur-welcome__lead {
    font-size: 17px;
    line-height: 1.6;
    color: rgba(255, 255, 255, .85);
    margin: 22px auto 32px;
    max-width: 600px;
}
.azur-welcome__lead strong { color: var(--white); font-weight: 700; }
.azur-welcome__lead .t-gold { font-weight: 800; }

.azur-welcome__cta-row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
}
.azur-welcome__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 28px;
    border-radius: 12px;
    font-weight: 800;
    font-size: 14px;
    text-decoration: none;
    transition: transform .15s, box-shadow .15s, background .15s;
}
.azur-welcome__btn--gold {
    background: var(--gold);
    color: var(--ink);
    box-shadow: 0 16px 36px rgba(255, 213, 74, .4);
}
.azur-welcome__btn--gold:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 50px rgba(255, 213, 74, .55);
}
.azur-welcome__btn--ghost {
    background: rgba(255, 255, 255, .1);
    color: var(--white);
    border: 1px solid rgba(255, 255, 255, .25);
}
.azur-welcome__btn--ghost:hover { background: rgba(255, 255, 255, .18); }

/* Stats sociales sous le hero */
.azur-welcome__stats {
    margin-top: 44px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    padding-top: 36px;
    border-top: 1px solid rgba(255, 255, 255, .12);
}
.azur-welcome__stat { text-align: center; }
.azur-welcome__stat-value {
    display: block;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 26px;
    color: var(--white);
    line-height: 1;
    letter-spacing: -0.025em;
}
.azur-welcome__stat-label {
    display: block;
    font-size: 12px;
    color: rgba(255, 255, 255, .6);
    margin-top: 8px;
    letter-spacing: 0.04em;
}

/* Steps — comment ça se passe (avant les perks) */
.azur-welcome__steps-wrap {
    max-width: 880px;
    margin: 0 auto;
    padding: 72px 32px 0;
}
.azur-welcome__steps-head {
    text-align: center;
    margin-bottom: 40px;
}
.azur-welcome__steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.azur-welcome__step {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 22px;
    align-items: flex-start;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 22px 24px;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.azur-welcome__step:hover {
    transform: translateY(-2px);
    border-color: var(--majorelle);
    box-shadow: 0 14px 30px -16px rgba(0, 43, 117, .25);
}
.azur-welcome__step-num {
    width: 56px;
    height: 56px;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--majorelle), var(--majorelle-deep));
    color: var(--gold);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 26px;
    letter-spacing: -0.03em;
    box-shadow: 0 10px 22px -8px rgba(0, 43, 117, .35);
    flex-shrink: 0;
}
.azur-welcome__step-body { min-width: 0; }
.azur-welcome__step h3 {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 19px;
    color: var(--ink);
    margin: 0 0 6px;
    letter-spacing: -0.02em;
    line-height: 1.2;
}
.azur-welcome__step p {
    font-size: 14px;
    line-height: 1.6;
    color: var(--ink-muted);
    margin: 0;
}
.azur-welcome__step p strong {
    color: var(--ink);
    background: rgba(255, 213, 74, .25);
    padding: 1px 6px;
    border-radius: 4px;
    font-weight: 700;
}
.azur-welcome__step p a {
    color: var(--majorelle);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* Perks — ce qui attend après activation */
.azur-welcome__perks-wrap {
    max-width: 1080px;
    margin: 0 auto;
    padding: 72px 32px 0;
}
.azur-welcome__perks-head {
    text-align: center;
    margin-bottom: 36px;
}
.azur-welcome__perks-eyebrow {
    font-size: var(--fs-eyebrow);
    color: var(--majorelle);
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 800;
    margin-bottom: 12px;
}
.azur-welcome__perks-title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(28px, 4vw, 42px);
    color: var(--ink);
    margin: 0;
    line-height: 1.1;
    letter-spacing: -0.035em;
}
.azur-welcome__perks {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.azur-welcome__perk {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 26px 22px;
    transition: transform .2s, border-color .2s, box-shadow .2s;
}
.azur-welcome__perk:hover {
    transform: translateY(-3px);
    border-color: var(--majorelle);
    box-shadow: 0 18px 40px -20px rgba(0, 43, 117, .25);
}
.azur-welcome__perk-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--majorelle), var(--majorelle-deep));
    color: var(--gold);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}
.azur-welcome__perk h3 {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 17px;
    color: var(--ink);
    margin: 0 0 8px;
    letter-spacing: -0.02em;
    line-height: 1.2;
}
.azur-welcome__perk p {
    font-size: 13px;
    line-height: 1.55;
    color: var(--ink-muted);
    margin: 0;
}

/* Footer footer */
.azur-welcome__footer {
    max-width: 1080px;
    margin: 60px auto 0;
    padding: 24px 32px 0;
    border-top: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 13px;
    color: var(--muted);
}
.azur-welcome__footer strong { color: var(--ink); font-weight: 700; }
.azur-welcome__footer-actions a {
    color: var(--majorelle);
    text-decoration: none;
    margin: 0 4px;
}
.azur-welcome__footer-actions a:hover { text-decoration: underline; }
.azur-welcome__footer-actions span { color: var(--line); margin: 0 4px; }

/* Responsive */
@media (max-width: 720px) {
    .azur-welcome__hero { padding: 56px 22px 44px; }
    .azur-welcome__title { font-size: 32px; }
    .azur-welcome__stats { grid-template-columns: 1fr 1fr; gap: 22px; padding-top: 28px; }
    .azur-welcome__stat-value { font-size: 22px; }
    .azur-welcome__perks-wrap { padding: 52px 22px 0; }
    .azur-welcome__perks { grid-template-columns: 1fr 1fr; }
    .azur-welcome__cta-row { flex-direction: column; align-items: stretch; }
    .azur-welcome__footer { flex-direction: column; text-align: center; padding: 20px 22px 0; }
    .azur-welcome__steps-wrap { padding: 52px 22px 0; }
    .azur-welcome__step { grid-template-columns: 48px 1fr; gap: 14px; padding: 18px 18px; }
    .azur-welcome__step-num { width: 44px; height: 44px; font-size: 20px; border-radius: 12px; }
    .azur-welcome__step h3 { font-size: 16px; }
    .azur-welcome__step p { font-size: 13px; }
}
@media (max-width: 480px) {
    .azur-welcome__perks { grid-template-columns: 1fr; }
}
.azur-account__warn-title {
    font-weight: var(--fw-extra);
    font-size: 14px;
    color: var(--white);
}
.azur-account__warn-meta {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.70);
    margin-top: 2px;
}

.azur-account__creds-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
@media (max-width: 760px) { .azur-account__creds-grid { grid-template-columns: 1fr; } }

.azur-account__creds-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 16px;
}

.azur-account__cred-row {
    padding: 16px 18px;
    background: var(--bg);
    border-radius: var(--r-md);
    border: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
}
.azur-account__cred-info {
    min-width: 0;
    flex: 1;
}
.azur-account__cred-label {
    font-size: 11px;
    color: var(--muted);
    font-weight: var(--fw-semibold);
    margin-bottom: 4px;
}
.azur-account__cred-value {
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--ink);
    font-weight: var(--fw-bold);
    word-break: break-all;
}
.azur-account__cred-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}
.azur-account__cred-btn {
    width: 34px;
    height: 34px;
    border-radius: var(--r-sm);
    background: var(--white);
    color: var(--ink-soft);
    border: 1px solid var(--line);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--t-fast), color var(--t-fast);
}
.azur-account__cred-btn--copy {
    background: var(--ink);
    color: var(--gold);
    border-color: var(--ink);
}
.azur-account__cred-btn--copy:hover { background: var(--majorelle-deep); color: var(--gold); }
.azur-account__cred-btn--copy.is-copied {
    background: var(--success);
    color: var(--white);
    border-color: var(--success);
}
.azur-account__cred-btn--reveal:hover { background: var(--bg-soft); color: var(--majorelle); }

.azur-account__creds-hint {
    margin-top: 16px;
    padding: 12px 16px;
    background: var(--bg);
    border-radius: var(--r-md);
    font-size: 12px;
    color: var(--ink-muted);
    display: flex;
    align-items: center;
    gap: 10px;
}

/* =========================================================
   IDENTIFIANTS — onglets par méthode (Lien M3U / Xtream / MAC)
   Segmented control : on n'affiche que le panneau de la méthode active.
   ========================================================= */
.azur-creds-methods {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 14px;
}
.azur-creds-methods__tabs {
    display: flex;
    gap: 4px;
    background: var(--bg);
    border-radius: var(--r-md);
    padding: 4px;
    margin-bottom: 16px;
}
.azur-creds-methods__tab {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 44px;
    padding: 8px 10px;
    border: 0;
    border-radius: calc(var(--r-md) - 2px);
    background: transparent;
    color: var(--muted);
    font-family: var(--font-sans);
    font-size: 13.5px;
    font-weight: var(--fw-semibold);
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
}
.azur-creds-methods__tab svg { flex-shrink: 0; }
.azur-creds-methods__tab:hover { color: var(--ink); }
.azur-creds-methods__tab.is-active {
    background: var(--white);
    color: var(--ink);
    box-shadow: 0 1px 3px rgba(13, 18, 48, 0.14);
}

.azur-creds-methods__panel { animation: azur-creds-fade 0.18s ease-out; }
@keyframes azur-creds-fade {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: none; }
}
.azur-creds-methods__panel .azur-account__creds-hint { margin-top: 14px; }

/* Hero M3U : URL + gros bouton copier (méthode primaire) */
.azur-creds-methods__hero {
    background: var(--bg);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 16px;
}
.azur-creds-methods__hero-label {
    font-size: 11px;
    font-weight: var(--fw-bold);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.09em;
    margin-bottom: 9px;
}
.azur-creds-methods__url {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 13px;
    color: var(--ink);
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-sm);
    padding: 12px 14px;
    word-break: break-all;
    line-height: 1.55;
    max-height: 86px;
    overflow-y: auto;
    margin-bottom: 12px;
}
.azur-creds-methods__copy-btn {
    width: 100%;
    min-height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    background: var(--ink);
    color: var(--gold);
    border: 0;
    border-radius: var(--r-md);
    font-family: var(--font-sans);
    font-size: 15px;
    font-weight: var(--fw-bold);
    cursor: pointer;
    transition: transform var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.azur-creds-methods__copy-btn svg { flex-shrink: 0; }
.azur-creds-methods__copy-btn:hover { background: #060a22; }
.azur-creds-methods__copy-btn:active { transform: scale(0.98); }
.azur-creds-methods__copy-btn.is-copied { background: var(--success); color: var(--white); }

@media (max-width: 560px) {
    .azur-creds-methods { padding: 12px; }
    .azur-creds-methods__tab { font-size: 12.5px; padding: 8px 6px; gap: 5px; }
    .azur-creds-methods__tab svg { width: 15px; height: 15px; }
    .azur-creds-methods__url { font-size: 12px; }
}

/* =========================================================
   RENOUVELER 1-CLIC — CTA in-line par dossier (vue multi)
   3 états visuels alignés sur l'urgence : actif / expire-bientôt / expiré.
   ========================================================= */
.azur-renew-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    min-height: 46px;
    padding: 11px 16px;
    margin-bottom: 14px;
    border-radius: var(--r-md);
    text-decoration: none;
    font-family: var(--font-sans);
    font-size: 13.5px;
    font-weight: var(--fw-bold);
    letter-spacing: -0.005em;
    transition: transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.azur-renew-cta svg { flex-shrink: 0; }
.azur-renew-cta:active { transform: scale(0.99); }

/* Actif : discret, ne crie pas */
.azur-renew-cta--active {
    background: var(--bg);
    color: var(--ink);
    border: 1px solid var(--line);
}
.azur-renew-cta--active:hover { background: var(--white); box-shadow: 0 1px 3px rgba(13,18,48,0.08); }

/* Expire bientôt : ambré, attire l'œil */
.azur-renew-cta--expiring {
    background: rgba(255, 213, 74, 0.18);
    color: var(--ink);
    border: 1px solid var(--gold);
}
.azur-renew-cta--expiring:hover { background: rgba(255, 213, 74, 0.28); }

/* Expiré : sombre + gold, action urgente */
.azur-renew-cta--expired {
    background: var(--ink);
    color: var(--gold);
    border: 1px solid var(--ink);
}
.azur-renew-cta--expired:hover { background: #060a22; }

.azur-account__creds-cta {
    margin-top: 24px;
    background: linear-gradient(135deg, var(--bg), var(--bg-soft));
    border-radius: var(--r-lg);
    padding: 24px 28px;
    border: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.azur-account__creds-cta-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 18px;
    color: var(--ink);
    letter-spacing: -0.02em;
}
.azur-account__creds-cta-meta {
    font-size: 13px;
    color: var(--ink-muted);
    margin-top: 4px;
}
.azur-account__creds-cta-btn {
    padding: 12px 20px;
    border-radius: var(--r-md);
    background: var(--ink);
    color: var(--gold);
    text-decoration: none;
    font-weight: var(--fw-extra);
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    transition: transform var(--t-base);
}
.azur-account__creds-cta-btn:hover { color: var(--gold); transform: translateY(-1px); }

/* =========================================================
   3. SUPPORT
   ========================================================= */
.azur-account__support-card {
    background: linear-gradient(135deg, var(--ink), var(--majorelle-deep));
    color: var(--white);
    border-radius: var(--r-xl);
    padding: 44px 48px;
    position: relative;
    overflow: hidden;
}
@media (max-width: 720px) { .azur-account__support-card { padding: 32px 24px; } }
.azur-account__support-glow {
    position: absolute;
    top: -100px;
    right: -100px;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 213, 74, 0.20), transparent 60%);
    filter: blur(40px);
    pointer-events: none;
}
.azur-account__support-grid {
    position: relative;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 36px;
    align-items: center;
}
@media (max-width: 980px) { .azur-account__support-grid { grid-template-columns: 1fr; } }
.azur-account__support-eyebrow {
    font-size: 11px;
    color: var(--gold);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: var(--fw-extra);
    margin-bottom: 12px;
    display: inline-block;
}
.azur-account__support-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: clamp(28px, 4vw, 40px);
    color: var(--white);
    margin: 0;
    line-height: 1;
    letter-spacing: -0.03em;
}
.azur-account__support-title i {
    color: var(--gold);
    font-style: italic;
    font-weight: var(--fw-medium);
}
.azur-account__support-lead {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.75);
    margin-top: 14px;
    max-width: 540px;
    line-height: 1.55;
}
.azur-account__support-channels {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.azur-account__support-channel {
    padding: 14px 18px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--r-md);
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    text-align: left;
    color: var(--white);
    transition: background var(--t-fast);
}
.azur-account__support-channel:hover { background: rgba(255, 255, 255, 0.14); }
.azur-account__support-channel-ico {
    width: 40px;
    height: 40px;
    border-radius: var(--r-md);
    color: var(--ink);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.azur-account__support-channel-ico--gold      { background: var(--gold); }
.azur-account__support-channel-ico--green     { background: #25d366; color: var(--white); }
.azur-account__support-channel-ico--majorelle { background: var(--majorelle-soft); color: var(--white); }
.azur-account__support-channel-ico--ink       { background: var(--white); color: var(--ink); }
a.azur-account__support-channel { text-decoration: none; }
button.azur-account__support-channel { width: 100%; font-family: inherit; font-size: inherit; appearance: none; -webkit-appearance: none; }
.azur-account__support-channel-body { flex: 1; color: var(--white); }
.azur-account__support-channel-title {
    font-size: 14px;
    font-weight: var(--fw-bold);
    color: var(--white);
}
.azur-account__support-channel-meta {
    font-size: 11px;
    color: rgba(255, 255, 255, 0.65);
    margin-top: 2px;
}
.azur-account__support-channel-arrow {
    color: rgba(255, 255, 255, 0.50);
}

/* =========================================================
   3b. SUPPORT — Formulaire de ticket (wizard 3 étapes)
   ========================================================= */
.azur-account__ticket {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-xl);
    padding: 32px 36px;
    box-shadow: var(--sh-md);
    position: relative;
}
@media (max-width: 720px) { .azur-account__ticket { padding: 24px 20px; } }

.azur-account__ticket-head { margin-bottom: 4px; }
.azur-account__ticket-eyebrow {
    font-size: 11px;
    color: var(--majorelle);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: var(--fw-extra);
    margin-bottom: 10px;
    display: inline-block;
}
.azur-account__ticket-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: clamp(24px, 3.4vw, 32px);
    color: var(--ink);
    margin: 0;
    line-height: 1.05;
    letter-spacing: -0.03em;
}
.azur-account__ticket-sub {
    font-size: 14px;
    color: var(--muted);
    margin-top: 8px;
}

/* Step pills */
.azur-account__ticket-steps {
    display: flex;
    gap: 8px;
    margin: 22px 0 26px;
    padding: 0;
    list-style: none;
    flex-wrap: wrap;
}
.azur-account__ticket-pill {
    display: flex;
    align-items: center;
    gap: 9px;
    font-size: 13px;
    font-weight: var(--fw-semibold);
    color: var(--muted);
    padding: 8px 16px 8px 8px;
    border-radius: var(--r-pill);
    background: var(--bg);
    border: 1px solid var(--line);
    flex: 1 1 auto;
    min-width: max-content;
    transition: color var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
}
.azur-account__ticket-pill-num {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: var(--fw-extra);
    background: var(--line);
    color: var(--muted);
    flex-shrink: 0;
}
.azur-account__ticket-pill.is-active {
    color: var(--ink);
    background: var(--white);
    border-color: var(--majorelle);
    box-shadow: 0 0 0 1px var(--majorelle);
}
.azur-account__ticket-pill.is-active .azur-account__ticket-pill-num { background: var(--majorelle); color: #fff; }
.azur-account__ticket-pill.is-done { color: var(--ink); }
.azur-account__ticket-pill.is-done .azur-account__ticket-pill-num { background: var(--majorelle-light); color: var(--majorelle-deep); }

/* Form */
.azur-account__ticket-form { position: relative; }
.azur-account__ticket-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.azur-account__ticket-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
}
@media (max-width: 600px) { .azur-account__ticket-grid { grid-template-columns: 1fr; } }

.azur-account__ticket-field {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-bottom: 16px;
}
.azur-account__ticket-field label {
    font-size: 13px;
    font-weight: var(--fw-bold);
    color: var(--ink-soft);
}
.azur-account__ticket-opt {
    font-weight: var(--fw-medium);
    color: var(--muted);
    font-size: 12px;
}
.azur-account__ticket-field input,
.azur-account__ticket-field select,
.azur-account__ticket-field textarea {
    width: 100%;
    font-family: inherit;
    font-size: 15px;
    color: var(--ink);
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
    padding: 12px 14px;
    min-height: 46px;
    transition: border-color var(--t-fast), box-shadow var(--t-fast);
    appearance: none;
    -webkit-appearance: none;
}
.azur-account__ticket-field textarea {
    min-height: 124px;
    resize: vertical;
    line-height: 1.55;
}
.azur-account__ticket-field select {
    padding-right: 40px;
    cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%233a4170' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
}
.azur-account__ticket-field input::placeholder,
.azur-account__ticket-field textarea::placeholder { color: var(--muted); }
.azur-account__ticket-field input:focus,
.azur-account__ticket-field select:focus,
.azur-account__ticket-field textarea:focus {
    outline: none;
    border-color: var(--majorelle);
    box-shadow: 0 0 0 3px rgba(0, 63, 163, 0.12);
}
.azur-account__ticket-field.has-error input,
.azur-account__ticket-field.has-error select,
.azur-account__ticket-field.has-error textarea {
    border-color: var(--danger);
    box-shadow: 0 0 0 3px rgba(198, 72, 58, 0.12);
}
.azur-account__ticket-hint {
    font-size: 12px;
    color: var(--muted);
    margin-top: -2px;
}

/* Encadrés d'aide (étape 2) : guident le choix de catégorie pour un tri rapide. */
.azur-account__ticket-tips {
    display: grid;
    gap: 9px;
    margin: 4px 0 2px;
}
.azur-account__ticket-tip {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    background: rgba(0, 63, 163, 0.06);
    border: 1px solid var(--line);
    border-left: 3px solid var(--majorelle);
    border-radius: var(--r-md);
    padding: 10px 13px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--ink-soft);
}
.azur-account__ticket-tip strong { color: var(--ink); font-weight: var(--fw-semibold); }
.azur-account__ticket-tip-ico {
    flex-shrink: 0;
    display: inline-flex;
    color: var(--majorelle);
    margin-top: 1px;
}

/* Actions */
.azur-account__ticket-actions {
    display: flex;
    gap: 12px;
    justify-content: space-between;
    margin-top: 22px;
}
.azur-account__ticket-actions--end { justify-content: flex-end; }
.azur-account__ticket-btn {
    font-family: inherit;
    font-size: 15px;
    font-weight: var(--fw-bold);
    border-radius: var(--r-pill);
    padding: 13px 26px;
    min-height: 48px;
    cursor: pointer;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.azur-account__ticket-btn--primary {
    background: var(--majorelle);
    color: #fff;
    box-shadow: var(--sh-glow-majorelle);
}
.azur-account__ticket-btn--primary:hover { background: var(--majorelle-deep); transform: translateY(-1px); }
.azur-account__ticket-btn--ghost {
    background: transparent;
    color: var(--ink-soft);
    border-color: var(--line);
}
.azur-account__ticket-btn--ghost:hover { background: var(--bg); }
.azur-account__ticket-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none; box-shadow: none; }
.azur-account__ticket-btn:focus-visible { outline: 2px solid var(--majorelle); outline-offset: 2px; }
.azur-account__ticket-btn.is-loading { color: transparent; pointer-events: none; position: relative; }
.azur-account__ticket-btn.is-loading::after {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.5);
    border-top-color: #fff;
    border-radius: 50%;
    animation: azur-tk-spin 0.7s linear infinite;
}
@keyframes azur-tk-spin { to { transform: rotate(360deg); } }

/* Recap (étape 3) */
.azur-account__ticket-recap {
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    overflow: hidden;
}
.azur-account__ticket-recap-row {
    display: flex;
    gap: 16px;
    padding: 13px 18px;
    border-bottom: 1px solid var(--line-soft);
    font-size: 14px;
}
.azur-account__ticket-recap-row:last-child { border-bottom: none; }
.azur-account__ticket-recap-label {
    color: var(--muted);
    width: 120px;
    flex-shrink: 0;
    font-weight: var(--fw-semibold);
    font-size: 13px;
}
.azur-account__ticket-recap-value {
    color: var(--ink);
    font-weight: var(--fw-semibold);
    white-space: pre-wrap;
    word-break: break-word;
}

/* Erreur */
.azur-account__ticket-error {
    margin-top: 16px;
    background: rgba(198, 72, 58, 0.08);
    border: 1px solid rgba(198, 72, 58, 0.30);
    color: #9a2f24;
    border-radius: var(--r-md);
    padding: 12px 16px;
    font-size: 14px;
    font-weight: var(--fw-semibold);
}

/* Succès */
.azur-account__ticket-success { text-align: center; padding: 24px 8px 8px; }
.azur-account__ticket-success-ico {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(31, 157, 85, 0.12);
    color: var(--success);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}
.azur-account__ticket-success-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 24px;
    color: var(--ink);
    margin: 0 0 8px;
    letter-spacing: -0.02em;
}
.azur-account__ticket-success-msg {
    color: var(--ink-muted);
    font-size: 15px;
    line-height: 1.6;
    max-width: 440px;
    margin: 0 auto 20px;
}

/* Carte « contact direct » sous le formulaire */
.azur-account__support-card--contact { margin-top: 18px; }
.azur-account__support-card--contact .azur-account__support-title { font-size: clamp(22px, 3vw, 30px); }

@media (prefers-reduced-motion: reduce) {
    .azur-account__ticket-btn,
    .azur-account__ticket-btn--primary:hover { transition: none; transform: none; }
    .azur-account__ticket-btn.is-loading::after { animation: none; }
}

/* ─────────────────────────────────────────────────────────────
   Confidentialité / RGPD (sous-page privacy)
   ───────────────────────────────────────────────────────────── */
.azur-privacy__intro {
    margin-bottom: 26px;
}
.azur-privacy__title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 26px;
    color: var(--ink);
    letter-spacing: -0.025em;
}
.azur-privacy__lead {
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.65;
    color: var(--ink-muted);
    max-width: 64ch;
}
.azur-privacy__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
    margin-bottom: 22px;
}
.azur-privacy__card {
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    padding: 24px 26px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.azur-privacy__card-ico {
    width: 46px;
    height: 46px;
    border-radius: var(--r-md);
    background: var(--majorelle-soft);
    color: var(--white);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}
.azur-privacy__card-title {
    font-family: var(--font-display);
    font-weight: var(--fw-extra);
    font-size: 18px;
    color: var(--ink);
    letter-spacing: -0.02em;
}
.azur-privacy__card-text {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--ink-muted);
    flex: 1;
}
.azur-privacy__btn {
    margin-top: 18px;
    appearance: none;
    border: 0;
    cursor: pointer;
    font-family: var(--font-sans);
    font-weight: var(--fw-bold);
    font-size: 14px;
    padding: 12px 20px;
    min-height: 46px;
    border-radius: var(--r-md);
    background: var(--majorelle);
    color: var(--white);
    transition: background var(--t-fast), transform var(--t-fast), opacity var(--t-fast);
}
.azur-privacy__btn:hover { background: var(--majorelle-deep); }
.azur-privacy__btn:active { transform: translateY(1px); }
.azur-privacy__btn:disabled { opacity: 0.55; cursor: progress; }
.azur-privacy__btn--ghost {
    background: transparent;
    color: var(--majorelle);
    border: 1.5px solid var(--line);
}
.azur-privacy__btn--ghost:hover {
    background: var(--bg-soft);
    border-color: var(--majorelle);
}
.azur-privacy__btn--danger {
    background: var(--danger);
    color: var(--white);
}
.azur-privacy__btn--danger:hover { background: var(--danger); filter: brightness(0.9); }
.azur-privacy__link {
    margin-top: 14px;
    font-size: 13px;
    font-weight: var(--fw-bold);
    color: var(--majorelle);
    text-decoration: none;
}
.azur-privacy__link:hover { color: var(--majorelle-deep); }
.azur-privacy__status {
    margin-top: 12px;
    font-size: 13px;
    line-height: 1.5;
    color: var(--ink-muted);
}
.azur-privacy__status.is-error   { color: var(--danger); font-weight: var(--fw-semibold); }
.azur-privacy__status.is-success { color: var(--success); font-weight: var(--fw-semibold); }

/* Zone danger — suppression du compte */
.azur-privacy__danger {
    background: rgba(198, 72, 58, 0.05);
    border: 1px solid rgba(198, 72, 58, 0.28);
    border-radius: var(--r-lg);
    padding: 24px 26px;
}
.azur-privacy__danger-head {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}
.azur-privacy__danger-ico {
    width: 42px;
    height: 42px;
    border-radius: var(--r-md);
    background: rgba(198, 72, 58, 0.12);
    color: var(--danger);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.azur-privacy__danger-body { flex: 1; }

@media (max-width: 720px) {
    .azur-privacy__grid { grid-template-columns: 1fr; }
    .azur-privacy__btn { width: 100%; }
}
