/*
Theme Name: LordTCG
Theme URI: https://lordtcg.fr
Description: Thème enfant de Storefront pour la boutique LordTCG (cartes Pokémon). Direction artistique "clean modern marketplace", avec un effet holo signature sur les cartes.
Author: Thibault Dubon
Template: storefront
Version: 1.5.0
Text Domain: lordtcg
*/

/* =========================================================
   1. Design tokens
   ---------------------------------------------------------
   Palette ajustable selon le logo. L'accent indigo a été
   choisi parce qu'il vit naturellement à l'intérieur du
   dégradé holographique (cyan -> magenta -> jaune -> cyan)
   utilisé pour les rares.
   ========================================================= */
:root {
    --lord-bg:           #FAFAFB;
    --lord-surface:      #FFFFFF;
    --lord-surface-2:    #F4F4F6;
    --lord-text:         #16161A;
    --lord-text-soft:    #6B7280;
    --lord-text-mute:    #9CA3AF;
    --lord-border:       #ECECEF;
    --lord-border-soft:  #F2F2F4;

    --lord-accent:       #6366F1;
    --lord-accent-hover: #4F46E5;
    --lord-accent-deep:  #312E81;
    --lord-accent-soft:  #EEF0FF;

    --lord-success:      #10B981;
    --lord-danger:       #EF4444;

    /* Dégradé holo signature, utilisé sur les rares uniquement */
    --lord-holo: conic-gradient(
        from 180deg at 50% 50%,
        #00E0FF 0deg,
        #FF2DD1 90deg,
        #FFE600 180deg,
        #00E0FF 270deg,
        #FF2DD1 360deg
    );

    --lord-shadow-xs: 0 1px 2px rgba(16,16,26,.04);
    --lord-shadow-sm: 0 2px 8px rgba(16,16,26,.06);
    --lord-shadow-md: 0 8px 24px rgba(16,16,26,.08);
    --lord-shadow-lg: 0 24px 60px rgba(16,16,26,.12);

    --lord-radius-sm: 8px;
    --lord-radius-md: 12px;
    --lord-radius-lg: 18px;
    --lord-radius-xl: 24px;

    --lord-container: 1520px;
    --lord-gutter:    32px;
    --lord-header-h:  72px;
    --lord-nav-h:     48px;
    --lord-header-stack: calc(var(--lord-header-h) + var(--lord-nav-h));

    --lord-font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

    --lord-ease: cubic-bezier(.22,.61,.36,1);
}

/* =========================================================
   2. Reset / base — on dépouille ce que Storefront pousse
   ========================================================= */
html {
    -webkit-text-size-adjust: 100%;
    text-rendering: optimizeLegibility;
}

body.wp-singular,
body {
    background: var(--lord-bg);
    color: var(--lord-text);
    font-family: var(--lord-font-sans);
    font-size: 16px;
    line-height: 1.55;
    font-feature-settings: "ss01", "cv11";
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Storefront contraint à 1200px via .col-full — on libère */
.lord-site .col-full {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
    width: 100%;
}

.lord-site #content.site-content {
    padding: 0;
    margin-top: 0;
}

a {
    color: inherit;
    text-decoration: none;
    transition: color .2s var(--lord-ease);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

button {
    font-family: inherit;
}

/* Skip link accessible */
.lord-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 1000;
    background: var(--lord-text);
    color: #fff;
    padding: 12px 16px;
    border-radius: 0 0 var(--lord-radius-sm) 0;
    font-weight: 600;
}
.lord-skip-link:focus { left: 0; }

/* Wrapper de contenu standard */
.lord-container {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
}

/* =========================================================
   3. Boutons
   ========================================================= */
.lord-btn {
    --bg: var(--lord-text);
    --fg: #fff;
    --br: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 22px;
    border-radius: 999px;
    background: var(--bg);
    color: var(--fg);
    border: 1px solid var(--br);
    font-weight: 600;
    font-size: 15px;
    letter-spacing: -0.01em;
    line-height: 1;
    cursor: pointer;
    transition: transform .2s var(--lord-ease), background .2s var(--lord-ease), color .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
    will-change: transform;
}
.lord-btn:hover { transform: translateY(-1px); box-shadow: var(--lord-shadow-md); }
.lord-btn:active { transform: translateY(0); }

.lord-btn--accent { --bg: var(--lord-accent); --fg: #fff; }
.lord-btn--accent:hover { --bg: var(--lord-accent-hover); }

.lord-btn--ghost {
    --bg: transparent;
    --fg: var(--lord-text);
    --br: var(--lord-border);
}
.lord-btn--ghost:hover { --bg: var(--lord-surface); }

.lord-btn--lg { padding: 16px 26px; font-size: 16px; }

/* =========================================================
   4. Header
   ========================================================= */
.lord-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255,255,255,.72);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid transparent;
    transition: background .25s var(--lord-ease), border-color .25s var(--lord-ease), box-shadow .25s var(--lord-ease);
}
.lord-header.is-scrolled {
    background: rgba(255,255,255,.86);
    border-bottom-color: var(--lord-border);
    box-shadow: var(--lord-shadow-xs);
}

.lord-header__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    height: var(--lord-header-h);
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 24px;
}

.lord-header__brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 800;
    font-size: 20px;
    letter-spacing: -0.02em;
    color: var(--lord-text);
}
.lord-header__brand-mark {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--lord-text);
    color: #fff;
    display: inline-grid;
    place-items: center;
    font-size: 14px;
    font-weight: 800;
    position: relative;
    overflow: hidden;
}
.lord-header__brand-mark::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .35;
}
.lord-header__brand .custom-logo { max-height: 36px; width: auto; }

/* Search */
.lord-search {
    position: relative;
    display: flex;
    align-items: center;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    padding: 0 6px 0 16px;
    height: 44px;
    width: min(560px, 100%);
    margin: 0 auto;
    transition: border-color .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
}
.lord-search:focus-within {
    border-color: var(--lord-accent);
    box-shadow: 0 0 0 4px rgba(99,102,241,.12);
}
.lord-search__icon {
    width: 18px;
    height: 18px;
    color: var(--lord-text-mute);
    flex-shrink: 0;
}
.lord-search__input {
    flex: 1;
    border: 0;
    background: transparent;
    outline: 0;
    height: 100%;
    padding: 0 12px;
    font-size: 14.5px;
    color: var(--lord-text);
    min-width: 0;
}
.lord-search__input::placeholder { color: var(--lord-text-mute); }
.lord-search__submit {
    border: 0;
    background: var(--lord-text);
    color: #fff;
    height: 34px;
    padding: 0 16px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 13.5px;
    cursor: pointer;
    transition: background .2s var(--lord-ease);
}
.lord-search__submit:hover { background: #000; }

/* Actions */
.lord-header__actions {
    display: flex;
    align-items: center;
    gap: 6px;
}
.lord-header__action {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    color: var(--lord-text);
    font-size: 14px;
    font-weight: 500;
    transition: background .2s var(--lord-ease);
    position: relative;
}
.lord-header__action:hover { background: var(--lord-surface-2); }
.lord-header__action svg { width: 20px; height: 20px; flex-shrink: 0; }
.lord-header__cart-count {
    position: absolute;
    top: 2px;
    right: 4px;
    background: var(--lord-accent);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    display: inline-grid;
    place-items: center;
    line-height: 1;
    box-shadow: 0 0 0 2px #fff;
}
.lord-header__cart-count[data-count="0"] { display: none; }

@media (max-width: 900px) {
    .lord-header__inner { grid-template-columns: auto 1fr auto; gap: 12px; padding: 0 16px; }
    .lord-header__action span:not(.lord-header__cart-count) { display: none; }
    .lord-search { height: 40px; padding-left: 12px; }
    .lord-search__submit { display: none; }
    .lord-search__input { padding-right: 8px; }
}

@media (max-width: 640px) {
    .lord-header__brand-text { display: none; }
}

/* =========================================================
   4b. Navbar catégories (sticky sous le header)
   ========================================================= */
.lord-nav {
    position: sticky;
    top: var(--lord-header-h);
    z-index: 99;
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--lord-border);
}
.lord-nav__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    height: var(--lord-nav-h);
    display: flex;
    align-items: center;
}
.lord-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 4px;
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
}
.lord-nav__list::-webkit-scrollbar { display: none; }
.lord-nav__item { flex: 0 0 auto; }
.lord-nav__link {
    display: inline-flex;
    align-items: center;
    height: 32px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    color: var(--lord-text);
    text-decoration: none;
    white-space: nowrap;
    transition: background .15s var(--lord-ease), color .15s var(--lord-ease);
}
.lord-nav__link:hover,
.lord-nav__link:focus-visible {
    background: var(--lord-surface-2);
    color: var(--lord-text);
}
.lord-nav__link.is-active {
    background: var(--lord-text);
    color: #fff;
}
@media (max-width: 900px) {
    .lord-nav__inner { padding: 0 16px; }
}

/* =========================================================
   4c. Mini-cart drawer (off-canvas droite)
   ========================================================= */
.lord-cart-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .45);
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s var(--lord-ease), visibility .25s var(--lord-ease);
    z-index: 200;
}
.lord-cart-drawer {
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    width: min(420px, 100vw);
    background: #fff;
    box-shadow: -12px 0 40px rgba(15,23,42,.18);
    transform: translateX(100%);
    transition: transform .3s var(--lord-ease);
    z-index: 201;
    display: flex;
    flex-direction: column;
    visibility: hidden;
}
body.lord-cart-open { overflow: hidden; }
body.lord-cart-open .lord-cart-overlay { opacity: 1; visibility: visible; }
body.lord-cart-open .lord-cart-drawer { transform: translateX(0); visibility: visible; }

.lord-cart-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid var(--lord-border);
    flex-shrink: 0;
}
.lord-cart-drawer__title {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--lord-text);
}
.lord-cart-drawer__close {
    width: 36px;
    height: 36px;
    border: 0;
    background: var(--lord-surface);
    border-radius: 999px;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
    color: var(--lord-text);
    transition: background .15s var(--lord-ease);
}
.lord-cart-drawer__close:hover { background: var(--lord-surface-2); }
.lord-cart-drawer__close svg { width: 18px; height: 18px; }

.lord-cart-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: 16px 22px;
}

/* Empty state */
.lord-cart-drawer__body .woocommerce-mini-cart__empty-message {
    text-align: center;
    color: var(--lord-text-mute);
    padding: 40px 0;
    font-size: 14.5px;
}

/* Mini-cart liste — surcharge des styles WC */
.lord-cart-drawer__body ul.cart_list,
.lord-cart-drawer__body ul.product_list_widget {
    list-style: none;
    margin: 0;
    padding: 0;
}
.lord-cart-drawer__body ul.cart_list li,
.lord-cart-drawer__body ul.product_list_widget li {
    position: relative;
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 12px;
    align-items: start;
    padding: 14px 0;
    border-bottom: 1px solid var(--lord-border);
}
.lord-cart-drawer__body ul.cart_list li::before { display: none; }
.lord-cart-drawer__body ul.cart_list li img,
.lord-cart-drawer__body ul.product_list_widget li img {
    width: 56px !important;
    height: 56px !important;
    object-fit: cover;
    border-radius: 8px;
    margin: 0 !important;
    float: none !important;
    background: var(--lord-surface);
}
.lord-cart-drawer__body ul.cart_list li a:not(.remove) {
    grid-column: 2;
    color: var(--lord-text);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.35;
    text-decoration: none;
    display: block;
}
.lord-cart-drawer__body ul.cart_list li .quantity {
    grid-column: 2;
    color: var(--lord-text-mute);
    font-size: 13px;
    font-weight: 500;
    margin-top: 4px;
}
.lord-cart-drawer__body ul.cart_list li .quantity .amount {
    color: var(--lord-text);
    font-weight: 600;
}
.lord-cart-drawer__body ul.cart_list li a.remove {
    grid-column: 3;
    grid-row: 1;
    position: static;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    background: var(--lord-surface);
    color: var(--lord-text-mute) !important;
    font-size: 16px;
    line-height: 26px;
    text-align: center;
    text-decoration: none;
    transition: background .15s var(--lord-ease), color .15s var(--lord-ease);
}
.lord-cart-drawer__body ul.cart_list li a.remove:hover {
    background: #fee2e2;
    color: #b91c1c !important;
}
.lord-cart-drawer__body .variation { display: none; }

.lord-cart-drawer__foot {
    flex-shrink: 0;
    padding: 16px 22px 22px;
    border-top: 1px solid var(--lord-border);
    background: #fff;
}
.lord-cart-drawer__body p.woocommerce-mini-cart__total {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin: 14px 0 0;
    padding: 14px 0 0;
    border-top: 1px solid var(--lord-border);
    font-size: 14px;
    color: var(--lord-text-mute);
}
.lord-cart-drawer__body p.woocommerce-mini-cart__total strong {
    color: var(--lord-text);
    font-weight: 700;
}
.lord-cart-drawer__body p.woocommerce-mini-cart__total .amount {
    color: var(--lord-text);
    font-size: 19px;
    font-weight: 800;
    margin-left: auto;
}
.lord-cart-drawer__body p.woocommerce-mini-cart__buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 16px 0 0;
}
.lord-cart-drawer__body p.woocommerce-mini-cart__buttons .button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    padding: 0 14px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    border: 1px solid var(--lord-border);
    background: #fff;
    color: var(--lord-text);
    transition: background .15s var(--lord-ease), color .15s var(--lord-ease), border-color .15s var(--lord-ease);
}
.lord-cart-drawer__body p.woocommerce-mini-cart__buttons .button:hover {
    background: var(--lord-surface);
}
.lord-cart-drawer__body p.woocommerce-mini-cart__buttons .checkout {
    background: var(--lord-text);
    color: #fff;
    border-color: var(--lord-text);
}
.lord-cart-drawer__body p.woocommerce-mini-cart__buttons .checkout:hover {
    background: #000;
    border-color: #000;
}

