/*
 Theme Name: KEMTAAN Universe
 Theme URI: https://aman-ics.com
 Author: Studio Amanirenas / Mame Mor Kandji
 Author URI: https://aman-ics.com
 Description: Portail sacré de l'univers transmédia africain KEMTAAN — Studio Amanirenas. V8 intègre la Matrice Sacrée des Quatre Yaa (Joor, Safar, Ndox, Ngelaw).
 Version: 8.0.0-phase1
 License: GNU General Public License v2 or later
 Text Domain: kemtaan
 Text Direction: ltr
 Requires at least: 6.0
 Tested up to: 6.4
 Requires PHP: 7.4
*/

/* ====================================================================
   V8 — MATRICE SACRÉE DES QUATRE YAA
   Fondation Phase 1 : tokens, réveils, registres.
   Joor = masse / structure
   Safar = lumière / révélation
   Ndox = mémoire / reflet
   Ngelaw = souffle / passage
   ==================================================================== */

:root {

    /* --- Yaa : easings ------------------------------------------------ */
    --ease-ndox-reflect: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ease-ndox-deep:    cubic-bezier(0.19, 1, 0.22, 1);
    --ease-ngelaw-breath: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-ngelaw-carry:  cubic-bezier(0.25, 0.8, 0.25, 1);
    --ease-safar-ignite:  cubic-bezier(0.7, 0, 0.3, 1);
    --ease-joor-settle:   cubic-bezier(0.6, 0, 0.4, 1);

    /* --- Yaa : durations --------------------------------------------- */
    --duree-souffle:       120ms;
    --duree-passage:       300ms;
    --duree-invocation:    500ms;
    --duree-traversee:     800ms;
    --duree-meditation:    1200ms;

    /* --- Yaa : spacing (Joor structure + Ngelaw oxygen) -------------- */
    --joor-dense:         0.5rem;
    --joor-close:         1rem;
    --joor-firm:          1.5rem;
    --joor-sacred:        2rem;
    --joor-monumental:    4rem;

    --ngelaw-breath-xs:   0.5rem;
    --ngelaw-breath-s:    1.25rem;
    --ngelaw-breath-m:    2rem;
    --ngelaw-breath-l:    6rem;
    --ngelaw-breath-xl:   10rem;

    /* --- Yaa : Safar luminance (rare par design) --------------------- */
    --safar-spark: 0 0 4px rgba(242, 194, 75, 0.5), 0 0 2px rgba(242, 194, 75, 0.8);
    --safar-halo:  0 0 24px rgba(242, 194, 75, 0.40), 0 0 8px rgba(242, 194, 75, 0.70);

    /* --- Yaa : Ndox blur / opacity ----------------------------------- */
    --ndox-veil-blur:   10px;
    --ndox-memory-blur: 22px;
    --ndox-pool-blur:   32px;
    --ndox-echo:        0.15;
    --ndox-mist:        0.35;
    --ndox-reflection:  0.6;

    /* --- Yaa : Joor borders / shadows -------------------------------- */
    --joor-edge-fine:    1px solid var(--kem-gold-soft, rgba(242,194,75,0.2));
    --joor-edge-firm:    1px solid var(--kem-gold, #f2c24b);
    --joor-edge-sacred:  2px solid var(--kem-gold, #f2c24b);

    --joor-shadow-resting: 0 1rem 2rem rgba(0, 0, 0, 0.30);
    --joor-shadow-lifted:  0 2rem 5rem rgba(0, 0, 0, 0.70), 0 1rem 2rem rgba(242, 194, 75, 0.10);
    --joor-shadow-sealed:  0 0 0 2px var(--kem-gold, #f2c24b), inset 0 2px 4px rgba(255, 255, 255, 0.08);

    /* --- Maison modulation placeholders (Phase 4 will write real values) */
    --maison-color: var(--kem-gold, #f2c24b);
    --maison-glow:  rgba(242, 194, 75, 0.35);
}

/* ====================================================================
   V8 — COUCHES PHASE 1
   Skip-link, registres, révélations, Trois Portes, Cercle d'Union,
   Sceau. Construites au-dessus des tokens Yaa (haut du fichier).
   ==================================================================== */

/* -------- Skip link (accessibilité, priorité Joor + Safar focus) ---- */
.kem-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: var(--kem-z-tooltip);
    padding: 0.75rem 1.25rem;
    background: var(--kem-bg);
    color: var(--kem-gold);
    border: var(--joor-edge-sacred);
    border-radius: var(--kem-radius-sm);
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
}

.kem-skip-link:focus,
.kem-skip-link:focus-visible {
    left: var(--joor-close);
    top: var(--joor-close);
    box-shadow: var(--safar-halo);
    outline: none;
}

/* -------- Registres (Phase 3 activera les palettes) ----------------- */
body.reg-sacred {
    /* registre KEMTAAN — défaut — laissé tel que V7 */
}
body.reg-living {
    /* registre Bëkk Néeg — Ngelaw + Ndox — à détailler Phase 3 */
}
body.reg-editorial {
    /* registre Studio — Joor sobre — à détailler Phase 3 */
}

/* -------- Révélations : IntersectionObserver-driven ------------------ */
.reveal {
    opacity: 0;
    transform: translateY(20px);
    transition:
        opacity var(--duree-invocation) var(--ease-ngelaw-carry),
        transform var(--duree-invocation) var(--ease-ngelaw-carry);
    will-change: opacity, transform;
}

.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
    will-change: auto;
}

.reveal-joor-settle {
    transition-timing-function: var(--ease-joor-settle);
    transform: translateY(10px) scale(0.98);
}
.reveal-joor-settle.is-visible { transform: translateY(0) scale(1); }

.reveal-ndox-deep {
    transition-duration: var(--duree-traversee);
    transition-timing-function: var(--ease-ndox-deep);
    transform: translateY(0);
    filter: blur(6px);
}
.reveal-ndox-deep.is-visible { filter: blur(0); }

.reveal-safar-ignite {
    transition-duration: var(--duree-passage);
    transition-timing-function: var(--ease-safar-ignite);
}

.reveal-stagger > * {
    opacity: 0;
    transform: translateY(20px);
    transition:
        opacity var(--duree-invocation) var(--ease-ngelaw-carry),
        transform var(--duree-invocation) var(--ease-ngelaw-carry);
}
.reveal-stagger.is-visible > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: 90ms; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: 180ms; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: 270ms; }
.reveal-stagger.is-visible > *:nth-child(5) { transition-delay: 360ms; }
.reveal-stagger.is-visible > *:nth-child(6) { transition-delay: 450ms; }

/* -------- §2 Verbe / Manifeste -------------------------------------- */
.kem-verbe {
    padding: var(--ngelaw-breath-l) var(--kem-space-lg);
    text-align: center;
}

.kem-verbe-inner {
    max-width: 56ch;
    margin: 0 auto;
}

.kem-verbe-sigil {
    display: block;
    font-size: 1.5rem;
    letter-spacing: 1rem;
    color: var(--kem-gold);
    opacity: 0.55;
    margin-bottom: var(--ngelaw-breath-m);
}

.kem-verbe p {
    font-family: "Cormorant Garamond", "EB Garamond", Georgia, serif;
    font-style: italic;
    font-size: clamp(1.15rem, 1.8vw, 1.45rem);
    line-height: 1.7;
    color: var(--kem-light);
}

.kem-verbe-overline {
    display: block;
    margin-top: var(--ngelaw-breath-m);
    font-size: 0.7rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--kem-muted);
}

