/* ==========================================================================
   LeGuideLibertin — Consolidated Theme CSS
   Extracted & merged from 8 MVP wireframe templates
   ========================================================================== */


/* ==========================================================================
   1. RESET & ROOT (CSS custom properties, box-sizing, html/body/a, ::selection)
   ========================================================================== */

*{margin:0;padding:0;box-sizing:border-box}

:root{
    --black:#0a0a0a;
    --black-light:#1a1a1a;
    --black-card:#161616;
    --red:#e8487a;
    --red-dark:#d4326c;
    --violet:#7c3aed;
    --violet-muted:#6d28d9;
    --white:#fff;
    --white-90:rgba(255,255,255,0.93);
    --white-60:rgba(255,255,255,0.72);
    --white-30:rgba(255,255,255,0.42);
    --white-10:rgba(255,255,255,0.1);
    --white-05:rgba(255,255,255,0.04);
    --serif:'Playfair Display',Georgia,serif;
    --sans:'Libre Franklin',Helvetica,Arial,sans-serif;
}

html{scroll-behavior:smooth}

body{
    font-family:var(--sans);
    background:var(--black);
    color:var(--white-90);
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
    font-weight:400;
}

a{color:inherit;text-decoration:none}

::selection{background:var(--red);color:var(--white)}


/* ==========================================================================
   2. NAVIGATION (nav, .nav-bg, .nav-inner, .logo, .nav-links, .nav-cta, mobile menu)
   ========================================================================== */

nav{
    position:fixed;top:0;left:0;right:0;z-index:100;
    border-bottom:1px solid var(--white-10);
}
.nav-bg{
    position:absolute;inset:0;
    background:rgba(10,10,10,0.92);
    backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);
}
.nav-inner{
    position:relative;z-index:1;
    max-width:1400px;margin:0 auto;padding:0 60px;
    display:flex;align-items:center;justify-content:space-between;
    height:72px;
}

.logo{
    font-family:var(--serif);font-size:21px;font-weight:500;
    letter-spacing:0.02em;
}
.logo span{color:var(--red);font-style:italic;font-weight:400}

.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{
    font-size:13px;letter-spacing:0.05em;text-transform:uppercase;
    color:var(--white-60);transition:color 0.3s;font-weight:400;
}
.nav-links a:hover{color:var(--white)}

.nav-cta{
    font-size:12px;letter-spacing:0.08em;text-transform:uppercase;
    color:var(--white) !important;background:var(--red);
    padding:10px 24px;font-weight:500;
    transition:background 0.3s;
}
.nav-cta:hover{background:var(--red-dark)}

/* Mobile menu */
.mobile-menu-btn{
    display:none;width:44px;height:44px;
    background:none;border:none;cursor:pointer;
    flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.mobile-menu-btn span{
    display:block;width:22px;height:1.5px;background:var(--white-90);
    transition:all 0.3s;
}
.mobile-overlay{
    display:none;position:fixed;inset:0;z-index:200;
    background:rgba(10,10,10,0.97);
    flex-direction:column;padding:80px 32px 32px;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.mobile-overlay.open{display:flex}
.mobile-overlay-close{
    position:absolute;top:20px;right:24px;
    width:44px;height:44px;background:none;border:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
}
.mobile-overlay-close svg{width:24px;height:24px;stroke:var(--white-60);fill:none;stroke-width:1.5}
.mobile-overlay a{
    font-family:var(--serif);font-size:28px;font-weight:400;
    color:var(--white);padding:16px 0;
    border-bottom:1px solid var(--white-10);display:block;
    transition:color 0.2s;
}
.mobile-overlay a:last-child{border-bottom:none}
.mobile-overlay a:active{color:var(--red)}
.mobile-overlay .mobile-cta{
    margin-top:24px;background:var(--red);color:var(--white);
    text-align:center;padding:18px;font-family:var(--sans);
    font-size:14px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;
    border-bottom:none;
}


/* ==========================================================================
   3. BUTTONS (.btn, .btn-primary, .btn-outline, .btn-text)
   ========================================================================== */

.btn{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--sans);font-size:12px;letter-spacing:0.1em;
    text-transform:uppercase;font-weight:500;
    transition:all 0.3s;cursor:pointer;border:none;
}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.btn-primary{
    background:var(--red);color:var(--white);
    padding:16px 36px;
}
.btn-primary:hover{background:var(--red-dark)}

.btn-outline{
    background:transparent;color:var(--white-60);
    padding:16px 36px;border:1px solid var(--white-30);
}
.btn-outline:hover{color:var(--white);border-color:var(--white-60)}

.btn-text{
    background:none;color:var(--white-60);padding:0;
}
.btn-text:hover{color:var(--white)}


/* ==========================================================================
   4. SECTION SYSTEM (section, .section-inner, .overline, .section-title, etc.)
   ========================================================================== */

section{padding:72px 60px;position:relative}
.section-inner{max-width:1400px;margin:0 auto}

.section-top{
    display:flex;justify-content:space-between;align-items:flex-end;
    margin-bottom:40px;
}
.section-top-center{
    text-align:center;margin-bottom:40px;
}

.overline{
    font-size:12px;letter-spacing:0.15em;text-transform:uppercase;
    color:var(--red);margin-bottom:12px;font-weight:500;
    display:flex;align-items:center;gap:10px;
}
.overline svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.overline-center{justify-content:center}

.section-title{
    font-family:var(--serif);font-size:clamp(28px,3vw,44px);
    font-weight:500;line-height:1.15;letter-spacing:-0.01em;
    color:#fff;
}
.section-title em{font-style:italic;color:var(--red)}

.section-desc{
    font-size:16px;color:rgba(255,255,255,0.75);max-width:440px;
    line-height:1.7;font-weight:400;
}
.section-desc-center{margin:12px auto 0;text-align:center}

.divider{
    width:40px;height:2px;background:var(--red);margin:14px 0;
}
.divider-center{margin:14px auto}

.section-border{border-top:1px solid var(--white-10)}

.link-arrow{
    font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
    color:var(--white-60);font-weight:400;
    display:inline-flex;align-items:center;gap:8px;
    transition:color 0.3s;
}
.link-arrow svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform 0.3s}
.link-arrow:hover{color:var(--white)}
.link-arrow:hover svg{transform:translateX(4px)}

/* Breadcrumb */
.breadcrumb{font-size:12px;color:var(--white-30);margin-bottom:24px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--white-30);transition:color 0.3s}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2}