@media (max-width: 640px) {
    .lord-cart-drawer { width: 100vw; }
}

/* =========================================================
   5. Hero homepage
   ========================================================= */
.lord-hero {
    position: relative;
    padding: 80px 0 100px;
    overflow: hidden;
    background: var(--lord-bg);
}
.lord-hero::before {
    /* halo très diffus derrière le visuel */
    content: "";
    position: absolute;
    right: -160px;
    top: -80px;
    width: 720px;
    height: 720px;
    background: radial-gradient(closest-side, rgba(99,102,241,.18), transparent 70%);
    filter: blur(20px);
    pointer-events: none;
    z-index: 0;
}

.lord-hero__inner {
    position: relative;
    z-index: 1;
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 64px;
    align-items: center;
}

.lord-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--lord-text-soft);
    letter-spacing: .02em;
    margin-bottom: 24px;
}
.lord-hero__eyebrow-dot {
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--lord-success);
    box-shadow: 0 0 0 4px rgba(16,185,129,.18);
}

.lord-hero__title {
    font-size: clamp(40px, 5.5vw, 68px);
    line-height: 1.02;
    letter-spacing: -0.035em;
    font-weight: 800;
    color: var(--lord-text);
    margin: 0 0 20px;
}
.lord-hero__title em {
    font-style: normal;
    background: linear-gradient(120deg, #6366F1 0%, #A855F7 35%, #EC4899 70%, #F59E0B 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lord-hero__lead {
    font-size: 18px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0 0 36px;
    max-width: 520px;
}

.lord-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 36px;
}

.lord-hero__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    padding-top: 28px;
    border-top: 1px solid var(--lord-border);
}
.lord-hero__trust-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13.5px;
    color: var(--lord-text-soft);
}
.lord-hero__trust-item svg {
    width: 18px;
    height: 18px;
    color: var(--lord-text);
    flex-shrink: 0;
}

/* Visuel carte (placeholder en attendant un vrai shot produit) */
.lord-hero__visual {
    position: relative;
    aspect-ratio: 1 / 1;
    display: grid;
    place-items: center;
}
.lord-card-demo {
    width: min(380px, 80%);
    aspect-ratio: 5 / 7;
    border-radius: 22px;
    position: relative;
    transform: rotate(-6deg);
    box-shadow: var(--lord-shadow-lg);
    background:
        linear-gradient(150deg, #1f2233 0%, #0f1120 60%, #1a1d35 100%);
    overflow: hidden;
    isolation: isolate;
}
.lord-card-demo::before {
    /* foil holographique sweep */
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .55;
    filter: saturate(140%);
    animation: lord-holo-rotate 16s linear infinite;
}
.lord-card-demo::after {
    /* lustre par-dessus */
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,.35) 50%, transparent 70%);
    mix-blend-mode: overlay;
    animation: lord-holo-sweep 6s ease-in-out infinite;
}
.lord-card-demo__frame {
    position: absolute;
    inset: 14px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.22);
    z-index: 2;
    display: flex;
    flex-direction: column;
    padding: 18px;
    color: #fff;
}
.lord-card-demo__name {
    font-weight: 700;
    font-size: 16px;
    letter-spacing: -0.01em;
}
.lord-card-demo__rarity {
    margin-top: auto;
    align-self: flex-start;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .15em;
    padding: 5px 9px;
    border-radius: 6px;
    background: rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(6px);
}

.lord-card-demo--secondary {
    position: absolute;
    width: 220px;
    aspect-ratio: 5 / 7;
    right: 4%;
    bottom: -4%;
    transform: rotate(12deg);
    background: linear-gradient(150deg, #b91c1c, #7c1d6f);
    border-radius: 16px;
    box-shadow: var(--lord-shadow-md);
    opacity: .92;
    z-index: -1;
    overflow: hidden;
}
.lord-card-demo--secondary::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .4;
    animation: lord-holo-rotate 22s linear infinite reverse;
}

@keyframes lord-holo-rotate {
    to { transform: rotate(360deg); }
}
@keyframes lord-holo-sweep {
    0%, 100% { transform: translateX(-30%); opacity: .15; }
    50%      { transform: translateX(30%);  opacity: .45; }
}

@media (max-width: 980px) {
    .lord-hero { padding: 56px 0 72px; }
    .lord-hero__inner { grid-template-columns: 1fr; gap: 40px; }
    .lord-hero__visual { order: -1; aspect-ratio: 4 / 3; }
    .lord-card-demo { width: min(280px, 70%); }
    .lord-card-demo--secondary { width: 170px; right: 8%; }
}

@media (prefers-reduced-motion: reduce) {
    .lord-card-demo::before,
    .lord-card-demo::after,
    .lord-card-demo--secondary::before {
        animation: none;
    }
}

/* =========================================================
   6. Sections home (titres de section, wrappers)
   ========================================================= */
.lord-section {
    padding: 72px 0;
}
.lord-section--tight { padding: 48px 0; }

.lord-section__head {
    max-width: var(--lord-container);
    margin: 0 auto 32px;
    padding: 0 24px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
}
.lord-section__title {
    font-size: clamp(24px, 2.6vw, 32px);
    line-height: 1.15;
    letter-spacing: -0.02em;
    font-weight: 800;
    margin: 0;
}
.lord-section__sub {
    color: var(--lord-text-soft);
    font-size: 14.5px;
    margin: 6px 0 0;
}
.lord-section__link {
    color: var(--lord-text);
    font-size: 14px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 10px;
    border-radius: 999px;
    transition: background .2s var(--lord-ease);
}
.lord-section__link:hover { background: var(--lord-surface-2); }

/* =========================================================
   7. Boutique — layout, sidebar, toolbar, grille, carte
   ---------------------------------------------------------
   Style sobre et dense type marketplace ; sidebar gauche
   avec filtres en accordéon checkbox, image carte carrée,
   bouton Ajouter / Choisir, plus de holo dans le grid.
   ========================================================= */

/* ---- Layout sidebar gauche + contenu ---- */
.woocommerce-page.left-sidebar #content,
.woocommerce-page.right-sidebar #content,
.woocommerce-page #content {
    background: var(--lord-bg);
}

.woocommerce-page #primary,
.woocommerce-page #secondary {
    box-sizing: border-box;
}

/* Storefront pose son #primary et #secondary à la suite. On les fait
   cohabiter en grille via le wrapper col-full du content uniquement
   (pas le wrapper breadcrumb). */
.woocommerce-page.left-sidebar #content > .col-full {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 32px;
    align-items: start;
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 32px 24px 80px;
    width: 100%;
}
.woocommerce-page.left-sidebar #secondary {
    grid-column: 1;
    grid-row: 1;
    width: auto;
    margin: 0;
    padding: 0;
    float: none;
    position: sticky;
    top: calc(var(--lord-header-stack) + 16px);
    max-height: calc(100vh - var(--lord-header-stack) - 32px);
    overflow-y: auto;
}
.woocommerce-page.left-sidebar #primary {
    grid-column: 2;
    grid-row: 1;
    width: auto;
    margin: 0;
    padding: 0;
    float: none;
    min-width: 0;
}

@media (max-width: 980px) {
    .woocommerce-page.left-sidebar #content > .col-full {
        grid-template-columns: 1fr;
        padding: 24px 16px 56px;
    }
    .woocommerce-page.left-sidebar #secondary {
        grid-column: 1;
        grid-row: 1;
        position: static;
        max-height: none;
    }
    .woocommerce-page.left-sidebar #primary {
        grid-column: 1;
        grid-row: 2;
    }
}

/* Breadcrumb sobre */
.woocommerce-page .storefront-breadcrumb {
    background: var(--lord-bg);
    border-bottom: 1px solid var(--lord-border);
    padding: 14px 0;
    margin: 0;
}
.woocommerce-page .storefront-breadcrumb .col-full {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
}
.woocommerce-page .woocommerce-breadcrumb {
    font-size: 13px;
    color: var(--lord-text-soft);
}
.woocommerce-page .woocommerce-breadcrumb a {
    color: var(--lord-text);
    font-weight: 600;
}

/* ---- Sidebar : filtres ---- */
.woocommerce-page #secondary .widget {
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    padding: 14px 16px;
    margin-bottom: 12px;
}
.woocommerce-page #secondary .widget-title,
.woocommerce-page #secondary .gamma {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0;
    padding: 0;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.005em;
    color: var(--lord-text);
    cursor: pointer;
    user-select: none;
}
.woocommerce-page #secondary .widget-title::after,
.woocommerce-page #secondary .gamma::after {
    content: "";
    width: 10px;
    height: 10px;
    border-right: 1.5px solid var(--lord-text);
    border-bottom: 1.5px solid var(--lord-text);
    transform: rotate(45deg);
    transition: transform .2s var(--lord-ease);
    margin-right: 4px;
}
.woocommerce-page #secondary .widget.is-collapsed .widget-title::after,
.woocommerce-page #secondary .widget.is-collapsed .gamma::after {
    transform: rotate(-45deg);
}

/* Liste filtres (les <ul> juste après le titre) */
.woocommerce-page #secondary .widget > ul {
    list-style: none;
    margin: 12px 0 0;
    padding: 0;
    max-height: 420px;
    overflow-y: auto;
    transition: max-height .25s var(--lord-ease), margin .2s var(--lord-ease), opacity .2s var(--lord-ease);
}
.woocommerce-page #secondary .widget.is-collapsed > ul {
    max-height: 0;
    margin-top: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
}

.woocommerce-page #secondary .widget > ul > li {
    margin: 0;
    padding: 0;
}
.woocommerce-page #secondary .widget > ul > li > a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 4px;
    color: var(--lord-text);
    font-size: 13.5px;
    line-height: 1.3;
    transition: color .15s var(--lord-ease);
    position: relative;
}
.woocommerce-page #secondary .widget > ul > li > a:hover {
    color: var(--lord-accent-hover);
}
.woocommerce-page #secondary .widget > ul > li > a::before {
    content: "";
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    border: 1.5px solid var(--lord-border);
    border-radius: 4px;
    background: var(--lord-surface);
    transition: background .15s var(--lord-ease), border-color .15s var(--lord-ease);
}
.woocommerce-page #secondary .widget > ul > li.chosen > a::before {
    background: var(--lord-text);
    border-color: var(--lord-text);
    background-image: linear-gradient(45deg, transparent 35%, #fff 35% 45%, transparent 45%, transparent 55%, #fff 55% 75%, transparent 75%);
    background-size: 16px 16px;
    background-position: -1px -1px;
}
.woocommerce-page #secondary .widget > ul > li > a > .count {
    margin-left: auto;
    color: var(--lord-text-mute);
    font-size: 12px;
    font-weight: 500;
}

/* Bouton "Tout effacer" en tête sidebar */
.lord-filters-clear {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    margin: 0 0 12px;
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    background: var(--lord-surface);
    color: var(--lord-text);
    font-size: 12.5px;
    font-weight: 600;
    transition: background .15s var(--lord-ease), border-color .15s var(--lord-ease);
}
.lord-filters-clear::before {
    content: "×";
    font-size: 16px;
    line-height: 1;
}
.lord-filters-clear:hover {
    background: var(--lord-text);
    color: #fff;
    border-color: var(--lord-text);
}

/* ---- Toolbar (compteur + tri en haut ; pagination en bas) ---- */
.woocommerce-page #primary .storefront-sorting {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    padding: 0 0 20px;
    margin: 0 0 24px;
    border-bottom: 1px solid var(--lord-border);
}
.woocommerce-page #primary .storefront-sorting::before,
.woocommerce-page #primary .storefront-sorting::after { content: none; }

.woocommerce-page #primary .storefront-sorting .woocommerce-result-count {
    order: 1;
    margin: 0;
    font-size: 13.5px;
    color: var(--lord-text-soft);
    font-weight: 500;
    float: none;
}
.woocommerce-page #primary .storefront-sorting .woocommerce-ordering {
    order: 2;
    margin: 0;
    float: none;
}
.woocommerce-page #primary .storefront-sorting .woocommerce-ordering select,
.woocommerce-page #primary .storefront-sorting .orderby {
    appearance: none;
    -webkit-appearance: none;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    color: var(--lord-text);
    font-family: inherit;
    font-size: 13.5px;
    font-weight: 600;
    padding: 8px 38px 8px 14px;
    cursor: pointer;
    background-image: linear-gradient(45deg, transparent 50%, var(--lord-text-soft) 50%), linear-gradient(135deg, var(--lord-text-soft) 50%, transparent 50%);
    background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
    background-size: 5px 5px;
    background-repeat: no-repeat;
}
.woocommerce-page #primary .storefront-sorting select:focus {
    outline: none;
    border-color: var(--lord-accent);
    box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}

/* Le second .storefront-sorting (après la grille) ne contient plus que
   la pagination — on l'allège (pas de bordure, marge propre). */
.woocommerce-page #primary ul.products + .storefront-sorting,
.woocommerce-page #primary .storefront-sorting:has(> nav.woocommerce-pagination:only-child) {
    border-bottom: 0;
    padding: 24px 0 0;
    margin: 0;
    justify-content: center;
}