/* -------- §3 Trois Portes ------------------------------------------- */
.kem-three-gates {
    padding: var(--ngelaw-breath-l) var(--kem-space-lg);
}

.kem-three-gates-intro {
    max-width: 60rem;
    margin: 0 auto var(--ngelaw-breath-m);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--ngelaw-breath-m);
    flex-wrap: wrap;
    font-size: 0.75rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--kem-muted);
}

.kem-three-gates-grid {
    max-width: 96rem;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ngelaw-breath-m);
}

.kem-gate {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    aspect-ratio: 3 / 4;
    padding: var(--joor-monumental) var(--joor-firm);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-lg);
    background: linear-gradient(180deg, var(--kem-bg-card), var(--kem-bg-alt));
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    isolation: isolate;
    transition:
        transform var(--duree-passage) var(--ease-ndox-reflect),
        border-color var(--duree-passage) var(--ease-ndox-reflect),
        box-shadow var(--duree-passage) var(--ease-ndox-reflect);
}

.kem-gate::before {
    /* Ndox : reflet traversant au hover */
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 35%, rgba(242, 194, 75, 0.08) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform 700ms var(--ease-ndox-reflect);
    pointer-events: none;
    z-index: 0;
}

.kem-gate:hover {
    transform: translateY(-6px);
    border-color: var(--kem-gold);
    box-shadow: var(--joor-shadow-lifted);
    text-decoration: none;
}

.kem-gate:hover::before {
    transform: translateX(120%);
}

.kem-gate:focus-visible {
    outline: none;
    border-color: var(--kem-gold);
    box-shadow: var(--safar-halo);
}

.kem-gate-glyph {
    position: relative;
    z-index: 1;
    font-size: 2.4rem;
    color: var(--kem-gold);
    opacity: 0.85;
    letter-spacing: 0.15em;
}

.kem-gate-body {
    position: relative;
    z-index: 1;
}

.kem-gate-title {
    font-family: "Cinzel", serif;
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--kem-text);
    margin: 0 0 var(--joor-dense);
}

.kem-gate-baseline {
    font-size: 0.9rem;
    color: var(--kem-muted);
    line-height: 1.6;
    margin: 0;
}

.kem-gate-cta {
    position: relative;
    z-index: 1;
    margin-top: var(--joor-firm);
    font-size: 0.8rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--kem-gold);
    display: inline-flex;
    align-items: center;
    gap: var(--joor-dense);
}

.kem-gate-cta::after {
    content: "→";
    transition: transform var(--duree-passage) var(--ease-ngelaw-breath);
}

.kem-gate:hover .kem-gate-cta::after {
    transform: translateX(4px);
}

/* Registre par porte (sobre en Phase 1 — ajustements Phase 3) */
.kem-gate.is-sacred    { --maison-color: var(--kem-gold); }
.kem-gate.is-living    { --maison-color: var(--kem-earth); }
.kem-gate.is-editorial { --maison-color: var(--kem-water); }

.kem-gate.is-sacred .kem-gate-glyph,
.kem-gate.is-living .kem-gate-glyph,
.kem-gate.is-editorial .kem-gate-glyph {
    color: var(--maison-color);
}

@media (max-width: 768px) {
    .kem-three-gates-grid {
        grid-template-columns: 1fr;
    }
    .kem-gate {
        aspect-ratio: auto;
        min-height: 18rem;
    }
}

/* -------- §9 Bëkk Néeg (aperçu — section stable, contenu statique) -- */
.kem-bekk-neeg-preview {
    padding: var(--ngelaw-breath-l) var(--kem-space-lg);
}

.kem-bekk-neeg-note {
    max-width: 60rem;
    margin: 0 auto;
    text-align: center;
    padding: var(--joor-monumental);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-lg);
    background: linear-gradient(135deg, var(--kem-bg-card), var(--kem-bg-alt));
}

.kem-bekk-neeg-note h2 {
    text-transform: uppercase;
    letter-spacing: 0.2em;
    margin-bottom: var(--joor-close);
}

.kem-bekk-neeg-note p {
    color: var(--kem-muted);
    max-width: 50ch;
    margin: 0 auto var(--joor-firm);
}

/* -------- §13 Cercle d'Union (newsletter — UI seule en Phase 1) ----- */
.kem-cercle-union {
    padding: var(--ngelaw-breath-xl) var(--kem-space-lg);
}

.kem-cercle-inner {
    max-width: 48rem;
    margin: 0 auto;
    text-align: center;
    padding: var(--joor-monumental);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-lg);
    background: radial-gradient(ellipse at top, rgba(242,194,75,0.08), transparent 65%), var(--kem-bg-card);
    position: relative;
    isolation: isolate;
}

.kem-cercle-inner::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(242,194,75,0.35), transparent 40%, transparent 60%, rgba(242,194,75,0.25));
    z-index: -1;
    opacity: 0.5;
}

.kem-cercle-inner h2 {
    letter-spacing: 0.2em;
    margin-bottom: var(--joor-close);
}

.kem-cercle-inner p {
    color: var(--kem-muted);
    margin-bottom: var(--joor-sacred);
    max-width: 40ch;
    margin-left: auto;
    margin-right: auto;
}

.kem-cercle-form {
    display: flex;
    gap: var(--joor-close);
    justify-content: center;
    flex-wrap: wrap;
}

.kem-cercle-form input[type="email"] {
    flex: 1 1 16rem;
    min-width: 12rem;
    padding: var(--joor-close) var(--joor-firm);
    background: transparent;
    color: var(--kem-text);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-xl);
    font-family: inherit;
    font-size: 0.95rem;
    letter-spacing: 0.02em;
    transition:
        border-color var(--duree-passage) var(--ease-ndox-reflect),
        box-shadow var(--duree-passage) var(--ease-safar-ignite);
}

.kem-cercle-form input[type="email"]::placeholder {
    color: var(--kem-muted);
    letter-spacing: 0.05em;
}

.kem-cercle-form input[type="email"]:focus,
.kem-cercle-form input[type="email"]:focus-visible {
    outline: none;
    border-color: var(--kem-gold);
    box-shadow: var(--safar-halo);
}

.kem-cercle-socials {
    margin-top: var(--joor-sacred);
    display: flex;
    justify-content: center;
    gap: var(--joor-firm);
    flex-wrap: wrap;
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--kem-muted);
}

.kem-cercle-socials a {
    color: var(--kem-muted);
}

.kem-cercle-socials a:hover {
    color: var(--kem-gold);
    text-decoration: none;
}

/* -------- §14 Sceau ------------------------------------------------- */
.kem-sceau {
    padding: var(--joor-monumental) var(--kem-space-lg) var(--ngelaw-breath-m);
    text-align: center;
    position: relative;
}