/* Subcategory pills */
.subcat{font-size:13px;padding:8px 20px;border:1px solid var(--white-10);color:var(--white-60);white-space:nowrap;transition:all 0.3s;text-decoration:none}
.subcat:hover{border-color:var(--white-30);color:var(--white)}
.subcat.active{background:var(--red);border-color:var(--red);color:#fff}

/* Badges (page-specific override values) */
.h-badge{font-size:10px;letter-spacing:0.08em;text-transform:uppercase;padding:5px 12px;display:inline-block}
.h-badge-vraie{background:var(--red);color:#fff}
.h-badge-fiction{background:var(--violet);color:#fff}
.h-badge-hot{background:rgba(255,255,255,0.15);color:var(--white);backdrop-filter:blur(6px)}


/* ==========================================================================
   5. HERO HOMEPAGE
   ========================================================================== */

.hero{
    display:flex;align-items:center;
    padding:120px 60px 80px;
    position:relative;
}
.hero::after{
    content:'';position:absolute;bottom:0;left:60px;right:60px;
    height:1px;background:var(--white-10);
}

.hero-inner{
    max-width:1400px;margin:0 auto;width:100%;
    display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}

.hero-text h1{
    font-family:var(--serif);font-size:clamp(42px,5vw,72px);
    font-weight:500;line-height:1.1;letter-spacing:-0.02em;
    margin-bottom:32px;color:#fff;
}
.hero-text h1 em{font-style:italic;color:var(--red)}

.hero-text p{
    font-size:18px;color:var(--white-60);max-width:440px;
    line-height:1.8;margin-bottom:36px;font-weight:400;
}

.hero-ctas{display:flex;gap:20px;align-items:center}

.hero-visual{
    position:relative;
    aspect-ratio:3/4;max-height:600px;
    background:var(--black-light);
    overflow:hidden;
}
.hero-visual::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(160deg, var(--red-dark) 0%, var(--black) 60%, var(--violet-muted) 100%);
    opacity:0.35;
}
.hero-visual::after{
    content:'';position:absolute;inset:0;
    border:1px solid var(--white-10);
}
.hero-visual-label{
    position:absolute;bottom:24px;left:24px;
    font-size:11px;letter-spacing:0.1em;text-transform:uppercase;
    color:var(--white-30);
}

.hero-proof{
    display:flex;align-items:center;gap:28px;
    margin-top:36px;padding-top:28px;
    border-top:1px solid var(--white-10);
}
.hero-proof-item strong{
    display:block;font-family:var(--serif);font-size:24px;
    font-weight:500;color:var(--white);
}
.hero-proof-item span{
    font-size:12px;color:var(--white-30);letter-spacing:0.02em;
    margin-top:2px;display:block;
}
.hero-proof-sep{
    width:1px;height:36px;background:var(--white-10);
}


/* ==========================================================================
   6. FEATURED SECTION
   ========================================================================== */

.featured{background:var(--black)}

.featured-grid{
    display:grid;grid-template-columns:1.4fr 1fr;gap:2px;
}

.featured-main{
    background:var(--black-card);padding:44px;
    display:flex;flex-direction:column;justify-content:flex-end;
    min-height:400px;position:relative;
}
.featured-main::before{
    content:'';position:absolute;top:0;left:0;right:0;height:200px;
    background:linear-gradient(180deg, rgba(232,72,122,0.1) 0%, transparent 100%);
}

.featured-main .overline{color:var(--white-30);margin-bottom:20px}
.featured-main h2{
    font-family:var(--serif);font-size:32px;font-weight:500;
    line-height:1.2;margin-bottom:16px;position:relative;color:#fff;
}
.featured-main h2 em{color:var(--red);font-style:italic}
.featured-main p{
    font-size:16px;color:var(--white-60);line-height:1.7;
    max-width:400px;margin-bottom:32px;font-weight:400;
}

.featured-side{display:flex;flex-direction:column;gap:2px}
.featured-card{
    flex:1;background:var(--black-card);padding:36px;
    display:flex;flex-direction:column;justify-content:center;
    transition:background 0.3s;
    position:relative;
}
.featured-card:hover{background:var(--black-light)}
.featured-card .overline{margin-bottom:12px}
.featured-card h3{
    font-family:var(--serif);font-size:20px;font-weight:500;
    line-height:1.3;margin-bottom:8px;color:#fff;
}
.featured-card p{font-size:14px;color:var(--white-60);line-height:1.65;font-weight:400}
.featured-card .card-num{
    position:absolute;top:24px;right:28px;
    font-family:var(--serif);font-size:48px;font-weight:400;
    color:var(--white-05);line-height:1;
}


/* ==========================================================================
   7. ARTICLE CARDS
   ========================================================================== */

.articles{background:var(--black)}

.articles-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
}

.article-card{
    background:var(--black-card);
    transition:background 0.3s;display:block;
}
.article-card:hover{background:var(--black-light)}

.article-card-img{
    aspect-ratio:16/10;
    background:var(--black-light);
    position:relative;overflow:hidden;
}
.article-card-img::before{
    content:'';position:absolute;inset:0;
    opacity:0.2;
}
.article-card-img svg{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:40px;height:40px;stroke:var(--white-30);fill:none;
    stroke-width:1;stroke-linecap:round;stroke-linejoin:round;
}
.article-img-1::before{background:linear-gradient(135deg,var(--red-dark),var(--black))}
.article-img-2::before{background:linear-gradient(135deg,var(--violet-muted),var(--black))}
.article-img-3::before{background:linear-gradient(135deg,var(--red),var(--violet-muted))}

.article-card-body{padding:32px}
.article-card .overline{font-size:10px;margin-bottom:12px}
.article-card h3{
    font-family:var(--serif);font-size:19px;font-weight:500;
    line-height:1.35;margin-bottom:12px;color:#fff;
}
.article-card p{font-size:14px;color:var(--white-60);line-height:1.65;font-weight:400}
.article-card .meta{
    margin-top:20px;font-size:11px;color:var(--white-30);
    display:flex;align-items:center;gap:6px;
}
.article-card .meta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}


/* ==========================================================================
   8. HISTOIRE CARDS (homepage)
   ========================================================================== */

.histoires{background:var(--black-light);position:relative}

.histoires-cats{
    display:flex;gap:24px;margin-bottom:36px;
    position:relative;z-index:1;
}
.hcat{
    font-size:14px;color:var(--white-30);padding-bottom:8px;
    border-bottom:1px solid transparent;transition:all 0.3s;
    font-weight:400;
}
.hcat:hover{color:var(--white-60)}
.hcat.active{color:var(--white);border-bottom-color:var(--red)}

.histoires-grid{
    display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2px;
    position:relative;z-index:1;
}

.histoire-card{
    background:var(--black-card);display:flex;flex-direction:column;
    transition:background 0.3s;
}
.histoire-card:hover{background:var(--black-light)}
.histoire-card.h-featured{grid-row:span 2}