/* Pagination */
.woocommerce-page .woocommerce-pagination ul.page-numbers {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border: 0;
    list-style: none;
    padding: 0;
    margin: 0;
}
.woocommerce-page .woocommerce-pagination ul.page-numbers li {
    border: 0;
    margin: 0;
}
.woocommerce-page .woocommerce-pagination .page-numbers {
    display: inline-grid;
    place-items: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    border-radius: 8px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    color: var(--lord-text);
    font-size: 13.5px;
    font-weight: 600;
    transition: background .15s var(--lord-ease);
}
.woocommerce-page .woocommerce-pagination .page-numbers:hover { background: var(--lord-surface-2); }
.woocommerce-page .woocommerce-pagination .page-numbers.current {
    background: var(--lord-text);
    color: #fff;
    border-color: var(--lord-text);
}
/* ---- Scroll infini : indicateur + bouton fallback ---- */
.woocommerce-pagination.lord-infinite-hidden,
nav.woocommerce-pagination.lord-infinite-hidden {
    display: none !important;
}
.lord-infinite {
    margin: 28px auto;
    max-width: var(--lord-container);
    padding: 0 24px;
    text-align: center;
}
.lord-infinite__status {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--lord-text-mute);
    font-size: 14px;
    font-weight: 500;
    padding: 18px 0;
}
.lord-infinite.is-loading .lord-infinite__status,
.lord-infinite.is-done    .lord-infinite__status {
    display: inline-flex;
}
.lord-infinite__spinner {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    border: 2px solid var(--lord-border);
    border-top-color: var(--lord-text);
    animation: lord-spin .7s linear infinite;
}
.lord-infinite.is-done .lord-infinite__spinner { display: none; }
.lord-infinite__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 42px;
    padding: 0 22px;
    border-radius: 999px;
    background: var(--lord-text);
    color: #fff;
    border: 0;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: background .15s var(--lord-ease);
}
.lord-infinite__btn:hover { background: #000; }
.lord-infinite__sentinel {
    height: 1px;
    width: 100%;
}

.woocommerce-page .woocommerce-pagination .page-numbers.dots {
    background: transparent;
    border: 0;
}

/* ---- Grille produits ---- */
.lord-products,
.lord-content ul.products,
.lord-section ul.products,
.woocommerce ul.products {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    /* Densité par défaut (home, archives WC) : 6 cols desktop, dégradé responsive */
    grid-template-columns: repeat(6, minmax(0, 1fr));
    column-gap: 20px;
    row-gap: 32px;
}
/* Wrappers pleins largeur (Nouveautés / Meilleures ventes home) — contraintes */
.lord-section ul.products,
.lord-content > ul.products,
.lord-products {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
}
/* Home sections : un peu plus aérées que la boutique pure */
.lord-section ul.products { gap: 20px; }

.lord-content ul.products::before,
.lord-content ul.products::after,
.lord-section ul.products::before,
.lord-section ul.products::after,
.woocommerce ul.products::before,
.woocommerce ul.products::after {
    content: none;
    display: none;
}

.woocommerce ul.products li.product,
.lord-content ul.products li.product,
.lord-section ul.products li.product {
    width: auto !important;
    margin: 0 !important;
    float: none !important;
    clear: none !important;
}

@media (max-width: 1400px) {
    .lord-products,
    .lord-content ul.products,
    .lord-section ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}
@media (max-width: 1180px) {
    .lord-products,
    .lord-content ul.products,
    .lord-section ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}
@media (max-width: 900px) {
    .lord-products,
    .lord-content ul.products,
    .lord-section ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 600px) {
    .lord-products,
    .lord-content ul.products,
    .lord-section ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }
}

/* ---- Carte produit — minimaliste, pas de boîte rigide ---- */
.lord-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: transparent;
    border: 0;
    border-radius: var(--lord-radius-md);
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
}
.lord-card:hover {
    transform: translateY(-2px);
}
.lord-card:hover .lord-card__media {
    box-shadow: 0 10px 24px rgba(16,16,26,.08);
}

.lord-card__media {
    display: block;
    aspect-ratio: 5 / 7;
    background: var(--lord-surface);
    position: relative;
    overflow: hidden;
    border-radius: var(--lord-radius-md);
    transition: box-shadow .2s var(--lord-ease);
}
.lord-card__media img,
.lord-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    padding: 0;
    margin: 0;
    transition: transform .3s var(--lord-ease);
    display: block;
}
.lord-card:hover .lord-card__img {
    transform: scale(1.04);
}

.lord-card--oos .lord-card__img { opacity: .45; }

.lord-card__sale-tag {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--lord-text);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 4px 8px;
    border-radius: 6px;
    z-index: 2;
}

/* Badge stock en overlay top-left (style pokecollection) */
.lord-card__stock {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    padding: 4px 9px 4px 7px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .02em;
    line-height: 1;
    color: var(--lord-text);
    box-shadow: 0 1px 3px rgba(15,23,42,.08);
}
.lord-card__stock-dot {
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--lord-success);
    flex-shrink: 0;
}
.lord-card__stock.is-out {
    color: var(--lord-text-mute);
}
.lord-card__stock.is-out .lord-card__stock-dot {
    background: var(--lord-text-mute);
}

.lord-card__body {
    padding: 12px 4px 4px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.lord-card__name {
    display: block;
    font-size: 13.5px;
    line-height: 1.35;
    font-weight: 500;
    color: var(--lord-text);
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color .15s var(--lord-ease);
}
.lord-card__name:hover { color: var(--lord-accent-hover); }

.lord-card__row {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: auto;
    padding-top: 8px;
}
.lord-card__price {
    display: block;
    font-size: 19px;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--lord-text);
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.lord-card__price del {
    color: var(--lord-text-mute);
    font-weight: 500;
    font-size: 13px;
    margin-right: 6px;
    text-decoration: line-through;
}
.lord-card__price ins {
    text-decoration: none;
    color: var(--lord-danger);
}
.lord-card__price ins .woocommerce-Price-amount {
    color: var(--lord-danger);
}
.lord-card__price .woocommerce-Price-amount {
    white-space: nowrap;
    color: var(--lord-text);
}
.lord-card__price .woocommerce-Price-currencySymbol {
    font-size: 0.85em;
    margin-left: 1px;
    color: var(--lord-text-mute);
    font-weight: 700;
}

/* Bouton Ajouter / Choisir — pleine largeur sous le prix */
.lord-card .lord-card__buy,
.lord-card .button.add_to_cart_button {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    background: var(--lord-text);
    color: #fff !important;
    border: 0;
    border-radius: 999px;
    padding: 9px 12px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    transition: background .15s var(--lord-ease), transform .15s var(--lord-ease);
    white-space: nowrap;
    cursor: pointer;
}
.lord-card .lord-card__buy:hover,
.lord-card .button.add_to_cart_button:hover {
    background: #000;
}
.lord-card .lord-card__buy:active,
.lord-card .button.add_to_cart_button:active {
    transform: scale(.96);
}

/* WC ajoute .loading pendant l'AJAX : on remplace le texte par un spinner */
.lord-card .button.add_to_cart_button.loading {
    color: transparent !important;
    pointer-events: none;
}
.lord-card .button.add_to_cart_button.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    border-radius: 999px;
    border: 2px solid rgba(255,255,255,.35);
    border-top-color: #fff;
    animation: lord-spin .7s linear infinite;
}

/* WC ajoute .added une fois l'item dans le panier : on swap pour un check */
.lord-card .button.add_to_cart_button.added {
    background: #16a34a;
    color: transparent !important;
    pointer-events: none;
}
.lord-card .button.add_to_cart_button.added::before {
    content: "Ajouté";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-size: 12.5px;
    font-weight: 600;
}
.lord-card .button.add_to_cart_button.added::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 14px;
    width: 12px;
    height: 6px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: translateY(-70%) rotate(-45deg);
    opacity: 0;
    animation: lord-check-pop .35s var(--lord-ease) forwards;
}

@keyframes lord-spin {
    to { transform: rotate(360deg); }
}
@keyframes lord-check-pop {
    0%   { opacity: 0; transform: translateY(-70%) rotate(-45deg) scale(.4); }
    60%  { opacity: 1; transform: translateY(-70%) rotate(-45deg) scale(1.1); }
    100% { opacity: 1; transform: translateY(-70%) rotate(-45deg) scale(1); }
}

.lord-card .added_to_cart {
    display: none; /* on retire le lien "voir le panier" sous le bouton — remplacé par le drawer */
}

/* Storefront / Woo posent des marges sur ses buttons — on les neutralise */
.lord-card .button { margin: 0 !important; }

/* Badge panier qui pulse quand on ajoute un article */
@keyframes lord-cart-bump {
    0%   { transform: scale(1); }
    40%  { transform: scale(1.35); }
    100% { transform: scale(1); }
}
.lord-header__cart-count.is-bumped {
    animation: lord-cart-bump .35s var(--lord-ease);
}

/* ---- Placeholder demo (cartes home tant que pas de catalogue) ---- */
.lord-card__image {
    aspect-ratio: 1 / 1;
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
}
.lord-card__image--demo {
    background:
        radial-gradient(120% 80% at 50% 0%, hsl(var(--demo-hue, 220) 65% 28%) 0%, hsl(var(--demo-hue, 220) 70% 14%) 60%, hsl(var(--demo-hue, 220) 65% 9%) 100%);
}
.lord-card__demo-art {
    width: 64%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background:
        radial-gradient(closest-side, hsl(var(--demo-hue, 220) 95% 70%) 0%, hsl(var(--demo-hue, 220) 75% 40%) 70%, transparent 100%);
    display: grid;
    place-items: center;
    filter: blur(.4px);
    position: relative;
    z-index: 1;
}
.lord-card__demo-art-inner {
    font-size: 56px;
    font-weight: 800;
    color: rgba(255,255,255,.92);
    letter-spacing: -0.04em;
    mix-blend-mode: overlay;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
}

/* Anciens éléments de carte (compat — non utilisés dans la v2 mais
   conservés pour les sections home qui peuvent encore les invoquer) */
.lord-card__link,
.lord-card__title,
.lord-card__sub,
.lord-card__foot,
.lord-card__cta,
.lord-card__badges,
.lord-card__holo,
.lord-card__oos,
.lord-card__sale {
    /* no-op overrides — kept harmless */
}
.lord-badge {
    display: inline-flex;
    align-items: center;
    height: 22px;
    padding: 0 8px;
    border-radius: 6px;
    background: rgba(22,22,26,.88);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
}
.lord-badge--langue { background: rgba(255,255,255,.92); color: var(--lord-text); border: 1px solid var(--lord-border); }
.lord-badge--etat   { background: rgba(22,22,26,.92); color: #fff; }

/* Placeholder visuel (tant que pas de catalogue) */
.lord-card__image--demo {
    background:
        radial-gradient(120% 80% at 50% 0%, hsl(var(--demo-hue, 220) 65% 28%) 0%, hsl(var(--demo-hue, 220) 70% 14%) 60%, hsl(var(--demo-hue, 220) 65% 9%) 100%);
}
.lord-card__demo-art {
    width: 64%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background:
        radial-gradient(closest-side, hsl(var(--demo-hue, 220) 95% 70%) 0%, hsl(var(--demo-hue, 220) 75% 40%) 70%, transparent 100%);
    display: grid;
    place-items: center;
    filter: blur(.4px);
    position: relative;
    z-index: 1;
}
.lord-card__demo-art-inner {
    font-size: 56px;
    font-weight: 800;
    color: rgba(255,255,255,.92);
    letter-spacing: -0.04em;
    mix-blend-mode: overlay;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
}

.lord-section__note {
    max-width: var(--lord-container);
    margin: 18px auto 0;
    padding: 0 24px;
    font-size: 12.5px;
    color: var(--lord-text-mute);
    text-align: center;
    font-style: italic;
}

/* Variante : section légèrement teintée (pour alterner) */
.lord-section--soft {
    background:
        linear-gradient(180deg, var(--lord-bg) 0%, #F1F1F6 50%, var(--lord-bg) 100%);
}

/* =========================================================
   7. Section "Explorer les séries" (bandeau sombre, vers /series-pokemon-tcg/)
   ========================================================= */
.lord-explore {
    position: relative;
    margin: 64px 24px;
    border-radius: var(--lord-radius-xl);
    background:
        radial-gradient(120% 80% at 80% 0%, rgba(99,102,241,.35) 0%, transparent 60%),
        radial-gradient(80% 60% at 0% 100%, rgba(236,72,153,.18) 0%, transparent 60%),
        linear-gradient(135deg, #0F0F1A 0%, #1E1B4B 100%);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.lord-explore::before {
    /* texture pointillée diffuse */
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.08) 1px, transparent 0);
    background-size: 18px 18px;
    opacity: .5;
    pointer-events: none;
}
.lord-explore__inner {
    position: relative;
    z-index: 1;
    max-width: calc(var(--lord-container) - 48px);
    margin: 0 auto;
    padding: 64px 40px;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 48px;
    align-items: center;
}

.lord-explore__copy { max-width: 560px; }

.lord-explore__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 600;
    color: rgba(255,255,255,.85);
    letter-spacing: .02em;
    margin-bottom: 22px;
}
.lord-explore__eyebrow-dot {
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: #A855F7;
    box-shadow: 0 0 0 4px rgba(168,85,247,.25);
}

