/* ============================================
   AKOLABS - App Specific Styles
   ============================================ */

/* === ONBOARDING === */
.onboarding-container {
    position: fixed;
    inset: 0;
    background: var(--color-bg);
    z-index: 150;
    display: flex;
    flex-direction: column;
}

/* === LOGIN PAGE === */
.login-container {
    position: fixed;
    inset: 0;
    background: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 140;
    padding: var(--space-xl);
}

.login-card {
    width: 100%;
    max-width: 380px;
    padding: var(--space-2xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    backdrop-filter: var(--glass-blur);
    animation: scaleIn 0.4s ease;
}

.login-logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
    margin: 0 auto var(--space-xl);
    display: block;
}

.login-title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-primary);
    text-align: center;
    margin-bottom: var(--space-xs);
}

.login-subtitle {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    text-align: center;
    margin-bottom: var(--space-2xl);
}

/* === SEARCH BAR === */
.search-bar {
    position: relative;
    margin-bottom: var(--space-xl);
}

.search-bar input {
    width: 100%;
    padding: var(--space-md) var(--space-base) var(--space-md) 44px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-primary);
    font-size: var(--text-sm);
}

.search-bar input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.1);
}

.search-bar input::placeholder {
    color: var(--color-gray-600);
}

.search-bar i {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray-500);
    font-size: var(--text-base);
}

/* === WELCOME SECTION === */
.welcome-section {
    margin-bottom: var(--space-xl);
    animation: fadeInDown 0.5s ease;
}

.welcome-greeting {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.welcome-name {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
    margin-top: 2px;
}

.welcome-name span {
    color: var(--color-primary);
}

.welcome-streak {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-sm);
    padding: 4px 12px;
    background: rgba(255, 152, 0, 0.15);
    border: 1px solid rgba(255, 152, 0, 0.3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    color: #FF9800;
    font-weight: var(--font-semibold);
}

/* === SECTION CARDS === */
.section-card {
    box-shadow: var(--card-shadow);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-base);
    margin-bottom: var(--space-base);
    position: relative;
}

.section-card:active {
    transform: scale(0.98);
    border-color: var(--glass-border-strong);
}

.section-card-banner {
    width: 100%;
    aspect-ratio: 16 / 9; /* GARANTIT LA TAILLE EXACTE */
    height: auto;
    object-fit: cover;
    background: var(--color-gray-800);
    display: flex;
    align-items: center;
    justify-content: center;
}

.section-card-badges {
    position: absolute;
    top: var(--space-sm);
    left: var(--space-sm);
    display: flex;
    gap: var(--space-xs);
    z-index: 2;
}

.section-card-body {
    padding: var(--space-base);
}

.section-card-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.section-card-desc {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.section-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.section-card-users {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

/* === WEBVIEW CONTAINER === */
.webview-container {
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: var(--content-max-width);
    height: 100%;
    height: 100dvh;
    z-index: 90;
    background: var(--color-white);
}

.webview-header {
    height: var(--header-height);
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: 0 var(--space-base);
    background: var(--color-primary);
    border-bottom: 1px solid var(--color-border);
}

.webview-back {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    font-size: var(--text-lg);
}

.webview-title {
    flex: 1;
    font-family: var(--font-heading);
    font-size: var(--text-base);
    color: var(--color-primary);
    font-weight: var(--font-semibold);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.webview-iframe {
    width: 100%;
    height: calc(100% - var(--header-height));
    border: none;
}

/* === FORMATION CARD === */
.formation-card {
    box-shadow: var(--card-shadow);
    display: flex;
    gap: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-md);
    margin-bottom: var(--space-md);
    transition: all var(--transition-base);
    position: relative;
}

.formation-card:active {
    transform: scale(0.98);
}

.formation-thumb {
    width: 85px;
    height: 85px;
    border-radius: var(--radius-md);
    object-fit: contain; /* Contain pour ne pas couper le logo */
    background: rgba(255,255,255,0.05); /* Fond transparent */
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px; /* Un peu d'air autour du logo */
}

.formation-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.formation-title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-bottom: 4px;
}

.formation-meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-bottom: var(--space-sm);
}

/* === AFFILIATION === */
.affiliate-link-box {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.affiliate-link-text {
    flex: 1;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.affiliate-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin: var(--space-xl) 0;
}

/* === PROFILE === */
.profile-header {
    text-align: center;
    padding: var(--space-2xl) 0;
}

.profile-avatar-container {
    position: relative;
    width: 96px;
    height: 96px;
    margin: 0 auto var(--space-base);
}

.profile-avatar-edit {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 30px;
    height: 30px;
    background: var(--color-accent);
    color: var(--color-primary);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-sm);
    border: 3px solid var(--color-primary);
}

.profile-name {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
}

.profile-email {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    margin-top: 4px;
}

.profile-level {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-sm);
    padding: 4px 14px;
    background: rgba(var(--color-accent-rgb), 0.15);
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
}

.profile-menu-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-base);
    border-bottom: 1px solid rgba(var(--color-primary-rgb), 0.1);
    transition: background var(--transition-fast);
}

.profile-menu-item:active {
    background: var(--color-surface);
}

.profile-menu-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface);
    border-radius: var(--radius-md);
    color: var(--color-primary);
}

.profile-menu-text {
    flex: 1;
}

.profile-menu-title {
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--color-text-primary);
}

.profile-menu-sub {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.profile-menu-arrow {
    color: var(--color-gray-600);
}

/* ============================================
   ONBOARDING STYLES
   ============================================ */

/* === ONBOARDING CONTAINER === */
.onboarding-container {
    position: fixed;
    inset: 0;
    background: var(--color-bg);
    z-index: 150;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* === SLIDES === */
.onboarding-slides {
    flex: 1;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.onboarding-slides::-webkit-scrollbar {
    display: none;
}

.onboarding-slide {
    min-width: 100%;
    width: 100%;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-3xl) var(--space-2xl);
    text-align: center;
    flex-shrink: 0;
}

.slide-icon-container {
    width: 140px;
    height: 140px;
    margin-bottom: var(--space-2xl);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
    position: relative;
    overflow: hidden;
}

.slide-icon-container::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at center, rgba(var(--color-accent-rgb), 0.12) 0%, transparent 70%);
}

.slide-icon {
    font-size: 56px;
    color: var(--color-primary);
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 0 20px rgba(var(--color-accent-rgb), 0.3));
}

.slide-title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-text-primary);
    font-weight: var(--font-bold);
    margin-bottom: var(--space-md);
    line-height: var(--line-height-tight);
}

.slide-title .accent {
    color: var(--color-primary);
}

.slide-description {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    max-width: 320px;
}

/* === ONBOARDING FOOTER === */
.onboarding-footer {
    padding: var(--space-xl) var(--space-2xl) var(--space-3xl);
}

/* === DOTS === */
.onboarding-dots {
    display: flex;
    justify-content: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.onboarding-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background: var(--color-gray-700);
    transition: all var(--transition-base);
}

.onboarding-dot.active {
    width: 28px;
    background: var(--color-accent);
}

/* === ONBOARDING BUTTONS === */
.onboarding-actions {
    display: flex;
    gap: var(--space-md);
}

.onboarding-actions .btn {
    flex: 1;
}

.onboarding-skip {
    background: none;
    color: var(--color-gray-500);
    font-size: var(--text-sm);
    padding: var(--space-sm);
    text-align: center;
    margin-top: var(--space-md);
    width: 100%;
}

/* === TERMS PAGE === */
.terms-container {
    position: fixed;
    inset: 0;
    background: var(--color-bg);
    z-index: 145;
    display: flex;
    flex-direction: column;
    padding: var(--space-2xl);
    overflow: hidden;
}

.terms-header {
    text-align: center;
    margin-bottom: var(--space-xl);
    flex-shrink: 0;
}