.h-visual{
    aspect-ratio:16/10;background:var(--black-light);
    position:relative;overflow:hidden;
}
.histoire-card.h-featured .h-visual{aspect-ratio:auto;flex:1;min-height:240px}
.h-visual::before{
    content:'';position:absolute;inset:0;opacity:0.25;
}
.h-vis-1::before{background:linear-gradient(150deg,var(--red-dark),#1a0a15)}
.h-vis-2::before{background:linear-gradient(150deg,var(--violet-muted),#0a0a1a)}
.h-vis-3::before{background:linear-gradient(150deg,var(--red),#1a0510)}
.h-vis-4::before{background:linear-gradient(150deg,#2d1a3d,var(--black))}

.h-visual svg{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:36px;height:36px;stroke:var(--white-30);fill:none;
    stroke-width:1;stroke-linecap:round;stroke-linejoin:round;
}

.h-badge{
    position:absolute;top:16px;left:16px;
    font-size:10px;letter-spacing:0.08em;text-transform:uppercase;
    padding:5px 14px;font-weight:500;
}

.h-time{
    position:absolute;bottom:16px;right:16px;
    font-size:11px;color:var(--white-30);
    display:flex;align-items:center;gap:5px;
}
.h-time svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.h-body{padding:28px;flex:1;display:flex;flex-direction:column}
.h-body .overline{font-size:10px;margin-bottom:10px}
.h-body h3{
    font-family:var(--serif);font-size:18px;font-weight:500;
    line-height:1.35;margin-bottom:10px;color:#fff;
}
.histoire-card.h-featured .h-body h3{font-size:24px}
.h-body .excerpt{font-size:14px;color:var(--white-60);line-height:1.65;flex:1;font-weight:400}
.h-footer{
    display:flex;gap:20px;margin-top:16px;padding-top:16px;
    border-top:1px solid var(--white-05);
    font-size:11px;color:var(--white-30);
}
.h-footer span{display:flex;align-items:center;gap:5px}
.h-footer svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.h-footer .rating svg{fill:var(--red);stroke:var(--red)}
.h-footer .rating{color:var(--red)}

.histoires-actions{
    display:flex;gap:20px;margin-top:40px;position:relative;z-index:1;
}

/* Libertinage section */
.libertinage{background:var(--black)}

.lib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}

.lib-card{
    background:var(--black-card);padding:36px 32px;
    transition:background 0.3s;position:relative;
}
.lib-card:hover{background:var(--black-light)}

.lib-card-icon{
    width:48px;height:48px;margin-bottom:20px;
    display:flex;align-items:center;justify-content:center;
}
.lib-card-icon svg{width:32px;height:32px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

.lib-card h3{
    font-family:var(--serif);font-size:22px;font-weight:500;
    margin-bottom:12px;color:#fff;
}
.lib-card p{font-size:15px;color:var(--white-60);line-height:1.7;margin-bottom:24px;font-weight:400}

/* Comparatif section */
.comparatif{background:var(--black)}

.platforms{
    max-width:1000px;margin:0 auto;
    display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
}

.plat-card{
    background:var(--black-card);padding:32px;text-align:center;
    transition:background 0.3s;position:relative;
}
.plat-card:hover{background:var(--black-light)}
.plat-card.plat-featured{background:var(--black-light)}
.plat-card.plat-featured::before{
    content:'';position:absolute;top:0;left:0;right:0;
    height:2px;background:var(--red);
}

.plat-logo{
    width:56px;height:56px;margin:0 auto 20px;
    display:flex;align-items:center;justify-content:center;
    font-family:var(--sans);font-size:20px;font-weight:600;
    border:1px solid var(--white-10);
}
.plat-card.plat-featured .plat-logo{
    border-color:var(--red);color:var(--red);
}

.plat-card h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:6px;color:#fff}
.plat-card .tagline{font-size:12px;color:var(--white-30);margin-bottom:24px}

.plat-stats{display:flex;justify-content:center;gap:32px;margin-bottom:24px}
.plat-stat .value{
    font-family:var(--serif);font-size:24px;font-weight:500;
}
.plat-card.plat-featured .plat-stat .value{color:var(--red)}
.plat-stat .label{font-size:10px;color:var(--white-30);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px}

.plat-cta{
    display:inline-block;font-size:11px;letter-spacing:0.1em;
    text-transform:uppercase;padding:12px 28px;font-weight:500;
    border:1px solid var(--white-10);color:var(--white-60);
    transition:all 0.3s;
}
.plat-cta:hover{border-color:var(--white-30);color:var(--white)}
.plat-card.plat-featured .plat-cta{
    background:var(--red);border-color:var(--red);color:var(--white);
}
.plat-card.plat-featured .plat-cta:hover{background:var(--red-dark);border-color:var(--red-dark)}

/* Disabled / coming soon state */
.plat-card.plat-disabled{opacity:0.45}
.plat-card.plat-disabled .plat-logo{border-color:var(--white-05);color:var(--white-30)}
.plat-card.plat-disabled h3{color:var(--white-60)}
.plat-cta-disabled{
    cursor:default;
    background:none;border:1px solid var(--white-05);color:var(--white-30);
    font-size:11px;letter-spacing:0.08em;text-transform:uppercase;
}

/* Clubs section */
.clubs{background:var(--black)}

.clubs-layout{display:grid;grid-template-columns:1fr 1fr;gap:2px}

.clubs-left{background:var(--black-card);padding:36px}
.clubs-right{
    background:var(--black-card);
    display:flex;align-items:center;justify-content:center;
    flex-direction:column;
    color:var(--white-30);
}
.clubs-right svg{width:48px;height:48px;stroke:var(--white-10);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;margin-bottom:12px}
.clubs-right p{font-size:13px}

.clubs-search{
    display:flex;gap:0;margin-bottom:24px;
}
.clubs-search input{
    flex:1;background:var(--white-05);border:1px solid var(--white-10);
    border-right:none;padding:14px 20px;color:var(--white);
    font-size:14px;font-family:var(--sans);font-weight:400;outline:none;
    transition:border-color 0.3s;
}
.clubs-search input::placeholder{color:var(--white-30)}
.clubs-search input:focus{border-color:var(--red)}
.clubs-search button{
    background:var(--red);border:none;color:var(--white);
    padding:14px 24px;cursor:pointer;
    display:flex;align-items:center;gap:8px;
    font-size:12px;letter-spacing:0.08em;text-transform:uppercase;
    font-family:var(--sans);font-weight:500;transition:background 0.3s;
}
.clubs-search button svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.clubs-search button:hover{background:var(--red-dark)}

.clubs-stats{display:flex;gap:2px;margin-bottom:24px}
.clubs-stat{
    flex:1;background:var(--white-05);padding:20px;text-align:center;
}
.clubs-stat .value{font-family:var(--serif);font-size:28px;font-weight:500}
.clubs-stat .label{font-size:11px;color:var(--white-30);margin-top:2px}

.clubs-group{margin-bottom:28px}
.clubs-group h4{
    font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
    color:var(--white-30);margin-bottom:14px;font-weight:500;
    display:flex;align-items:center;gap:8px;
}
.clubs-group h4 svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.clubs-tags{display:flex;flex-wrap:wrap;gap:8px}
.ctag{
    font-size:14px;color:var(--white-60);padding:8px 18px;
    border:1px solid var(--white-10);transition:all 0.3s;font-weight:400;
    display:inline-flex;align-items:center;gap:8px;
}
.ctag:hover{border-color:var(--red);color:var(--white)}
.ctag span{font-size:10px;color:var(--white-30);font-weight:500}


/* ==========================================================================
   9. NEWSLETTER
   ========================================================================== */

.newsletter{
    background:var(--black);
    padding:72px 60px;
}
.newsletter-inner{
    max-width:560px;margin:0 auto;text-align:center;
}
.newsletter-inner h2{
    font-family:var(--serif);font-size:clamp(30px,3vw,40px);
    font-weight:500;margin-bottom:16px;color:#fff;
}
.newsletter-inner h2 em{color:var(--red);font-style:italic}
.newsletter-inner > p{
    font-size:16px;color:var(--white-60);line-height:1.7;
    margin-bottom:32px;font-weight:400;
}

.nl-form{display:flex;gap:0;max-width:440px;margin:0 auto 20px}
.nl-form input{
    flex:1;background:var(--white-05);border:1px solid var(--white-10);
    border-right:none;padding:16px 20px;color:var(--white);
    font-size:14px;font-family:var(--sans);font-weight:400;outline:none;
    transition:border-color 0.3s;
}
.nl-form input::placeholder{color:var(--white-30)}
.nl-form input:focus{border-color:var(--red)}
.nl-form button{
    background:var(--red);border:none;color:var(--white);
    padding:16px 28px;font-size:12px;letter-spacing:0.1em;
    text-transform:uppercase;font-family:var(--sans);font-weight:500;
    cursor:pointer;transition:background 0.3s;
}
.nl-form button:hover{background:var(--red-dark)}

.nl-note{
    font-size:12px;color:var(--white-30);
    display:flex;align-items:center;justify-content:center;gap:8px;
}
.nl-note svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}


/* ==========================================================================
   10. FOOTER
   ========================================================================== */

footer{
    background:var(--black);
    border-top:1px solid var(--white-10);
    padding:60px 60px 40px;
}
.footer-grid{
    max-width:1400px;margin:0 auto;
    display:grid;grid-template-columns:1.6fr repeat(5,1fr);gap:48px;
    padding-bottom:48px;
}

.footer-brand p{font-size:14px;color:var(--white-60);line-height:1.7;margin:20px 0 28px;font-weight:400}

.footer-social{display:flex;gap:16px}
.footer-social a{
    color:var(--white-30);transition:color 0.3s;
    display:flex;align-items:center;
}
.footer-social a:hover{color:var(--red)}
.footer-social svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

.footer-col h4{
    font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
    color:var(--white-60);margin-bottom:20px;font-weight:500;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{font-size:14px;color:var(--white-60);transition:color 0.3s;font-weight:400}
.footer-col a:hover{color:var(--white)}

.footer-bottom{
    max-width:1400px;margin:0 auto;padding-top:32px;
    border-top:1px solid var(--white-05);
    display:flex;justify-content:space-between;align-items:center;
}
.footer-bottom p{font-size:12px;color:var(--white-30);font-weight:400}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:12px;color:var(--white-30);transition:color 0.3s;font-weight:400}
.footer-bottom-links a:hover{color:var(--white-60)}


/* ==========================================================================
   11. ARTICLE SINGLE (hero, layout, content styles, sidebar, TOC, author-box, related)
   ========================================================================== */

.article-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10)}
.article-hero-inner{max-width:800px;margin:0 auto}
.article-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:500;color:#fff;line-height:1.15;margin-bottom:20px}
.article-hero h1 em{color:var(--red);font-style:italic}
.article-meta{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--white-30);flex-wrap:wrap}
.article-meta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.article-meta span{display:flex;align-items:center;gap:6px}

/* Hero image for article */
.article-hero-img{aspect-ratio:21/9;background:var(--black-light);position:relative;overflow:hidden;margin-top:28px}
.article-hero-img::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--red-dark),var(--black));opacity:0.25}
.article-hero-img svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;stroke:var(--white-30);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}