.lord-explore__title {
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    font-weight: 800;
    margin: 0 0 18px;
    color: #fff;
}
.lord-explore__title em {
    font-style: normal;
    background: linear-gradient(120deg, #F472B6 0%, #A855F7 50%, #06B6D4 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lord-explore__lead {
    font-size: 16.5px;
    line-height: 1.6;
    color: rgba(255,255,255,.72);
    margin: 0 0 28px;
}

.lord-explore__copy .lord-btn--accent {
    background: #fff;
    color: var(--lord-text);
}
.lord-explore__copy .lord-btn--accent:hover {
    background: #fff;
    color: var(--lord-accent);
    transform: translateY(-1px);
}

/* Visuel : éventail de cartes d'ères */
.lord-explore__visual {
    position: relative;
    aspect-ratio: 1 / 1;
    max-width: 480px;
    margin: 0 auto;
}
.lord-explore__card {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 60%;
    aspect-ratio: 16 / 10;
    border-radius: 16px;
    background:
        radial-gradient(120% 90% at 20% 0%, rgba(255,255,255,.20) 0%, transparent 55%),
        linear-gradient(135deg, var(--from) 0%, var(--to) 100%);
    box-shadow: 0 24px 60px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.08);
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: transform .3s var(--lord-ease);
    overflow: hidden;
}
.lord-explore__card::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.18) 1px, transparent 0);
    background-size: 14px 14px;
    mix-blend-mode: overlay;
    opacity: .4;
    pointer-events: none;
}
.lord-explore__card-year {
    position: relative;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .12em;
    color: rgba(255,255,255,.85);
    text-transform: uppercase;
    align-self: flex-start;
    padding: 4px 8px;
    background: rgba(0,0,0,.25);
    border-radius: 6px;
    backdrop-filter: blur(6px);
}
.lord-explore__card-name {
    position: relative;
    font-size: clamp(16px, 1.6vw, 20px);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #fff;
    text-transform: uppercase;
    text-shadow: 0 4px 14px rgba(0,0,0,.35);
}

/* Disposition de l'éventail (3 cartes superposées et inclinées) */
.lord-explore__card--1 { transform: translate(-50%, -68%) rotate(-9deg) translateX(-110px); z-index: 1; }
.lord-explore__card--2 { transform: translate(-50%, -50%) rotate(0deg);  z-index: 3; }
.lord-explore__card--3 { transform: translate(-50%, -32%) rotate(9deg)  translateX(110px); z-index: 2; }

.lord-explore:hover .lord-explore__card--1 { transform: translate(-50%, -68%) rotate(-11deg) translateX(-130px); }
.lord-explore:hover .lord-explore__card--3 { transform: translate(-50%, -32%) rotate(11deg)  translateX(130px); }

@media (max-width: 980px) {
    .lord-explore { margin: 48px 16px; }
    .lord-explore__inner { grid-template-columns: 1fr; gap: 24px; padding: 48px 28px; }
    .lord-explore__visual { order: -1; aspect-ratio: 16 / 9; max-width: 100%; }
    .lord-explore__card { width: 52%; }
    .lord-explore__card--1 { transform: translate(-50%, -50%) rotate(-9deg) translateX(-90px); }
    .lord-explore__card--3 { transform: translate(-50%, -50%) rotate(9deg)  translateX(90px); }
}
@media (max-width: 560px) {
    .lord-explore__card { width: 70%; }
    .lord-explore__card--1 { transform: translate(-50%, -50%) rotate(-7deg) translateX(-50px); }
    .lord-explore__card--3 { transform: translate(-50%, -50%) rotate(7deg)  translateX(50px); }
}

@media (prefers-reduced-motion: reduce) {
    .lord-explore:hover .lord-explore__card { transition: none; }
}

/* =========================================================
   7bis. Section "À propos" (story + stats)
   ========================================================= */
.lord-about {
    position: relative;
    padding: 88px 0 24px;
    overflow: hidden;
}
.lord-about::before {
    content: "";
    position: absolute;
    left: -200px;
    top: -120px;
    width: 700px;
    height: 700px;
    background: radial-gradient(closest-side, rgba(99,102,241,.16), transparent 70%);
    filter: blur(20px);
    z-index: 0;
    pointer-events: none;
}

.lord-about__inner {
    position: relative;
    z-index: 1;
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 64px;
    align-items: center;
}