.kem-sceau-band {
    font-size: 1.4rem;
    letter-spacing: 1.2rem;
    color: var(--kem-gold);
    opacity: 0.35;
    white-space: nowrap;
    overflow: hidden;
    margin-bottom: var(--joor-firm);
    user-select: none;
}

.kem-sceau-caption {
    font-size: 0.8rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--kem-muted);
}

/* -------- Chroniques (aperçu homepage §11) -------------------------- */
.kem-home-chroniques {
    padding: var(--ngelaw-breath-l) var(--kem-space-lg);
}

.kem-home-chroniques-grid {
    max-width: 90rem;
    margin: 0 auto;
    display: grid;
    gap: var(--ngelaw-breath-s);
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
}

.kem-home-chronique {
    padding: var(--joor-firm);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-md);
    background: linear-gradient(180deg, var(--kem-bg-card), var(--kem-bg-alt));
    display: flex;
    flex-direction: column;
    gap: var(--joor-close);
    transition:
        transform var(--duree-passage) var(--ease-ndox-reflect),
        border-color var(--duree-passage) var(--ease-ndox-reflect),
        box-shadow var(--duree-passage) var(--ease-ndox-reflect);
}

.kem-home-chronique:hover {
    transform: translateY(-4px);
    border-color: var(--kem-gold);
    box-shadow: var(--joor-shadow-lifted);
}

.kem-home-chronique time {
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--kem-muted);
}

.kem-home-chronique h3 {
    font-size: 1.05rem;
    margin: 0;
}

.kem-home-chronique h3 a {
    color: var(--kem-text);
}

.kem-home-chronique h3 a:hover {
    color: var(--kem-gold);
    text-decoration: none;
}

.kem-home-chronique p {
    color: var(--kem-muted);
    font-size: 0.9rem;
    margin: 0;
}

/* -------- Placeholder pour sections Phase 2+ ------------------------ */
.kem-phase2-placeholder {
    max-width: 60rem;
    margin: 0 auto;
    padding: var(--joor-firm);
    border: 1px dashed var(--kem-gold-soft);
    border-radius: var(--kem-radius-md);
    color: var(--kem-muted);
    font-size: 0.8rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    text-align: center;
    opacity: 0.55;
}

/* -------- §9 Bëkk Néeg — grille 3 cartes (contes/figures/assistant) -- */
.kem-bekk-neeg-section { padding: var(--ngelaw-breath-l) var(--kem-space-lg); }

.kem-bn-grid {
    max-width: 96rem;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ngelaw-breath-m);
}

.kem-bn-card {
    display: flex;
    flex-direction: column;
    gap: var(--joor-close);
    padding: var(--joor-monumental) var(--joor-firm);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-lg);
    background: linear-gradient(180deg, var(--kem-bg-card), var(--kem-bg-alt));
    transition:
        transform var(--duree-passage) var(--ease-ndox-reflect),
        border-color var(--duree-passage) var(--ease-ndox-reflect),
        box-shadow var(--duree-passage) var(--ease-ndox-reflect);
}

.kem-bn-card:hover {
    transform: translateY(-4px);
    border-color: var(--kem-gold);
    box-shadow: var(--joor-shadow-lifted);
}

.kem-bn-glyph {
    font-size: 2.4rem;
    color: var(--kem-earth);
    opacity: 0.9;
    letter-spacing: 0.1em;
}

.kem-bn-card h3 {
    font-size: 1.2rem;
    margin: 0;
    color: var(--kem-text);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.kem-bn-card p {
    color: var(--kem-muted);
    font-size: 0.95rem;
    line-height: 1.65;
    margin: 0;
    flex: 1 0 auto;
}

/* -------- §10 Œuvres du Studio — grille 3 cartes Amanirenas --------- */
.kem-oeuvres-section { padding: var(--ngelaw-breath-l) var(--kem-space-lg); }

.kem-oeuvres-grid {
    max-width: 96rem;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ngelaw-breath-m);
}

.kem-oeuvre-card {
    display: flex;
    flex-direction: column;
    gap: var(--joor-close);
    padding: var(--joor-firm);
    border: var(--joor-edge-fine);
    border-radius: var(--kem-radius-md);
    background: linear-gradient(180deg, var(--kem-bg-card), var(--kem-bg-alt));
    position: relative;
    transition:
        transform var(--duree-passage) var(--ease-ndox-reflect),
        border-color var(--duree-passage) var(--ease-ndox-reflect),
        box-shadow var(--duree-passage) var(--ease-ndox-reflect);
}

.kem-oeuvre-card:hover {
    transform: translateY(-4px);
    border-color: var(--kem-gold);
    box-shadow: var(--joor-shadow-lifted);
}

.kem-oeuvre-badge {
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--kem-muted);
    align-self: flex-start;
    padding: 0.15rem 0.6rem;
    border: 1px solid var(--kem-gold-soft);
    border-radius: var(--kem-radius-xl);
}

.kem-oeuvre-card h3 {
    font-size: 1.25rem;
    margin: 0;
    color: var(--kem-gold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.kem-oeuvre-card p {
    color: var(--kem-muted);
    font-size: 0.95rem;
    line-height: 1.65;
    margin: 0;
    flex: 1 0 auto;
}

.kem-oeuvre-status {
    font-size: 0.75rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--kem-fire);
    opacity: 0.9;
}

/* Responsive compressions pour Bëkk Néeg et Œuvres */
@media (max-width: 900px) {
    .kem-bn-grid,
    .kem-oeuvres-grid {
        grid-template-columns: 1fr;
    }
}

/* -------- Reduced-motion : neutralise les révélations V8 ------------ */
@media (prefers-reduced-motion: reduce) {
    .reveal,
    .reveal-stagger > * {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
    .kem-gate::before { display: none; }
}


/* ====================================================================
   FIN DU STYLE PRINCIPAL
   ==================================================================== */


:root {
    /* Couleurs principales - Palette sacrée KEMTAAN */
    --kem-bg: #090605;
    --kem-bg-alt: #160f0b;
    --kem-bg-card: #1a1310;
    --kem-bg-overlay: rgba(26, 19, 16, 0.95);
    
    /* Éléments sacrés */
    --kem-gold: #f2c24b;
    --kem-gold-soft: #f2c24b33; /* 20% opacity */
    --kem-gold-strong: #ffda5c;
    --kem-water: #4a90e2;
    --kem-earth: #8b4513;
    --kem-fire: #f05a3f;
    --kem-air: #87ceeb;
    --kem-shadow: #2a1e15;
    
    /* Typographie */
    --kem-text: #f8f3e6;
    --kem-muted: #c3b7a0;
    --kem-light: #e8dfd0;
    
    /* Espacements systématiques */
    --kem-space-xs: 0.25rem;
    --kem-space-sm: 0.5rem;
    --kem-space-md: 1rem;
    --kem-space-lg: 2rem;
    --kem-space-xl: 4rem;
    
    /* Bordures et ombres */
    --kem-radius-sm: 0.5rem;
    --kem-radius-md: 1rem;
    --kem-radius-lg: 2rem;
    --kem-radius-xl: 4rem;
    
    /* Animations */
    --kem-ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --kem-ease-in-out: cubic-bezier(0.42, 0, 0.58, 1);
    --kem-ease-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
    
    /* Z-index systématique */
    --kem-z-dropdown: 1000;
    --kem-z-sticky: 1020;
    --kem-z-fixed: 1030;
    --kem-z-modal: 1040;
    --kem-z-popover: 1050;
    --kem-z-tooltip: 1060;
}

/* ====================================================================
   RESET ET BASE OPTIMISÉS
   ==================================================================== */

/* Reset moderne avec preserve */
*, 
*::before, 
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* Focus visible pour accessibilité */
:focus-visible {
    outline: 2px solid var(--kem-gold);
    outline-offset: 2px;
    border-radius: var(--kem-radius-sm);
}

/* Sélection de texte stylisée */
::selection {
    background-color: var(--kem-gold-soft);
    color: var(--kem-gold-strong);
}

/* Scrollbar personnalisée */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--kem-bg);
}