.terms-icon {
    font-size: 48px;
    color: var(--color-primary);
    margin-bottom: var(--space-base);
}

.terms-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
    margin-bottom: var(--space-xs);
}

.terms-subtitle {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
}

.terms-content {
    flex: 1;
    overflow-y: auto;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    -webkit-overflow-scrolling: touch;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
}

.terms-content h3 {
    font-size: var(--text-base);
    color: var(--color-primary);
    margin: var(--space-lg) 0 var(--space-sm);
    font-weight: var(--font-semibold);
}

.terms-content h3:first-child {
    margin-top: 0;
}

.terms-content p {
    margin-bottom: var(--space-md);
}

.terms-content ul {
    padding-left: var(--space-lg);
    margin-bottom: var(--space-md);
}

.terms-content ul li {
    list-style: disc;
    margin-bottom: var(--space-xs);
}

.terms-footer {
    flex-shrink: 0;
}

.terms-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    cursor: pointer;
}

.terms-checkbox input[type="checkbox"] {
    width: 22px;
    height: 22px;
    margin-top: 2px;
    accent-color: var(--color-primary);
    flex-shrink: 0;
    cursor: pointer;
}

.terms-checkbox-label {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
}

/* === LOGIN PAGE AMÉLIORÉE === */
.login-container {
    position: fixed;
    inset: 0;
    background: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 140;
    padding: var(--space-xl);
    overflow-y: auto;
}

.login-card {
    width: 100%;
    max-width: 380px;
    padding: var(--space-2xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    animation: scaleIn 0.4s ease;
}

.login-logo {
    width: 80px;
    height: 80px;
    object-fit: contain;
    margin: 0 auto var(--space-xl);
    display: block;
    filter: drop-shadow(0 0 20px rgba(var(--color-accent-rgb), 0.3));
}

.login-title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-primary);
    text-align: center;
    margin-bottom: var(--space-xs);
}

.login-subtitle {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    text-align: center;
    margin-bottom: var(--space-2xl);
}

.login-show-password {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray-500);
    font-size: var(--text-base);
    cursor: pointer;
    padding: var(--space-xs);
}

.login-forgot {
    display: block;
    text-align: right;
    font-size: var(--text-xs);
    color: var(--color-primary);
    margin-top: calc(-1 * var(--space-sm));
    margin-bottom: var(--space-lg);
}

.login-divider {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin: var(--space-xl) 0;
    color: var(--color-gray-600);
    font-size: var(--text-xs);
}

.login-divider::before,
.login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--glass-border);
}

/* ============================================
   HOME PAGE STYLES
   ============================================ */

/* === WELCOME === */
.welcome-section {
    margin-bottom: var(--space-xl);
    animation: fadeInDown 0.5s ease;
}

.welcome-greeting {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.welcome-name {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
    margin-top: 2px;
}

.welcome-name .accent {
    color: var(--color-primary);
}

.welcome-streak {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-sm);
    padding: 4px 12px;
    background: rgba(255, 152, 0, 0.15);
    border: 1px solid rgba(255, 152, 0, 0.3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    color: #FF9800;
    font-weight: var(--font-semibold);
}

/* === PROGRESS CARD === */
.progress-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    margin-bottom: var(--space-xl);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    animation: fadeInUp 0.5s ease 0.1s both;
}

.progress-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-md);
}

.progress-card-title {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.progress-card-value {
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    color: var(--color-primary);
}

.progress-bar {
    width: 100%;
    height: 8px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: var(--radius-full);
    overflow: hidden;
    margin-bottom: var(--space-sm);
}

.progress-fill {
    height: 100%;
    background: var(--gradient-accent);
    border-radius: var(--radius-full);
    transition: width 1s ease;
}

.progress-card-level {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.progress-card-level i {
    color: var(--color-primary);
}

/* === SEARCH BAR === */
.search-bar {
    position: relative;
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.2s both;
}

.search-bar input {
    width: 100%;
    padding: 14px 16px 14px 44px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-primary);
    font-size: var(--text-sm);
    font-family: var(--font-body);
    transition: all var(--transition-base);
}

.search-bar input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.1);
    background: var(--color-surface-alt);
}

.search-bar input::placeholder {
    color: var(--color-gray-600);
}

.search-bar .search-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray-500);
    font-size: var(--text-base);
    pointer-events: none;
}

.search-bar .search-clear {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-gray-500);
    font-size: var(--text-sm);
    padding: 4px;
    display: none;
    cursor: pointer;
}

.search-bar .search-clear.visible {
    display: block;
}

/* === SEARCH RESULTS === */
.search-results {
    margin-bottom: var(--space-xl);
}

.search-results-title {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    margin-bottom: var(--space-base);
}

.search-no-results {
    text-align: center;
    padding: var(--space-2xl) var(--space-base);
    color: var(--color-gray-500);
}

.search-no-results i {
    font-size: 36px;
    color: var(--color-gray-600);
    margin-bottom: var(--space-base);
    display: block;
}

/* === QUICK STATS === */
.quick-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.15s both;
}

.quick-stat-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-md);
    text-align: center;
    backdrop-filter: var(--glass-blur);
}

.quick-stat-icon {
    font-size: var(--text-lg);
    color: var(--color-primary);
    margin-bottom: 4px;
}

.quick-stat-value {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--color-text-primary);
}

.quick-stat-label {
    font-size: 10px;
    color: var(--color-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* === SECTION HEADER === */
.home-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-base);
}

.home-section-title-group {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.home-section-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.12);
    border-radius: var(--radius-sm);
    color: var(--color-primary);
    font-size: var(--text-sm);
}

.home-section-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    font-weight: var(--font-semibold);
}

.home-section-subtitle {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-top: 1px;
}

.home-section-count {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    background: var(--color-surface);
    padding: 4px 10px;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-border);
}

/* === SECTION CARDS (grandes cartes) === */
.section-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-base);
    margin-bottom: var(--space-base);
    position: relative;
    cursor: pointer;
}

.section-card:active {
    transform: scale(0.98);
    border-color: var(--glass-border-strong);
}

.section-card-banner {
    width: 100%;
    height: 150px;
    object-fit: cover;
    background: var(--color-gray-800);
    display: flex;
    align-items: center;
    justify-content: center;
}

.section-card-banner-placeholder {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-primary);
    opacity: 0.5;
}

.section-card-badges {
    position: absolute;
    top: var(--space-sm);
    left: var(--space-sm);
    display: flex;
    gap: var(--space-xs);
    z-index: 2;
}

.section-card-access {
    position: absolute;
    top: var(--space-sm);
    right: var(--space-sm);
    z-index: 2;
}

.access-unlocked {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: rgba(40, 167, 69, 0.9);
    border-radius: var(--radius-full);
    font-size: 10px;
    font-weight: var(--font-semibold);
    color: white;
}

.section-card-body {
    padding: var(--space-base);
}

.section-card-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.section-card-desc {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.section-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.section-card-price {
    display: flex;
    align-items: baseline;
    gap: var(--space-xs);
}

.section-card-price-old {
    font-size: var(--text-xs);
    color: var(--color-gray-600);
    text-decoration: line-through;
}

.section-card-price-current {
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    color: var(--color-primary);
}

.section-card-price-free {
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    color: var(--color-success);
}

.section-card-users {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.section-card-btn {
    padding: 8px 16px;
    background: var(--gradient-accent);
    color: var(--color-primary);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    transition: all var(--transition-base);
}

.section-card-btn:active {
    transform: scale(0.95);
}

.section-card-btn-unlocked {
    background: rgba(40, 167, 69, 0.15);
    color: var(--color-success);
    border: 1px solid rgba(40, 167, 69, 0.3);
}

/* === FORMATION CARDS (cartes horizontales) === */
.formation-card {
    display: flex;
    gap: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-md);
    margin-bottom: var(--space-md);
    transition: all var(--transition-base);
    position: relative;
    cursor: pointer;
}

.formation-card:active {
    transform: scale(0.98);
    border-color: var(--glass-border-strong);
}

.formation-thumb {
    width: 85px;
    height: 85px;
    border-radius: var(--radius-md);
    object-fit: cover;
    flex-shrink: 0;
    background: var(--color-gray-800);
    display: flex;
    align-items: center;
    justify-content: center;
}

.formation-thumb-placeholder {
    font-size: var(--text-2xl);
    color: var(--color-primary);
    opacity: 0.5;
}

.formation-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.formation-badges {
    display: flex;
    gap: var(--space-xs);
    margin-bottom: 4px;
}

.formation-title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.formation-meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-bottom: var(--space-sm);
}

