/* ═══════════════════════════════════════════════════════════════════════════
   KODA LEXICON SWITCH — CSS
   ═══════════════════════════════════════════════════════════════════════════
   1. Visibilité des termes lexicaux (.koda-lex)
   2. Barre flottante footer (toggle Immersion ↔ Pro)
   3. Responsive — barre footer
   4. Transition globale — animation de bascule
   5. Mode Pro — overrides design (body.koda-mode-pro)
   ═══════════════════════════════════════════════════════════════════════════ */


/* ══════════════════════════════════════════════════════════════════════════
   SECTION 1 : TERMES LEXICAUX — VISIBILITÉ PAR MODE
   ══════════════════════════════════════════════════════════════════════════ */

/* Par défaut (Immersion) : on montre immersion, on masque pro */
.koda-lex__pro {
    display: none;
}
.koda-lex__immersion {
    display: inline;
}

/* Mode Pro : inverse */
body.koda-mode-pro .koda-lex__pro {
    display: inline;
}
body.koda-mode-pro .koda-lex__immersion {
    display: none;
}

/* Éléments avec data-koda-lex (swap JS) — transition douce */
[data-koda-lex] {
    transition: opacity 0.2s ease;
}


/* ══════════════════════════════════════════════════════════════════════════
   SECTION 2 : BARRE FLOTTANTE FOOTER
   ══════════════════════════════════════════════════════════════════════════ */

.koda-lexicon-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99990;
    transform: translateY(0);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.koda-lexicon-bar.is-hidden {
    transform: translateY(110%);
    pointer-events: none;
}

.koda-lexicon-bar__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    max-width: 560px;
    margin: 0 auto 1rem;
    padding: 0.75rem 1.25rem;
    border-radius: 16px;
    border: 1px solid var(--koda-border-light, #3d3a35);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    box-shadow:
        0 8px 32px rgba(0, 0, 0, 0.4),
        0 0 0 1px rgba(255, 255, 255, 0.05) inset;
}

/* ── Immersion mode: fond sombre DA ── */
body.koda-mode-immersion .koda-lexicon-bar__inner {
    background: rgba(18, 18, 18, 0.92);
}

/* ── Pro mode: fond DA plus chaud, différenciation subtile ── */
body.koda-mode-pro .koda-lexicon-bar__inner {
    background: rgba(25, 22, 18, 0.94);
    border-color: rgba(192, 192, 192, 0.25);
}

/* ── Labels ── */
.koda-lexicon-bar__label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    opacity: 0.45;
    transition: opacity 0.3s ease;
    user-select: none;
}

.koda-lexicon-bar__label.is-active {
    opacity: 1;
}

.koda-lexicon-bar__label:hover {
    opacity: 0.8;
}