::-webkit-scrollbar-thumb {
    background: var(--kem-gold-soft);
    border-radius: var(--kem-radius-sm);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--kem-gold);
}

/* ====================================================================
   ANIMATIONS ET KEYFRAMES PERFORMANTS
   ==================================================================== */

@keyframes loy-float {
    0%, 100% { 
        transform: translateY(0px) rotate(0deg) scale(1);
        filter: drop-shadow(0 0 5px rgba(242, 194, 75, 0.3));
    }
    50% { 
        transform: translateY(-8px) rotate(5deg) scale(1.05);
        filter: drop-shadow(0 0 15px rgba(242, 194, 75, 0.6));
    }
}

@keyframes spiral-rotate {
    from { 
        transform: rotate(0deg); 
    }
    to { 
        transform: rotate(360deg); 
    }
}

@keyframes pulse-glow {
    0%, 100% { 
        opacity: 0.6;
        box-shadow: 0 0 10px rgba(242, 194, 75, 0.4);
    }
    50% { 
        opacity: 1;
        box-shadow: 0 0 20px rgba(242, 194, 75, 0.8);
    }
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

@keyframes fade-in-up {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes scale-in {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* ====================================================================
   TYPOGRAPHIE ET BASE
   ==================================================================== */

html {
    scroll-behavior: smooth;
    font-size: 16px;
    line-height: 1.5;
}

body {
    margin: 0;
    font-family: "Source Sans 3", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: 
        radial-gradient(ellipse at top, var(--kem-gold-soft) 0%, transparent 50%),
        radial-gradient(ellipse at bottom, rgba(74, 144, 226, 0.08) 0%, transparent 50%),
        linear-gradient(135deg, var(--kem-bg) 0%, var(--kem-bg-alt) 50%, var(--kem-bg) 100%);
    color: var(--kem-text);
    min-height: 100vh;
    text-rendering: optimizeSpeed;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Hiérarchie typographique cohérente */
h1, h2, h3, h4, h5, h6 {
    font-family: "Cinzel", serif;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: var(--kem-space-md);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

h1 { font-size: clamp(2.5rem, 5vw, 4.5rem); }
h2 { font-size: clamp(2rem, 4vw, 3rem); }
h3 { font-size: clamp(1.5rem, 3vw, 2rem); }
h4 { font-size: clamp(1.25rem, 2.5vw, 1.5rem); }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; }

p {
    margin-bottom: var(--kem-space-md);
    line-height: 1.7;
}

a {
    color: var(--kem-gold);
    text-decoration: none;
    transition: all 0.3s var(--kem-ease-out);
}

a:hover,
a:focus {
    color: var(--kem-gold-strong);
    text-decoration: underline;
}

/* ====================================================================
   HALO COSMIQUE ET ARRIÈRE-PLAN
   ==================================================================== */

.kem-page-aura {
    min-height: 100vh;
    position: relative;
    isolation: isolate;
    background:
        radial-gradient(circle at 20% 80%, var(--kem-gold-soft) 0%, transparent 40%),
        radial-gradient(circle at 80% 20%, rgba(74, 144, 226, 0.08) 0%, transparent 40%),
        linear-gradient(to bottom, var(--kem-bg) 0%, var(--kem-bg-alt) 60%, var(--kem-bg) 100%);
}

.kem-page-aura::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: 
        radial-gradient(circle at 25% 25%, transparent 2rem, var(--kem-gold-soft) 2.1rem, transparent 2.2rem),
        radial-gradient(circle at 75% 75%, transparent 1.5rem, rgba(74, 144, 226, 0.05) 1.6rem, transparent 1.7rem);
    background-size: 10rem 10rem, 8rem 8rem;
    pointer-events: none;
    z-index: -1;
    opacity: 0.3;
    animation: spiral-rotate 120s linear infinite;
}

/* ====================================================================
   HEADER SACRÉ OPTIMISÉ
   ==================================================================== */

.kem-header {
    position: sticky;
    top: 0;
    z-index: var(--kem-z-sticky);
    background: linear-gradient(to bottom, 
        color-mix(in srgb, var(--kem-bg) 95%, transparent) 0%,
        color-mix(in srgb, var(--kem-bg) 85%, transparent) 100%);
    backdrop-filter: blur(1rem) saturate(180%);
    border-bottom: 1px solid var(--kem-gold-soft);
    transition: all 0.3s var(--kem-ease-out);
}

.kem-header.scrolled {
    background: color-mix(in srgb, var(--kem-bg) 98%, transparent);
    backdrop-filter: blur(1.5rem) saturate(200%);
}

.kem-header-inner {
    max-width: 120rem;
    margin: 0 auto;
    padding: var(--kem-space-md) var(--kem-space-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--kem-space-lg);
}

/* Marque sacrée */
.kem-brand-link {
    display: flex;
    align-items: center;
    gap: var(--kem-space-md);
    text-decoration: none;
    transition: transform 0.3s var(--kem-ease-out);
}

.kem-brand-link:hover {
    transform: translateY(-2px);
}

.kem-brand-mark {
    width: 3rem;
    height: 3rem;
    position: relative;
    background: 
        radial-gradient(circle at 30% 30%, var(--kem-gold-strong), var(--kem-fire));
    border-radius: 50%;
    box-shadow: 
        0 0 2rem rgba(242, 194, 75, 0.6),
        inset 0 2px 4px rgba(255, 255, 255, 0.1);
    animation: loy-float 8s var(--kem-ease-in-out) infinite;
    flex-shrink: 0;
}

.kem-brand-mark::before {
    content: "𓃒";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.25rem;
    color: #000;
    font-weight: 900;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.3);
}

.kem-brand-text {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.kem-brand-title {
    font-family: "Cinzel", serif;
    font-size: clamp(1.1rem, 2vw, 1.5rem);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    background: linear-gradient(135deg, var(--kem-gold), var(--kem-fire));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
}

.kem-brand-subtitle {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--kem-muted);
    margin-top: 0.125rem;
}

/* Navigation principale */
.kem-main-nav {
    display: flex;
}

.kem-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: var(--kem-space-lg);
    align-items: center;
}

.kem-menu a {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--kem-text);
    position: relative;
    padding: var(--kem-space-sm) 0;
    font-weight: 500;
    text-decoration: none;
}