.lord-about__title {
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    font-weight: 800;
    margin: 0 0 20px;
    color: var(--lord-text);
}
.lord-about__title em {
    font-style: normal;
    background: linear-gradient(120deg, #6366F1 0%, #A855F7 45%, #EC4899 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lord-about__lead {
    font-size: 16.5px;
    line-height: 1.6;
    color: var(--lord-text-soft);
    margin: 0 0 16px;
    max-width: 540px;
}
.lord-about__copy .lord-btn { margin-top: 12px; }

/* Visuel : éventail de cartes (mini-portfolio) */
.lord-about__visual {
    position: relative;
    aspect-ratio: 1 / 1;
    display: grid;
    place-items: center;
}
.lord-about__fan {
    position: relative;
    width: min(380px, 80%);
    aspect-ratio: 1 / 1;
}
.lord-about__fan-card {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 38%;
    aspect-ratio: 5 / 7;
    border-radius: 14px;
    background: linear-gradient(160deg, #1f2233 0%, #0f1120 60%, #1a1d35 100%);
    box-shadow: var(--lord-shadow-md);
    transform-origin: 50% 100%;
}
.lord-about__fan-card--1 { transform: translate(-50%, -50%) rotate(-22deg) translateX(-90px); background: linear-gradient(160deg, #b91c1c, #7c1d6f); }
.lord-about__fan-card--2 { transform: translate(-50%, -50%) rotate(-11deg) translateX(-45px); background: linear-gradient(160deg, #1e3a8a, #2563eb); }
.lord-about__fan-card--3 { transform: translate(-50%, -55%) rotate(0deg); z-index: 3; }
.lord-about__fan-card--4 { transform: translate(-50%, -50%) rotate(11deg) translateX(45px);  background: linear-gradient(160deg, #047857, #10b981); }
.lord-about__fan-card--5 { transform: translate(-50%, -50%) rotate(22deg) translateX(90px);  background: linear-gradient(160deg, #d97706, #facc15); }

.lord-about__fan-card--rare { overflow: hidden; }
.lord-about__fan-holo {
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .55;
    filter: saturate(140%);
    animation: lord-holo-rotate 16s linear infinite;
}
.lord-about__fan-card--rare::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,.18);
}

@media (prefers-reduced-motion: reduce) {
    .lord-about__fan-holo { animation: none; }
}

/* Stats — bande de 4 sous le contenu */
.lord-about__stats {
    position: relative;
    z-index: 1;
    list-style: none;
    margin: 56px auto 0;
    padding: 28px 24px;
    max-width: var(--lord-container);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    border-top: 1px solid var(--lord-border);
    border-bottom: 1px solid var(--lord-border);
}
.lord-about__stat {
    text-align: left;
    padding: 8px 0;
}
.lord-about__stat-value {
    font-size: clamp(28px, 3vw, 36px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--lord-text);
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
}
.lord-about__stat-star {
    color: #F59E0B;
    margin-left: 2px;
}
.lord-about__stat-label {
    margin-top: 8px;
    font-size: 13.5px;
    color: var(--lord-text-soft);
    line-height: 1.4;
}

@media (max-width: 980px) {
    .lord-about { padding-top: 64px; }
    .lord-about__inner { grid-template-columns: 1fr; gap: 36px; }
    .lord-about__visual { order: -1; aspect-ratio: 4 / 3; }
    .lord-about__fan { width: min(320px, 70%); }
}
@media (max-width: 720px) {
    .lord-about__stats { grid-template-columns: repeat(2, 1fr); gap: 18px; }
}

/* =========================================================
   8. Trust strip "Pourquoi LordTCG"
   ========================================================= */
.lord-trust {
    background: var(--lord-surface);
    border-top: 1px solid var(--lord-border);
    border-bottom: 1px solid var(--lord-border);
    padding: 28px 0;
}
.lord-trust__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
.lord-trust__item {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}
.lord-trust__icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: var(--lord-accent-soft);
    color: var(--lord-accent-hover);
}
.lord-trust__icon svg { width: 22px; height: 22px; }
.lord-trust__body { min-width: 0; }
.lord-trust__title {
    font-weight: 700;
    font-size: 14.5px;
    letter-spacing: -0.005em;
    color: var(--lord-text);
    line-height: 1.2;
}
.lord-trust__desc {
    font-size: 13px;
    color: var(--lord-text-soft);
    margin-top: 2px;
    line-height: 1.35;
}

@media (max-width: 900px) {
    .lord-trust__inner { grid-template-columns: repeat(2, 1fr); gap: 18px; }
}
@media (max-width: 480px) {
    .lord-trust__inner { grid-template-columns: 1fr; }
}

/* =========================================================
   9. Section "Acheter en confiance" (3 piliers détaillés)
   ========================================================= */
.lord-section__head--center {
    justify-content: center;
    text-align: center;
}
.lord-section__head--center > div { max-width: 640px; }

.lord-engagement__grid {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.lord-pillar {
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    transition: transform .25s var(--lord-ease), box-shadow .25s var(--lord-ease), border-color .25s var(--lord-ease);
}
.lord-pillar:hover {
    transform: translateY(-2px);
    box-shadow: var(--lord-shadow-md);
    border-color: transparent;
}
.lord-pillar__title {
    font-size: 19px;
    line-height: 1.25;
    letter-spacing: -0.015em;
    font-weight: 700;
    margin: 0;
    color: var(--lord-text);
}
.lord-pillar__text {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0;
}

/* Visuel des piliers — illustrations CSS, légères, dans l'esprit du site */
.lord-pillar__visual {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: var(--lord-radius-md);
    background: linear-gradient(160deg, var(--lord-surface-2) 0%, #ECECF4 100%);
    overflow: hidden;
}
.lord-pillar__chip {
    position: absolute;
    top: 12px;
    left: 12px;
    background: rgba(22,22,26,.86);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 5px 9px;
    border-radius: 6px;
    z-index: 5;
    backdrop-filter: blur(6px);
}

/* Visuel 1 — photo réelle (faux cadre photo) */
.lord-pillar__visual--photo {
    background:
        radial-gradient(circle at 30% 30%, #6366F1 0%, #4338CA 40%, #1E1B4B 90%);
}
.lord-pillar__visual--photo::before {
    content: "";
    position: absolute;
    inset: 18% 30%;
    border-radius: 8px;
    background:
        repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 8px, rgba(255,255,255,0) 8px 16px),
        linear-gradient(160deg, #ffffff 0%, #e5e7f5 100%);
    box-shadow: 0 14px 30px rgba(0,0,0,.25);
    transform: rotate(-3deg);
}
.lord-pillar__visual--photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
    mix-blend-mode: overlay;
}

/* Visuel 2 — pile d'emballage (carte > sleeve > toploader > mailer) */
.lord-pillar__visual--pack {
    background: linear-gradient(160deg, #F4F4F6 0%, #E5E7EB 100%);
}
.lord-pillar__visual--pack > span:not(.lord-pillar__chip) {
    position: absolute;
    left: 50%;
    top: 50%;
    border-radius: 10px;
    transform-origin: center;
    box-shadow: var(--lord-shadow-sm);
}
.lord-pillar__pack-mailer {
    width: 70%;
    aspect-ratio: 1.6 / 1;
    background: linear-gradient(160deg, #c2c4cc, #9ca0aa);
    transform: translate(-50%, -50%) rotate(-6deg);
    z-index: 1;
}
.lord-pillar__pack-top {
    width: 38%;
    aspect-ratio: 5 / 7;
    background: linear-gradient(160deg, rgba(255,255,255,.92), rgba(220,225,235,.92));
    border: 1px solid rgba(0,0,0,.06);
    transform: translate(-58%, -52%) rotate(-3deg);
    z-index: 2;
}
.lord-pillar__pack-sleeve {
    width: 28%;
    aspect-ratio: 5 / 7;
    background: linear-gradient(160deg, #fff, #f0f1f4);
    border: 1px solid rgba(0,0,0,.05);
    transform: translate(-48%, -48%) rotate(2deg);
    z-index: 3;
}
.lord-pillar__pack-card {
    width: 22%;
    aspect-ratio: 5 / 7;
    background: linear-gradient(160deg, #1E1B4B 0%, #4338CA 70%, #EC4899 100%);
    transform: translate(-44%, -45%) rotate(5deg);
    z-index: 4;
    overflow: hidden;
}
.lord-pillar__pack-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .35;
    border-radius: inherit;
}

/* Visuel 3 — SAV (bulle de chat) */
.lord-pillar__visual--support {
    background: radial-gradient(120% 80% at 30% 20%, #10B981 0%, #047857 60%, #064E3B 100%);
}
.lord-pillar__visual--support::before {
    content: "";
    position: absolute;
    width: 130%;
    height: 130%;
    left: -15%;
    top: -15%;
    background: radial-gradient(closest-side, rgba(255,255,255,.15), transparent 60%);
}
.lord-pillar__chat {
    position: absolute;
    width: 38%;
    height: auto;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) rotate(-6deg);
    color: rgba(255,255,255,.95);
    filter: drop-shadow(0 8px 18px rgba(0,0,0,.25));
}

@media (max-width: 900px) {
    .lord-engagement__grid { grid-template-columns: 1fr; }
    .lord-pillar__visual { aspect-ratio: 21 / 9; }
}

/* =========================================================
   10. Page Séries Pokémon TCG
   ========================================================= */
.lord-page-head {
    position: relative;
    padding: 64px 0 32px;
    overflow: hidden;
}
.lord-page-head::before {
    content: "";
    position: absolute;
    right: -200px;
    top: -100px;
    width: 700px;
    height: 700px;
    background: radial-gradient(closest-side, rgba(99,102,241,.14), transparent 70%);
    z-index: 0;
    pointer-events: none;
}
.lord-page-head__inner {
    position: relative;
    z-index: 1;
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
}
.lord-page-head__title {
    font-size: clamp(34px, 5vw, 60px);
    line-height: 1.04;
    letter-spacing: -0.035em;
    font-weight: 800;
    margin: 18px 0 18px;
    color: var(--lord-text);
}
.lord-page-head__title em {
    font-style: normal;
    background: linear-gradient(120deg, #6366F1 0%, #A855F7 45%, #EC4899 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.lord-page-head__lead {
    max-width: 640px;
    font-size: 17px;
    line-height: 1.6;
    color: var(--lord-text-soft);
    margin: 0;
}

.lord-series-grid {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}

.lord-series-card {
    display: flex;
    flex-direction: column;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    overflow: hidden;
    color: var(--lord-text);
    isolation: isolate;
    transition: transform .25s var(--lord-ease), box-shadow .25s var(--lord-ease), border-color .25s var(--lord-ease);
}
.lord-series-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--lord-shadow-md);
    border-color: transparent;
}

.lord-series-card__cover {
    position: relative;
    aspect-ratio: 16 / 10;
    background:
        radial-gradient(120% 90% at 20% 0%, rgba(255,255,255,.18) 0%, transparent 55%),
        linear-gradient(135deg, var(--from) 0%, var(--to) 100%);
    color: #fff;
    overflow: hidden;
    display: grid;
    place-items: center;
    text-align: center;
    padding: 22px;
    transition: transform .35s var(--lord-ease);
}
.lord-series-card:hover .lord-series-card__cover {
    transform: scale(1.015);
}
.lord-series-card--light .lord-series-card__cover { color: #16161A; }

/* Variante carte avec assets officiels : bg image + logo image centré */
.lord-series-card--real .lord-series-card__cover {
    background:
        linear-gradient(180deg, rgba(0,0,0,.12) 0%, rgba(0,0,0,.28) 60%, rgba(0,0,0,.5) 100%),
        var(--series-bg, linear-gradient(135deg, var(--from) 0%, var(--to) 100%)) center/cover no-repeat,
        linear-gradient(135deg, var(--from) 0%, var(--to) 100%);
}
.lord-series-card__logo {
    position: relative;
    z-index: 2;
    max-width: 78%;
    max-height: 70%;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 6px 16px rgba(0,0,0,.45));
}

.lord-series-card__noise {
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 1px 1px, rgba(255,255,255,.18) 1px, transparent 0);
    background-size: 14px 14px;
    mix-blend-mode: overlay;
    opacity: .35;
    pointer-events: none;
}

.lord-series-card__wordmark {
    position: relative;
    z-index: 1;
    font-size: clamp(22px, 2.4vw, 30px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.025em;
    text-transform: uppercase;
    max-width: 90%;
    text-shadow: 0 4px 18px rgba(0,0,0,.25);
}
.lord-series-card--light .lord-series-card__wordmark { text-shadow: none; }

.lord-series-card__sub-wordmark {
    position: relative;
    z-index: 1;
    font-size: 11px;
    letter-spacing: .25em;
    font-weight: 700;
    margin-top: 8px;
    opacity: .75;
    text-transform: uppercase;
}

.lord-series-card__year-tag {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .08em;
    padding: 5px 9px;
    border-radius: 6px;
    background: rgba(0,0,0,.32);
    color: #fff;
    backdrop-filter: blur(6px);
}
.lord-series-card--light .lord-series-card__year-tag {
    background: rgba(255,255,255,.7);
    color: #16161A;
}

.lord-series-card__badge {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 5px 9px;
    border-radius: 6px;
    background: #fff;
    color: var(--lord-text);
    box-shadow: 0 6px 14px rgba(0,0,0,.18);
}

.lord-series-card__body {
    padding: 16px 18px 18px;
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 12px;
}
.lord-series-card__meta {
    font-size: 13px;
    color: var(--lord-text-soft);
    font-weight: 600;
}
.lord-series-card__count {
    font-size: 13.5px;
    font-weight: 700;
    color: var(--lord-text);
}
.lord-series-card__arrow {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: var(--lord-surface-2);
    color: var(--lord-text);
    transition: background .2s var(--lord-ease), color .2s var(--lord-ease), transform .2s var(--lord-ease);
}
.lord-series-card:hover .lord-series-card__arrow {
    background: var(--lord-text);
    color: #fff;
    transform: translateX(2px);
}

.lord-page-content {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 24px;
    font-size: 16px;
    line-height: 1.7;
    color: var(--lord-text-soft);
}
.lord-page-content h2, .lord-page-content h3 { color: var(--lord-text); }

/* ----------- Bloc-détail : entête + grille extensions ----------- */
.lord-bloc-head {
    position: relative;
    background: linear-gradient(135deg, var(--from, #1E1B4B) 0%, var(--to, #6366F1) 100%);
    color: #fff;
    padding: 56px 0 72px;
    overflow: hidden;
}
.lord-bloc-head--bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--bloc-bg);
    background-size: cover;
    background-position: center;
    opacity: .55;
    z-index: 0;
}
.lord-bloc-head::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.4) 100%);
    z-index: 0;
}
.lord-bloc-head__inner {
    position: relative;
    z-index: 1;
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    text-align: center;
}
.lord-bloc-head__crumbs {
    align-self: flex-start;
    font-size: 13.5px;
    margin-bottom: 8px;
}
.lord-bloc-head__crumbs a {
    color: rgba(255,255,255,.78);
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    transition: background .2s var(--lord-ease);
}
.lord-bloc-head__crumbs a:hover { background: rgba(255,255,255,.18); }

.lord-bloc-head__logo {
    max-width: min(440px, 80%);
    max-height: 180px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 10px 24px rgba(0,0,0,.45));
    margin: 8px 0;
}
.lord-bloc-head__title-fallback {
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.025em;
    color: #fff;
    text-shadow: 0 4px 18px rgba(0,0,0,.35);
    margin: 0;
}
.lord-bloc-head__meta {
    margin: 0;
    font-size: 14px;
    color: rgba(255,255,255,.85);
    font-weight: 600;
    letter-spacing: .02em;
    text-transform: uppercase;
}

/* Grille extensions */
.lord-ext-grid {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 20px;
}

.lord-ext-card {
    display: flex;
    flex-direction: column;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    overflow: hidden;
    color: var(--lord-text);
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease), border-color .2s var(--lord-ease);
}
.lord-ext-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--lord-shadow-md);
    border-color: transparent;
}
.lord-ext-card__cover {
    position: relative;
    aspect-ratio: 16 / 9;
    background:
        linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.35) 100%),
        var(--ext-bg, linear-gradient(135deg, #1E1B4B 0%, #6366F1 100%)) center/cover no-repeat,
        var(--lord-surface-2);
    display: grid;
    place-items: center;
    overflow: hidden;
}
.lord-ext-card__logo {
    position: relative;
    z-index: 1;
    max-width: 78%;
    max-height: 72%;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 6px 14px rgba(0,0,0,.45));
}
.lord-ext-card__body {
    padding: 12px 14px 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.lord-ext-card__name {
    font-size: 14px;
    font-weight: 700;
    color: var(--lord-text);
    letter-spacing: -0.01em;
}
.lord-ext-card__count {
    font-size: 12px;
    font-weight: 600;
    color: var(--lord-text-soft);
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--lord-surface-2);
}
.lord-ext-card__count--soon {
    background: transparent;
    color: var(--lord-text-mute);
    font-style: italic;
}
.lord-ext-card--empty { opacity: .78; }
.lord-ext-card--empty:hover { opacity: 1; }

@media (max-width: 720px) {
    .lord-series-card__body { grid-template-columns: 1fr auto; }
    .lord-series-card__count { grid-column: 1 / 2; grid-row: 2; }
    .lord-series-card__arrow { grid-row: 1 / 3; }
}

/* =========================================================
   11. Footer enrichi
   ========================================================= */
.lord-footer {
    background: var(--lord-text);
    color: rgba(255,255,255,.7);
    padding: 64px 0 28px;
    margin-top: 80px;
}
.lord-footer__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.lord-footer__top {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
    gap: 32px;
}
.lord-footer__brand-col { display: flex; flex-direction: column; gap: 14px; max-width: 380px; }
.lord-footer__brand {
    color: #fff;
    font-weight: 800;
    font-size: 22px;
    letter-spacing: -0.02em;
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.lord-footer__brand-mark {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--lord-accent);
    color: #fff;
    display: inline-grid;
    place-items: center;
    font-size: 14px;
    font-weight: 800;
    position: relative;
    overflow: hidden;
}
.lord-footer__brand-mark::after {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--lord-holo);
    mix-blend-mode: color-dodge;
    opacity: .45;
}
.lord-footer__tagline { font-size: 14px; line-height: 1.55; color: rgba(255,255,255,.62); margin: 0; }

.lord-footer__col-title {
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin: 0 0 14px;
}
.lord-footer__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.lord-footer__list a {
    color: rgba(255,255,255,.72);
    font-size: 14px;
    transition: color .2s var(--lord-ease);
}
.lord-footer__list a:hover { color: #fff; }

.lord-footer__pay {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 24px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.lord-footer__pay-label {
    font-size: 12.5px;
    color: rgba(255,255,255,.5);
    margin-right: 4px;
}
.lord-footer__pay-list {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.lord-footer__pay-item {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.08);
    color: rgba(255,255,255,.9);
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 5px 10px;
    border-radius: 6px;
}

.lord-footer__credit {
    font-size: 12.5px;
    color: rgba(255,255,255,.45);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

@media (max-width: 900px) {
    .lord-footer__top { grid-template-columns: 1fr 1fr; }
    .lord-footer__brand-col { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
    .lord-footer__top { grid-template-columns: 1fr; }
}

/* ============================================================
   ARTICLE — Single post layout & typography (LordTCG)
   ============================================================ */

.lord-article {
    --article-width: 740px;
    --aside-width: 260px;
    --gutter: 56px;
    color: var(--lord-text);
}

/* ---------- Hero ---------- */
.lord-article__head {
    position: relative;
    padding: 56px 24px 48px;
    background:
        radial-gradient(1200px 400px at 80% -10%, rgba(99,102,241,.10), transparent 60%),
        radial-gradient(900px 360px at 10% 0%, rgba(99,102,241,.06), transparent 60%),
        var(--lord-surface);
    border-bottom: 1px solid var(--lord-border);
    margin-bottom: 48px;
}
.lord-article__head-inner {
    max-width: 880px;
    margin: 0 auto;
}
.lord-article__breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-size: 13px;
    color: var(--lord-text-soft);
    margin-bottom: 24px;
}
.lord-article__breadcrumb a {
    color: var(--lord-text-soft);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color .2s var(--lord-ease), border-color .2s var(--lord-ease);
}
.lord-article__breadcrumb a:hover {
    color: var(--lord-text);
    border-bottom-color: var(--lord-text);
}
.lord-article__breadcrumb span { opacity: .5; }

.lord-article__category {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--lord-accent-soft);
    color: var(--lord-accent-deep);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .02em;
    text-decoration: none;
    text-transform: uppercase;
    margin-bottom: 20px;
    transition: background .2s var(--lord-ease);
}
.lord-article__category:hover {
    background: var(--lord-accent);
    color: #fff;
}

.lord-article__title {
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--lord-text);
    margin: 0 0 20px;
}
.lord-article__lead {
    font-size: 18px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0 0 28px;
    max-width: 720px;
}
.lord-article__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    font-size: 13px;
    color: var(--lord-text-soft);
}
.lord-article__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.lord-article__meta-item svg {
    opacity: .7;
}

/* ---------- Layout 2 colonnes ---------- */
.lord-article__layout {
    max-width: calc(var(--article-width) + var(--aside-width) + var(--gutter));
    margin: 0 auto;
    padding: 0 24px 80px;
    display: grid;
    grid-template-columns: var(--aside-width) 1fr;
    gap: var(--gutter);
    align-items: start;
}
.lord-article__aside {
    position: sticky;
    top: calc(var(--lord-header-stack) + 24px);
}
.lord-article__body {
    min-width: 0;
}

/* ---------- TOC (sommaire) ---------- */
.lord-article__toc {
    padding: 20px 18px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    box-shadow: var(--lord-shadow-xs);
}
.lord-article__toc-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--lord-text-mute);
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--lord-border-soft);
}
.lord-article__toc-list {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: lord-toc;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.lord-article__toc-list li { margin: 0; }
.lord-article__toc-list a {
    display: flex;
    gap: 10px;
    padding: 8px 10px;
    border-radius: var(--lord-radius-sm);
    font-size: 13.5px;
    line-height: 1.4;
    color: var(--lord-text-soft);
    text-decoration: none;
    transition: background .2s var(--lord-ease), color .2s var(--lord-ease);
}
.lord-article__toc-list a:hover {
    background: var(--lord-accent-soft);
    color: var(--lord-accent-deep);
}
.lord-article__toc-num {
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    color: var(--lord-text-mute);
    font-size: 12px;
    padding-top: 1px;
}
.lord-article__toc-list a:hover .lord-article__toc-num {
    color: var(--lord-accent);
}

/* ---------- Contenu typographique ---------- */
.lord-article__content {
    font-size: 16.5px;
    line-height: 1.72;
    color: var(--lord-text);
}
.lord-article__content > * + * { margin-top: 1.1em; }
.lord-article__content p { margin: 0 0 1.1em; }
.lord-article__content p:last-child { margin-bottom: 0; }

/* Headings */
.lord-article__content h2 {
    position: relative;
    font-size: clamp(22px, 2.6vw, 28px);
    line-height: 1.25;
    font-weight: 800;
    letter-spacing: -0.015em;
    margin: 2.5em 0 .8em;
    padding-top: .3em;
    color: var(--lord-text);
    scroll-margin-top: calc(var(--lord-header-stack) + 24px);
}
.lord-article__content h2::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 36px;
    height: 3px;
    background: var(--lord-accent);
    border-radius: 2px;
}
.lord-article__content h3 {
    font-size: clamp(18px, 2vw, 21px);
    line-height: 1.3;
    font-weight: 700;
    margin: 2em 0 .6em;
    color: var(--lord-text);
    scroll-margin-top: calc(var(--lord-header-stack) + 24px);
}
.lord-article__content h4 {
    font-size: 16.5px;
    font-weight: 700;
    margin: 1.6em 0 .5em;
    color: var(--lord-text);
}