/* Article layout */
.article-layout{max-width:1200px;margin:0 auto;padding:48px 60px;display:grid;grid-template-columns:1fr 280px;gap:48px}
.article-content{max-width:100%}
.article-content h2{font-family:var(--serif);font-size:26px;font-weight:500;color:#fff;margin:44px 0 14px}
.article-content h3{font-family:var(--serif);font-size:19px;font-weight:500;color:#fff;margin:28px 0 10px}
.article-content p{font-size:16px;color:var(--white-60);line-height:1.85;margin-bottom:18px}
.article-content ul,.article-content ol{margin:0 0 18px 24px;color:var(--white-60);font-size:16px;line-height:1.85}
.article-content li{margin-bottom:6px}
.article-content blockquote{border-left:2px solid var(--red);padding:14px 22px;margin:24px 0;font-family:var(--serif);font-size:17px;font-style:italic;color:var(--white-60);line-height:1.7}

/* Info & Warning boxes */
.info-box{background:var(--black-card);border-left:2px solid var(--violet);padding:18px 22px;margin:24px 0}
.info-box h4{font-size:13px;color:var(--violet);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em}
.info-box p{margin-bottom:0;font-size:15px}
.warning-box{background:var(--black-card);border-left:2px solid var(--red);padding:18px 22px;margin:24px 0}
.warning-box h4{font-size:13px;color:var(--red);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em}
.warning-box p{margin-bottom:0;font-size:15px}

/* Mid-article CTA */
.mid-cta{background:var(--black-card);padding:28px;margin:36px 0;text-align:center}
.mid-cta p{font-family:var(--serif);font-size:19px;color:#fff;margin-bottom:14px}
.mid-cta .btn{display:inline-flex}

/* Sidebar */
.article-sidebar{position:sticky;top:80px;align-self:start}
.sidebar-block{background:var(--black-card);padding:24px;margin-bottom:2px}
.sidebar-block h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600}

/* Table of contents */
.toc-list{list-style:none}
.toc-list li{margin-bottom:8px}
.toc-list a{font-size:14px;color:var(--white-60);transition:color 0.3s;display:block;padding:3px 0}
.toc-list a:hover{color:var(--white)}
.toc-list a.active{color:var(--red);border-left:2px solid var(--red);padding-left:12px}

/* Author box */
.author-box{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--white-10);margin-top:14px}
.author-avatar{width:36px;height:36px;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}
.author-name{font-size:13px;font-weight:500;color:#fff}
.author-role{font-size:11px;color:var(--white-30)}
.sidebar-cta{text-align:left}
.sidebar-cta-label{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:10px}
.sidebar-cta p,.sidebar-reco p{font-size:14px;color:var(--white-60);margin-bottom:16px;line-height:1.5}
.sidebar-reco{text-align:left}
.btn-full{width:100%;text-align:center}

/* Related articles */
.related-articles{padding:48px 60px;border-top:1px solid var(--white-10)}
.related-articles .section-inner{max-width:1200px;margin:0 auto}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:28px}


/* ==========================================================================
   12. CATEGORY LISTING
   ========================================================================== */

.cat-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10)}
.cat-hero-inner{max-width:1400px;margin:0 auto}
.cat-hero h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:500;color:#fff;margin-bottom:12px}
.cat-hero h1 em{color:var(--red);font-style:italic}
.cat-hero .desc{font-size:16px;color:var(--white-60);max-width:520px;line-height:1.7;margin-bottom:20px}
.cat-stats{display:flex;gap:28px;font-size:14px;color:var(--white-30)}
.cat-stats strong{color:#fff;font-weight:500}

.subcats{max-width:1400px;margin:0 auto;padding:20px 60px;display:flex;gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-bottom:1px solid var(--white-10)}
.subcats::-webkit-scrollbar{display:none}

.cat-layout{max-width:1400px;margin:0 auto;padding:44px 60px;display:grid;grid-template-columns:1fr 280px;gap:44px}
.cat-main{display:flex;flex-direction:column;gap:2px}

.cat-article{display:flex;gap:0;background:var(--black-card);transition:background 0.3s;text-decoration:none}
.cat-article:hover{background:var(--black-light)}
.cat-article-img{width:220px;flex-shrink:0;background:var(--black-light);position:relative;overflow:hidden}
.cat-article-img::before{content:'';position:absolute;inset:0;opacity:0.2}
.cat-a-1::before{background:linear-gradient(135deg,var(--red-dark),var(--black))}
.cat-a-2::before{background:linear-gradient(135deg,var(--violet-muted),var(--black))}
.cat-a-3::before{background:linear-gradient(135deg,var(--red),var(--violet-muted))}
.cat-article-img svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;stroke:var(--white-30);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.cat-article-body{padding:24px;flex:1;display:flex;flex-direction:column;justify-content:center}
.cat-article-body h3{font-family:var(--serif);font-size:19px;font-weight:500;color:#fff;margin-bottom:6px;line-height:1.35}
.cat-article-body p{font-size:14px;color:var(--white-60);line-height:1.6}
.cat-article-meta{display:flex;gap:14px;margin-top:10px;font-size:12px;color:var(--white-30)}
.cat-article-meta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cat-article-meta span{display:flex;align-items:center;gap:5px}

.cat-featured .cat-article{flex-direction:column}
.cat-featured .cat-article-img{width:100%;aspect-ratio:21/9}
.cat-featured .cat-article-body h3{font-size:24px}

.cat-sidebar{position:sticky;top:80px;align-self:start;display:flex;flex-direction:column;gap:2px}
.cat-sidebar .sidebar-block{background:var(--black-card);padding:24px}
.cat-sidebar h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600}

.other-cats{padding:44px 60px;border-top:1px solid var(--white-10);max-width:1400px;margin:0 auto}
.other-cats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2px;margin-top:20px}
.other-cat-card{background:var(--black-card);padding:24px;transition:background 0.3s;text-align:center;text-decoration:none}
.other-cat-card:hover{background:var(--black-light)}
.other-cat-card svg{width:24px;height:24px;stroke:var(--red);fill:none;stroke-width:1.5;margin-bottom:10px;stroke-linecap:round;stroke-linejoin:round}
.other-cat-card h4{font-family:var(--serif);font-size:15px;font-weight:500;color:#fff;margin-bottom:3px}
.other-cat-card p{font-size:12px;color:var(--white-30)}


/* ==========================================================================
   13. HISTOIRE LISTING
   ========================================================================== */

.h-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10)}
.h-hero-inner{max-width:1400px;margin:0 auto;text-align:center}
.h-hero h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:500;color:#fff;margin-bottom:12px}
.h-hero h1 em{color:var(--red);font-style:italic}
.h-hero .desc{font-size:16px;color:var(--white-60);max-width:480px;margin:0 auto 24px;line-height:1.7}
.h-hero-stats{display:flex;gap:2px;max-width:420px;margin:0 auto}
.h-hero-stat{flex:1;background:var(--black-card);padding:14px;text-align:center}
.h-hero-stat strong{font-family:var(--serif);font-size:20px;color:#fff;display:block}
.h-hero-stat span{font-size:11px;color:var(--white-30)}

.h-layout{max-width:1400px;margin:0 auto;padding:44px 60px;display:grid;grid-template-columns:1fr 260px;gap:44px}
.h-filters{display:flex;gap:10px;margin-bottom:28px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
.h-filters::-webkit-scrollbar{display:none}
.h-list{display:flex;flex-direction:column;gap:2px}

.h-list-card{display:flex;gap:0;background:var(--black-card);transition:background 0.3s;text-decoration:none}
.h-list-card:hover{background:var(--black-light)}
.h-list-img{width:180px;flex-shrink:0;background:var(--black-light);position:relative;overflow:hidden}
.h-list-img::before{content:'';position:absolute;inset:0;opacity:0.25}
.h-l-1::before{background:linear-gradient(150deg,var(--red-dark),#1a0a15)}
.h-l-2::before{background:linear-gradient(150deg,var(--violet-muted),#0a0a1a)}
.h-l-3::before{background:linear-gradient(150deg,var(--red),var(--violet-muted))}
.h-list-img .h-badge{position:absolute;top:10px;left:10px}
.h-list-img svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;stroke:var(--white-30);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.h-list-body{padding:22px;flex:1;display:flex;flex-direction:column;justify-content:center}
.h-list-body h3{font-family:var(--serif);font-size:18px;font-weight:500;color:#fff;margin-bottom:6px;line-height:1.35}
.h-list-body p{font-size:14px;color:var(--white-60);line-height:1.6}
.h-list-meta{display:flex;gap:14px;margin-top:10px;font-size:12px;color:var(--white-30)}
.h-list-meta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.h-list-meta span{display:flex;align-items:center;gap:5px}
.h-list-meta .rating svg{fill:var(--red);stroke:var(--red)}
.h-list-meta .rating{color:var(--red)}

.h-submit-cta{background:var(--black-card);padding:32px;text-align:center;margin-top:28px}
.h-submit-cta h3{font-family:var(--serif);font-size:20px;color:#fff;font-weight:500;margin-bottom:6px}
.h-submit-cta p{font-size:14px;color:var(--white-60);margin-bottom:14px}

.h-sidebar{position:sticky;top:80px;align-self:start;display:flex;flex-direction:column;gap:2px}
.h-sidebar .sidebar-block{background:var(--black-card);padding:24px}
.h-sidebar h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600}
.h-top-list{list-style:none}
.h-top-list li{padding:8px 0;border-bottom:1px solid var(--white-05);display:flex;gap:10px;align-items:center}
.h-top-list li:last-child{border-bottom:none}
.h-top-num{font-family:var(--serif);font-size:18px;color:var(--white-30);width:22px;flex-shrink:0}
.h-top-list a{font-size:14px;color:var(--white-60);transition:color 0.3s;line-height:1.4}
.h-top-list a:hover{color:var(--white)}


/* ==========================================================================
   14. HISTOIRE SINGLE (with progress bar)
   ========================================================================== */

.story-hero{padding:120px 0 0;border-bottom:1px solid var(--white-10)}
.story-hero-inner{max-width:800px;margin:0 auto;padding:0 60px 48px}
.story-hero h1{font-family:var(--serif);font-size:clamp(26px,4vw,44px);font-weight:500;color:#fff;line-height:1.2;margin-bottom:16px}
.story-hero h1 em{color:var(--red);font-style:italic}
.story-hero-img{aspect-ratio:21/9;background:var(--black-light);position:relative;overflow:hidden;margin-top:24px}
.story-hero-img::before{content:'';position:absolute;inset:0;background:linear-gradient(150deg,var(--red-dark),#0a0a0a);opacity:0.3}
.story-hero-img svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;stroke:var(--white-30);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.story-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--white-30);align-items:center}
.story-meta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.story-meta span{display:flex;align-items:center;gap:6px}
.story-meta .rating svg{fill:var(--red);stroke:var(--red);width:12px;height:12px}
.story-meta .rating{color:var(--red)}

.story-layout{max-width:1000px;margin:0 auto;padding:44px 60px;display:grid;grid-template-columns:1fr 240px;gap:44px}
.story-text{font-size:17px;color:var(--white-60);line-height:1.9}
.story-text p{margin-bottom:18px}
.story-text p:first-of-type::first-letter{font-family:var(--serif);font-size:48px;float:left;line-height:1;padding-right:10px;color:var(--red);font-weight:500}

.story-sidebar{position:sticky;top:80px;align-self:start;display:flex;flex-direction:column;gap:2px}
.story-sidebar .sidebar-block{background:var(--black-card);padding:22px}
.story-sidebar h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600}

.story-related{padding:44px 60px;border-top:1px solid var(--white-10);max-width:1000px;margin:0 auto}
.story-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:20px}
.story-related-card{background:var(--black-card);padding:20px;transition:background 0.3s;text-decoration:none}
.story-related-card:hover{background:var(--black-light)}
.story-related-card h4{font-family:var(--serif);font-size:16px;font-weight:500;color:#fff;margin-bottom:4px}
.story-related-card p{font-size:13px;color:var(--white-30)}

/* Progress bar */
.progress-bar{position:fixed;top:56px;left:0;height:2px;background:var(--red);z-index:99;transition:width 0.1s}


/* ==========================================================================
   15. SUBMIT FORM (histoire soumettre)
   ========================================================================== */

.submit-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10);text-align:center}
.submit-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:500;color:#fff;margin-bottom:12px}
.submit-hero h1 em{color:var(--red);font-style:italic}
.submit-hero p{font-size:16px;color:var(--white-60);max-width:460px;margin:0 auto;line-height:1.7}
.submit-layout{max-width:1000px;margin:0 auto;padding:44px 60px;display:grid;grid-template-columns:1fr 280px;gap:44px}
.submit-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:13px;color:var(--white-60);font-weight:500}
.form-group input,.form-group textarea,.form-group select{background:var(--white-05);border:1px solid var(--white-10);padding:14px 18px;color:#fff;font-size:15px;font-family:var(--sans);transition:border-color 0.3s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--red)}
.form-group textarea{min-height:240px;resize:vertical;line-height:1.8}
.form-group select{cursor:pointer;-webkit-appearance:none;appearance:none}
.form-group .hint{font-size:12px;color:var(--white-30)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-check{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--white-60)}
.form-check input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--red)}
.guidelines{position:sticky;top:80px;align-self:start}
.guidelines-card{background:var(--black-card);padding:24px}
.guidelines-card h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:14px;font-weight:600}
.guidelines-card ul{list-style:none}
.guidelines-card li{font-size:14px;color:var(--white-60);padding:7px 0;border-bottom:1px solid var(--white-05);display:flex;align-items:center;gap:10px}
.guidelines-card li:last-child{border-bottom:none}
.guidelines-card li svg{width:16px;height:16px;flex-shrink:0}
.g-yes svg{stroke:#10B981;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.g-no svg{stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}


/* ==========================================================================
   16. ABOUT PAGE
   ========================================================================== */

.about-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10);text-align:center}
.about-hero h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:500;color:#fff;margin-bottom:12px}
.about-hero h1 em{color:var(--red);font-style:italic}
.about-hero p{font-size:16px;color:var(--white-60);max-width:500px;margin:0 auto;line-height:1.7}
.about-content{max-width:1000px;margin:0 auto;padding:44px 60px}
.about-section{margin-bottom:48px}
.about-section h2{font-family:var(--serif);font-size:26px;font-weight:500;color:#fff;margin-bottom:18px}
.about-section h2 em{color:var(--red);font-style:italic}
.about-section p{font-size:16px;color:var(--white-60);line-height:1.8;margin-bottom:14px}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin:28px 0}
.about-stat{background:var(--black-card);padding:24px;text-align:center}
.about-stat strong{font-family:var(--serif);font-size:26px;color:#fff;display:block}
.about-stat span{font-size:12px;color:var(--white-30)}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px}
.value-card{background:var(--black-card);padding:24px}
.value-card h3{font-family:var(--serif);font-size:17px;font-weight:500;color:#fff;margin-bottom:6px}
.value-card p{font-size:14px;color:var(--white-60);line-height:1.65;margin-bottom:0}
.value-card svg{width:22px;height:22px;stroke:var(--red);fill:none;stroke-width:1.5;margin-bottom:10px;stroke-linecap:round;stroke-linejoin:round}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.team-card{background:var(--black-card);padding:24px;text-align:center}
.team-avatar{width:50px;height:50px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;margin:0 auto 14px}
.team-avatar.v2{background:var(--violet)}
.team-avatar.v3{background:var(--white-10);color:var(--white-60)}
.team-card h3{font-family:var(--serif);font-size:16px;font-weight:500;color:#fff;margin-bottom:3px}
.team-card .role{font-size:13px;color:var(--red);margin-bottom:6px}
.team-card p{font-size:13px;color:var(--white-60);line-height:1.6}


/* ==========================================================================
   17. CONTACT PAGE
   ========================================================================== */

.contact-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10);text-align:center}
.contact-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:500;color:#fff;margin-bottom:12px}
.contact-hero h1 em{color:var(--red);font-style:italic}
.contact-hero p{font-size:16px;color:var(--white-60);max-width:420px;margin:0 auto;line-height:1.7}
.contact-layout{max-width:1000px;margin:0 auto;padding:44px 60px;display:grid;grid-template-columns:1fr 300px;gap:44px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.contact-form .form-group{display:flex;flex-direction:column;gap:6px}
.contact-form label{font-size:13px;color:var(--white-60);font-weight:500}
.contact-form input,.contact-form textarea,.contact-form select{background:var(--white-05);border:1px solid var(--white-10);padding:14px 18px;color:#fff;font-size:15px;font-family:var(--sans);outline:none;transition:border-color 0.3s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--red)}
.contact-form textarea{min-height:150px;resize:vertical;line-height:1.7}
.contact-form select{-webkit-appearance:none;cursor:pointer}
.contact-sidebar{display:flex;flex-direction:column;gap:2px}
.contact-card{background:var(--black-card);padding:24px}
.contact-card h4{font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);margin-bottom:10px;font-weight:600}
.contact-card p{font-size:14px;color:var(--white-60);line-height:1.6;margin-bottom:0}
.contact-card a{color:var(--red);transition:color 0.3s}
.contact-card a:hover{color:#fff}
.contact-faq{max-width:1000px;margin:0 auto;padding:0 60px 44px}
.faq-item{background:var(--black-card);padding:22px;margin-bottom:2px}
.faq-item h4{font-family:var(--serif);font-size:16px;font-weight:500;color:#fff;margin-bottom:6px}
.faq-item p{font-size:14px;color:var(--white-60);line-height:1.65}


/* ==========================================================================
   18. RESPONSIVE MEDIA QUERIES (consolidated by breakpoint)
   ========================================================================== */

/* ---------- Tablet (max-width: 1024px) ---------- */
@media(max-width:1024px){

    /* Base layout */
    section{padding:56px 32px}
    .hero{padding:96px 32px 56px}
    .hero-inner{grid-template-columns:1fr;gap:40px}
    .hero-visual{max-height:340px}
    .hero-proof{flex-wrap:wrap;gap:20px}

    /* Featured */
    .featured-grid{grid-template-columns:1fr}
    .featured-main{min-height:320px;padding:36px}

    /* Article cards */
    .articles-grid{grid-template-columns:1fr 1fr}

    /* Histoires */
    .histoires-grid{grid-template-columns:1fr 1fr}
    .histoire-card.h-featured{grid-row:auto}

    /* Libertinage */
    .lib-grid{grid-template-columns:1fr 1fr}

    /* Comparatif */
    .platforms{grid-template-columns:1fr 1fr}

    /* Clubs */
    .clubs-layout{grid-template-columns:1fr}
    .clubs-right{min-height:280px}

    /* Footer */
    .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:32px}

    /* Article single */
    .article-layout{grid-template-columns:1fr;padding:36px 32px}
    .article-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:2px}
    .related-articles{padding:40px 32px}

    /* Category listing */
    .cat-layout{grid-template-columns:1fr;padding:36px 32px}
    .cat-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:2px}
    .other-cats-grid{grid-template-columns:repeat(3,1fr)}
    .cat-article-img{width:180px}

    /* Histoire listing */
    .h-layout{grid-template-columns:1fr;padding:36px 32px}
    .h-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:2px}

    /* Histoire single */
    .story-layout{grid-template-columns:1fr;padding:36px 32px}
    .story-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:2px}

    /* Submit form */
    .submit-layout{grid-template-columns:1fr;padding:36px 32px}
    .guidelines{position:static}

    /* About page */
    .about-stats{grid-template-columns:repeat(2,1fr)}
    .team-grid{grid-template-columns:1fr 1fr}

    /* Contact page */
    .contact-layout{grid-template-columns:1fr}
}