.kem-menu a::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--kem-gold), var(--kem-fire));
    transition: width 0.3s var(--kem-ease-out);
    border-radius: 1px;
}

.kem-menu a:hover::after,
.kem-menu .current-menu-item > a::after,
.kem-menu .current_page_item > a::after {
    width: 100%;
}

.kem-menu a:hover,
.kem-menu .current-menu-item > a,
.kem-menu .current_page_item > a {
    color: var(--kem-gold);
    text-decoration: none;
}

/* Bouton menu mobile */
.kem-nav-toggle {
    display: none;
    width: 2.5rem;
    height: 2rem;
    border: none;
    background: transparent;
    padding: 0;
    flex-direction: column;
    justify-content: space-between;
    cursor: pointer;
    position: relative;
    z-index: var(--kem-z-fixed);
}

.kem-nav-toggle span {
    height: 2px;
    background: var(--kem-text);
    border-radius: 1px;
    transition: all 0.3s var(--kem-ease-out);
    transform-origin: center;
}

.kem-nav-toggle[aria-expanded="true"] span:nth-child(1) {
    transform: translateY(0.7rem) rotate(45deg);
}

.kem-nav-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0;
}

.kem-nav-toggle[aria-expanded="true"] span:nth-child(3) {
    transform: translateY(-0.7rem) rotate(-45deg);
}

/* ====================================================================
   HERO ÉPIQUE AVEC PERFORMANCE
   ==================================================================== */

.kem-hero {
    position: relative;
    padding: clamp(6rem, 15vh, 12rem) var(--kem-space-lg) clamp(4rem, 10vh, 8rem);
    text-align: center;
    overflow: hidden;
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    isolation: isolate;
}

.kem-hero-orbit {
    position: absolute;
    inset: -30%;
    background: 
        radial-gradient(circle at 30% 30%, rgba(242, 194, 75, 0.15), transparent 50%),
        radial-gradient(circle at 70% 70%, rgba(74, 144, 226, 0.1), transparent 50%);
    animation: spiral-rotate 80s linear infinite;
    pointer-events: none;
}

.kem-hero-inner {
    position: relative;
    max-width: 80rem;
    margin: 0 auto;
    width: 100%;
}

/* Glyphe central performant */
.kem-hero-glyph {
    margin: 0 auto var(--kem-space-xl);
    width: clamp(8rem, 20vw, 12rem);
    height: clamp(8rem, 20vw, 12rem);
    position: relative;
    animation: loy-float 10s var(--kem-ease-in-out) infinite;
    will-change: transform;
}

.kem-hero-glyph::before {
    content: "𓃔𓃕𓃖";
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(2.5rem, 6vw, 4rem);
    color: var(--kem-gold);
    text-shadow: 
        0 0 3rem rgba(242, 194, 75, 0.8),
        0 0 6rem rgba(242, 194, 75, 0.4);
    z-index: 2;
}

.kem-hero-circle {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--kem-gold-strong), var(--kem-fire));
    box-shadow: 
        0 0 6rem rgba(242, 194, 75, 0.8),
        inset 0 4px 12px rgba(255, 255, 255, 0.1);
    opacity: 0.9;
}

.kem-hero-spiral {
    position: absolute;
    inset: 1.25rem;
    border: 3px solid transparent;
    border-top: 3px solid color-mix(in srgb, var(--kem-bg) 80%, transparent);
    border-right: 3px solid color-mix(in srgb, var(--kem-bg) 80%, transparent);
    border-radius: 50%;
    animation: spiral-rotate 25s linear infinite;
}

/* Contenu hero */
.kem-title {
    font-family: "Cinzel", serif;
    font-size: clamp(2.5rem, 6vw, 5rem);
    letter-spacing: 0.25em;
    text-transform: uppercase;
    margin: var(--kem-space-lg) 0 var(--kem-space-md);
    background: linear-gradient(135deg, var(--kem-gold), var(--kem-fire), var(--kem-water));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    background-size: 200% 200%;
    animation: shimmer 3s ease-in-out infinite;
    font-weight: 700;
    line-height: 1.1;
}

.kem-tagline {
    font-size: clamp(1.1rem, 2.5vw, 1.5rem);
    color: var(--kem-muted);
    margin-bottom: var(--kem-space-xl);
    font-style: italic;
    line-height: 1.6;
    max-width: 40rem;
    margin-left: auto;
    margin-right: auto;
}

.kem-hero-actions {
    display: flex;
    justify-content: center;
    gap: var(--kem-space-md);
    margin-bottom: var(--kem-space-lg);
    flex-wrap: wrap;
}

.kem-hero-meta {
    font-size: 0.9rem;
    color: var(--kem-muted);
    opacity: 0.8;
}

/* ====================================================================
   BOUTONS ÉLÉMENTAIRES AVEC ÉTATS
   ==================================================================== */

.kem-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--kem-space-sm);
    padding: var(--kem-space-md) var(--kem-space-xl);
    border-radius: var(--kem-radius-xl);
    border: none;
    background: linear-gradient(135deg, var(--kem-gold-strong), var(--kem-fire));
    color: color-mix(in srgb, var(--kem-bg) 95%, black);
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: all 0.3s var(--kem-ease-out);
    text-decoration: none;
    isolation: isolate;
    font-family: inherit;
}

.kem-btn::before {
    content: "𓃗";
    font-size: 1.1em;
    transition: transform 0.3s var(--kem-ease-out);
}

.kem-btn::after {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.6s var(--kem-ease-out);
}

.kem-btn:hover {
    transform: translateY(-3px);
    box-shadow: 
        0 1rem 3rem rgba(242, 194, 75, 0.4),
        0 0.5rem 1rem rgba(0, 0, 0, 0.3);
    text-decoration: none;
}

.kem-btn:hover::after {
    left: 100%;
}

.kem-btn:hover::before {
    transform: scale(1.1);
}

.kem-btn:active {
    transform: translateY(-1px);
}

.kem-btn:focus-visible {
    outline: 2px solid var(--kem-gold);
    outline-offset: 2px;
}

/* Variante outline */
.kem-btn-outline {
    background: transparent;
    color: var(--kem-gold);
    border: 2px solid var(--kem-gold-soft);
    backdrop-filter: blur(10px);
}

.kem-btn-outline::before {
    content: "𓃘";
}

.kem-btn-outline:hover {
    background: var(--kem-gold-soft);
    border-color: var(--kem-gold);
    color: var(--kem-bg);
}

/* Taille small */
.kem-btn-small {
    padding: var(--kem-space-sm) var(--kem-space-lg);
    font-size: 0.8rem;
}

/* ====================================================================
   SECTIONS ET BLOCS STRUCTURÉS
   ==================================================================== */

.site-main {
    min-height: 70vh;
}

.kem-block {
    padding: var(--kem-space-xl) var(--kem-space-lg);
    position: relative;
}

.kem-block::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: min(10rem, 80%);
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--kem-gold), transparent);
}

.kem-section-title {
    text-align: center;
    margin-bottom: var(--kem-space-xl);
}