.formation-price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* === COMING SOON === */
.coming-soon-card {
    background: var(--color-surface);
    border: 1px dashed var(--glass-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    text-align: center;
    margin-bottom: var(--space-md);
    opacity: 0.7;
}

.coming-soon-icon {
    font-size: var(--text-3xl);
    color: var(--color-gray-600);
    margin-bottom: var(--space-sm);
}

.coming-soon-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xs);
}

.coming-soon-desc {
    font-size: var(--text-xs);
    color: var(--color-gray-600);
}

/* === HOME FOOTER SPACER === */
.home-footer-spacer {
    height: var(--space-2xl);
}

/* === ANIMATIONS POUR LES CARTES === */
.section-card,
.formation-card,
.coming-soon-card {
    animation: fadeInUp 0.4s ease both;
}

.section-card:nth-child(1) { animation-delay: 0.05s; }
.section-card:nth-child(2) { animation-delay: 0.1s; }
.section-card:nth-child(3) { animation-delay: 0.15s; }
.section-card:nth-child(4) { animation-delay: 0.2s; }

.formation-card:nth-child(1) { animation-delay: 0.05s; }
.formation-card:nth-child(2) { animation-delay: 0.1s; }
.formation-card:nth-child(3) { animation-delay: 0.15s; }
.formation-card:nth-child(4) { animation-delay: 0.2s; }

/* === HORIZONTAL SCROLL SECTION === */
.h-scroll-section {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    display: flex;
    gap: var(--space-md);
    padding-bottom: var(--space-sm);
    margin: 0 calc(-1 * var(--space-base));
    padding-left: var(--space-base);
    padding-right: var(--space-base);
}

.h-scroll-section::-webkit-scrollbar {
    display: none;
}

.h-scroll-section .section-card {
    min-width: 280px;
    flex-shrink: 0;
    scroll-snap-align: start;
    margin-bottom: 0;
}

/* === FEATURED BANNER === */
.featured-banner {
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.15) 0%, rgba(var(--color-primary-rgb), 0.3) 100%);
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    border-radius: var(--radius-xl);
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    display: flex;
    align-items: center;
    gap: var(--space-base);
    cursor: pointer;
    transition: all var(--transition-base);
    animation: fadeInUp 0.5s ease 0.25s both;
}

.featured-banner:active {
    transform: scale(0.98);
}

.featured-banner-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.2);
    border-radius: var(--radius-lg);
    font-size: var(--text-2xl);
    color: var(--color-primary);
    flex-shrink: 0;
}

.featured-banner-content {
    flex: 1;
    min-width: 0;
}

.featured-banner-tag {
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-primary);
    font-weight: var(--font-semibold);
}

.featured-banner-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-top: 2px;
}

.featured-banner-desc {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-top: 2px;
}

.featured-banner-arrow {
    color: var(--color-primary);
    font-size: var(--text-lg);
    flex-shrink: 0;
}

/* ============================================
   SECTION DETAIL PAGE
   ============================================ */

/* === BACK HEADER === */
.detail-back-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}

.detail-back-btn {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-primary);
    font-size: var(--text-base);
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.detail-back-btn:active {
    transform: scale(0.9);
    background: var(--color-surface-alt);
}

.detail-back-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* === DETAIL BANNER === */
.detail-banner {
    width: calc(100% + 2 * var(--space-base));
    margin-left: calc(-1 * var(--space-base));
    margin-top: calc(-1 * var(--space-base));
    aspect-ratio: 16 / 9; /* GARANTIT LA TAILLE EXACTE */
    height: auto; /* Supprime le height: 200px fixe */
    background: var(--color-gray-800);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-bottom: var(--space-lg);
}

.detail-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.detail-banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.detail-banner-placeholder {
    font-family: var(--font-heading);
    font-size: 48px;
    color: var(--color-primary);
    opacity: 0.3;
}

.detail-banner-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 80px;
    background: linear-gradient(transparent, rgba(var(--color-primary-rgb), 0.95));
}

.detail-banner-badges {
    position: absolute;
    top: var(--space-base);
    left: var(--space-base);
    display: flex;
    gap: var(--space-xs);
}

.detail-banner-back {
    position: absolute;
    top: var(--space-base);
    right: var(--space-base);
}

/* === DETAIL INFO === */
.detail-title {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
    line-height: var(--line-height-tight);
}

.detail-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.detail-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.detail-meta-item i {
    color: var(--color-primary);
}

.detail-description {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-xl);
}

/* === DETAIL SECTIONS === */
.detail-section {
    margin-bottom: var(--space-xl);
}

.detail-section-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-text-primary);
    margin-bottom: var(--space-base);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.detail-section-title i {
    color: var(--color-primary);
    font-size: var(--text-sm);
}

/* === ADVANTAGES === */
.advantage-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    padding: var(--space-md) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.advantage-item:last-child {
    border-bottom: none;
}

.advantage-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(40, 167, 69, 0.15);
    border-radius: var(--radius-sm);
    color: var(--color-success);
    font-size: var(--text-xs);
    flex-shrink: 0;
    margin-top: 2px;
}

.advantage-text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

/* === PREVIEW GALLERY === */
.preview-gallery {
    display: flex;
    gap: var(--space-sm);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--space-sm);
    margin: 0 calc(-1 * var(--space-base));
    padding-left: var(--space-base);
    padding-right: var(--space-base);
}

.preview-gallery::-webkit-scrollbar {
    display: none;
}

.preview-gallery-item {
    min-width: 200px;
    height: 140px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border);
    flex-shrink: 0;
    scroll-snap-align: start;
    background: var(--color-gray-800);
}

.preview-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* === VIDEO PREVIEW === */
.video-preview {
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    background: var(--color-gray-800);
    position: relative;
    cursor: pointer;
    margin-bottom: var(--space-base);
}

.video-preview iframe {
    width: 100%;
    height: 100%;
    border: none;
}

.video-preview video.video-native {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-lg);
    background: #000;
    display: block;
    object-fit: cover;
    aspect-ratio: 16 / 9;
}

/* Bouton play overlay sur la video native */
.video-preview {
    aspect-ratio: 16 / 9;
}

.video-preview-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    gap: var(--space-sm);
}

.video-play-btn {
    width: 56px;
    height: 56px;
    background: rgba(var(--color-accent-rgb), 0.2);
    border: 2px solid var(--color-accent);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-xl);
}

/* === SOCIAL PROOF === */
.detail-social-proof {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-xl);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.detail-social-proof i {
    color: var(--color-primary);
}

.detail-social-proof strong {
    color: var(--color-text-primary);
}

/* === PURCHASE BOX === */
.purchase-box {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
    margin-bottom: var(--space-xl);
}

.purchase-box-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    color: var(--color-primary);
    text-align: center;
    margin-bottom: var(--space-lg);
}

.purchase-price-display {
    text-align: center;
    padding: var(--space-lg);
    background: rgba(var(--color-accent-rgb), 0.08);
    border: 1px solid rgba(var(--color-accent-rgb), 0.2);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-lg);
}