/* Strong / em */
.lord-article__content strong { color: var(--lord-text); font-weight: 700; }
.lord-article__content em { font-style: italic; color: var(--lord-text); }

/* Links */
.lord-article__content a {
    color: var(--lord-accent);
    text-decoration: none;
    background-image: linear-gradient(currentColor, currentColor);
    background-position: 0 100%;
    background-repeat: no-repeat;
    background-size: 100% 1px;
    transition: color .2s var(--lord-ease), background-size .2s var(--lord-ease);
    word-break: break-word;
}
.lord-article__content a:hover {
    color: var(--lord-accent-hover);
    background-size: 100% 2px;
}

/* Lists */
.lord-article__content ul,
.lord-article__content ol {
    margin: 0 0 1.2em;
    padding-left: 1.5em;
}
.lord-article__content ul { list-style: none; padding-left: 0; }
.lord-article__content ul > li {
    position: relative;
    padding-left: 1.5em;
    margin-bottom: .5em;
}
.lord-article__content ul > li::before {
    content: "";
    position: absolute;
    left: .1em;
    top: .75em;
    width: 6px;
    height: 6px;
    background: var(--lord-accent);
    border-radius: 50%;
}
.lord-article__content ol > li { margin-bottom: .5em; padding-left: .3em; }
.lord-article__content ol > li::marker {
    color: var(--lord-accent);
    font-weight: 700;
}
.lord-article__content li > ul,
.lord-article__content li > ol { margin-top: .5em; }

/* Tables */
.lord-article__content table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    overflow: hidden;
    margin: 1.8em 0;
    font-size: 14.5px;
    box-shadow: var(--lord-shadow-xs);
}
.lord-article__content table thead {
    background: var(--lord-surface-2);
}
.lord-article__content table th {
    text-align: left;
    font-weight: 700;
    font-size: 12px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--lord-text-soft);
    padding: 14px 16px;
    border-bottom: 1px solid var(--lord-border);
}
.lord-article__content table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--lord-border-soft);
    vertical-align: top;
    color: var(--lord-text);
}
.lord-article__content table tr:last-child td { border-bottom: none; }
.lord-article__content table tbody tr:nth-child(even) {
    background: rgba(244,244,246,.4);
}
.lord-article__content table tbody tr:hover {
    background: var(--lord-accent-soft);
}
.lord-article__content table strong { color: var(--lord-text); }
.lord-article__content table td:first-child {
    font-weight: 600;
    color: var(--lord-text);
}
/* Tables responsive : scroll horizontal sur mobile */
.lord-article__content table {
    display: block;
    overflow-x: auto;
}
@media (min-width: 768px) {
    .lord-article__content table {
        display: table;
        overflow-x: visible;
    }
}

/* Blockquotes */
.lord-article__content blockquote {
    margin: 1.6em 0;
    padding: 16px 22px;
    border-left: 3px solid var(--lord-accent);
    background: var(--lord-accent-soft);
    border-radius: 0 var(--lord-radius-md) var(--lord-radius-md) 0;
    color: var(--lord-text);
    font-style: normal;
}
.lord-article__content blockquote p { margin: 0; }
.lord-article__content blockquote p + p { margin-top: .6em; }

/* Encart CTA inline (.lord-cta) — produit par les agents */
.lord-article__content .lord-cta {
    position: relative;
    margin: 2em 0;
    padding: 22px 24px;
    background: linear-gradient(135deg, var(--lord-accent-soft) 0%, #fff 100%);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    box-shadow: var(--lord-shadow-sm);
    overflow: hidden;
}
.lord-article__content .lord-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--lord-accent);
}
.lord-article__content .lord-cta p { margin: 0; }
.lord-article__content .lord-cta p + p { margin-top: .6em; }
.lord-article__content .lord-cta strong {
    display: block;
    font-size: 17px;
    margin-bottom: .3em;
}
.lord-article__content .lord-cta a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: .8em;
    padding: 10px 18px;
    background: var(--lord-accent);
    color: #fff;
    font-weight: 600;
    border-radius: 999px;
    text-decoration: none;
    background-image: none;
    transition: background .2s var(--lord-ease), transform .2s var(--lord-ease);
}
.lord-article__content .lord-cta a:hover {
    background: var(--lord-accent-hover);
    transform: translateY(-1px);
}

/* Code inline (au cas où) */
.lord-article__content code {
    background: var(--lord-surface-2);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: .92em;
    color: var(--lord-text);
}

/* Images */
.lord-article__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--lord-radius-md);
    margin: 1.5em 0;
}

/* HR */
.lord-article__content hr {
    margin: 2.4em 0;
    border: 0;
    height: 1px;
    background: var(--lord-border);
}

/* ---------- CTA fin d'article ---------- */
.lord-article__end-cta {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 20px;
    align-items: center;
    margin: 56px 0 0;
    padding: 28px 28px;
    background: linear-gradient(135deg, #312E81 0%, #6366F1 100%);
    color: #fff;
    border-radius: var(--lord-radius-lg);
    box-shadow: var(--lord-shadow-md);
}
.lord-article__end-cta-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255,255,255,.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}
.lord-article__end-cta-title {
    font-size: 20px;
    font-weight: 800;
    margin: 0 0 6px;
    color: #fff;
    letter-spacing: -0.01em;
}
.lord-article__end-cta-text {
    font-size: 14.5px;
    line-height: 1.5;
    color: rgba(255,255,255,.85);
    margin: 0;
}
.lord-article__end-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 22px;
    background: #fff;
    color: var(--lord-accent-deep);
    font-weight: 700;
    border-radius: 999px;
    text-decoration: none;
    white-space: nowrap;
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
}
.lord-article__end-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0,0,0,.2);
}

/* ---------- Articles liés ---------- */
.lord-article__related {
    margin-top: 64px;
    padding-top: 40px;
    border-top: 1px solid var(--lord-border);
}
.lord-article__related-title {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 0 0 24px;
}
.lord-article__related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.lord-article__related-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 22px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    text-decoration: none;
    color: var(--lord-text);
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease), border-color .2s var(--lord-ease);
}
.lord-article__related-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--lord-shadow-md);
    border-color: transparent;
}
.lord-article__related-tag {
    align-self: flex-start;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--lord-accent);
}
.lord-article__related-card-title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.35;
    margin: 0;
    flex: 1;
    color: var(--lord-text);
}
.lord-article__related-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    font-size: 13px;
    color: var(--lord-text-soft);
}
.lord-article__related-card-arrow {
    color: var(--lord-accent);
    font-weight: 700;
    transition: transform .2s var(--lord-ease);
}
.lord-article__related-card:hover .lord-article__related-card-arrow {
    transform: translateX(4px);
}

/* ---------- Layout no-sidebar pour single posts ---------- */
body.lord-single-post #primary,
body.lord-single-post .content-area {
    width: 100%;
    max-width: none;
    float: none;
    margin: 0;
    padding: 0;
}
body.lord-single-post .col-full {
    max-width: none;
    padding: 0;
}
body.lord-single-post .storefront-breadcrumb { display: none; }

/* Cache l'éventuel "Laisser un commentaire" / footer post Storefront */
body.lord-single-post .entry-header,
body.lord-single-post .entry-footer,
body.lord-single-post #comments,
body.lord-single-post .post-navigation { display: none; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
    .lord-article__layout {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .lord-article__aside {
        position: static;
        order: -1;
    }
    .lord-article__toc {
        padding: 16px 14px;
    }
}
@media (max-width: 720px) {
    .lord-article__head { padding: 40px 20px 36px; }
    .lord-article__layout { padding: 0 20px 56px; }
    .lord-article__end-cta {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 24px 20px;
    }
    .lord-article__end-cta-icon { margin: 0 auto; }
    .lord-article__end-cta-btn { justify-self: center; }
    .lord-article__related-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   PRODUIT — Variations en boutons (au lieu du dropdown WC)
   ============================================================ */
.lord-variation-buttons {
    display: inline-flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 0;
}
.lord-variation-btn {
    background: var(--lord-surface);
    border: 1.5px solid var(--lord-border);
    color: var(--lord-text);
    padding: 9px 18px;
    border-radius: 999px;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s var(--lord-ease), border-color .15s var(--lord-ease), color .15s var(--lord-ease), transform .15s var(--lord-ease);
    line-height: 1;
}
.lord-variation-btn:hover {
    border-color: var(--lord-accent);
    color: var(--lord-accent);
}
.lord-variation-btn.is-selected {
    background: var(--lord-text);
    border-color: var(--lord-text);
    color: #fff;
}
.lord-variation-btn:focus-visible {
    outline: 2px solid var(--lord-accent);
    outline-offset: 2px;
}
/* Hide the now-superfluous "Effacer" reset link & the select itself */
.variations .reset_variations { display: none; }
.lord-variation-select { display: none !important; }
/* Le label TH "Version" reste mais on lui donne un style propre */
.variations th.label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--lord-text-soft);
    font-weight: 700;
    padding: 14px 0 8px;
}
.variations td.value { padding: 0 0 14px; }

/* ============================================================
   BLOG — Landing /blog/ + archives catégorie
   ============================================================ */

/* ---------- Layout : retirer la sidebar Storefront ---------- */
body.blog #primary,
body.blog .content-area,
body.archive #primary,
body.archive .content-area {
    width: 100%;
    max-width: none;
    float: none;
}
body.blog .col-full,
body.archive .col-full { max-width: none; padding: 0; }
body.blog .storefront-breadcrumb,
body.archive .storefront-breadcrumb { display: none; }

/* ---------- Hero ---------- */
.lord-blog-hero {
    position: relative;
    padding: 64px 24px 56px;
    background:
        radial-gradient(1200px 400px at 80% -10%, rgba(99,102,241,.10), transparent 60%),
        radial-gradient(900px 360px at 10% 0%, rgba(99,102,241,.06), transparent 60%),
        var(--lord-surface);
    border-bottom: 1px solid var(--lord-border);
}
.lord-blog-hero__inner {
    max-width: 880px;
    margin: 0 auto;
    text-align: left;
}
.lord-blog-hero__title {
    font-size: clamp(32px, 4.4vw, 48px);
    line-height: 1.1;
    font-weight: 800;
    letter-spacing: -0.025em;
    color: var(--lord-text);
    margin: 16px 0 18px;
}
.lord-blog-hero__title em {
    font-style: normal;
    background: linear-gradient(135deg, var(--lord-accent), #A78BFA);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.lord-blog-hero__lead {
    font-size: 18px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    max-width: 680px;
    margin: 0;
}

/* ---------- Filtres catégorie (chips) ---------- */
.lord-blog-filters {
    background: var(--lord-bg);
    border-bottom: 1px solid var(--lord-border);
    padding: 16px 24px;
}
.lord-blog-filters__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.lord-blog-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--lord-text-soft);
    text-decoration: none;
    transition: background .15s var(--lord-ease), color .15s var(--lord-ease), border-color .15s var(--lord-ease);
}
.lord-blog-chip:hover {
    border-color: var(--lord-accent);
    color: var(--lord-accent);
}
.lord-blog-chip.is-active {
    background: var(--lord-text);
    border-color: var(--lord-text);
    color: #fff;
}
.lord-blog-chip__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 20px;
    padding: 0 7px;
    background: var(--lord-surface-2);
    color: var(--lord-text-soft);
    font-size: 11px;
    font-weight: 700;
    border-radius: 999px;
}
.lord-blog-chip.is-active .lord-blog-chip__count {
    background: rgba(255,255,255,.18);
    color: #fff;
}

/* ---------- Section principale ---------- */
.lord-blog {
    padding: 56px 24px 80px;
    background: var(--lord-bg);
}
.lord-blog__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
}