.kem-section-title h2 {
    font-family: "Cinzel", serif;
    font-size: clamp(2rem, 4vw, 3rem);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: var(--kem-space-md);
    position: relative;
    display: inline-block;
}

.kem-section-title h2::after {
    content: "𓃙";
    position: absolute;
    bottom: -1.5rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.5rem;
    opacity: 0.7;
    animation: loy-float 4s var(--kem-ease-in-out) infinite;
}

.kem-section-title p {
    max-width: 60rem;
    margin: 0 auto;
    color: var(--kem-muted);
    font-size: 1.1rem;
}

/* ====================================================================
   PORTES DES MAISONS INTERACTIVES
   ==================================================================== */

.kem-doors-grid {
    max-width: 90rem;
    margin: 0 auto;
    display: grid;
    gap: var(--kem-space-lg);
}

.kem-door {
    position: relative;
    padding: var(--kem-space-xl);
    border-radius: var(--kem-radius-lg);
    background: linear-gradient(135deg, var(--kem-bg-card), var(--kem-bg-alt));
    border: 1px solid var(--kem-gold-soft);
    transition: all 0.4s var(--kem-ease-out);
    overflow: hidden;
    isolation: isolate;
}

.kem-door::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, var(--kem-gold-soft), transparent);
    transition: left 0.6s var(--kem-ease-out);
}

.kem-door:hover::before {
    left: 100%;
}

.kem-door:hover {
    transform: translateY(-8px);
    border-color: var(--kem-gold);
    box-shadow: 
        0 2rem 5rem rgba(0, 0, 0, 0.8),
        0 1rem 2rem rgba(242, 194, 75, 0.1);
}

.kem-door-label {
    display: inline-block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--kem-muted);
    margin-bottom: var(--kem-space-sm);
    position: relative;
    padding-left: 1.25rem;
    font-weight: 500;
}

.kem-door-label::before {
    content: "𓃚";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.kem-door h3 {
    font-size: 1.3rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--kem-space-md);
    color: var(--kem-gold);
    font-weight: 600;
}

.kem-door p {
    color: var(--kem-text);
    opacity: 0.9;
    margin-bottom: var(--kem-space-lg);
    line-height: 1.6;
}

.kem-link {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    font-weight: 500;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--kem-space-sm);
}

.kem-link::after {
    content: "→";
    transition: transform 0.3s var(--kem-ease-out);
}

.kem-link:hover {
    text-decoration: none;
}

.kem-link:hover::after {
    transform: translateX(4px);
}

/* ====================================================================
   TIMELINE SACRÉE AMÉLIORÉE
   ==================================================================== */

.kem-timeline {
    max-width: 70rem;
    margin: 0 auto;
    position: relative;
}

.kem-timeline::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, 
        transparent, 
        var(--kem-gold), 
        var(--kem-gold), 
        transparent);
    transform: translateX(-50%);
}

.kem-timeline-item {
    position: relative;
    width: calc(50% - 4rem);
    margin-bottom: var(--kem-space-xl);
    padding: var(--kem-space-lg);
    background: var(--kem-bg-overlay);
    border: 1px solid var(--kem-gold-soft);
    border-radius: var(--kem-radius-md);
    backdrop-filter: blur(10px);
    transition: all 0.3s var(--kem-ease-out);
    animation: fade-in-up 0.6s var(--kem-ease-out) both;
}

.kem-timeline-item:nth-child(odd) {
    left: 0;
    animation-delay: 0.1s;
}

.kem-timeline-item:nth-child(even) {
    left: calc(50% + 4rem);
    animation-delay: 0.2s;
}

.kem-timeline-item:hover {
    transform: translateY(-4px);
    border-color: var(--kem-gold);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.5);
}

.kem-timeline-dot {
    position: absolute;
    top: 50%;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    background: var(--kem-gold);
    box-shadow: 
        0 0 2rem rgba(242, 194, 75, 0.8),
        0 0 1rem rgba(242, 194, 75, 0.4);
    animation: pulse-glow 2s var(--kem-ease-in-out) infinite;
    z-index: 2;
}

.kem-timeline-item:nth-child(odd) .kem-timeline-dot {
    right: -3.5rem;
    transform: translateY(-50%);
}

.kem-timeline-item:nth-child(even) .kem-timeline-dot {
    left: -3.5rem;
    transform: translateY(-50%);
}

.kem-timeline-item h3 {
    font-size: 1.1rem;
    margin-bottom: var(--kem-space-sm);
    color: var(--kem-gold);
}

.kem-timeline-item p {
    margin: 0;
    color: var(--kem-muted);
    font-size: 0.9rem;
    line-height: 1.6;
}

/* ====================================================================
   SYSTÈME DE CARTES AVANCÉ
   ==================================================================== */

.kem-card-list {
    display: grid;
    gap: var(--kem-space-lg);
}

.kem-card {
    padding: var(--kem-space-lg);
    border-radius: var(--kem-radius-md);
    background: var(--kem-bg-card);
    border: 1px solid var(--kem-gold-soft);
    transition: all 0.3s var(--kem-ease-out);
}

.kem-card:hover {
    transform: translateY(-4px);
    border-color: var(--kem-gold);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.4);
}

.kem-card h3 {
    font-size: 1.1rem;
    margin-bottom: var(--kem-space-sm);
    color: var(--kem-gold);
}

.kem-card p {
    color: var(--kem-muted);
    font-size: 0.9rem;
    margin: 0;
}

/* Layout deux colonnes */
.kem-two-cols {
    max-width: 90rem;
    margin: 0 auto;
    display: grid;
    gap: var(--kem-space-xl);
}

/* ====================================================================
   SHORTCODES LOY OPTIMISÉS
   ==================================================================== */

.kem-loy-symbole {
    display: inline-block;
    font-size: 1.2em;
    margin: 0 0.125rem;
    vertical-align: middle;
    transition: all 0.3s var(--kem-ease-out);
    line-height: 1;
}

.kem-loy-symbole.kem-taille-s { font-size: 1em; }
.kem-loy-symbole.kem-taille-m { font-size: 1.5em; }
.kem-loy-symbole.kem-taille-l { font-size: 2em; }
.kem-loy-symbole.kem-taille-xl { font-size: 3em; }

.kem-loy-symbole.kem-loy-anime {
    animation: loy-float 3s var(--kem-ease-in-out) infinite;
}

.kem-loy-symbole.kem-loy-feu { color: var(--kem-fire); }
.kem-loy-symbole.kem-loy-eau { color: var(--kem-water); }
.kem-loy-symbole.kem-loy-vent { color: var(--kem-air); }
.kem-loy-symbole.kem-loy-terre { color: var(--kem-earth); }
.kem-loy-symbole.kem-loy-meen { color: var(--kem-gold); }
.kem-loy-symbole.kem-loy-union { 
    background: linear-gradient(135deg, var(--kem-fire), var(--kem-water), var(--kem-air), var(--kem-earth));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.kem-glyphe-element {
    font-size: 1.8em;
    margin: 0 0.25rem;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
}

.kem-glyphe-element.kem-glyphe-s { font-size: 1.2em; }
.kem-glyphe-element.kem-glyphe-m { font-size: 1.8em; }
.kem-glyphe-element.kem-glyphe-l { font-size: 2.5em; }

/* ====================================================================
   CARTES DES MAISONS DYNAMIQUES
   ==================================================================== */

.kem-cartes-maisons {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
    gap: var(--kem-space-lg);
    margin: var(--kem-space-xl) 0;
}

.kem-maison-card {
    background: linear-gradient(135deg, var(--kem-bg-alt), var(--kem-bg-card));
    border: 1px solid var(--kem-gold-soft);
    border-radius: var(--kem-radius-lg);
    padding: var(--kem-space-xl);
    text-align: center;
    transition: all 0.4s var(--kem-ease-out);
    position: relative;
    overflow: hidden;
    isolation: isolate;
}

.kem-maison-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, var(--kem-gold-soft), transparent);
    transition: left 0.6s var(--kem-ease-out);
}