.purchase-price-old {
    font-size: var(--text-base);
    color: var(--color-gray-500);
    text-decoration: line-through;
    margin-bottom: 4px;
}

.purchase-price-main {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    color: var(--color-primary);
    font-weight: var(--font-bold);
}

.purchase-price-label {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-top: 4px;
}

.purchase-countdown {
    margin-bottom: var(--space-lg);
}

.purchase-promo-input {
    margin-bottom: var(--space-lg);
}

.purchase-promo-result {
    margin-top: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    display: none;
}

.purchase-promo-result.success {
    display: block;
    background: rgba(40, 167, 69, 0.1);
    border: 1px solid rgba(40, 167, 69, 0.2);
    color: var(--color-success);
}

.purchase-promo-result.error {
    display: block;
    background: rgba(220, 53, 69, 0.1);
    border: 1px solid rgba(220, 53, 69, 0.2);
    color: var(--color-error);
}

.purchase-summary {
    padding: var(--space-base);
    background: rgba(var(--color-accent-rgb), 0.05);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-lg);
}

.purchase-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.purchase-summary-row.total {
    border-top: 1px solid var(--color-border);
    margin-top: var(--space-sm);
    padding-top: var(--space-sm);
    font-weight: var(--font-bold);
    color: var(--color-primary);
    font-size: var(--text-md);
}

.purchase-summary-row .discount {
    color: var(--color-success);
}

.purchase-guarantee {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
    padding: var(--space-md);
    background: rgba(40, 167, 69, 0.06);
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.purchase-guarantee i {
    color: var(--color-success);
    font-size: var(--text-lg);
    flex-shrink: 0;
}

/* === ALREADY PURCHASED === */
.access-granted-box {
    text-align: center;
    padding: var(--space-xl);
    background: rgba(40, 167, 69, 0.08);
    border: 1px solid rgba(40, 167, 69, 0.2);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-xl);
}

.access-granted-icon {
    font-size: 48px;
    color: var(--color-success);
    margin-bottom: var(--space-base);
}

.access-granted-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    color: var(--color-success);
    margin-bottom: var(--space-xs);
}

.access-granted-desc {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

/* === TESTIMONIALS IN DETAIL === */
.detail-testimonial {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    margin-bottom: var(--space-sm);
}

.detail-testimonial-text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    font-style: italic;
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-sm);
}

.detail-testimonial-author {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.detail-testimonial-author i {
    color: var(--color-primary);
}/* ============================================
   WEBVIEW STYLES
   ============================================ */

.webview-page {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-width: none !important;
    z-index: 9999;
    background: var(--color-white);
    display: flex;
    flex-direction: column;
    margin: 0 !important;
    padding: 0 !important;
    transform: none !important;
}

.webview-iframe-container {
    flex: 1;
    position: relative;
    overflow: hidden;
    background: var(--color-white);
    width: 100vw;
}

.webview-iframe {
    width: 100%;
    height: 100%;
    border: none;
    background: var(--color-white);
}

.webview-header {
    height: 52px;
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: 0 var(--space-base);
    background: var(--color-primary);
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
    z-index: 10;
    width: 100vw;
}

.webview-back-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    font-size: var(--text-base);
    border-radius: var(--radius-full);
    background: var(--color-surface);
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.webview-back-btn:active {
    transform: scale(0.9);
    background: var(--color-surface-alt);
}

.webview-logo {
    width: 32px;
    height: 32px;
    border-radius: var(--radius-sm);
    object-fit: contain;
    flex-shrink: 0;
    -webkit-user-select: none;
    pointer-events: none;
}

.webview-title-area {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.webview-title {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    color: #FFFFFF;
    font-weight: var(--font-bold);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
    letter-spacing: 0.5px;
}

.webview-subtitle {
    font-size: 10px;
    color: rgba(255,255,255,0.55);
    margin-top: 1px;
}

.webview-actions {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.webview-action-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    border-radius: var(--radius-full);
    transition: all var(--transition-base);
}

.webview-action-btn:active {
    background: var(--color-surface);
    color: var(--color-primary);
}

.webview-loader {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--color-bg);
    z-index: 5;
    transition: opacity 0.4s ease;
}

.webview-loader.hidden {
    opacity: 0;
    pointer-events: none;
}

.webview-loader-text {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    margin-top: var(--space-base);
}

.webview-error {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--color-bg);
    z-index: 5;
    padding: var(--space-2xl);
    text-align: center;
}

.webview-error-icon {
    font-size: 48px;
    color: var(--color-error);
    margin-bottom: var(--space-base);
}

.webview-error-title {
    font-size: var(--text-md);
    color: var(--color-text-primary);
    margin-bottom: var(--space-sm);
}

.webview-error-desc {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    margin-bottom: var(--space-xl);
}

/* === PROTECTION OVERLAY (anti right-click, anti-copy) === */
.webview-protection {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 0;
    z-index: 3;
    pointer-events: none;
}

/* === WEBVIEW PULL TAB === */
.webview-pull-tab {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 24px;
    background: linear-gradient(transparent, rgba(var(--color-primary-rgb), 0.8));
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 4px;
    z-index: 4;
    pointer-events: none;
}

.webview-pull-tab-handle {
    width: 36px;
    height: 4px;
    background: var(--color-gray-600);
    border-radius: var(--radius-full);
    opacity: 0.5;
}

/* ============================================
   AFFILIATION PAGE
   ============================================ */

.affil-header {
    text-align: center;
    padding: var(--space-lg) 0;
    animation: fadeInDown 0.5s ease;
}

.affil-header-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto var(--space-base);
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.12);
    border: 1px solid rgba(var(--color-accent-rgb), 0.2);
    border-radius: var(--radius-xl);
    font-size: 32px;
    color: var(--color-primary);
}

.affil-header-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.affil-header-desc {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    max-width: 300px;
    margin: 0 auto;
    line-height: var(--line-height-relaxed);
}

/* === LINK BOX === */
.affil-link-box {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.1s both;
}

.affil-link-label {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-bottom: var(--space-sm);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.affil-link-row {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
}

.affil-link-text {
    flex: 1;
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: monospace;
}

.affil-link-copy {
    padding: 6px 14px;
    background: var(--color-accent);
    color: var(--color-primary);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    flex-shrink: 0;
}

.affil-link-copy:active {
    transform: scale(0.95);
}

.affil-code-row {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.affil-code-badge {
    padding: 6px 16px;
    background: rgba(var(--color-accent-rgb), 0.12);
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    border-radius: var(--radius-full);
    font-family: monospace;
    font-size: var(--text-md);
    font-weight: var(--font-bold);
    color: var(--color-primary);
    letter-spacing: 2px;
}

.affil-share-btns {
    display: flex;
    gap: var(--space-sm);
}

.affil-share-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    transition: all var(--transition-base);
}

.affil-share-btn:active {
    transform: scale(0.95);
}

.affil-share-whatsapp {
    background: rgba(37, 211, 102, 0.15);
    color: #25D366;
    border: 1px solid rgba(37, 211, 102, 0.3);
}

.affil-share-telegram {
    background: rgba(0, 136, 204, 0.15);
    color: #0088CC;
    border: 1px solid rgba(0, 136, 204, 0.3);
}

.affil-share-copy {
    background: var(--color-surface);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}

/* === STATS GRID === */
.affil-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.15s both;
}

.affil-stat-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    text-align: center;
}

.affil-stat-icon {
    font-size: var(--text-lg);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.affil-stat-value {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--color-text-primary);
    font-family: var(--font-heading);
}

.affil-stat-label {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-top: 2px;
}

/* === HOW IT WORKS === */
.affil-how {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.2s both;
}

.affil-how-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    margin-bottom: var(--space-base);
}