/* ---------- Featured article ---------- */
.lord-blog-featured {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-xl);
    overflow: hidden;
    margin-bottom: 48px;
    box-shadow: var(--lord-shadow-sm);
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
}
.lord-blog-featured:hover { transform: translateY(-2px); box-shadow: var(--lord-shadow-md); }
.lord-blog-featured__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: linear-gradient(135deg, #312E81 0%, #6366F1 50%, #A78BFA 100%);
}
.lord-blog-featured__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.lord-blog-featured__placeholder {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 20% 30%, rgba(255,255,255,.15), transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(255,255,255,.1), transparent 50%),
        linear-gradient(135deg, #312E81 0%, #6366F1 100%);
}
.lord-blog-featured__placeholder-mark {
    font-size: 96px;
    font-weight: 800;
    color: rgba(255,255,255,.25);
    letter-spacing: -0.05em;
}
.lord-blog-featured__body {
    padding: 40px 40px 40px 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
}
.lord-blog-featured__tag {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    background: var(--lord-text);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    border-radius: 999px;
}
.lord-blog-featured__title {
    font-size: clamp(22px, 2.6vw, 30px);
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0;
}
.lord-blog-featured__title a {
    color: var(--lord-text);
    text-decoration: none;
    transition: color .15s var(--lord-ease);
}
.lord-blog-featured__title a:hover { color: var(--lord-accent); }
.lord-blog-featured__excerpt {
    font-size: 16px;
    line-height: 1.6;
    color: var(--lord-text-soft);
    margin: 0;
}
.lord-blog-featured__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
    padding: 12px 22px;
    background: var(--lord-text);
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    border-radius: 999px;
    text-decoration: none;
    transition: background .15s var(--lord-ease), transform .15s var(--lord-ease);
}
.lord-blog-featured__cta:hover {
    background: var(--lord-accent);
    transform: translateY(-1px);
}

/* ---------- Grille cards ---------- */
.lord-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    margin-bottom: 56px;
}
.lord-blog-card {
    position: relative;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease), border-color .2s var(--lord-ease);
}
.lord-blog-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--lord-shadow-md);
    border-color: transparent;
}
.lord-blog-card__link {
    position: absolute;
    inset: 0;
    z-index: 1;
}
.lord-blog-card__media {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--lord-surface-2);
}
.lord-blog-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s var(--lord-ease);
}
.lord-blog-card:hover .lord-blog-card__img { transform: scale(1.04); }
.lord-blog-card__placeholder {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.12), transparent 55%),
        linear-gradient(135deg, var(--lord-accent-deep) 0%, var(--lord-accent) 100%);
}
.lord-blog-card__placeholder-mark {
    font-size: 64px;
    font-weight: 800;
    color: rgba(255,255,255,.25);
    letter-spacing: -0.04em;
    text-transform: uppercase;
}
.lord-blog-card__body {
    padding: 22px 22px 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}
.lord-blog-card__cat {
    align-self: flex-start;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--lord-accent);
    text-decoration: none;
    position: relative;
    z-index: 2;
}
.lord-blog-card__cat:hover { color: var(--lord-accent-deep); }
.lord-blog-card__cat--static { pointer-events: none; }
.lord-blog-card__title {
    font-size: 18px;
    line-height: 1.3;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--lord-text);
    margin: 0;
}
.lord-blog-card__excerpt {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.lord-blog-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12.5px;
    color: var(--lord-text-mute);
    margin-top: auto;
    padding-top: 6px;
}

/* ---------- Pagination ---------- */
.lord-blog-pagination,
nav.pagination,
.woocommerce-pagination {
    display: flex;
    justify-content: center;
    margin-top: 16px;
}
.lord-blog-pagination .nav-links,
nav.pagination .nav-links {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.lord-blog-pagination a,
.lord-blog-pagination span.current,
.lord-blog-pagination span.dots,
nav.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 14px;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: 999px;
    color: var(--lord-text);
    font-size: 13.5px;
    font-weight: 600;
    text-decoration: none;
    transition: background .15s var(--lord-ease), color .15s var(--lord-ease), border-color .15s var(--lord-ease);
}
.lord-blog-pagination a:hover,
nav.pagination .page-numbers:hover {
    border-color: var(--lord-accent);
    color: var(--lord-accent);
}
.lord-blog-pagination .current,
nav.pagination .current {
    background: var(--lord-text);
    border-color: var(--lord-text);
    color: #fff;
}

/* ---------- Empty state ---------- */
.lord-blog-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--lord-text-soft);
    font-size: 16px;
}

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
    .lord-blog-featured { grid-template-columns: 1fr; gap: 0; }
    .lord-blog-featured__body { padding: 30px 28px 32px; }
    .lord-blog-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 640px) {
    .lord-blog-hero { padding: 48px 20px 40px; }
    .lord-blog { padding: 40px 20px 64px; }
    .lord-blog-grid { grid-template-columns: 1fr; }
    .lord-blog-featured__body { padding: 24px 20px 28px; }
}

/* ============================================================
   RACHAT — Landing /rachat-cartes-pokemon/
   ============================================================ */

/* Layout sans sidebar */
body.page-template-page-rachat-cartes-pokemon-php #primary,
body.page-template-page-rachat-cartes-pokemon-php .content-area,
body.page-id-754 #primary,
body.page-id-754 .content-area {
    width: 100%;
    max-width: none;
    float: none;
}
body.page-id-754 .col-full { max-width: none; padding: 0; }
body.page-id-754 .storefront-breadcrumb,
body.page-id-754 .entry-header,
body.page-id-754 .entry-footer { display: none; }

.lord-rachat { color: var(--lord-text); }

/* ---------- HERO ---------- */
.lord-rachat-hero {
    position: relative;
    padding: 80px 24px 72px;
    background:
        radial-gradient(900px 500px at 85% -10%, rgba(99,102,241,.20), transparent 60%),
        radial-gradient(700px 400px at 15% 0%, rgba(167,139,250,.12), transparent 60%),
        linear-gradient(180deg, var(--lord-surface) 0%, var(--lord-bg) 100%);
    border-bottom: 1px solid var(--lord-border);
    overflow: hidden;
}
.lord-rachat-hero__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 60px;
    align-items: center;
}
.lord-rachat-hero__title {
    font-size: clamp(34px, 5vw, 56px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.025em;
    margin: 14px 0 22px;
    color: var(--lord-text);
}
.lord-rachat-hero__title em {
    font-style: normal;
    background: linear-gradient(135deg, var(--lord-accent), #A78BFA 60%, #F472B6);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.lord-rachat-hero__lead {
    font-size: 19px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    max-width: 540px;
    margin: 0 0 32px;
}
.lord-rachat-hero__ctas {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* Visual cards stack */
.lord-rachat-hero__visual {
    position: relative;
    height: 360px;
}
.lord-rachat-hero__card {
    position: absolute;
    width: 200px;
    height: 280px;
    border-radius: var(--lord-radius-lg);
    box-shadow: 0 20px 50px rgba(16,16,26,.18);
    background-size: cover;
    background-position: center;
}
.lord-rachat-hero__card--1 {
    top: 10px;
    left: 0;
    background: linear-gradient(160deg, #312E81, #6366F1);
    transform: rotate(-9deg);
}
.lord-rachat-hero__card--1::after {
    content: "";
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 14px;
}
.lord-rachat-hero__card--2 {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(160deg, #FBBF24, #DC2626);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    padding: 24px;
    text-align: center;
}
.lord-rachat-hero__card--3 {
    top: 30px;
    right: 0;
    background: linear-gradient(160deg, #0EA5E9, #7C3AED);
    transform: rotate(9deg);
}
.lord-rachat-hero__card--3::after {
    content: "";
    position: absolute;
    inset: 12px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 14px;
}
.lord-rachat-hero__price {
    font-size: 56px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: 8px;
    text-shadow: 0 2px 10px rgba(0,0,0,.2);
}
.lord-rachat-hero__price-label {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    opacity: .85;
}

/* ---------- STATS strip ---------- */
.lord-rachat-stats {
    background: var(--lord-text);
    color: #fff;
    padding: 32px 24px;
}
.lord-rachat-stats__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
}
.lord-rachat-stat {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.lord-rachat-stat__value {
    font-size: 32px;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1;
    background: linear-gradient(135deg, #fff 0%, #A78BFA 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.lord-rachat-stat__label {
    font-size: 13px;
    color: rgba(255,255,255,.7);
    line-height: 1.4;
}

/* ---------- SECTIONS (generic) ---------- */
.lord-rachat-section {
    padding: 80px 24px;
    background: var(--lord-bg);
}
.lord-rachat-section--soft {
    background: var(--lord-surface);
}
.lord-rachat-section__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
}
.lord-rachat-section__head {
    max-width: 720px;
    margin: 0 auto 48px;
    text-align: center;
}
.lord-rachat-section__eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--lord-accent);
    margin-bottom: 12px;
}
.lord-rachat-section__title {
    font-size: clamp(26px, 3.4vw, 36px);
    line-height: 1.15;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0 0 14px;
}
.lord-rachat-section__sub {
    font-size: 17px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0;
}
.lord-rachat-section__note {
    margin-top: 32px;
    padding: 16px 22px;
    background: var(--lord-accent-soft);
    border-left: 3px solid var(--lord-accent);
    border-radius: 0 var(--lord-radius-md) var(--lord-radius-md) 0;
    color: var(--lord-text);
    font-size: 14.5px;
    line-height: 1.5;
}

/* ---------- STEPS ---------- */
.lord-rachat-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    counter-reset: step;
}
.lord-rachat-step {
    position: relative;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    padding: 28px 24px;
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease);
}
.lord-rachat-step:hover {
    transform: translateY(-3px);
    box-shadow: var(--lord-shadow-md);
}
.lord-rachat-step__num {
    display: inline-block;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .1em;
    color: var(--lord-accent);
    margin-bottom: 14px;
}
.lord-rachat-step__title {
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 10px;
}
.lord-rachat-step__text {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0;
}

/* ---------- "Ce qu'on rachète" — pills grid ---------- */
.lord-rachat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}
.lord-rachat-pill {
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    padding: 26px 24px;
    transition: transform .2s var(--lord-ease), box-shadow .2s var(--lord-ease), border-color .2s var(--lord-ease);
}
.lord-rachat-pill:hover {
    transform: translateY(-2px);
    box-shadow: var(--lord-shadow-sm);
    border-color: var(--lord-accent);
}
.lord-rachat-pill__icon {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: var(--lord-accent-soft);
    color: var(--lord-accent);
    margin-bottom: 16px;
}
.lord-rachat-pill__title {
    font-size: 17px;
    font-weight: 700;
    margin: 0 0 8px;
}
.lord-rachat-pill__text {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--lord-text-soft);
    margin: 0;
}

/* ---------- TARIFS ---------- */
.lord-rachat-tarifs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: stretch;
}
.lord-rachat-tarif-card {
    position: relative;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-lg);
    padding: 32px 28px;
    display: flex;
    flex-direction: column;
}
.lord-rachat-tarif-card--featured {
    background: linear-gradient(160deg, #312E81 0%, #6366F1 100%);
    color: #fff;
    border-color: transparent;
    box-shadow: var(--lord-shadow-md);
    transform: scale(1.02);
}
.lord-rachat-tarif-card--featured .lord-rachat-tarif-card__title { color: #fff; }
.lord-rachat-tarif-card--featured .lord-rachat-tarif-card__sub { color: rgba(255,255,255,.75); }
.lord-rachat-tarif-card--featured .lord-rachat-tarif-list { color: #fff; }
.lord-rachat-tarif-card--featured .lord-rachat-tarif-list strong { color: #fff; }
.lord-rachat-tarif-card__badge {
    position: absolute;
    top: -10px;
    left: 28px;
    background: #FBBF24;
    color: #312E81;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 5px 11px;
    border-radius: 999px;
}
.lord-rachat-tarif-card__title {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 0 0 6px;
}
.lord-rachat-tarif-card__sub {
    font-size: 14px;
    color: var(--lord-text-soft);
    margin: 0 0 20px;
}
.lord-rachat-tarif-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}
.lord-rachat-tarif-table th {
    text-align: left;
    font-weight: 500;
    color: var(--lord-text);
    padding: 12px 0;
    border-bottom: 1px solid var(--lord-border-soft);
    font-size: 14.5px;
}
.lord-rachat-tarif-table td {
    text-align: right;
    font-weight: 700;
    color: var(--lord-text);
    padding: 12px 0;
    border-bottom: 1px solid var(--lord-border-soft);
    font-size: 15px;
    white-space: nowrap;
}
.lord-rachat-tarif-table tr:last-child th,
.lord-rachat-tarif-table tr:last-child td { border-bottom: 0; }

.lord-rachat-tarif-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.lord-rachat-tarif-list li {
    font-size: 14.5px;
    line-height: 1.5;
    padding-left: 24px;
    position: relative;
}
.lord-rachat-tarif-list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--lord-accent);
    font-weight: 800;
}
.lord-rachat-tarif-card--featured .lord-rachat-tarif-list li::before {
    color: #FBBF24;
}

/* ---------- FORMULAIRE ---------- */
.lord-rachat-section--form {
    background: linear-gradient(180deg, var(--lord-bg) 0%, var(--lord-surface) 100%);
}
.lord-rachat-form {
    max-width: 880px;
    margin: 0 auto;
    background: var(--lord-surface);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-xl);
    padding: 40px 40px 36px;
    box-shadow: var(--lord-shadow-sm);
}
.lord-rachat-form__hp { display: none !important; }
.lord-rachat-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px 24px;
    margin-bottom: 18px;
}
.lord-rachat-form__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.lord-rachat-form__field--full {
    grid-column: 1 / -1;
    margin-top: 18px;
}
.lord-rachat-form__field--check {
    flex-direction: row;
    align-items: flex-start;
    gap: 10px;
}
.lord-rachat-form__field label {
    font-size: 13px;
    font-weight: 600;
    color: var(--lord-text);
    letter-spacing: -0.005em;
}
.lord-rachat-form__field label span[aria-hidden] {
    color: var(--lord-danger);
    margin-left: 2px;
}
.lord-rachat-form__opt {
    color: var(--lord-text-mute);
    font-weight: 400;
}
.lord-rachat-form__field input[type="text"],
.lord-rachat-form__field input[type="email"],
.lord-rachat-form__field input[type="tel"],
.lord-rachat-form__field select,
.lord-rachat-form__field textarea {
    width: 100%;
    background: var(--lord-bg);
    border: 1.5px solid var(--lord-border);
    border-radius: var(--lord-radius-sm);
    padding: 12px 14px;
    font-family: inherit;
    font-size: 14.5px;
    color: var(--lord-text);
    transition: border-color .15s var(--lord-ease), background .15s var(--lord-ease), box-shadow .15s var(--lord-ease);
}
.lord-rachat-form__field input:focus,
.lord-rachat-form__field select:focus,
.lord-rachat-form__field textarea:focus {
    outline: none;
    border-color: var(--lord-accent);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}