.koda-lexicon-bar__icon {
    flex-shrink: 0;
    color: var(--koda-text-secondary, #a89f8d);
}

.koda-lexicon-bar__label.is-active .koda-lexicon-bar__icon {
    color: var(--koda-gold, #d4af37);
}

body.koda-mode-pro .koda-lexicon-bar__label.is-active .koda-lexicon-bar__icon {
    color: #c0c0c0;
}

.koda-lexicon-bar__text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.koda-lexicon-bar__title {
    font-family: var(--font-tech, 'Montserrat', sans-serif);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    color: var(--koda-text-primary, #f4f1ea);
}

.koda-lexicon-bar__subtitle {
    font-size: 0.65rem;
    color: var(--koda-text-muted, #6b6358);
    letter-spacing: 0.02em;
}

/* ── Toggle Switch ── */
.koda-lexicon-bar__toggle {
    position: relative;
    flex-shrink: 0;
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.koda-lexicon-bar__toggle:focus-visible {
    outline: 2px solid var(--koda-gold, #d4af37);
    outline-offset: 2px;
    border-radius: 20px;
}

body.koda-mode-pro .koda-lexicon-bar__toggle:focus-visible {
    outline-color: #c0c0c0;
}

.koda-lexicon-bar__toggle-track {
    display: block;
    width: 48px;
    height: 26px;
    border-radius: 13px;
    background: var(--koda-surface, #1e1e1e);
    border: 1px solid var(--koda-border-light, #3d3a35);
    position: relative;
    transition: background 0.3s ease, border-color 0.3s ease;
}

body.koda-mode-pro .koda-lexicon-bar__toggle-track {
    background: #a0a0a0;
    border-color: #8a8a8a;
}

.koda-lexicon-bar__toggle-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--koda-gold, #d4af37);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.3s ease;
}

body.koda-mode-pro .koda-lexicon-bar__toggle-thumb {
    transform: translateX(22px);
    background: #c0c0c0;
}

/* ── Bouton fermer ── */
.koda-lexicon-bar__close {
    flex-shrink: 0;
    background: none;
    border: none;
    padding: 6px;
    cursor: pointer;
    opacity: 0.4;
    color: var(--koda-text-secondary, #a89f8d);
    transition: opacity 0.2s ease;
    border-radius: 8px;
}

.koda-lexicon-bar__close:hover {
    opacity: 1;
}

/* ── Bouton réapparition (quand barre masquée) ── */
.koda-lexicon-reopen {
    position: fixed;
    bottom: 1rem;
    right: 1rem;
    z-index: 99989;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--koda-border-light, #3d3a35);
    background: rgba(18, 18, 18, 0.9);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    color: var(--koda-gold, #d4af37);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.koda-lexicon-reopen:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.4);
}

.koda-lexicon-reopen.is-visible {
    display: flex;
}

body.koda-mode-pro .koda-lexicon-reopen {
    background: rgba(25, 22, 18, 0.92);
    border-color: rgba(192, 192, 192, 0.25);
    color: #c0c0c0;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}


/* ══════════════════════════════════════════════════════════════════════════
   SECTION 3 : RESPONSIVE — BARRE FOOTER
   ══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 600px) {
    .koda-lexicon-bar__inner {
        max-width: calc(100% - 2rem);
        gap: 0.6rem;
        padding: 0.6rem 1rem;
    }

    .koda-lexicon-bar__subtitle {
        display: none;
    }

    .koda-lexicon-bar__title {
        font-size: 0.75rem;
    }
}


/* ══════════════════════════════════════════════════════════════════════════
   SECTION 4 : TRANSITION GLOBALE — ANIMATION DE BASCULE
   ══════════════════════════════════════════════════════════════════════════ */

body.koda-mode-switching,
body.koda-mode-switching * {
    transition:
        background-color 0.5s ease,
        color 0.4s ease,
        border-color 0.4s ease,
        box-shadow 0.4s ease !important;
}

/* Empêcher la transition sur les éléments qui ne doivent pas bouger */
body.koda-mode-switching img,
body.koda-mode-switching video,
body.koda-mode-switching svg path,
body.koda-mode-switching iframe {
    transition: none !important;
}


/* ══════════════════════════════════════════════════════════════════════════
   SECTION 5 : MODE PRO — OVERRIDES DESIGN (Experience Switcher)
   ══════════════════════════════════════════════════════════════════════════ */

/* ── 5.1 Tokens typographiques Pro ──
   H1 GARDE Cinzel Decorative (--koda-font-display inchangé)
   Mono GARDE JetBrains Mono (--koda-font-mono inchangé)
   H2/H3/body/UI → Montserrat                                            */
body.koda-mode-pro {
    --koda-font-heading: 'Montserrat', 'Helvetica Neue', sans-serif;
    --koda-font-body: 'Montserrat', 'Helvetica Neue', sans-serif;

    /* Body text : plus compact */
    font-size: 16px;
    line-height: 1.5;

    /* Small-caps désactivé (feature Cormorant) */
    font-variant: normal;
}

/* ── 5.2 Headings — letter-spacing adapté à Montserrat ── */
body.koda-mode-pro h2,
body.koda-mode-pro h3,
body.koda-mode-pro h4,
body.koda-mode-pro .koda-monde__section-title,
body.koda-mode-pro .koda-academy-crosslink__title {
    letter-spacing: 0;
    font-family: var(--koda-font-heading);
}

/* H1 garde Cinzel Decorative mais réduit le letter-spacing */
body.koda-mode-pro h1,
body.koda-mode-pro .koda-monde__hero-title {
    letter-spacing: 0.5px;
}

/* ── 5.3 Small-caps — forçage off sur éléments inline ── */
body.koda-mode-pro [style*="font-variant"],
body.koda-mode-pro .small-caps {
    font-variant: normal !important;
}

/* ── 5.4 Navigation & QG Dashboard ── */
body.koda-mode-pro .qg-totem-compact .totem-name,
body.koda-mode-pro .qg-tabs__btn,
body.koda-mode-pro .koda-nav-item {
    font-family: var(--koda-font-heading);
}

/* ── 5.5 Espacement & Densité ── */

/* Sections plus serrées */
body.koda-mode-pro .koda-monde__section {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

/* Headers de section compacts */
body.koda-mode-pro .koda-monde__section-header {
    margin-bottom: 1rem;
}

/* Badges décoratifs masqués en Pro */
body.koda-mode-pro .koda-monde__section-badge {
    display: none;
}

/* Cards compactes (sélecteur générique + spécifiques) */
body.koda-mode-pro .koda-monde__pricing-card,
body.koda-mode-pro .koda-academy-preview,
body.koda-mode-pro .koda-academy-crosslink,
body.koda-mode-pro [class*="__card"] {
    padding: 16px;
    border-radius: var(--koda-radius-md, 8px);
}

/* Marges paragraphes réduites */
body.koda-mode-pro p {
    margin-bottom: 0.5em;
}

/* QG dashboard compact */
body.koda-mode-pro .koda-qg-dashboard {
    padding: 20px;
}

/* Onglets QG plus serrés */
body.koda-mode-pro .qg-tabs__nav {
    margin-bottom: 16px;
}
body.koda-mode-pro .qg-tabs__btn {
    padding: 8px 16px;
}

/* ── 5.6 Suppression effets visuels ── */

/* Neutraliser toutes les variables de glow */
body.koda-mode-pro {
    --koda-gold-glow: transparent;
    --koda-gold-subtle: transparent;
    --koda-terra-glow: transparent;
    --koda-terra-subtle: transparent;
    --koda-aqua-glow: transparent;
    --koda-aqua-subtle: transparent;
    --koda-lupus-glow: transparent;
    --koda-lupus-subtle: transparent;
    --koda-aeria-glow: transparent;
    --koda-aeria-subtle: transparent;
    --koda-tanae-glow: transparent;
    --koda-tanae-subtle: transparent;
    --koda-myrmex-glow: transparent;
    --koda-myrmex-subtle: transparent;
    --koda-shadow-glow: none;

    /* Ombres réduites */
    --koda-shadow-lg: var(--koda-shadow-sm);
    --koda-shadow-md: var(--koda-shadow-sm);

    /* Border-radius simplifiés */
    --koda-radius-lg: 6px;
    --koda-radius-xl: 8px;
}

/* Textures et overlays */
body.koda-mode-pro .koda-texture-overlay,
body.koda-mode-pro [class*="texture"],
body.koda-mode-pro [class*="grain-overlay"] {
    display: none !important;
}

/* Glassmorphism supprimé partout SAUF la barre toggle */
body.koda-mode-pro .koda-glass,
body.koda-mode-pro .koda-monde__section [style*="backdrop-filter"] {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
/* Exception explicite : la barre toggle garde son glassmorphism */
body.koda-mode-pro .koda-lexicon-bar__inner {
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
}

/* Bordures dorées → bordures neutres */
body.koda-mode-pro .koda-gold-border,
body.koda-mode-pro [class*="gold-border"] {
    border-color: var(--koda-border-light) !important;
}

/* ── 5.7 Animations & Hero ── */

/* Désactiver les animations d'entrée au scroll */
body.koda-mode-pro [class*="animate"],
body.koda-mode-pro [class*="fade-in"],
body.koda-mode-pro [class*="slide-up"],
body.koda-mode-pro [class*="slide-in"] {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
}

/* Désactiver le parallax */
body.koda-mode-pro .koda-monde__hero,
body.koda-mode-pro [class*="parallax"] {
    transform: none !important;
    background-attachment: scroll !important;
}

/* Hover cards simplifié */
body.koda-mode-pro [class*="__card"]:hover {
    transform: none !important;
    box-shadow: var(--koda-shadow-sm) !important;
    border-color: var(--koda-border-light);
}

/* Progress bars sans animation décorative */
body.koda-mode-pro [class*="progress"]:not(.grimoire-terra *) {
    transition: width 0.1s linear !important;
}

/* EXCEPTION CRT TERRA — on ne touche PAS ces éléments
   Le terminal Grimoire Terra garde toutes ses animations */
body.koda-mode-pro .koda-grimoire-terra [class*="scanline"],
body.koda-mode-pro .koda-grimoire-terra [class*="crt"],
body.koda-mode-pro .koda-grimoire-terra [class*="terminal"],
body.koda-mode-pro [data-koda-terra] [class*="scanline"],
body.koda-mode-pro [data-koda-terra] [class*="crt"] {
    animation: revert !important;
    opacity: revert !important;
}

/* Hero sections réduites (conteneurs uniquement, pas les enfants) */
body.koda-mode-pro .koda-monde__hero,
body.koda-mode-pro .koda-hero-split,
body.koda-mode-pro section[class*="__hero"],
body.koda-mode-pro div[class*="__hero"]:not([class*="__hero-"]) {
    min-height: auto !important;
    max-height: 40vh;
    height: 40vh;
}

/* Vidéo autoplay masquée en Pro (image poster visible) */
body.koda-mode-pro .koda-monde__hero video {
    display: none;
}

/* Overlay hero simplifié */
body.koda-mode-pro .koda-monde__hero-overlay,
body.koda-mode-pro [class*="__hero-overlay"] {
    background: rgba(10, 10, 10, 0.7) !important;
}

/* Contenu hero : aligné à gauche en Pro */
body.koda-mode-pro .koda-monde__hero-content {
    padding: 2rem;
    text-align: left;
}
body.koda-mode-pro .koda-monde__hero-subtitle {
    max-width: 600px;
    font-size: 1rem;
}

/* Respecter prefers-reduced-motion (dans les DEUX modes) */
@media (prefers-reduced-motion: reduce) {
    [class*="animate"],
    [class*="fade-in"],
    [class*="slide-"] {
        opacity: 1 !important;
        transform: none !important;
        animation: none !important;
    }
}

/* ── 5.8 Masquage section Ordre en Pro ── */
body.koda-mode-pro .koda-monde__order,
body.koda-mode-pro [class*="order-section"],
body.koda-mode-pro section#ordre,
body.koda-mode-pro #order-section {
    display: none !important;
}

/* ── 5.9 Breadcrumb Pro-only ── */

.koda-breadcrumb {
    display: none;
}

body.koda-mode-pro .koda-breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 2rem;
    font-family: var(--koda-font-ui, 'Montserrat', sans-serif);
    font-size: 0.8rem;
    color: var(--koda-text-muted, #6b6358);
    border-bottom: 1px solid var(--koda-border, #2d2a25);
    background: var(--koda-panel, #121212);
}

body.koda-mode-pro .koda-breadcrumb a {
    color: var(--koda-text-secondary, #a89f8d);
    text-decoration: none;
    transition: color 0.2s ease;
}

body.koda-mode-pro .koda-breadcrumb a:hover {
    color: var(--koda-gold, #d4af37);
}

body.koda-mode-pro .koda-breadcrumb__sep {
    color: var(--koda-text-muted);
    font-size: 0.9rem;
}

body.koda-mode-pro .koda-breadcrumb__current {
    color: var(--koda-text-primary, #f4f1ea);
    font-weight: 500;
}

/* ── 5.10 Pricing dual format ── */

/* En Pro : transformer la grille de cards en layout tableau */
body.koda-mode-pro .koda-monde__pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--koda-border, #2d2a25);
    border: 1px solid var(--koda-border);
    border-radius: var(--koda-radius-md);
    overflow: hidden;
}

body.koda-mode-pro .koda-monde__pricing-card {
    background: var(--koda-panel, #121212);
    border: none;
    border-radius: 0;
    padding: 16px 20px;
}

/* En Pro : card "featured" se distingue par un simple top-border */
body.koda-mode-pro .koda-monde__pricing-card--featured,
body.koda-mode-pro .koda-monde__pricing-card.gardien {
    border-top: 3px solid var(--koda-gold);
    background: var(--koda-panel-elevated, #1a1a1a);
}

/* En Pro : prix plus compact */
body.koda-mode-pro .koda-monde__pricing-amount {
    font-size: 1.8rem;
}
body.koda-mode-pro .koda-monde__pricing-period {
    font-size: 0.8rem;
}

/* En Pro : features en liste dense */
body.koda-mode-pro .koda-monde__pricing-features li {
    font-size: 0.8rem;
    padding: 3px 0;
    line-height: 1.3;
}

/* En Pro : masquer le badge "Populaire" (remplacé par border-top) */
body.koda-mode-pro .koda-monde__pricing-popular {
    display: none;
}

/* En Pro : CTA compact */
body.koda-mode-pro .koda-monde__pricing-card .koda-btn,
body.koda-mode-pro .pricing-cta {
    padding: 8px 16px;
    font-size: 0.85rem;
}

/* En Pro mobile : pricing retombe en colonne unique */
@media (max-width: 768px) {
    body.koda-mode-pro .koda-monde__pricing-grid {
        grid-template-columns: 1fr;
    }
}