.affil-how-step {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    padding: var(--space-md) 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.affil-how-step:last-child {
    border-bottom: none;
}

.affil-how-num {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.15);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    color: var(--color-primary);
    flex-shrink: 0;
}

.affil-how-text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

.affil-how-text strong {
    color: var(--color-primary);
}

/* === CHART === */
.affil-chart-container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.25s both;
}

.affil-chart-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    margin-bottom: var(--space-base);
}

.affil-chart {
    display: flex;
    align-items: flex-end;
    gap: 4px;
    height: 120px;
    padding-top: var(--space-sm);
}

.affil-chart-bar-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
    justify-content: flex-end;
}

.affil-chart-bar {
    width: 100%;
    max-width: 30px;
    background: var(--gradient-accent);
    border-radius: 4px 4px 0 0;
    min-height: 4px;
    transition: height 0.8s ease;
}

.affil-chart-label {
    font-size: 9px;
    color: var(--color-gray-600);
    margin-top: 6px;
    text-align: center;
}

.affil-chart-value {
    font-size: 9px;
    color: var(--color-primary);
    margin-bottom: 4px;
    font-weight: var(--font-semibold);
}

/* === HISTORY === */
.affil-history {
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.3s both;
}

.affil-history-title {
    font-family: var(--font-heading);
    font-size: var(--text-md);
    color: var(--color-primary);
    margin-bottom: var(--space-base);
}

.affil-history-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-sm);
}

.affil-history-avatar {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    background: rgba(var(--color-accent-rgb), 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    font-weight: var(--font-bold);
    font-size: var(--text-sm);
    flex-shrink: 0;
}

.affil-history-info {
    flex: 1;
    min-width: 0;
}

.affil-history-name {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
}

.affil-history-date {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.affil-history-amount {
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    color: var(--color-success);
    flex-shrink: 0;
}

.affil-history-status {
    font-size: 9px;
    padding: 2px 8px;
    border-radius: var(--radius-full);
    font-weight: var(--font-semibold);
}

.affil-history-status.confirmed {
    background: rgba(40, 167, 69, 0.15);
    color: var(--color-success);
}

.affil-history-status.pending {
    background: rgba(255, 193, 7, 0.15);
    color: var(--color-warning);
}

/* ============================================
   FILES PAGE
   ============================================ */

.files-header {
    text-align: center;
    padding: var(--space-lg) 0;
    animation: fadeInDown 0.5s ease;
}

.files-header-icon {
    width: 72px;
    height: 72px;
    margin: 0 auto var(--space-base);
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.12);
    border: 1px solid rgba(var(--color-accent-rgb), 0.2);
    border-radius: var(--radius-xl);
    font-size: 32px;
    color: var(--color-primary);
}

.files-header-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-primary);
    margin-bottom: var(--space-xs);
}

.files-header-desc {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
}

.files-storage-bar {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-base);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.1s both;
}

.files-storage-info {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-sm);
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.files-storage-info strong {
    color: var(--color-primary);
}

.files-filter-tabs {
    display: flex;
    gap: var(--space-xs);
    margin-bottom: var(--space-lg);
    overflow-x: auto;
    padding-bottom: var(--space-xs);
    animation: fadeInUp 0.5s ease 0.15s both;
}

.files-filter-tabs::-webkit-scrollbar {
    display: none;
}

.files-filter-tab {
    padding: 8px 16px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    white-space: nowrap;
    transition: all var(--transition-base);
    flex-shrink: 0;
}

.files-filter-tab:active {
    transform: scale(0.95);
}

.files-filter-tab.active {
    background: rgba(var(--color-accent-rgb), 0.15);
    border-color: rgba(var(--color-accent-rgb), 0.3);
    color: var(--color-primary);
    font-weight: var(--font-semibold);
}

.file-card {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-sm);
    transition: all var(--transition-base);
    animation: fadeInUp 0.4s ease both;
}

.file-card:active {
    transform: scale(0.98);
    border-color: var(--glass-border-strong);
}

.file-icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    font-size: var(--text-xl);
    flex-shrink: 0;
}

.file-icon.pdf { background: rgba(220, 53, 69, 0.15); color: #DC3545; }
.file-icon.doc { background: rgba(0, 123, 255, 0.15); color: #007BFF; }
.file-icon.video { background: rgba(111, 66, 193, 0.15); color: #6F42C1; }
.file-icon.image { background: rgba(40, 167, 69, 0.15); color: #28A745; }
.file-icon.apk { background: rgba(61, 220, 132, 0.15); color: #3DDC84; }
.file-icon.other { background: rgba(var(--color-accent-rgb), 0.15); color: var(--color-primary); }

.file-info {
    flex: 1;
    min-width: 0;
}

.file-name {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.file-meta {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
    margin-top: 2px;
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.file-actions {
    display: flex;
    gap: var(--space-xs);
    flex-shrink: 0;
}

.file-action-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    transition: all var(--transition-base);
}

.file-action-btn.view {
    background: rgba(var(--color-accent-rgb), 0.12);
    color: var(--color-primary);
}

.file-action-btn.delete {
    background: rgba(220, 53, 69, 0.12);
    color: #DC3545;
}

.file-action-btn:active {
    transform: scale(0.9);
}

/* === FILE VIEWER === */
.file-viewer {
    position: fixed;
    inset: 0;
    z-index: 9998;
    background: rgba(0, 0, 0, 0.95);
    display: flex;
    flex-direction: column;
}

.file-viewer-header {
    height: 52px;
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: 0 var(--space-base);
    background: var(--color-primary);
    flex-shrink: 0;
}

.file-viewer-title {
    flex: 1;
    font-size: var(--text-sm);
    color: var(--color-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.file-viewer-close {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-primary);
    font-size: var(--text-lg);
}

.file-viewer-content {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: auto;
    padding: var(--space-base);
}

.file-viewer-content img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: var(--radius-md);
}

.file-viewer-content video {
    max-width: 100%;
    max-height: 100%;
    border-radius: var(--radius-md);
}/* ============================================
   NOTIFICATIONS PAGE
   ============================================ */

.notif-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-lg);
    animation: fadeInDown 0.5s ease;
}

.notif-header-left {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.notif-header-title {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-primary);
}

.notif-header-count {
    padding: 2px 10px;
    background: rgba(220, 53, 69, 0.15);
    border: 1px solid rgba(220, 53, 69, 0.3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    color: var(--color-error);
}

.notif-mark-all {
    font-size: var(--text-xs);
    color: var(--color-primary);
    padding: 6px 12px;
    background: rgba(var(--color-accent-rgb), 0.1);
    border-radius: var(--radius-full);
}

.notif-card {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-base);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-sm);
    transition: all var(--transition-base);
    animation: fadeInUp 0.4s ease both;
}

.notif-card.unread {
    border-left: 3px solid var(--color-accent);
    background: var(--color-surface-alt);
}

.notif-card:active {
    transform: scale(0.98);
}

.notif-icon-box {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    font-size: var(--text-lg);
    flex-shrink: 0;
}

.notif-icon-box.system { background: rgba(var(--color-accent-rgb), 0.12); color: var(--color-primary); }
.notif-icon-box.purchase { background: rgba(40, 167, 69, 0.12); color: #28A745; }
.notif-icon-box.promo { background: rgba(220, 53, 69, 0.12); color: #DC3545; }
.notif-icon-box.affiliate { background: rgba(0, 136, 204, 0.12); color: #0088CC; }
.notif-icon-box.welcome { background: rgba(255, 193, 7, 0.12); color: #FFC107; }
.notif-icon-box.update { background: rgba(111, 66, 193, 0.12); color: #6F42C1; }

.notif-content {
    flex: 1;
    min-width: 0;
}

.notif-title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
    margin-bottom: 2px;
}

.notif-message {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    line-height: var(--line-height-relaxed);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.notif-time {
    font-size: 10px;
    color: var(--color-gray-600);
    margin-top: 4px;
}

.notif-dot {
    width: 8px;
    height: 8px;
    background: var(--color-accent);
    border-radius: var(--radius-full);
    flex-shrink: 0;
    margin-top: 4px;
}

/* ============================================
   PROFILE PAGE
   ============================================ */

.profile-page-header {
    text-align: center;
    padding: var(--space-xl) 0;
    animation: fadeInDown 0.5s ease;
}

.profile-avatar-wrapper {
    position: relative;
    width: 96px;
    height: 96px;
    margin: 0 auto var(--space-base);
}

.profile-avatar-img {
    width: 96px;
    height: 96px;
    border-radius: var(--radius-full);
    object-fit: cover;
    border: 3px solid var(--color-accent);
}

.profile-avatar-edit {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 32px;
    height: 32px;
    background: var(--color-accent);
    color: var(--color-primary);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-xs);
    border: 3px solid var(--color-primary);
    cursor: pointer;
}

.profile-name {
    font-family: var(--font-heading);
    font-size: var(--text-xl);
    color: var(--color-text-primary);
}

.profile-email {
    font-size: var(--text-sm);
    color: var(--color-gray-500);
    margin-top: 2px;
}

.profile-level-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-sm);
    padding: 4px 14px;
    background: rgba(var(--color-accent-rgb), 0.15);
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
}

.profile-stats-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
    animation: fadeInUp 0.5s ease 0.1s both;
}

.profile-stat {
    text-align: center;
    padding: var(--space-base);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
}

.profile-stat-value {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    color: var(--color-primary);
}

.profile-stat-label {
    font-size: 10px;
    color: var(--color-gray-500);
    margin-top: 2px;
}

.profile-menu {
    animation: fadeInUp 0.5s ease 0.15s both;
}

.profile-menu-section {
    margin-bottom: var(--space-lg);
}

.profile-menu-section-title {
    font-size: var(--text-xs);
    color: var(--color-gray-600);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--space-sm);
    padding-left: var(--space-xs);
}

.profile-menu-item {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-xs);
    transition: all var(--transition-base);
    cursor: pointer;
}

.profile-menu-item:active {
    transform: scale(0.98);
    background: var(--color-surface-alt);
}

.profile-menu-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-rgb), 0.1);
    border-radius: var(--radius-md);
    color: var(--color-primary);
    font-size: var(--text-sm);
    flex-shrink: 0;
}