/* ---------- Mobile (max-width: 768px) ---------- */
@media(max-width:768px){

    /* Base */
    section{padding:44px 20px}
    .section-inner{max-width:100%}

    /* Nav */
    nav .nav-inner{padding:0 20px;height:56px}
    .nav-links{display:none}
    .mobile-menu-btn{display:flex}
    .logo{font-size:18px}

    /* Hero homepage */
    .hero{padding:72px 0 0}
    .hero-inner{grid-template-columns:1fr;gap:0}
    .hero-visual{
        aspect-ratio:16/9;max-height:220px;width:100%;order:-1;
    }
    .hero-visual-label{font-size:9px;padding:5px 10px}
    .hero-text{padding:28px 20px 40px}
    .hero-text .overline{margin-bottom:12px}
    .hero-text h1{font-size:28px;margin-bottom:16px}
    .hero-text p{font-size:15px;margin-bottom:24px;max-width:100%}
    .hero-ctas{flex-direction:column;gap:10px}
    .hero-ctas .btn{width:100%;justify-content:center;padding:15px 24px}
    .hero-proof{
        gap:0;margin-top:24px;padding-top:20px;
        justify-content:space-between;
    }
    .hero-proof-item{flex:1;text-align:center}
    .hero-proof-item strong{font-size:18px}
    .hero-proof-item span{font-size:10px}
    .hero-proof-sep{height:24px}

    /* Section headers */
    .section-top{flex-direction:column;gap:10px;align-items:flex-start;margin-bottom:24px}
    .section-top-center{margin-bottom:24px}
    .section-title{font-size:24px}
    .link-arrow{font-size:11px}
    .overline{font-size:11px}

    /* Featured */
    .featured-grid{grid-template-columns:1fr;gap:2px}
    .featured-main{min-height:240px;padding:24px}
    .featured-main h2{font-size:22px}
    .featured-main p{font-size:14px}
    .featured-card{padding:20px}
    .featured-card .card-num{display:none}

    /* Articles — horizontal scroll, KEEP images */
    .articles-grid{
        grid-template-columns:none;
        display:flex;overflow-x:auto;scroll-snap-type:x mandatory;
        gap:12px;padding-bottom:8px;
        -webkit-overflow-scrolling:touch;
        scrollbar-width:none;
    }
    .articles-grid::-webkit-scrollbar{display:none}
    .articles-grid .article-card{
        min-width:260px;max-width:280px;flex-shrink:0;
        scroll-snap-align:start;
    }
    .article-card-img{aspect-ratio:3/2}
    .article-card-body{padding:16px}
    .article-card-body h3{font-size:16px}

    /* Histoires — keep images visible */
    .histoires-cats{
        flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;
        gap:10px;padding-bottom:8px;margin-bottom:24px;
        -webkit-overflow-scrolling:touch;
        scrollbar-width:none;
    }
    .histoires-cats::-webkit-scrollbar{display:none}
    .hcat{white-space:nowrap;scroll-snap-align:start;padding-bottom:10px}

    .histoires-grid{grid-template-columns:1fr;gap:2px}
    .histoire-card.h-featured{flex-direction:column}
    .histoire-card.h-featured .h-visual{min-height:160px;aspect-ratio:16/9;flex:none;width:100%}
    .h-visual{aspect-ratio:3/2}
    .h-body{padding:16px}
    .h-body h3{font-size:16px}
    .histoire-card.h-featured .h-body{padding:20px}
    .histoire-card.h-featured .h-body h3{font-size:19px}

    .histoires-actions{flex-direction:column;gap:10px;margin-top:28px}
    .histoires-actions .btn{width:100%;justify-content:center}

    /* Libertinage */
    .lib-grid{grid-template-columns:1fr;gap:2px}
    .lib-card{padding:24px 20px}
    .lib-card h3{font-size:18px}
    .lib-card p{font-size:14px}

    /* Comparatif */
    .platforms{grid-template-columns:1fr;gap:2px;max-width:100%}
    .plat-card{padding:24px;flex-direction:row;align-items:center;gap:16px;text-align:left}
    .plat-logo{width:44px;height:44px;font-size:14px;flex-shrink:0}
    .plat-card h3{font-size:17px}
    .plat-stats{gap:16px}
    .plat-card.plat-featured{transform:none}
    .plat-card.plat-featured:hover{transform:none}

    /* Clubs */
    .clubs-layout{grid-template-columns:1fr;gap:2px}
    .clubs-left{padding:20px}
    .clubs-right{min-height:200px}
    .clubs-search{flex-direction:column}
    .clubs-search input{border-right:1px solid var(--white-10);border-bottom:none}
    .clubs-search button{justify-content:center}
    .clubs-stats .clubs-stat{padding:14px}
    .clubs-stat .value{font-size:22px}
    .ctag{padding:10px 16px;font-size:13px}

    /* Newsletter */
    .newsletter{padding:44px 20px}
    .newsletter-inner h2{font-size:24px}
    .nl-form{flex-direction:column}
    .nl-form input{border-right:1px solid var(--white-10);border-bottom:none}
    .nl-form button{text-align:center}

    /* Footer */
    footer{padding:44px 20px 28px}
    .footer-grid{
        grid-template-columns:1fr 1fr;gap:24px;
        padding-bottom:28px;
    }
    .footer-brand{grid-column:span 2}
    .footer-bottom{flex-direction:column;gap:12px;text-align:center}
    .footer-bottom-links{gap:16px}

    /* Touch targets >= 48px */
    .btn{min-height:48px}
    .ctag{min-height:44px}
    .hcat{min-height:44px;display:inline-flex;align-items:center}
    .clubs-search input,.nl-form input{min-height:48px}
    .clubs-search button,.nl-form button{min-height:48px}

    /* Article single */
    .article-hero{padding:72px 0 0}
    .article-hero-inner{padding:0 20px}
    .article-hero-img{margin-top:20px;aspect-ratio:16/9;margin-left:-20px;margin-right:-20px;width:calc(100% + 40px)}
    .article-layout{padding:28px 20px;gap:28px}
    .article-sidebar{grid-template-columns:1fr}
    .article-content h2{font-size:22px;margin-top:32px}
    .article-content h3{font-size:17px}
    .article-content p{font-size:15px}
    .related-articles{padding:36px 20px}
    .related-grid{grid-template-columns:1fr;gap:2px}
    .related-grid .article-card{display:flex;flex-direction:row}
    .related-grid .article-card-img{width:110px;flex-shrink:0;aspect-ratio:1/1}
    .related-grid .article-card-body{padding:14px}
    .related-grid .article-card-body h3{font-size:15px}

    /* Category listing */
    .cat-hero{padding:72px 20px 36px}
    .cat-layout{padding:28px 20px}
    .subcats{padding:14px 20px;gap:8px}
    .cat-article{flex-direction:column}
    .cat-article-img{width:100%;aspect-ratio:16/9}
    .cat-article-body{padding:16px}
    .cat-article-body h3{font-size:17px}
    .cat-featured .cat-article-body h3{font-size:20px}
    .cat-sidebar{grid-template-columns:1fr}
    .other-cats{padding:36px 20px}
    .other-cats-grid{grid-template-columns:1fr 1fr}
    .other-cat-card{padding:18px}

    /* Histoire listing */
    .h-hero{padding:72px 20px 36px}
    .h-layout{padding:28px 20px}
    .h-sidebar{grid-template-columns:1fr}
    .h-list-card{flex-direction:column}
    .h-list-img{width:100%;aspect-ratio:16/9}
    .h-list-body{padding:16px}
    .h-list-body h3{font-size:16px}
    .h-hero-stats{max-width:100%}
    .h-hero-stat{padding:12px 8px}
    .h-hero-stat strong{font-size:17px}

    /* Histoire single */
    .story-hero{padding:68px 0 0}
    .story-hero-inner{padding:0 20px 32px}
    .story-hero-img{margin-left:-20px;margin-right:-20px;width:calc(100% + 40px);aspect-ratio:16/9}
    .story-layout{padding:28px 20px}
    .story-sidebar{grid-template-columns:1fr}
    .story-text{font-size:16px}
    .story-text p:first-of-type::first-letter{font-size:40px}
    .story-related{padding:36px 20px}
    .story-related-grid{grid-template-columns:1fr}

    /* Submit form */
    .submit-hero{padding:72px 20px 36px}
    .submit-layout{padding:28px 20px}
    .form-row{grid-template-columns:1fr}

    /* About page */
    .about-hero{padding:72px 20px 36px}
    .about-content{padding:28px 20px}
    .about-stats{grid-template-columns:1fr 1fr}
    .values-grid{grid-template-columns:1fr}
    .team-grid{grid-template-columns:1fr}
    .about-stat{padding:18px}

    /* Contact page */
    .contact-hero{padding:72px 20px 36px}
    .contact-layout{padding:28px 20px}
    .contact-faq{padding:0 20px 36px}
}