.kem-maison-card:hover::before {
    left: 100%;
}

.kem-maison-card:hover {
    transform: translateY(-8px);
    border-color: var(--kem-gold);
    box-shadow: 
        0 2rem 4rem rgba(0, 0, 0, 0.6),
        0 1rem 2rem rgba(242, 194, 75, 0.1);
}

.kem-maison-glyphe {
    font-size: 3em;
    margin-bottom: var(--kem-space-lg);
    display: block;
    animation: loy-float 6s var(--kem-ease-in-out) infinite;
}

.kem-maison-card h4 {
    color: var(--kem-gold);
    margin-bottom: var(--kem-space-md);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 600;
}

.kem-maison-card p {
    color: var(--kem-muted);
    margin-bottom: var(--kem-space-lg);
    font-size: 0.9em;
    line-height: 1.6;
}

/* ====================================================================
   SYSTÈME PERSONNAGES AVANCÉ
   ==================================================================== */

.kem-personnages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
    gap: var(--kem-space-lg);
    margin-top: var(--kem-space-xl);
}

.kem-personnage-card {
    background: linear-gradient(135deg, var(--kem-bg-alt), var(--kem-bg-card));
    border: 1px solid var(--kem-gold-soft);
    border-radius: var(--kem-radius-lg);
    overflow: hidden;
    transition: all 0.4s var(--kem-ease-out);
    position: relative;
    isolation: isolate;
}

.kem-personnage-card:hover {
    transform: translateY(-8px);
    border-color: var(--kem-gold);
    box-shadow: 
        0 2rem 5rem rgba(0, 0, 0, 0.7),
        0 1rem 2rem rgba(242, 194, 75, 0.1);
}

.kem-personnage-card-image {
    position: relative;
    height: 16rem;
    overflow: hidden;
}

.kem-personnage-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--kem-ease-out);
}

.kem-personnage-card:hover .kem-personnage-card-image img {
    transform: scale(1.08);
}

.kem-personnage-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, var(--kem-bg-alt), var(--kem-bg-card));
    display: flex;
    align-items: center;
    justify-content: center;
}

.kem-placeholder-glyph {
    font-size: 4em;
    opacity: 0.3;
    color: var(--kem-gold);
}

.kem-personnage-card-elements {
    position: absolute;
    top: var(--kem-space-md);
    right: var(--kem-space-md);
    display: flex;
    gap: var(--kem-space-sm);
}

.kem-element-indicator {
    background: var(--kem-bg-overlay);
    color: var(--kem-gold);
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2em;
    border: 1px solid var(--kem-gold-soft);
    backdrop-filter: blur(10px);
}

.kem-personnage-card-content {
    padding: var(--kem-space-lg);
}

.kem-personnage-card-title {
    margin-bottom: var(--kem-space-sm);
}

.kem-personnage-card-title a {
    color: var(--kem-text);
    text-decoration: none;
    font-size: 1.2em;
    font-weight: 600;
    transition: color 0.3s var(--kem-ease-out);
}

.kem-personnage-card-title a:hover {
    color: var(--kem-gold);
    text-decoration: none;
}

.kem-maison-tag {
    background: var(--kem-gold-soft);
    color: var(--kem-text);
    padding: 0.25rem 0.75rem;
    border-radius: var(--kem-radius-sm);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: inline-block;
    margin-bottom: var(--kem-space-md);
}

.kem-personnage-card-excerpt {
    color: var(--kem-muted);
    margin: var(--kem-space-md) 0;
    font-size: 0.9em;
    line-height: 1.6;
}

/* Filtres personnages */
.kem-filters {
    margin-bottom: var(--kem-space-xl);
    text-align: center;
}

.kem-filter-buttons {
    display: flex;
    justify-content: center;
    gap: var(--kem-space-sm);
    flex-wrap: wrap;
    margin-top: var(--kem-space-lg);
}

.kem-filter-btn {
    background: transparent;
    color: var(--kem-text);
    border: 1px solid var(--kem-gold-soft);
    padding: var(--kem-space-sm) var(--kem-space-lg);
    border-radius: var(--kem-radius-xl);
    cursor: pointer;
    transition: all 0.3s var(--kem-ease-out);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.8rem;
    font-weight: 500;
}

.kem-filter-btn.active,
.kem-filter-btn:hover {
    background: var(--kem-gold);
    color: var(--kem-bg);
    border-color: var(--kem-gold);
    transform: translateY(-2px);
}

/* ====================================================================
   BOUTIQUE KEMTAAN
   ==================================================================== */

.kem-shop-block,
.kem-shop-page {
    background: radial-gradient(circle at top, color-mix(in srgb, var(--kem-bg-alt) 60%, transparent), transparent 60%);
}

.kem-shop-layout {
    max-width: 90rem;
    margin: 0 auto;
    display: grid;
    gap: var(--kem-space-xl);
}

.kem-shop-highlight {
    border-radius: var(--kem-radius-lg);
    padding: var(--kem-space-xl);
    background: linear-gradient(135deg, var(--kem-bg-card), var(--kem-bg-alt));
    border: 1px solid var(--kem-gold-soft);
    text-align: center;
}

.kem-shop-highlight h3 {
    color: var(--kem-gold);
    margin-bottom: var(--kem-space-md);
}

.kem-shop-products {
    border-radius: var(--kem-radius-lg);
    padding: var(--kem-space-xl);
    background: var(--kem-bg-card);
    border: 1px solid color-mix(in srgb, var(--kem-gold-soft) 50%, transparent);
}

/* ====================================================================
   PAGES SPÉCIFIQUES
   ==================================================================== */

/* Page univers */
.kem-univers-page .kem-univers-lore {
    font-size: 1.1rem;
    line-height: 1.8;
}

.kem-univers-page .kem-univers-lore h2 {
    color: var(--kem-gold);
    margin-top: var(--kem-space-xl);
}

.kem-univers-page .kem-univers-lore h3 {
    color: var(--kem-text);
    margin-top: var(--kem-space-lg);
}

/* Page personnage single */
.kem-character-single .kem-character-content {
    font-size: 1.1rem;
    line-height: 1.8;
}

.kem-character-thumb-large {
    margin-bottom: var(--kem-space-lg);
    border-radius: var(--kem-radius-lg);
    overflow: hidden;
    border: 1px solid var(--kem-gold-soft);
}