.profile-menu-icon.danger {
    background: rgba(220, 53, 69, 0.1);
    color: #DC3545;
}

.profile-menu-text {
    flex: 1;
}

.profile-menu-label {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-text-primary);
}

.profile-menu-sub {
    font-size: var(--text-xs);
    color: var(--color-gray-500);
}

.profile-menu-arrow {
    color: var(--color-gray-600);
    font-size: var(--text-xs);
}

.profile-version {
    text-align: center;
    padding: var(--space-xl) 0;
    font-size: var(--text-xs);
    color: var(--color-gray-700);
}

/* ============================================
   PWA INSTALL BANNER
   ============================================ */

.pwa-install-banner {
    position: fixed;
    bottom: calc(var(--bottom-nav-height) + 16px);
    left: 50%;
    transform: translateX(-50%) translateY(150%);
    width: calc(100% - 32px);
    max-width: var(--content-max-width);
    background: rgba(26, 26, 46, 0.95);
    border: 1px solid rgba(212, 175, 55, 0.4);
    border-radius: var(--radius-lg);
    padding: var(--space-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 120;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
    transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.pwa-install-banner.show {
    transform: translateX(-50%) translateY(0);
}

.pwa-info {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.pwa-icon {
    width: 44px;
    height: 44px;
    background: var(--color-primary);
    border-radius: 12px;
    padding: 6px;
    border: 1px solid var(--color-border);
}

.pwa-text-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 2px;
}

.pwa-text-desc {
    font-size: 11px;
    color: var(--color-text-muted);
}

.pwa-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.pwa-btn-install {
    background: var(--gradient-accent);
    color: var(--color-primary);
    border: none;
    padding: 8px 16px;
    border-radius: 20px;
    font-weight: 700;
    font-size: 12px;
    cursor: pointer;
    box-shadow: var(--shadow-gold);
}

.pwa-btn-install:active {
    transform: scale(0.95);
}

.pwa-btn-close {
    background: transparent;
    color: var(--color-gray-500);
    border: none;
    font-size: 18px;
    padding: 4px;
    cursor: pointer;
}

/* Tooltip spécial pour iOS (iPhone) */
.pwa-ios-tooltip {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-white);
    color: var(--color-dark);
    padding: 16px;
    border-radius: 12px;
    font-size: 13px;
    text-align: center;
    width: calc(100% - 40px);
    max-width: 320px;
    z-index: 1000;
    box-shadow: 0 10px 25px rgba(0,0,0,0.5);
    display: none;
}
.pwa-ios-tooltip::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    border-width: 10px 10px 0;
    border-style: solid;
    border-color: var(--color-white) transparent transparent transparent;
}
/* ============================================
   WEBVIEW - BARRE DE TELECHARGEMENT
   ============================================ */

.webview-download-bar {
    position: fixed;
    top: 60px; /* juste sous le webview-header */
    left: 0;
    right: 0;
    z-index: 200;
    background: rgba(26, 26, 46, 0.97);
    border-bottom: 1px solid rgba(212, 175, 55, 0.35);
    padding: 10px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
    animation: slideDownFade 0.3s ease;
}

@keyframes slideDownFade {
    from { transform: translateY(-100%); opacity: 0; }
    to   { transform: translateY(0);     opacity: 1; }
}

.webview-download-info {
    display: flex;
    align-items: center;
    font-size: 13px;
    color: var(--color-white);
    font-weight: 600;
    gap: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.webview-download-progress-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}

.webview-download-progress-bar {
    flex: 1;
    height: 6px;
    background: rgba(255,255,255,0.12);
    border-radius: 10px;
    overflow: hidden;
}

.webview-download-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #D4AF37, #F5D87A);
    border-radius: 10px;
    transition: width 0.3s ease;
    box-shadow: 0 0 8px rgba(212,175,55,0.5);
}

.webview-download-percent {
    font-size: 12px;
    color: #D4AF37;
    font-weight: 700;
    min-width: 36px;
    text-align: right;
}

/* ============================================
   PATCH THÈME PREMIUM - Light/White/Violet/Or
   ============================================ */

/* Fond général */
body, .app-wrapper {
    background: var(--color-bg) !important;
    color: var(--color-text-primary) !important;
}

/* Toutes les cartes et surfaces */
.card, .formation-card, .section-card,
.modal-content, .bottom-sheet,
.auth-card, .onboarding-card,
.profile-card, .stat-card,
.detail-card, .purchase-box,
.files-item, .notification-item,
.affiliate-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--card-shadow) !important;
    color: var(--color-text-primary) !important;
}

/* Titres dans les cartes */
.card-title, .section-title, .formation-title,
.detail-title, h1, h2, h3 {
    color: var(--color-text-primary) !important;
}

/* Prix et badges accent → or */
.price, .price-amount, .card-price,
/* Prix sections */
.section-price, .formation-price {
    color: var(--color-accent) !important;
}

/* Tags génériques uniquement (pas les badges sur bannière) */
.tag, .section-type-badge {
    background: rgba(75,0,130,0.08) !important;
    color: var(--color-primary) !important;
    border: 1px solid rgba(75,0,130,0.12) !important;
}

/* Inputs sur fond clair */
input, textarea, select,
.form-input, .auth-input, .search-input {
    background: var(--color-bg) !important;
    color: var(--color-text-primary) !important;
    border: 1.5px solid var(--color-border) !important;
}

input::placeholder, textarea::placeholder {
    color: var(--color-text-muted) !important;
}