/* ---------- Small phones (max-width: 380px) ---------- */
@media(max-width:380px){
    section{padding:36px 16px}
    .hero{padding:64px 0 0}
    .hero-text{padding:24px 16px 36px}
    .hero-text h1{font-size:25px}
    .hero-proof-item strong{font-size:16px}
    .section-title{font-size:22px}
    .featured-main{min-height:200px;padding:20px}
    .featured-main h2{font-size:20px}
    .articles-grid .article-card{min-width:240px}
    nav .nav-inner{padding:0 16px}
}


/* ==========================================================================
   16. QUIZ RESULT PAGE
   ========================================================================== */

.quiz-hero{padding:120px 60px 48px;text-align:center;border-bottom:1px solid var(--white-10)}
.quiz-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:500;color:#fff;margin-bottom:16px}
.quiz-hero h1 em{color:var(--red);font-style:italic}
.quiz-score{display:inline-flex;align-items:center;gap:14px;background:var(--black-card);padding:18px 32px;margin-bottom:28px}
.quiz-score-num{font-family:var(--serif);font-size:44px;font-weight:500;color:var(--red)}
.quiz-score-label{text-align:left}
.quiz-score-label strong{display:block;font-size:16px;color:#fff}
.quiz-score-label span{font-size:13px;color:var(--white-30)}
.quiz-content{max-width:720px;margin:0 auto;padding:44px 60px}
.quiz-profile{background:var(--black-card);padding:32px;margin-bottom:28px;text-align:center}
.quiz-profile h2{font-family:var(--serif);font-size:26px;font-weight:500;color:#fff;margin-bottom:8px}
.quiz-profile h2 em{color:var(--red);font-style:italic}
.quiz-profile p{font-size:15px;color:var(--white-60);line-height:1.7;max-width:500px;margin:0 auto}
.quiz-reco{margin-bottom:28px}
.quiz-reco h3{font-family:var(--serif);font-size:21px;font-weight:500;color:#fff;margin-bottom:18px}
.quiz-reco-grid{display:flex;flex-direction:column;gap:2px}
.quiz-reco-card{background:var(--black-card);padding:20px;display:flex;gap:14px;align-items:center;transition:background 0.3s;text-decoration:none}
.quiz-reco-card:hover{background:var(--black-light)}
.quiz-reco-icon{width:40px;height:40px;background:var(--white-05);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.quiz-reco-icon svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.quiz-reco-text h4{font-size:15px;color:#fff;font-weight:500;margin-bottom:2px}
.quiz-reco-text p{font-size:13px;color:var(--white-30)}
.quiz-cta{background:var(--black-card);padding:32px;text-align:center;margin-top:28px}
.quiz-cta h3{font-family:var(--serif);font-size:22px;font-weight:500;color:#fff;margin-bottom:6px}
.quiz-cta p{font-size:14px;color:var(--white-60);margin-bottom:18px}
.quiz-intro{font-size:16px;color:var(--white-60);max-width:500px;margin:0 auto}
.quiz-container{background:var(--black-card);padding:40px;margin-bottom:28px}
.quiz-progress{height:4px;background:var(--white-05);margin-bottom:24px}
.quiz-progress-bar{height:100%;background:var(--red);width:10%;transition:width .4s ease}
.quiz-step-count{font-size:13px;color:var(--white-30);margin-bottom:24px}
.quiz-question{display:none}
.quiz-question.active{display:block}
.quiz-question h2{font-family:var(--serif);font-size:clamp(20px,3vw,28px);font-weight:500;color:#fff;margin-bottom:24px}
.quiz-question h2 em{color:var(--red);font-style:italic}
.quiz-options{display:flex;flex-direction:column;gap:10px}
.quiz-option{display:flex;align-items:center;gap:14px;background:var(--white-05);padding:16px 20px;cursor:pointer;transition:background .2s,border-color .2s;border:1px solid transparent}
.quiz-option:hover{background:var(--white-10)}
.quiz-option.selected{background:rgba(232,72,122,0.1);border-color:var(--red)}
.quiz-option input{display:none}
.quiz-option span{font-size:15px;color:var(--white-80);line-height:1.5}
.quiz-option.selected span{color:#fff}
.quiz-nav{display:flex;gap:16px;margin-top:32px;justify-content:center}
.quiz-nav .btn{min-width:140px}

@media(max-width:768px){
    .quiz-hero{padding:72px 20px 36px}
    .quiz-content{padding:28px 20px}
    .quiz-score{padding:14px 20px;flex-wrap:wrap;justify-content:center}
    .quiz-score-num{font-size:36px}
}

/* ===== CLUBS PAGE ===== */
.clubs-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10)}
.clubs-hero-inner{max-width:1400px;margin:0 auto}
.clubs-hero h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:500;color:#fff;margin-bottom:12px}
.clubs-hero h1 em{color:var(--red);font-style:italic}
.clubs-hero .desc{font-size:16px;color:var(--white-60);max-width:520px;line-height:1.7;margin-bottom:20px}

.clubs-page-layout{max-width:1400px;margin:0 auto;padding:44px 60px}

.clubs-search-bar{display:flex;gap:0;margin-bottom:28px}
.clubs-search-bar input{flex:1;background:var(--white-05);border:1px solid var(--white-10);border-right:none;padding:14px 18px;color:#fff;font-size:15px;font-family:var(--sans);outline:none}
.clubs-search-bar input:focus{border-color:var(--red)}
.clubs-search-bar select{background:var(--white-05);border:1px solid var(--white-10);border-right:none;padding:14px 18px;color:var(--white-60);font-size:14px;font-family:var(--sans);outline:none;min-width:170px;-webkit-appearance:none}
.clubs-search-bar button{background:var(--red);border:none;color:#fff;padding:14px 24px;font-size:12px;letter-spacing:0.08em;text-transform:uppercase;font-family:var(--sans);font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;white-space:nowrap}
.clubs-search-bar button svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.clubs-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-bottom:28px}

.club-card{background:var(--black-card);padding:24px;transition:background 0.3s;display:flex;gap:16px;text-decoration:none}
.club-card:hover{background:var(--black-light)}
.club-icon{width:48px;height:48px;background:var(--white-05);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.club-icon svg{width:22px;height:22px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.club-info h3{font-family:var(--serif);font-size:17px;font-weight:500;color:#fff;margin-bottom:3px}
.club-info .club-loc{font-size:13px;color:var(--white-30);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.club-info .club-loc svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.club-tags-row{display:flex;gap:5px;flex-wrap:wrap}
.club-tag{font-size:11px;padding:3px 9px;border:1px solid var(--white-10);color:var(--white-30)}

.clubs-regions{margin-top:44px}
.clubs-regions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:20px}
.region-card{background:var(--black-card);padding:20px;transition:background 0.3s;text-align:center;text-decoration:none;display:block}
.region-card:hover{background:var(--black-light)}
.region-card h4{font-family:var(--serif);font-size:15px;font-weight:500;color:#fff;margin-bottom:3px}
.region-card p{font-size:12px;color:var(--white-30)}

.clubs-faq{margin-top:44px;padding-top:44px;border-top:1px solid var(--white-10)}
.faq-item{background:var(--black-card);padding:22px;margin-bottom:2px}
.faq-item h4{font-family:var(--serif);font-size:16px;font-weight:500;color:#fff;margin-bottom:6px}
.faq-item p{font-size:14px;color:var(--white-60);line-height:1.65}

/* ===== COMPARATIF PAGE ===== */
.comp-hero{padding:120px 60px 48px;border-bottom:1px solid var(--white-10);text-align:center}
.comp-hero h1{font-family:var(--serif);font-size:clamp(28px,4vw,48px);font-weight:500;color:#fff;margin-bottom:12px}
.comp-hero h1 em{color:var(--red);font-style:italic}
.comp-hero p{font-size:16px;color:var(--white-60);max-width:500px;margin:0 auto;line-height:1.7}
.comp-hero .updated{font-size:12px;color:var(--white-30);margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px}
.comp-hero .updated svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.comp-content{max-width:1000px;margin:0 auto;padding:44px 60px}

.comp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:44px}
.comp-table{width:100%;border-collapse:collapse;min-width:500px}
.comp-table th{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:var(--white-30);padding:12px 14px;text-align:left;border-bottom:1px solid var(--white-10);font-weight:500}
.comp-table td{padding:12px 14px;font-size:14px;color:var(--white-60);border-bottom:1px solid var(--white-05)}
.comp-table tr:hover td{background:var(--white-05)}
.comp-table .site-name{font-family:var(--serif);font-size:16px;color:#fff;font-weight:500}
.comp-table .featured-row td{background:rgba(232,72,122,0.04)}
.comp-table .score{font-family:var(--serif);font-size:18px;font-weight:500}
.comp-table .score-high{color:var(--red)}

.comp-review{background:var(--black-card);padding:32px;margin-bottom:2px}
.comp-review h3{font-family:var(--serif);font-size:21px;font-weight:500;color:#fff;margin-bottom:6px}
.comp-review .tagline{font-size:13px;color:var(--white-30);margin-bottom:14px}
.comp-review p{font-size:15px;color:var(--white-60);line-height:1.7;margin-bottom:14px}

.comp-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
.comp-pros h5,.comp-cons h5{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:8px;font-weight:600}
.comp-pros h5{color:#10B981}
.comp-cons h5{color:var(--red)}
.comp-pros ul,.comp-cons ul{list-style:none;padding:0}
.comp-pros li,.comp-cons li{font-size:14px;color:var(--white-60);padding:3px 0;display:flex;align-items:center;gap:8px}
.comp-pros li svg,.comp-cons li svg{width:14px;height:14px;flex-shrink:0;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}
.comp-pros li svg{stroke:#10B981}
.comp-cons li svg{stroke:var(--red)}

.comp-method{margin-top:44px;padding-top:44px;border-top:1px solid var(--white-10)}
.comp-method p{font-size:15px;color:var(--white-60);line-height:1.7;margin-top:14px}

/* ===== RESPONSIVE CLUBS + COMPARATIF ===== */
@media(max-width:1024px){
    .clubs-page-grid{grid-template-columns:1fr}
    .clubs-regions-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .clubs-hero{padding:72px 20px 36px}
    .clubs-page-layout{padding:28px 20px}
    .clubs-search-bar{flex-direction:column}
    .clubs-search-bar input,.clubs-search-bar select{border-right:1px solid var(--white-10);border-bottom:none}
    .clubs-search-bar button{justify-content:center}
    .clubs-regions-grid{grid-template-columns:1fr 1fr}
    .club-card{padding:18px}
    .comp-hero{padding:72px 20px 36px}
    .comp-content{padding:28px 20px}
    .comp-pros-cons{grid-template-columns:1fr}
    .comp-review{padding:22px}
}

/* Fix: images histoire cards */
.h-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}

/* Histoires section actions */
.histoires-actions{display:flex;gap:20px;margin-top:40px;justify-content:center}
@media(max-width:768px){
    .histoires-actions{flex-direction:column;gap:10px;margin-top:28px}
    .histoires-actions .btn{width:100%;justify-content:center}
}

/* ===== SECTION LIBERTINAGE (homepage) ===== */
.libertinage{background:var(--black)}
.lib-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.lib-card{background:var(--black-card);padding:36px 32px;transition:background 0.3s;position:relative;display:flex;flex-direction:column}
.lib-card:hover{background:var(--black-light)}
.lib-card-icon{width:48px;height:48px;margin-bottom:20px;display:flex;align-items:center;justify-content:center}
.lib-card-icon svg{width:32px;height:32px;stroke:var(--red);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.lib-card h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:12px;color:#fff}
.lib-card p{font-size:15px;color:var(--white-60);line-height:1.7;margin-bottom:24px;font-weight:400;flex:1}

/* ===== SECTION COMPARATIF/PLATEFORMES (homepage) ===== */
.comparatif{background:var(--black)}
.platforms{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.plat-card{background:var(--black-card);padding:32px;text-align:center;transition:background 0.3s;position:relative}
.plat-card:hover{background:var(--black-light)}
.plat-card.plat-featured{background:var(--black-light)}
.plat-card.plat-featured::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--red)}
.plat-logo{width:56px;height:56px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:20px;font-weight:600;border:1px solid var(--white-10)}
.plat-card.plat-featured .plat-logo{border-color:var(--red);color:var(--red)}
.plat-card h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:6px;color:#fff}
.plat-card .tagline{font-size:12px;color:var(--white-30);margin-bottom:24px}
.plat-stats{display:flex;justify-content:center;gap:32px;margin-bottom:24px}
.plat-stat .value{font-family:var(--serif);font-size:24px;font-weight:500}
.plat-card.plat-featured .plat-stat .value{color:var(--red)}
.plat-stat .label{font-size:10px;color:var(--white-30);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px}
.plat-cta{display:inline-block;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:12px 28px;font-weight:500;border:1px solid var(--white-10);color:var(--white-60);transition:all 0.3s}
.plat-cta:hover{border-color:var(--white-30);color:var(--white)}
.plat-card.plat-featured .plat-cta{background:var(--red);border-color:var(--red);color:var(--white)}
.plat-card.plat-featured .plat-cta:hover{background:var(--red-dark);border-color:var(--red-dark)}

/* ===== SECTION CLUBS (homepage) ===== */
.clubs-layout{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.clubs-left{background:var(--black-card);padding:36px}
.clubs-right{background:var(--black-card);display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--white-30)}
.clubs-right svg{width:48px;height:48px;stroke:var(--white-10);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round;margin-bottom:12px}
.clubs-right p{font-size:13px}
.clubs-search{display:flex;gap:0;margin-bottom:24px}
.clubs-search input{flex:1;background:var(--white-05);border:1px solid var(--white-10);border-right:none;padding:14px 20px;color:var(--white);font-size:14px;font-family:var(--sans);font-weight:400;outline:none;transition:border-color 0.3s}
.clubs-search input::placeholder{color:var(--white-30)}
.clubs-search input:focus{border-color:var(--red)}
.clubs-search button{background:var(--red);border:none;color:var(--white);padding:14px 24px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:0.08em;text-transform:uppercase;font-family:var(--sans);font-weight:500;transition:background 0.3s}
.clubs-search button svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.clubs-search button:hover{background:var(--red-dark)}
.clubs-stats{display:flex;gap:2px;margin-bottom:24px}
.clubs-stat{flex:1;background:var(--white-05);padding:20px;text-align:center}
.clubs-stat .value{font-family:var(--serif);font-size:28px;font-weight:500}
.clubs-stat .label{font-size:11px;color:var(--white-30);margin-top:2px}
.clubs-group{margin-bottom:28px}
.clubs-group h4{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--white-30);margin-bottom:14px;font-weight:500;display:flex;align-items:center;gap:8px}
.clubs-group h4 svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.clubs-tags{display:flex;flex-wrap:wrap;gap:8px}
.ctag{font-size:14px;color:var(--white-60);padding:8px 18px;border:1px solid var(--white-10);transition:all 0.3s;font-weight:400;display:inline-flex;align-items:center;gap:8px}
.ctag:hover{border-color:var(--red);color:var(--white)}
.ctag span{font-size:10px;color:var(--white-30);font-weight:500}

/* ===== RESPONSIVE NOUVELLES SECTIONS ===== */
@media(max-width:1024px){
    .lib-grid{grid-template-columns:1fr 1fr}
    .platforms{grid-template-columns:1fr 1fr}
    .clubs-layout{grid-template-columns:1fr}
    .clubs-right{min-height:280px}
}
@media(max-width:768px){
    .lib-grid{grid-template-columns:1fr}
    .lib-card{padding:24px 20px}
    .lib-card h3{font-size:18px}
    .platforms{grid-template-columns:1fr;max-width:100%}
    .plat-card{padding:24px;flex-direction:row;align-items:center;gap:16px;text-align:left}
    .clubs-layout{grid-template-columns:1fr;gap:2px}
    .clubs-left{padding:20px}
    .clubs-right{min-height:200px}
    .clubs-search{flex-direction:column}
    .clubs-search input{border-right:1px solid var(--white-10);border-bottom:none}
    .clubs-search button{justify-content:center}
    .clubs-stats .clubs-stat{padding:14px}
    .clubs-stat .value{font-size:22px}
    .ctag{padding:10px 16px;font-size:13px}
    .clubs-search input{min-height:48px}
    .clubs-search button{min-height:48px}
    .ctag{min-height:44px}
}

/* ===== CARTE FRANCE SVG ===== */
.clubs-map{padding:24px;justify-content:center;align-items:center}
.clubs-right.clubs-map svg.france-map{width:100%;max-width:520px;height:auto}
.france-map a.map-pin{cursor:pointer;text-decoration:none}
.france-map a.map-pin:hover .pin-glow{fill:rgba(232,72,122,0.35);transition:fill .2s}
.france-map a.map-pin:hover text{fill:rgba(255,255,255,1)!important}