.lord-rachat-form__field textarea { resize: vertical; min-height: 130px; }
.lord-rachat-form__field input[type="file"] {
    padding: 10px;
    background: var(--lord-bg);
    border: 1.5px dashed var(--lord-border);
    border-radius: var(--lord-radius-sm);
    cursor: pointer;
    font-size: 13.5px;
}
.lord-rachat-form__field input[type="file"]::file-selector-button {
    background: var(--lord-text);
    color: #fff;
    border: 0;
    padding: 7px 14px;
    border-radius: 999px;
    margin-right: 12px;
    font-weight: 600;
    cursor: pointer;
}
.lord-rachat-form__hint {
    font-size: 12.5px;
    color: var(--lord-text-mute);
    line-height: 1.4;
}
.lord-rachat-form__field--check input[type="checkbox"] {
    margin-top: 3px;
    flex-shrink: 0;
}
.lord-rachat-form__field--check span {
    font-size: 13.5px;
    line-height: 1.5;
    color: var(--lord-text-soft);
}
.lord-rachat-form__field--check a {
    color: var(--lord-accent);
    text-decoration: underline;
}
.lord-rachat-form__actions {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--lord-border-soft);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
}
.lord-rachat-form__legal {
    font-size: 13px;
    color: var(--lord-text-mute);
    margin: 0;
}

/* Alerts (success/error after submit) */
.lord-rachat-alert {
    max-width: 880px;
    margin: 0 auto 24px;
    padding: 18px 22px;
    border-radius: var(--lord-radius-md);
    font-size: 14.5px;
    line-height: 1.5;
}
.lord-rachat-alert strong { display: block; margin-bottom: 4px; font-size: 15.5px; }
.lord-rachat-alert--success {
    background: #ECFDF5;
    border: 1px solid var(--lord-success);
    color: #065F46;
}
.lord-rachat-alert--error {
    background: #FEF2F2;
    border: 1px solid var(--lord-danger);
    color: #7F1D1D;
}

/* ---------- FAQ accordion ---------- */
.lord-rachat-faq {
    max-width: 820px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.lord-rachat-faq__item {
    background: var(--lord-bg);
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-md);
    overflow: hidden;
    transition: border-color .15s var(--lord-ease);
}
.lord-rachat-faq__item[open] {
    border-color: var(--lord-accent);
    background: var(--lord-surface);
}
.lord-rachat-faq__q {
    cursor: pointer;
    padding: 18px 24px;
    font-weight: 700;
    font-size: 15.5px;
    color: var(--lord-text);
    list-style: none;
    position: relative;
    padding-right: 50px;
    transition: color .15s var(--lord-ease);
}
.lord-rachat-faq__q::-webkit-details-marker { display: none; }
.lord-rachat-faq__q::after {
    content: "+";
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 22px;
    font-weight: 300;
    color: var(--lord-accent);
    line-height: 1;
    transition: transform .2s var(--lord-ease);
}
.lord-rachat-faq__item[open] .lord-rachat-faq__q::after {
    content: "−";
}
.lord-rachat-faq__q:hover { color: var(--lord-accent); }
.lord-rachat-faq__a {
    padding: 0 24px 22px;
}
.lord-rachat-faq__a p {
    font-size: 14.5px;
    line-height: 1.65;
    color: var(--lord-text-soft);
    margin: 0;
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
    .lord-rachat-hero__inner { grid-template-columns: 1fr; gap: 40px; }
    .lord-rachat-hero__visual { height: 320px; max-width: 480px; margin: 0 auto; }
    .lord-rachat-stats__inner { grid-template-columns: repeat(2, 1fr); gap: 28px; }
    .lord-rachat-steps { grid-template-columns: repeat(2, 1fr); }
    .lord-rachat-grid { grid-template-columns: repeat(2, 1fr); }
    .lord-rachat-tarifs { grid-template-columns: 1fr; }
    .lord-rachat-tarif-card--featured { transform: none; }
}
@media (max-width: 640px) {
    .lord-rachat-hero { padding: 56px 20px 48px; }
    .lord-rachat-section { padding: 56px 20px; }
    .lord-rachat-stats__inner { grid-template-columns: 1fr; gap: 20px; }
    .lord-rachat-steps { grid-template-columns: 1fr; }
    .lord-rachat-grid { grid-template-columns: 1fr; }
    .lord-rachat-form { padding: 28px 22px 24px; }
    .lord-rachat-form__grid { grid-template-columns: 1fr; gap: 16px; }
    .lord-rachat-form__actions { flex-direction: column; align-items: stretch; }
    .lord-rachat-form__legal { text-align: center; }
}


/* =========================================================
   18. Page Contact
   ========================================================= */
.lord-contact {
    background: var(--lord-bg);
}
.lord-contact-hero {
    padding: 72px 24px 40px;
    background: linear-gradient(180deg, var(--lord-surface) 0%, var(--lord-bg) 100%);
}
.lord-contact-hero__inner {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.lord-contact-hero__eyebrow {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: var(--lord-accent);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 14px;
}
.lord-contact-hero__title {
    font-size: clamp(36px, 5vw, 52px);
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1.1;
    color: var(--lord-text);
    margin: 0 0 16px;
}
.lord-contact-hero__lead {
    font-size: 16.5px;
    line-height: 1.6;
    color: var(--lord-text-mute);
    margin: 0;
}

.lord-contact-section {
    padding: 40px 24px 96px;
}
.lord-contact-section__inner {
    max-width: var(--lord-container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 48px;
    align-items: start;
}

/* --- Aside info --- */
.lord-contact-info {
    background: #fff;
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-xl);
    padding: 28px 26px;
    box-shadow: var(--lord-shadow-xs);
    position: sticky;
    top: calc(var(--lord-header-stack) + 24px);
}
.lord-contact-info__title {
    margin: 0 0 18px;
    font-size: 14px;
    font-weight: 700;
    color: var(--lord-text);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.lord-contact-info__item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 0;
    border-top: 1px solid var(--lord-border);
}
.lord-contact-info__item:first-of-type { border-top: 0; padding-top: 0; }
.lord-contact-info__label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--lord-text-mute);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.lord-contact-info__value {
    font-size: 15px;
    font-weight: 600;
    color: var(--lord-text);
    text-decoration: none;
    word-break: break-word;
}
a.lord-contact-info__value:hover { color: var(--lord-accent); }

/* --- Form wrapper --- */
.lord-contact-form-wrap { min-width: 0; }

/* --- Alerts --- */
.lord-contact-alert {
    border-radius: var(--lord-radius-md);
    padding: 16px 18px;
    margin-bottom: 22px;
    border: 1px solid var(--lord-border);
    background: #fff;
}
.lord-contact-alert strong {
    display: block;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 4px;
}
.lord-contact-alert p {
    margin: 0;
    font-size: 14px;
    color: var(--lord-text-mute);
}
.lord-contact-alert--ok {
    border-color: #bbf7d0;
    background: #f0fdf4;
}
.lord-contact-alert--ok strong { color: #15803d; }
.lord-contact-alert--err {
    border-color: #fecaca;
    background: #fef2f2;
}
.lord-contact-alert--err strong { color: #b91c1c; }

/* --- Form --- */
.lord-contact-form {
    background: #fff;
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-xl);
    padding: 36px 36px 32px;
    box-shadow: var(--lord-shadow-sm);
}
.lord-contact-form__hp { display: none !important; }
.lord-contact-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px 22px;
    margin-bottom: 18px;
}
.lord-contact-form__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 18px;
}
.lord-contact-form__field:last-of-type { margin-bottom: 24px; }
.lord-contact-form__grid .lord-contact-form__field { margin-bottom: 0; }
.lord-contact-form__field label {
    font-size: 13px;
    font-weight: 600;
    color: var(--lord-text);
    letter-spacing: -0.005em;
}
.lord-contact-form__field label span[aria-hidden] {
    color: var(--lord-danger);
    margin-left: 2px;
}
.lord-contact-form__opt {
    color: var(--lord-text-mute);
    font-weight: 400;
}
.lord-contact-form__field input[type="text"],
.lord-contact-form__field input[type="email"],
.lord-contact-form__field select,
.lord-contact-form__field textarea {
    width: 100%;
    background: var(--lord-bg);
    border: 1.5px solid var(--lord-border);
    border-radius: var(--lord-radius-sm);
    padding: 12px 14px;
    font-family: inherit;
    font-size: 14.5px;
    color: var(--lord-text);
    transition: border-color .15s var(--lord-ease), background .15s var(--lord-ease), box-shadow .15s var(--lord-ease);
}
.lord-contact-form__field input:focus,
.lord-contact-form__field select:focus,
.lord-contact-form__field textarea:focus {
    outline: none;
    border-color: var(--lord-accent);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}
.lord-contact-form__field textarea { resize: vertical; min-height: 150px; }

.lord-contact-form__actions {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.lord-contact-form__legal {
    margin: 0;
    font-size: 12.5px;
    color: var(--lord-text-mute);
    flex: 1;
    min-width: 220px;
}

@media (max-width: 1024px) {
    .lord-contact-section__inner { grid-template-columns: 1fr; gap: 32px; }
    .lord-contact-info { position: static; }
}
@media (max-width: 640px) {
    .lord-contact-hero { padding: 56px 20px 32px; }
    .lord-contact-section { padding: 32px 20px 64px; }
    .lord-contact-form { padding: 28px 22px 26px; }
    .lord-contact-form__grid { grid-template-columns: 1fr; gap: 18px; }
    .lord-contact-form__actions { flex-direction: column; align-items: stretch; }
    .lord-contact-form__legal { text-align: center; }
}

/* ===========================================================
   Page Mentions légales (page-mentions-legales.php)
   =========================================================== */
.lord-legal {
    background: var(--lord-bg);
}
.lord-legal-hero {
    padding: 72px 24px 40px;
    background: linear-gradient(180deg, var(--lord-surface) 0%, var(--lord-bg) 100%);
}
.lord-legal-hero__inner {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.lord-legal-hero__eyebrow {
    display: inline-block;
    font-size: 13px;
    font-weight: 600;
    color: var(--lord-accent);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 14px;
}
.lord-legal-hero__title {
    font-size: clamp(36px, 5vw, 52px);
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1.1;
    color: var(--lord-text);
    margin: 0 0 16px;
}
.lord-legal-hero__lead {
    font-size: 15px;
    color: var(--lord-text-mute);
    margin: 0;
}

.lord-legal-section {
    padding: 32px 24px 96px;
}
.lord-legal-section__inner {
    max-width: 820px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid var(--lord-border);
    border-radius: var(--lord-radius-xl);
    padding: 40px 44px 44px;
    box-shadow: var(--lord-shadow-xs);
    color: var(--lord-text);
    font-size: 15.5px;
    line-height: 1.7;
}
.lord-legal-section__inner p {
    margin: 0 0 16px;
}
.lord-legal-section__inner a {
    color: var(--lord-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.lord-legal-section__inner a:hover {
    text-decoration: none;
}

.lord-legal-h2 {
    font-size: 20px;
    font-weight: 700;
    color: var(--lord-text);
    margin: 32px 0 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--lord-border);
}
.lord-legal-h2:first-of-type {
    margin-top: 0;
}

.lord-legal-dl {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 8px 24px;
    margin: 0 0 20px;
    padding: 18px 20px;
    background: var(--lord-surface);
    border-radius: var(--lord-radius-lg, 12px);
}
.lord-legal-dl dt {
    font-weight: 600;
    color: var(--lord-text-mute);
    font-size: 14px;
}
.lord-legal-dl dd {
    margin: 0;
    color: var(--lord-text);
    font-size: 15px;
}

@media (max-width: 760px) {
    .lord-legal-hero { padding: 56px 18px 32px; }
    .lord-legal-section { padding: 24px 16px 64px; }
    .lord-legal-section__inner { padding: 28px 22px 30px; font-size: 15px; }
    .lord-legal-h2 { font-size: 18px; margin-top: 26px; }
    .lord-legal-dl {
        grid-template-columns: 1fr;
        gap: 2px 0;
        padding: 16px 16px;
    }
    .lord-legal-dl dt { margin-top: 8px; }
    .lord-legal-dl dt:first-child { margin-top: 0; }
}