input:focus, textarea:focus, select:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px rgba(75,0,130,0.08) !important;
}

/* Descriptions et textes secondaires */
.card-description, .section-desc,
.formation-desc, p.muted,
.text-muted, .subtitle {
    color: var(--color-text-secondary) !important;
}

/* Dividers */
.divider, hr {
    border-color: var(--color-border) !important;
}

/* Splash screen garde le violet */
.splash-screen {
    background: var(--gradient-primary) !important;
}

/* Modal backdrop */
.modal-backdrop, .bottom-sheet-backdrop {
    background: rgba(26, 26, 46, 0.5) !important;
}

/* Section active state sur carte */
.card:active, .formation-card:active,
.section-card:active {
    box-shadow: var(--card-shadow-hover) !important;
    border-color: rgba(75,0,130,0.20) !important;
}


/* ============================================
   PATCH FINAL COMPLET - THÈME PREMIUM LIGHT
   Corrections visuelles exhaustives
   ============================================ */

/* === 1. FIX SCROLL - contenu caché derrière header === */
.main-content {
    /* Pas de padding-top supplémentaire, le margin-top suffit */
    padding-top: var(--space-base) !important;
    /* S'assurer que le scroll fonctionne bien jusqu'en bas */
    padding-bottom: calc(var(--space-base) + env(safe-area-inset-bottom, 0px)) !important;
    box-sizing: border-box !important;
}

/* === 2. FOND GÉNÉRAL === */
body, .app-container, .main-content {
    background: var(--color-bg) !important;
}

/* === 3. WELCOME SECTION === */
.welcome-section {
    margin-bottom: var(--space-xl) !important;
}
.welcome-greeting {
    color: var(--color-text-muted) !important;
    font-size: var(--text-sm) !important;
}
.welcome-name {
    color: var(--color-text-primary) !important;
}
.welcome-name .accent {
    color: var(--color-primary) !important;
}

/* === 4. BARRE DE RECHERCHE === */
.search-bar {
    background: var(--color-surface) !important;
    border: 1.5px solid var(--color-border) !important;
    border-radius: var(--radius-full) !important;
    box-shadow: var(--shadow-xs) !important;
}
.search-input {
    background: transparent !important;
    color: var(--color-text-primary) !important;
}
.search-input::placeholder {
    color: var(--color-text-muted) !important;
}
.search-icon {
    color: var(--color-text-muted) !important;
}

/* === 5. PROGRESS CARD === */
.progress-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--card-shadow) !important;
}
.progress-card-title {
    color: var(--color-text-muted) !important;
}
.progress-card-value {
    color: var(--color-primary) !important;
    font-weight: var(--font-bold) !important;
}
.progress-bar {
    background: var(--color-bg-alt) !important;
    border-radius: var(--radius-full) !important;
}
.progress-fill {
    background: var(--gradient-accent) !important;
}
.progress-card-level {
    color: var(--color-text-secondary) !important;
}
.progress-card-level i {
    color: var(--color-accent) !important;
}

/* === 6. QUICK STATS === */
.quick-stat-item {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-xs) !important;
    border-radius: var(--radius-lg) !important;
}
.quick-stat-icon {
    color: var(--color-primary) !important;
    font-size: var(--text-xl) !important;
}
.quick-stat-value {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-bold) !important;
}
.quick-stat-label {
    color: var(--color-text-muted) !important;
}

/* === 7. FEATURED BANNER (PROMO EN COURS) === */
.featured-banner {
    background: linear-gradient(135deg, rgba(75,0,130,0.06) 0%, rgba(201,168,76,0.06) 100%) !important;
    border: 1.5px solid rgba(75,0,130,0.15) !important;
    box-shadow: var(--shadow-sm) !important;
}
.featured-banner-icon {
    background: rgba(75,0,130,0.10) !important;
    color: var(--color-primary) !important;
}
.featured-banner-tag {
    color: var(--color-accent-dark) !important;
    font-weight: var(--font-bold) !important;
}
.featured-banner-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-semibold) !important;
}
.featured-banner-desc {
    color: var(--color-text-secondary) !important;
}
.featured-banner-arrow {
    color: var(--color-primary) !important;
}

/* === 8. SECTION CARDS (home) === */
.section-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--card-shadow) !important;
    border-radius: var(--radius-xl) !important;
    overflow: hidden !important;
}
.section-card:active {
    box-shadow: var(--card-shadow-hover) !important;
    transform: scale(0.98) !important;
}
.section-card-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-semibold) !important;
}
.section-card-desc {
    color: var(--color-text-secondary) !important;
}
.section-card-price-current {
    color: var(--color-accent) !important;
    font-weight: var(--font-bold) !important;
}
.section-card-price-free {
    color: var(--color-success) !important;
}
.section-card-price-old {
    color: var(--color-text-muted) !important;
}
.section-card-btn {
    background: var(--gradient-accent) !important;
    color: var(--color-primary) !important;
    font-weight: var(--font-semibold) !important;
    border-radius: var(--radius-full) !important;
}
.section-card-btn-unlocked {
    background: rgba(46,158,91,0.1) !important;
    color: var(--color-success) !important;
    border: 1px solid rgba(46,158,91,0.2) !important;
}
.section-card-banner-placeholder {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%) !important;
}
.section-card-access {
    background: rgba(46,158,91,0.08) !important;
    color: var(--color-success) !important;
    border-color: rgba(46,158,91,0.15) !important;
}

/* === 9. HOME SECTION HEADER === */
.home-section-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-semibold) !important;
}
.home-section-icon {
    background: rgba(201,168,76,0.10) !important;
    color: var(--color-accent) !important;
}
.home-see-all {
    color: var(--color-primary) !important;
    font-weight: var(--font-medium) !important;
}

/* === 10. SECTION DETAIL PAGE === */
.detail-back-btn {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    color: var(--color-text-primary) !important;
    box-shadow: var(--shadow-xs) !important;
}
.detail-title {
    color: var(--color-text-primary) !important;
}
.detail-meta span {
    color: var(--color-text-secondary) !important;
}
.detail-meta i {
    color: var(--color-primary) !important;
}
.detail-desc {
    color: var(--color-text-secondary) !important;
}
.detail-users-count {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    color: var(--color-text-secondary) !important;
    box-shadow: var(--shadow-xs) !important;
}
.detail-users-count strong {
    color: var(--color-primary) !important;
}

/* === 11. PURCHASE BOX (dans section detail) === */
.purchase-box {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-lg) !important;
    border-radius: var(--radius-xl) !important;
}
.purchase-box-title {
    color: var(--color-primary) !important;
    font-family: var(--font-heading) !important;
}
.purchase-price-box, .price-display-box {
    background: rgba(201,168,76,0.06) !important;
    border: 1px solid rgba(201,168,76,0.2) !important;
}
.price-old-display {
    color: var(--color-text-muted) !important;
    text-decoration: line-through !important;
}
.price-main-display {
    color: var(--color-accent) !important;
    font-weight: var(--font-bold) !important;
}
.price-label-display {
    color: var(--color-text-muted) !important;
}

/* Chrono promo */
.countdown-box {
    background: rgba(217,59,59,0.06) !important;
    border: 1px solid rgba(217,59,59,0.15) !important;
    border-radius: var(--radius-lg) !important;
}
.countdown-number {
    color: var(--color-error) !important;
    font-weight: var(--font-bold) !important;
}
.countdown-label {
    color: var(--color-text-muted) !important;
    font-size: var(--text-xs) !important;
}
.countdown-sep {
    color: var(--color-error) !important;
}

/* Bouton acheter */
.btn-buy, .btn-purchase {
    background: var(--gradient-accent) !important;
    color: var(--color-primary) !important;
    font-weight: var(--font-bold) !important;
    box-shadow: var(--shadow-gold) !important;
}