.kem-character-thumb-large img {
    width: 100%;
    height: auto;
    display: block;
}

/* ====================================================================
   FOOTER SACRÉ OPTIMISÉ
   ==================================================================== */

.kem-footer {
    border-top: 1px solid var(--kem-gold-soft);
    background: linear-gradient(to top, var(--kem-bg), var(--kem-bg-alt));
    padding: var(--kem-space-xl) var(--kem-space-lg);
    position: relative;
    margin-top: var(--kem-space-xl);
}

.kem-footer::before {
    content: "𓃒𓃓𓃔𓃕𓃖𓃗";
    position: absolute;
    top: -1.5rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2rem;
    opacity: 0.2;
    letter-spacing: 1.5rem;
    white-space: nowrap;
}

.kem-footer-inner {
    max-width: 80rem;
    margin: 0 auto;
    display: grid;
    gap: var(--kem-space-xl);
}

.kem-footer-col h4 {
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: var(--kem-space-md);
    color: var(--kem-gold);
    font-weight: 600;
}

.kem-footer-col p {
    font-size: 0.9rem;
    color: var(--kem-muted);
    line-height: 1.6;
    margin: 0;
}

.kem-footer-col .kem-menu {
    flex-direction: column;
    gap: var(--kem-space-sm);
    align-items: flex-start;
}

.kem-footer-col .kem-menu a {
    font-size: 0.85rem;
    padding: 0;
}

.kem-footer-col .kem-menu a::after {
    display: none;
}

/* ====================================================================
   RESPONSIVE DESIGN MOBILE-FIRST
   ==================================================================== */

@media (max-width: 768px) {
    :root {
        --kem-space-lg: 1.5rem;
        --kem-space-xl: 3rem;
    }

    .kem-header-inner {
        padding: var(--kem-space-md);
    }

    .kem-nav-toggle {
        display: flex;
    }

    .kem-main-nav {
        position: fixed;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--kem-bg-overlay);
        backdrop-filter: blur(2rem);
        border-top: 1px solid var(--kem-gold-soft);
        padding: var(--kem-space-lg);
        display: none;
        z-index: var(--kem-z-dropdown);
    }

    .kem-main-nav.is-open {
        display: block;
        animation: fade-in-up 0.3s var(--kem-ease-out);
    }

    .kem-menu {
        flex-direction: column;
        gap: var(--kem-space-md);
        text-align: center;
    }

    .kem-hero {
        padding: 6rem var(--kem-space-md) 4rem;
        min-height: 60vh;
    }

    .kem-title {
        letter-spacing: 0.15em;
    }

    .kem-hero-actions {
        flex-direction: column;
        align-items: center;
    }

    .kem-btn {
        width: 100%;
        max-width: 20rem;
        justify-content: center;
    }

    .kem-timeline::before {
        left: 2rem;
    }

    .kem-timeline-item {
        width: calc(100% - 5rem);
        left: 2.5rem !important;
        margin-left: 0;
    }

    .kem-timeline-dot {
        left: -2.5rem !important;
        right: auto !important;
    }

    .kem-personnages-grid {
        grid-template-columns: 1fr;
    }

    .kem-cartes-maisons {
        grid-template-columns: 1fr;
    }

    .kem-filter-buttons {
        justify-content: flex-start;
    }

    .kem-two-cols {
        grid-template-columns: 1fr;
        gap: var(--kem-space-lg);
    }

    .kem-footer-inner {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .kem-footer-col .kem-menu {
        align-items: center;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .kem-doors-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .kem-personnages-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .kem-footer-inner {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1025px) {
    .kem-doors-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .kem-footer-inner {
        grid-template-columns: repeat(3, 1fr);
    }

    .kem-two-cols {
        grid-template-columns: 2fr 1fr;
    }
}

/* ====================================================================
   ACCESSIBILITÉ ET PERFORMANCE
   ==================================================================== */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }

    .kem-hero-glyph,
    .kem-brand-mark,
    .kem-timeline-dot,
    .kem-loy-anime,
    .kem-maison-glyphe {
        animation: none !important;
    }
}

@media (prefers-contrast: high) {
    :root {
        --kem-gold-soft: var(--kem-gold);
        --kem-muted: var(--kem-text);
    }

    .kem-card,
    .kem-door,
    .kem-maison-card {
        border-width: 2px;
    }
}

/* Support des navigateurs plus anciens */
@supports not (backdrop-filter: blur(1rem)) {
    .kem-header {
        background: var(--kem-bg);
    }

    .kem-main-nav.is-open {
        background: var(--kem-bg);
    }
}

/* Impression */
@media print {
    .kem-header,
    .kem-footer,
    .kem-hero-actions,
    .kem-nav-toggle {
        display: none;
    }

    .kem-hero {
        padding: 2rem 0;
        min-height: auto;
    }

    .kem-block {
        padding: 1rem 0;
    }

    .kem-page-aura::before {
        display: none;
    }

    body {
        background: white;
        color: black;
    }

    a {
        color: black;
        text-decoration: underline;
    }
}

/* ====================================================================
   ÉTATS DE CHARGEMENT ET MESSAGES
   ==================================================================== */

.kem-loading {
    opacity: 0.7;
    pointer-events: none;
    position: relative;
}

.kem-loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 2rem;
    height: 2rem;
    border: 2px solid var(--kem-gold-soft);
    border-top: 2px solid var(--kem-gold);
    border-radius: 50%;
    animation: spiral-rotate 1s linear infinite;
    transform: translate(-50%, -50%);
}

.kem-error {
    background: color-mix(in srgb, var(--kem-fire) 20%, transparent);
    border: 1px solid var(--kem-fire);
    color: var(--kem-text);
    padding: var(--kem-space-md);
    border-radius: var(--kem-radius-md);
    text-align: center;
}

.kem-success {
    background: color-mix(in srgb, var(--kem-water) 20%, transparent);
    border: 1px solid var(--kem-water);
    color: var(--kem-text);
    padding: var(--kem-space-md);
    border-radius: var(--kem-radius-md);
    text-align: center;
}

/* ====================================================================
   PAGINATION
   ==================================================================== */

.kem-pagination {
    display: flex;
    justify-content: center;
    gap: var(--kem-space-sm);
    margin-top: var(--kem-space-xl);
}

.kem-pagination .page-numbers {
    padding: var(--kem-space-sm) var(--kem-space-md);
    border: 1px solid var(--kem-gold-soft);
    border-radius: var(--kem-radius-sm);
    text-decoration: none;
    transition: all 0.3s var(--kem-ease-out);
}

.kem-pagination .page-numbers.current,
.kem-pagination .page-numbers:hover {
    background: var(--kem-gold);
    color: var(--kem-bg);
    border-color: var(--kem-gold);
}

/* ====================================================================
   WOOCOMMERCE COMPATIBILITÉ
   ==================================================================== */

.woocommerce .kem-btn {
    font-family: inherit;
}

.woocommerce .kem-card {
    background: var(--kem-bg-card);
}

.woocommerce .price {
    color: var(--kem-gold);
}

/* ====================================================================
   FIN DU STYLE PRINCIPAL
   ==================================================================== */