:root{--bg:#160d0c;--surface:#231613;--text:#f7ece6;--muted:#a8897f;--accent:#e3261d;--accent2:#f0c987;--radius:10px}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Inter', system-ui, sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%}
h1,h2,h3{font-family:'DM Serif Display', Georgia, serif;line-height:1.2;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(1.6rem,4vw,2.3rem)}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--accent2);outline-offset:2px;border-radius:4px}
.wrap{max-width:1240px;margin:0 auto;padding:0 18px}
/* Header */
header.site{background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(10px);padding:12px 0;position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(255,255,255,.07)}
header.site .wrap{display:flex;align-items:center;gap:20px}
.logo{font-size:1.32rem;font-weight:800;color:var(--text);display:inline-flex;align-items:center;gap:9px;flex:none}
.logo svg{display:block;flex:none;border-radius:9px}.logo__txt{letter-spacing:-.5px}.logo .dot{color:var(--accent)}
nav.main{display:flex;gap:6px;flex-wrap:wrap}
nav.main a{color:var(--muted);font-weight:600;padding:7px 11px;border-radius:99px;font-size:.96rem}
nav.main a:hover{color:var(--text);background:rgba(255,255,255,.06);text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;padding:11px 20px;border-radius:99px;font-weight:700;border:none;cursor:pointer;transition:transform .15s,filter .15s;box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 40%,transparent)}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px);text-decoration:none}
.btn--ghost{background:none;border:2px solid var(--accent);color:var(--accent);box-shadow:none}
.btn--ghost:hover{background:color-mix(in srgb,var(--accent) 14%,transparent)}
.btn--cta{margin-left:auto}
.btn--lg{padding:15px 30px;font-size:1.08rem}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:4px}
@media(max-width:760px){.btn--cta{display:none}.logo{margin-right:auto}nav.main{order:3;width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}}
main{padding:26px 0 56px}
/* Hero with model-image background (showcase pages) */
.hero{position:relative;border-radius:var(--radius);overflow:hidden;margin:6px 0 22px;padding:52px 30px;min-height:300px;display:flex;align-items:center;background-size:cover;background-position:center 28%;background-color:var(--surface)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(100deg,color-mix(in srgb,var(--bg) 95%,transparent),color-mix(in srgb,var(--bg) 80%,transparent) 42%,color-mix(in srgb,var(--bg) 40%,transparent))}
.hero__in{position:relative;z-index:1;max-width:660px}
.hero h1{margin-bottom:8px}
.hero__sub{color:var(--muted);max-width:560px;margin:4px 0 18px}
.hero .livecount{margin-bottom:14px}
@media(max-width:600px){.hero{padding:34px 18px;min-height:230px}}
/* Hero encadré par 2 bannières (desktop) : hero centré, bien posé */
.herorail{display:flex;gap:16px;align-items:stretch;margin:6px 0 22px}
.herorail .hero{flex:1 1 auto;margin:0}
.herorail__side{flex:0 0 300px;display:flex;align-items:center;justify-content:center}
.herorail__side .bannerrow{margin:0}
@media(max-width:1040px){.herorail__side{display:none}}
/* Live count pill */
.livecount{display:inline-flex;align-items:center;gap:8px;background:var(--surface);color:var(--text);font-weight:700;margin:0 0 16px;font-size:.95rem;padding:7px 14px;border-radius:99px;border:1px solid rgba(255,255,255,.08)}
.livecount:before{content:'';width:9px;height:9px;border-radius:50%;background:#ff3b3b;box-shadow:0 0 0 0 rgba(255,59,59,.6);animation:pulse 1.8s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
/* Grid + cards (overlay style) */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin:18px 0}
@media(max-width:520px){.grid{grid-template-columns:repeat(2,1fr);gap:11px}}
.card{background:var(--surface);border-radius:var(--radius);overflow:hidden;position:relative;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px)}
.card__link{display:block;color:#fff}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#000}
.card__thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.card:hover .card__thumb{transform:scale(1.07)}
.card__scrim{position:absolute;left:0;right:0;bottom:0;padding:22px 12px 10px;background:linear-gradient(to top,rgba(0,0,0,.88),rgba(0,0,0,.35) 60%,transparent)}
.card__name{font-weight:700;font-size:1.02rem;color:#fff;line-height:1.2;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card__meta{color:rgba(255,255,255,.82);font-size:.82rem}
.card__cta{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%) scale(.92);opacity:0;background:var(--accent);color:#fff;font-weight:700;font-size:.86rem;padding:9px 16px;border-radius:99px;transition:opacity .18s,transform .18s;pointer-events:none;white-space:nowrap}
.card:hover .card__cta{opacity:1;transform:translate(-50%,-50%) scale(1)}
.badge{position:absolute;top:9px;left:9px;display:inline-flex;align-items:center;gap:5px;background:#ff2d4d;color:#fff;font-size:.68rem;font-weight:800;padding:4px 9px;border-radius:99px;letter-spacing:.6px;text-transform:uppercase;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.badge .pulse{width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 1.8s infinite}
.badge--off{background:rgba(0,0,0,.7);color:var(--muted)}
/* SEO text blocks */
.seo{color:var(--muted);max-width:880px}.seo p{margin:.6em 0}
.seo--bottom{max-width:100%;margin-top:34px;border-top:1px solid rgba(255,255,255,.06);padding-top:20px}
/* Filters */
.filters{background:var(--surface);border-radius:var(--radius);padding:13px 15px;margin:6px 0 20px;display:flex;flex-direction:column;gap:9px}
.filters__row{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.filters__lbl{color:var(--muted);font-size:.78rem;font-weight:800;min-width:80px;text-transform:uppercase;letter-spacing:.5px}
.chip{display:inline-block;padding:6px 13px;border-radius:99px;background:var(--bg);color:var(--muted);font-size:.86rem;border:1px solid rgba(255,255,255,.09);transition:.15s}
.chip:hover{color:var(--text);text-decoration:none;border-color:var(--accent);transform:translateY(-1px)}
.chip--on{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-color:transparent;font-weight:700}
.chip--clear{color:var(--accent);border-color:var(--accent)}
/* Pagination */
.pagination{display:flex;gap:8px;margin:28px 0;flex-wrap:wrap;align-items:center}
.pagination a,.pagination span{padding:9px 16px;background:var(--surface);border-radius:99px;color:var(--text);border:1px solid rgba(255,255,255,.08)}
.pagination a:hover{text-decoration:none;border-color:var(--accent)}
.pagination .cur{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-weight:700;border-color:transparent}
/* Model page */
.model-hero{display:grid;grid-template-columns:1.9fr 1fr;gap:24px;margin:18px 0}
@media(max-width:820px){.model-hero{grid-template-columns:1fr}}
.embed{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;aspect-ratio:16/10;box-shadow:0 10px 40px rgba(0,0,0,.5)}
.embed iframe{width:100%;height:100%;border:0;pointer-events:none}
.embed a{position:absolute;inset:0;display:block}
.panel{background:var(--surface);border-radius:var(--radius);padding:20px}
.panel dl{display:grid;grid-template-columns:auto 1fr;gap:8px 14px;margin-top:4px}
.panel dt{color:var(--muted)}.panel dd{font-weight:600;text-transform:capitalize}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.tags a{background:var(--bg);padding:6px 13px;border-radius:99px;font-size:.84rem;color:var(--muted);border:1px solid rgba(255,255,255,.08)}
.tags a:hover{color:var(--text);border-color:var(--accent);text-decoration:none}
/* Editorial content */
article.content{max-width:800px}article.content h2{margin-top:1.6em;font-size:1.5rem}article.content h3{margin-top:1.2em}
article.content p,article.content li{margin:.6em 0}article.content ul{padding-left:1.2em}
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
@media(max-width:640px){.proscons{grid-template-columns:1fr}}
.proscons .panel ul{list-style:none;padding:0}.proscons .panel li{margin:.5em 0;padding-left:24px;position:relative}
.proscons .pros li:before{content:'\2713';position:absolute;left:0;color:#3ddc84;font-weight:800}
.proscons .cons li:before{content:'\2715';position:absolute;left:0;color:var(--accent);font-weight:800}
.faq details{background:var(--surface);border-radius:var(--radius);padding:14px 18px;margin:9px 0;border:1px solid rgba(255,255,255,.06)}
.faq summary{font-weight:700;cursor:pointer;list-style:none}.faq summary::-webkit-details-marker{display:none}
.faq summary:before{content:'+';color:var(--accent);font-weight:800;margin-right:9px}
.faq details[open] summary:before{content:'\2013'}
/* Footer */
footer.site{background:var(--surface);padding:40px 0 96px;color:var(--muted);font-size:.92rem;margin-top:40px;border-top:1px solid rgba(255,255,255,.07)}
.footcols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;margin-bottom:26px}
@media(max-width:680px){.footcols{grid-template-columns:1fr 1fr}}
.footcols h4{color:var(--text);font-size:.82rem;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.footcols ul{list-style:none}.footcols li{margin:.4em 0}
footer.site a{color:var(--muted)}footer.site a:hover{color:var(--text)}
.foot-legal{border-top:1px solid rgba(255,255,255,.07);padding-top:16px;display:flex;gap:8px 18px;flex-wrap:wrap;align-items:center;font-size:.85rem}
/* Forms */
form.std{display:grid;gap:13px;max-width:560px}
form.std input,form.std textarea,form.std select{background:var(--bg);border:1px solid rgba(255,255,255,.14);color:var(--text);padding:11px 13px;border-radius:var(--radius);font:inherit;width:100%}
form.std label{display:grid;gap:5px;font-size:.9rem;color:var(--muted)}
.notice{background:var(--surface);border-left:4px solid var(--accent2);padding:13px 17px;border-radius:var(--radius);margin:14px 0}
/* Age gate + cookie + mobile CTA */
#age-gate{position:fixed;inset:0;background:rgba(5,5,8,.94);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}
#age-gate .panel{max-width:440px;text-align:center;border:1px solid rgba(255,255,255,.1)}
#age-gate h2{font-size:1.5rem}
#age-gate .age-gate__scope{color:var(--muted);font-size:.78rem;line-height:1.5;margin-top:16px}
#age-gate .actions{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap}
body.gated main,body.gated header.site{filter:blur(16px);pointer-events:none;user-select:none}
#cookie-bar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);padding:12px 16px;display:flex;gap:14px;align-items:center;justify-content:center;z-index:95;font-size:.9rem;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.08)}
/* Breadcrumbs + calculator tool */
.crumbs{color:var(--muted);font-size:.85rem;margin:4px 0 10px}.crumbs a{color:var(--muted)}
.calc{padding:18px}
.calc__controls{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-end;margin-bottom:16px}
.calc__field{display:flex;flex-direction:column;gap:8px;flex:1;min-width:220px}
.calc__field--tip{flex:0 0 150px}
.calc__field input[type=range]{width:100%;accent-color:var(--accent);height:6px}
.calc__field input[type=number]{background:var(--bg);border:1px solid rgba(255,255,255,.14);color:var(--text);padding:9px 12px;border-radius:var(--radius);font:inherit;width:100%}
.calc__table{width:100%;border-collapse:collapse;font-size:.95rem}
.calc__table th,.calc__table td{text-align:left;padding:11px 12px;border-bottom:1px solid rgba(255,255,255,.07);vertical-align:middle}
.calc__table th{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.5px}
.calc__table .est{font-weight:800;color:var(--accent2);white-space:nowrap;font-size:1.05rem}
.calc__table td:nth-child(4){color:var(--muted);font-size:.88rem}
.calc__table tr[data-best] td:first-child:after{content:'\2605';color:var(--accent2);margin-left:6px}
.calc__table tr.is-jerkmate{background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 16%,transparent),transparent)}
.calc__table tr.is-jerkmate td:first-child{font-weight:800}
.calc__table .btn{padding:6px 12px;font-size:.82rem;margin-left:6px}
.calc__note{color:var(--muted);font-size:.82rem;margin-top:14px;font-style:italic}
.bannerrow{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center;margin:20px 0}
.banner{display:inline-block;line-height:0;flex:0 0 auto;transition:transform .15s}
.banner:hover{transform:translateY(-2px)}
.banner img{max-width:100%;height:auto;border-radius:8px;display:block;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.mobcta{display:none}
@media(max-width:760px){.mobcta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:80;padding:10px 14px;background:color-mix(in srgb,var(--surface) 94%,transparent);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1)}.mobcta .btn{width:100%;justify-content:center}}
/* Scorecard + methodology (v2) */
.scorecard{background:var(--bg);border-radius:var(--radius);padding:18px;margin:18px 0;border:1px solid rgba(255,255,255,.08)}
.scorecard__head{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.scorecard__score{flex:none;width:66px;height:66px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:conic-gradient(var(--accent) calc(var(--p,80)*1%),color-mix(in srgb,var(--text) 12%,transparent) 0);position:relative}
.scorecard__score::before{content:'';position:absolute;inset:5px;border-radius:50%;background:var(--bg)}
.scorecard__num{position:relative;z-index:1;font-weight:800;font-size:1.3rem;line-height:1}
.scorecard__out{position:relative;z-index:1;font-size:.62rem;color:var(--muted)}
.scorecard__name strong{font-size:1.1rem}.scorecard__name a{color:var(--text)}
.scorecard__meta{color:var(--muted);font-size:.85rem;margin-left:8px}
.scorecard__cats{list-style:none;display:grid;gap:9px}
.scorecard__cats li{display:grid;grid-template-columns:135px 1fr 44px;align-items:center;gap:10px;font-size:.85rem}
.scorecard__cat{color:var(--muted)}
.scorecard__bar{height:7px;border-radius:99px;background:color-mix(in srgb,var(--text) 11%,transparent);overflow:hidden}
.scorecard__bar span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.scorecard__val{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
@media(max-width:520px){.scorecard__cats li{grid-template-columns:88px 1fr 40px;font-size:.8rem}}
.weights{list-style:none;display:grid;gap:12px;margin:14px 0}
.weights li{display:grid;grid-template-columns:46px 1fr;gap:14px;align-items:start}
.weights__pts{font-weight:800;font-size:1.35rem;color:var(--accent2);line-height:1.1}
.weights__lab span{color:var(--muted);font-size:.9rem}
/* Compare engine (v2) */
.compare__table{width:100%;border-collapse:collapse;margin:14px 0;background:var(--surface);border-radius:var(--radius);overflow:hidden}
.compare__table th,.compare__table td{padding:12px 14px;text-align:center;border-bottom:1px solid rgba(255,255,255,.07);vertical-align:middle}
.compare__table thead th{font-size:1.05rem;font-weight:800}
.compare__table tbody th{text-align:left;color:var(--muted);font-weight:600;font-size:.84rem}
.compare__table th.is-win{color:var(--accent2)}
.compare__table thead th.is-win:after{content:'\2605';display:block;font-size:.7rem;color:var(--accent2)}
.compare__score strong{font-size:1.3rem;color:var(--accent2)}
.compare__table td a.btn{padding:8px 14px;font-size:.86rem}
.compare__table td a{font-size:.82rem}
.compare__verdict{text-align:center;color:var(--muted);margin:14px 0;font-style:italic}
.compare__links{display:flex;flex-wrap:wrap;gap:9px;margin:12px 0}
/* Best-for leaderboards (v2) */
.lboard{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);overflow:hidden;margin:14px 0}
.lboard th,.lboard td{padding:11px 13px;border-bottom:1px solid rgba(255,255,255,.07);text-align:left;vertical-align:middle}
.lboard th{color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.5px}
.lboard .rank{font-weight:800;color:var(--accent2);text-align:center;width:34px}
.lboard .sc{font-weight:800;color:var(--accent2)}
.lboard tr[data-top] td{background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 12%,transparent),transparent)}
.lboard td a.btn{padding:7px 13px;font-size:.82rem}
.bestgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin:18px 0}
.bestcard{background:var(--surface);border-radius:var(--radius);padding:16px;border:1px solid rgba(255,255,255,.07);display:block;color:var(--text);transition:.15s}
.bestcard:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-3px)}
.bestcard strong{display:block;font-size:1.04rem;margin-bottom:5px}
.bestcard span{color:var(--muted);font-size:.88rem}
/* Finder quiz + tool hub (v2) */
.finder{max-width:760px}
.finder__q{border:none;margin:0 0 20px;padding:0}
.finder__q legend{font-weight:800;font-size:1.15rem;margin-bottom:10px}
.finder__opts{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.finder__opt{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:13px 15px;cursor:pointer;transition:.15s}
.finder__opt:hover{border-color:var(--accent)}.finder__opt input{accent-color:var(--accent)}
.finder__opt:has(input:checked){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface))}
.finder__results{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:16px 0}
.finder__card{background:var(--surface);border-radius:var(--radius);padding:18px;border:1px solid rgba(255,255,255,.08);position:relative;display:flex;flex-direction:column;gap:9px}
.finder__card.is-match{border-color:var(--accent2);box-shadow:0 0 0 1px var(--accent2)}
.finder__badge{position:absolute;top:-10px;left:14px;background:var(--accent2);color:#111;font-size:.7rem;font-weight:800;padding:3px 9px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px}
.finder__top{display:flex;align-items:center;gap:9px}.finder__top strong{font-size:1.1rem;flex:1}
.finder__rank,.finder__score{font-weight:800;color:var(--accent2)}
.finder__why{color:var(--muted);font-size:.86rem}
.finder__cta{display:flex;flex-direction:column;gap:6px;margin-top:auto}
.finder__rev{font-size:.82rem;color:var(--muted);text-align:center}
.toolhub{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:8px 0 26px}
.toolhub a{display:block;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:15px;color:var(--text);transition:.15s}
.toolhub a:hover{border-color:var(--accent);transform:translateY(-3px);text-decoration:none}
.toolhub strong{display:block;margin-bottom:3px;font-size:.98rem}.toolhub span{color:var(--muted);font-size:.83rem}
.card{border:none}
body{background:radial-gradient(900px 500px at 50% -12%,color-mix(in srgb,var(--accent) 15%,transparent),transparent 58%),var(--bg);background-attachment:fixed}
.hero::before{background:linear-gradient(105deg,var(--bg) 20%,color-mix(in srgb,var(--bg) 50%,transparent))}
.hero h1,article.content h2{font-style:italic}
.card{border-top:2px solid color-mix(in srgb,var(--accent) 70%,transparent)}
.card:hover{transform:translateY(-4px)}
.btn{box-shadow:0 8px 24px color-mix(in srgb,var(--accent) 36%,transparent)}
.badge{background:var(--accent)}