/* Trust badge paiement */
.payment-trust, .secure-badge {
    background: rgba(46,158,91,0.06) !important;
    border: 1px solid rgba(46,158,91,0.15) !important;
    border-radius: var(--radius-lg) !important;
    color: var(--color-text-secondary) !important;
}
.payment-trust strong, .secure-badge strong {
    color: var(--color-success) !important;
}

/* === 12. PROFIL === */
.profile-header-bg {
    background: var(--gradient-header) !important;
}
.profile-avatar-img {
    border: 3px solid var(--color-accent) !important;
    box-shadow: var(--shadow-gold) !important;
}
.profile-avatar-edit {
    background: var(--color-accent) !important;
    color: var(--color-primary) !important;
    border: 2px solid var(--color-surface) !important;
}
.profile-name {
    color: var(--color-text-primary) !important;
}
.profile-email {
    color: var(--color-text-muted) !important;
}
.profile-level-badge {
    background: rgba(201,168,76,0.10) !important;
    border: 1px solid rgba(201,168,76,0.25) !important;
    color: var(--color-accent-dark) !important;
}
.profile-stats-row .stat-item {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-xs) !important;
}
.stat-value {
    color: var(--color-primary) !important;
    font-weight: var(--font-bold) !important;
}
.stat-label {
    color: var(--color-text-muted) !important;
}

/* Settings items profil */
.settings-group-label {
    color: var(--color-text-muted) !important;
    font-size: var(--text-xs) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}
.settings-item {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-xs) !important;
}
.settings-item-icon {
    background: rgba(75,0,130,0.06) !important;
    color: var(--color-primary) !important;
}
.settings-item-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-medium) !important;
}
.settings-item-subtitle {
    color: var(--color-text-muted) !important;
}
.settings-item-arrow {
    color: var(--color-text-muted) !important;
}

/* === 13. AFFILIATION === */
.affiliate-stats-grid .stat-card,
.affil-stat-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--card-shadow) !important;
}
.affil-stat-value {
    color: var(--color-primary) !important;
    font-weight: var(--font-bold) !important;
}
.affil-stat-label {
    color: var(--color-text-muted) !important;
}
.affil-chart-card, .affil-how-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--card-shadow) !important;
}
.affil-chart-title, .affil-how-title {
    color: var(--color-text-primary) !important;
}
.affil-step-number {
    background: rgba(201,168,76,0.12) !important;
    color: var(--color-accent-dark) !important;
    border: 1px solid rgba(201,168,76,0.2) !important;
    font-weight: var(--font-bold) !important;
}
.affil-step-text {
    color: var(--color-text-secondary) !important;
}
.affil-step-text strong {
    color: var(--color-primary) !important;
}
.affil-code-box {
    background: var(--color-bg) !important;
    border: 1.5px dashed var(--color-primary) !important;
    border-radius: var(--radius-lg) !important;
}
.affil-code-value {
    color: var(--color-primary) !important;
    font-weight: var(--font-bold) !important;
}

/* === 14. FICHIERS === */
.files-empty-icon {
    color: var(--color-gray-300) !important;
}
.files-empty-text {
    color: var(--color-text-secondary) !important;
}
.file-item {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-xs) !important;
}
.file-type-icon {
    background: rgba(75,0,130,0.06) !important;
    color: var(--color-primary) !important;
}
.file-name {
    color: var(--color-text-primary) !important;
}
.file-meta {
    color: var(--color-text-muted) !important;
}
.file-filter-btn {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}
.file-filter-btn.active {
    background: rgba(75,0,130,0.08) !important;
    border-color: rgba(75,0,130,0.2) !important;
    color: var(--color-primary) !important;
}
.storage-info-card {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
}
.storage-label {
    color: var(--color-text-secondary) !important;
}
.storage-value {
    color: var(--color-primary) !important;
    font-weight: var(--font-semibold) !important;
}

/* === 15. NOTIFICATIONS === */
.notification-item {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
}
.notification-item.unread {
    background: rgba(75,0,130,0.03) !important;
    border-left: 3px solid var(--color-primary) !important;
}
.notification-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-semibold) !important;
}
.notification-body {
    color: var(--color-text-secondary) !important;
}
.notification-time {
    color: var(--color-text-muted) !important;
}

/* === 16. MODALS === */
.modal-content, .bottom-sheet {
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    box-shadow: var(--shadow-xl) !important;
}
.modal-title {
    color: var(--color-text-primary) !important;
    font-weight: var(--font-semibold) !important;
}
.modal-close {
    background: var(--color-bg) !important;
    color: var(--color-text-secondary) !important;
    border: 1px solid var(--color-border) !important;
}
.modal-backdrop, .bottom-sheet-backdrop {
    background: rgba(26,26,46,0.55) !important;
}
.bottom-sheet-handle {
    background: var(--color-border) !important;
}

/* === 17. BADGES GÉNÉRAUX === */
.badge {
    border-radius: var(--radius-full) !important;
    font-size: var(--text-xs) !important;
    font-weight: var(--font-semibold) !important;
    padding: 2px 10px !important;
}
.badge-primary {
    background: rgba(75,0,130,0.08) !important;
    color: var(--color-primary) !important;
    border: 1px solid rgba(75,0,130,0.15) !important;
}
.badge-gold, .badge-premium {
    background: rgba(201,168,76,0.10) !important;
    color: var(--color-accent-dark) !important;
    border: 1px solid rgba(201,168,76,0.2) !important;
}
.badge-success, .badge-free {
    background: rgba(46,158,91,0.08) !important;
    color: var(--color-success) !important;
    border: 1px solid rgba(46,158,91,0.15) !important;
}

/* === 18. ONBOARDING (si applicable) === */
.onboarding-screen {
    background: var(--gradient-header) !important;
}
.onboarding-content {
    background: var(--color-surface) !important;
    border-radius: var(--radius-2xl) var(--radius-2xl) 0 0 !important;
}

/* === 19. AUTH SCREENS === */
.auth-screen {
    background: var(--gradient-primary) !important;
}
.auth-card {
    background: var(--color-surface) !important;
    box-shadow: var(--shadow-xl) !important;
}
.auth-title {
    color: var(--color-primary) !important;
}
.auth-subtitle {
    color: var(--color-text-secondary) !important;
}
.auth-input-group label {
    color: var(--color-text-secondary) !important;
    font-weight: var(--font-medium) !important;
}
.auth-input {
    background: var(--color-bg) !important;
    border: 1.5px solid var(--color-border) !important;
    color: var(--color-text-primary) !important;
}
.auth-input:focus {
    border-color: var(--color-primary) !important;
    box-shadow: 0 0 0 3px rgba(75,0,130,0.08) !important;
}
.auth-input::placeholder {
    color: var(--color-text-muted) !important;
}

/* === 20. SPLASH SCREEN garder violet === */
.splash-screen {
    background: var(--gradient-primary) !important;
}
.splash-title, .splash-text {
    color: rgba(255,255,255,0.9) !important;
}


/* ===== LAZY LOADING & SKELETON GLOBAL ===== */
/* Fade-in générique pour toutes les images lazy */
img[loading="lazy"] {
    background: linear-gradient(90deg, #ede9f5 25%, #f5f3fa 50%, #ede9f5 75%);
    background-size: 200% 100%;
    animation: img-shimmer 1.4s infinite;
}
img[loading="lazy"].loaded,
img[loading="lazy"][style*="opacity:1"] {
    animation: none;
    background: transparent;
}
@keyframes img-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Placeholder bannière section card pendant le chargement */
.section-card-banner {
    min-height: 150px;
    background: linear-gradient(135deg, #2D0060, #4B0082);
}

/* Placeholder bannière detail */
.detail-banner img {
    background: linear-gradient(135deg, #2D0060, #4B0082);
}
