/* ===== NexScript — FiveM marketplace (flat, v3) ===== */
:root{
  --bg:#08080a;
  --bg-2:#0b0b0e;
  --surface:#101013;
  --surface-2:#161619;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.22);
  --text:#f5f5f7;
  --muted:#9a9aa6;
  --muted-2:#5c5c66;
  --accent:#7c5cff;
  --accent-2:#a78bfa;
  --grad:linear-gradient(100deg,#a78bfa,#7c5cff);
  --radius:2px;
  --radius-lg:3px;
  --max:1280px;
  --mono:ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
/* Texture technique : grille hairline fixe, très discrète */
body::after{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.6;
  background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:72px 72px;
  -webkit-mask-image:radial-gradient(ellipse 95% 75% at 50% 0%,#000 25%,transparent 100%);mask-image:radial-gradient(ellipse 95% 75% at 50% 0%,#000 25%,transparent 100%)}
/* Bande cinématique (GIF voiture, N&B) */
.cine{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:24px 0}
.cine::before{content:"";position:absolute;inset:0;z-index:0;background:url('assets/bg.gif') center 58%/cover no-repeat;filter:grayscale(1) contrast(1.05) brightness(.9)}
.cine::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(8,8,12,.94),rgba(8,8,12,.4) 55%,rgba(8,8,12,.72)),linear-gradient(180deg,rgba(8,8,12,.5),rgba(8,8,12,.5))}
.cine-inner{position:relative;z-index:2;padding:88px 26px;display:flex;flex-direction:column;align-items:flex-start}
.cine-title{font-size:clamp(1.8rem,3.4vw,2.8rem);font-weight:700;margin:10px 0 8px}
.cine-sub{color:#c7c7d4;font-size:1.02rem;max-width:460px;margin-bottom:24px}
h1,h2,h3,h4,.brand-text,.p-price,.bb-price b,.hero-title{font-family:'Space Grotesk','Inter',sans-serif;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 26px}
.container.narrow{max-width:840px}
.accent-text{color:var(--accent-2)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.eyebrow::before{content:"";width:18px;height:2px;background:var(--accent)}
.stars-sm{color:#fbbf24;letter-spacing:2px;font-size:13px}
.arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;padding:11px 18px;border-radius:11px;border:1px solid transparent;cursor:pointer;transition:.2s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;font-weight:600}
.btn-primary:hover{background:#8e72ff}
.btn-ghost{background:transparent;border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.05)}
.btn-lg{padding:14px 24px;font-size:15px}
.btn-sm{padding:8px 16px;font-size:13px}
.btn.full{width:100%;justify-content:center}

/* ===== Topbar ===== */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,10,13,.85);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:22px;height:64px}
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand-mark{color:#fff;display:grid;place-items:center;filter:drop-shadow(0 3px 10px rgba(124,92,255,.45));transition:transform .3s,filter .3s}
.brand:hover .brand-mark{transform:rotate(-6deg) scale(1.08);filter:drop-shadow(0 4px 16px rgba(124,92,255,.85))}
.brand-text{font-size:19px;font-weight:700}
.nav-links{display:flex;gap:22px;font-size:14px;font-weight:500;flex:none}
.nav-links a{color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-search{flex:1;max-width:440px;margin:0 auto;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:0 14px;height:40px;color:var(--muted-2);transition:.2s}
.nav-search:focus-within{border-color:var(--accent);color:var(--muted)}
.nav-search input{flex:1;background:none;border:0;outline:0;color:var(--text);font-size:14px;font-family:inherit}
.nav-search input::placeholder{color:var(--muted-2)}
.nav-utils{display:flex;align-items:center;gap:8px;flex:none}
.util{background:none;border:0;color:var(--muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;padding:8px;border-radius:9px;transition:.2s;display:flex;align-items:center}
.util:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:0 26px;max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s;border-bottom:1px solid transparent}
.mobile-menu.open{max-height:460px;padding:16px 26px 24px;border-bottom-color:var(--line)}
.nav-search.mobile{max-width:none;margin:0 0 8px}
.mobile-menu>a{padding:12px 0;color:var(--muted);border-bottom:1px solid var(--line);font-weight:500}
.mobile-menu>a.btn{border-bottom:0;margin-top:10px;color:#fff;justify-content:center}

/* ===== Hero (premier écran, plein cadre) ===== */
.hero{position:relative;isolation:isolate;min-height:calc(100vh - 64px);display:flex;flex-direction:column;justify-content:center;padding:60px 0 0;overflow:hidden}
.hero-bg{position:absolute;top:-64px;left:0;right:0;bottom:0;z-index:-2}
.hero-bg::before{content:"";position:absolute;inset:0;background:url('assets/hero.jpg') center 26%/cover no-repeat;filter:grayscale(.35) brightness(.62) contrast(1.12) saturate(1.1)}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 70% at 88% 35%,rgba(124,92,255,.28),transparent 60%),
  linear-gradient(90deg,var(--bg) 0%,rgba(8,8,10,.78) 38%,rgba(8,8,10,.25) 100%),
  linear-gradient(180deg,var(--bg) 0%,transparent 18% 58%,var(--bg) 100%)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;flex:1;width:100%}
.hero-kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-2);margin-bottom:26px}
.hero-kicker::before{content:"";width:34px;height:1px;background:var(--accent)}
.hero-title{font-size:clamp(2.7rem,6.6vw,5.6rem);line-height:1.12;letter-spacing:-.035em;font-weight:700;margin-bottom:26px;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero-hl{background:var(--accent);color:#fff;padding:.03em .16em;border-radius:2px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.hero-dot{color:var(--text)}
.hero-sub{font-size:clamp(1rem,1.3vw,1.15rem);color:var(--muted);max-width:460px;margin-bottom:32px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-meta{display:flex;flex-wrap:wrap;gap:0}
.hero-meta span{font-family:var(--mono);font-size:12px;color:var(--muted);padding:8px 18px;border-left:1px solid var(--line)}
.hero-meta span:first-child{padding-left:0;border-left:0}
.hero-meta b{color:var(--text);font-weight:600}

.hero-visual{position:relative;aspect-ratio:1/1;max-height:62vh}

/* Bandeau frameworks qui défile */
.hero-marquee{position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:16px 0;background:rgba(8,8,10,.5);backdrop-filter:blur(4px);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.hero-marquee-track{display:flex;align-items:center;gap:30px;width:max-content;animation:heromq 28s linear infinite;font-family:var(--mono);font-size:15px;font-weight:500;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.hero-marquee-track i{color:var(--accent);font-style:normal}
@keyframes heromq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.hero-marquee-track{animation:none}}
/* Logo NexScript animé, sans fond/panneau */
.hv-logo{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none}
.hv-logo svg{position:relative;z-index:2;display:block;filter:drop-shadow(0 0 26px rgba(124,92,255,.65));animation:hvFloat 5s ease-in-out infinite}
.hv-halo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;height:300px;border-radius:50%;z-index:0;background:radial-gradient(circle,rgba(124,92,255,.5),transparent 60%);filter:blur(40px);animation:hvHalo 4s ease-in-out infinite}
.hv-ring{position:absolute;top:50%;left:50%;width:230px;height:230px;border-radius:50%;z-index:1;background:conic-gradient(from 0deg,transparent 0 68%,#7c5cff 84%,#3b82f6 95%,transparent 100%);-webkit-mask:radial-gradient(circle,transparent 98px,#000 100px,#000 113px,transparent 115px);mask:radial-gradient(circle,transparent 98px,#000 100px,#000 113px,transparent 115px);opacity:.8;animation:hvSpin 8s linear infinite}
.hv-n,.hv-s{stroke-dasharray:240;stroke-dashoffset:240;animation:hvDraw 1.4s ease forwards}
.hv-s{animation-delay:.5s}
@keyframes hvDraw{to{stroke-dashoffset:0}}
@keyframes hvFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes hvSpin{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes hvHalo{0%,100%{opacity:.5}50%{opacity:.92}}
@media (prefers-reduced-motion:reduce){.hv-n,.hv-s{stroke-dashoffset:0;animation:none}.hv-logo svg,.hv-ring,.hv-halo{animation:none}}

/* ===== Sections / block heads ===== */
.section{padding:64px 0}
.block-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px}
.block-title{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:700}
.block-sub{color:var(--muted);font-size:.98rem;margin-top:8px;max-width:560px}
.block-head-right{display:flex;align-items:center;gap:18px;flex:none}
.link-arrow{font-size:14px;font-weight:600;color:var(--accent)}
.link-arrow:hover{color:#9a82ff}
.carousel-nav{display:flex;gap:8px}
.cnav{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-strong);background:var(--surface);color:var(--text);font-size:20px;cursor:pointer;transition:.2s;display:grid;place-items:center;line-height:1}
.cnav:hover{background:var(--accent);border-color:var(--accent)}

/* ===== Categories carousel ===== */
.cats-track{display:flex;gap:14px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:8px;scrollbar-width:none}
.cats-track::-webkit-scrollbar{display:none}
.cat-card{flex:0 0 268px;display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;transition:.25s}
.cat-card:hover{border-color:var(--line-strong);background:var(--surface-2)}
.cat-ic{width:42px;height:42px;flex:none;display:grid;place-items:center;border-radius:11px;background:rgba(124,92,255,.1);border:1px solid var(--line);color:var(--accent)}
.cat-ic svg{width:22px;height:22px}
.cat-meta{flex:1;min-width:0}
.cat-card h3{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-count{font-size:12.5px;color:var(--muted-2)}
.cat-go{color:var(--muted-2);font-size:18px;transition:.25s}
.cat-card:hover .cat-go{color:var(--accent);transform:translateX(3px)}

/* ===== Products grid ===== */
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:13px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:100px;padding:8px 16px;cursor:pointer;transition:.2s;font-family:inherit}
.chip:hover{color:var(--text)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.product{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.product:hover{border-color:rgba(124,92,255,.5);transform:translateY(-4px)}
.p-thumb{position:relative;aspect-ratio:16/10;display:grid;place-items:center;border-bottom:1px solid var(--line);background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.16),transparent 66%),var(--surface-2)}
.p-thumb.t2{background:radial-gradient(110% 90% at 50% 6%,rgba(59,130,246,.18),transparent 66%),var(--surface-2)}
.p-thumb.t3{background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.1),transparent 66%),var(--surface-2)}
.p-thumb.t4{background:radial-gradient(110% 90% at 50% 6%,rgba(224,81,143,.14),transparent 66%),var(--surface-2)}
.p-emoji{font-size:46px;opacity:.92;filter:drop-shadow(0 8px 16px rgba(0,0,0,.45))}
.p-badge{position:absolute;top:12px;left:12px;z-index:2;font-size:11px;font-weight:700;padding:5px 11px;border-radius:100px;color:#fff}
.p-badge.hot{background:linear-gradient(120deg,#f59e0b,#ef4444)}
.p-badge.new{background:var(--accent)}
.p-body{padding:18px;display:flex;flex-direction:column;flex:1}
.p-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.p-tags span{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:6px;padding:3px 8px}
.p-body h3{font-size:1.15rem;font-weight:600;margin-bottom:6px}
.p-body>p{color:var(--muted);font-size:.9rem;margin-bottom:16px;flex:1}
.p-foot{display:flex;align-items:center;justify-content:space-between}
.p-price{font-size:1.3rem;font-weight:700;color:var(--text)}

/* ===== Bundle banner ===== */
.bundle-banner{display:grid;grid-template-columns:1.5fr 1fr;gap:30px;align-items:center;background:linear-gradient(120deg,rgba(124,92,255,.14),rgba(59,130,246,.06));border:1px solid var(--line-strong);border-radius:var(--radius-lg);padding:42px}
.bb-actions{display:flex;align-items:center;gap:18px;margin-top:24px;flex-wrap:wrap}
.bb-price{font-size:1.1rem;color:var(--muted)}
.bb-price s{color:var(--muted-2);margin-right:6px}
.bb-price b{font-size:1.7rem;color:var(--text)}
.bb-icons{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bb-icons span{aspect-ratio:1;display:grid;place-items:center;font-size:34px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}

/* ===== Trust strip ===== */
.trust-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:40px 26px}
.ts{display:flex;gap:13px;align-items:flex-start}
.ts-ic{width:42px;height:42px;flex:none;display:grid;place-items:center;font-size:20px;border-radius:11px;background:rgba(124,92,255,.12);border:1px solid var(--line-strong)}
.ts h4{font-size:1rem;font-weight:600;margin-bottom:2px}
.ts p{font-size:.85rem;color:var(--muted)}

/* ===== Reviews ===== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px}
.review blockquote{font-size:.96rem;color:var(--text);margin:12px 0 18px;line-height:1.6}
.review figcaption{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--muted)}
.rev-ava{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;background:var(--accent);font-size:13px}

/* ===== FAQ ===== */
.faq{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:2px 22px;transition:.25s}
.faq-item[open]{border-color:var(--line-strong);background:var(--surface-2)}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 0;font-weight:600;font-size:1rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.5rem;color:var(--accent);transition:transform .3s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{color:var(--muted);padding:0 0 20px;font-size:.95rem}

/* ===== CTA ===== */
.cta-final{padding:30px 0 90px}
.cta-box{text-align:center;padding:64px 40px;border-radius:var(--radius-lg);background:linear-gradient(120deg,rgba(124,92,255,.14),rgba(59,130,246,.06));border:1px solid var(--line-strong)}
.cta-box h2{font-size:clamp(1.7rem,3.2vw,2.6rem);font-weight:700;margin-bottom:14px}
.cta-box p{color:var(--muted);font-size:1.05rem;max-width:520px;margin:0 auto 28px}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== Footer ===== */
.footer{border-top:1px solid var(--line);padding:56px 0 30px;background:var(--bg-2)}
.footer-inner{display:grid;grid-template-columns:1.3fr 2fr;gap:48px;margin-bottom:40px}
.footer-brand p{color:var(--muted);font-size:.93rem;max-width:300px;margin-top:14px}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer-col h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);margin-bottom:14px}
.footer-col a{display:block;color:var(--muted);font-size:.92rem;padding:6px 0;transition:color .2s}
.footer-col a:hover{color:var(--text)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;border-top:1px solid var(--line);font-size:.85rem;color:var(--muted-2)}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.2,.7,.3,1),transform .6s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:1080px){
  .nav-links{display:none}
  .nav-search{max-width:none}
}
@media(max-width:900px){
  .nav-search,.nav-utils{display:none}
  .nav-burger{display:flex}
  .mobile-menu{display:flex}
  .hero{min-height:auto;padding-top:48px}
  .hero-grid{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .hero-visual{order:-1;aspect-ratio:16/9;max-height:240px}
  .hero-meta span{padding:8px 12px}
  .products,.reviews,.trust-grid{grid-template-columns:repeat(2,1fr)}
  .bundle-banner{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
}
@media(max-width:600px){
  .block-head{flex-direction:column;align-items:flex-start}
  .products,.reviews,.trust-grid{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
  .section{padding:48px 0}
  .cta-box,.bundle-banner{padding:40px 22px}
  .bb-icons{grid-template-columns:repeat(4,1fr)}
}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== Product detail page ===== */
.pd{padding:48px 0 90px}
.pd-back{display:inline-block;font-size:14px;color:var(--muted);margin-bottom:28px;transition:color .2s}
.pd-back:hover{color:var(--text)}
.pd-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:40px;align-items:start}
.pd-media{position:sticky;top:88px}
.pd-thumb{position:relative;aspect-ratio:16/10;display:grid;place-items:center;border:1px solid var(--line);border-radius:var(--radius-lg);background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.18),transparent 66%),var(--surface-2)}
.pd-thumb.t2{background:radial-gradient(110% 90% at 50% 6%,rgba(59,130,246,.2),transparent 66%),var(--surface-2)}
.pd-thumb.t3{background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.12),transparent 66%),var(--surface-2)}
.pd-thumb.t4{background:radial-gradient(110% 90% at 50% 6%,rgba(224,81,143,.16),transparent 66%),var(--surface-2)}
.pd-thumb .p-emoji{font-size:88px}
.pd-thumb .p-badge{position:absolute;top:14px;left:14px}
.pd-shots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}
.pd-shot{aspect-ratio:16/10;border:1px solid var(--line);border-radius:10px;background:var(--surface-2);opacity:.7}
.pd-info{padding-top:4px}
.pd-info .p-tags{margin-bottom:14px}
.pd-title{font-size:clamp(1.9rem,3.4vw,2.8rem);font-weight:700;margin-bottom:10px}
.pd-tagline{color:var(--muted);font-size:1.08rem;margin-bottom:24px;line-height:1.55}
.pd-buybox{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;margin-bottom:26px}
.pd-price{display:block;font-family:'Space Grotesk',sans-serif;font-size:2.4rem;font-weight:700;line-height:1;margin-bottom:16px}
.pd-buy{width:100%;justify-content:center;font-size:16px}
.pd-secure{display:block;text-align:center;font-size:12px;color:var(--muted-2);margin-top:12px}
.pd-feats{list-style:none;display:flex;flex-direction:column;gap:12px}
.pd-feats li{position:relative;padding-left:28px;font-size:.98rem;color:var(--muted)}
.pd-feats li::before{content:'';position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;background:rgba(124,92,255,.14);border:1px solid var(--accent)}
.pd-feats li::after{content:'✓';position:absolute;left:3px;top:-1px;font-size:11px;color:var(--accent);font-weight:700}
.pd-desc{max-width:760px;margin-top:54px;padding-top:34px;border-top:1px solid var(--line)}
.pd-desc h2{font-size:1.4rem;font-weight:600;margin-bottom:16px}
.pd-desc p{color:var(--muted);font-size:1.02rem;line-height:1.75;margin-bottom:16px}
@media(max-width:900px){.pd-grid{grid-template-columns:1fr;gap:28px}.pd-media{position:static}}

/* ===== Étoiles (affichage) ===== */
.stars,.rv-stars,.rv-item-stars,.bcard-rate .stars{display:inline-flex;gap:1px;color:#3a3a48;font-size:13px;line-height:1}
.stars span.on,.rv-stars span.on,.rv-item-stars span.on{color:#fbbf24}

/* ===== Boutique (browse) ===== */
.browse-hero{position:relative;overflow:hidden;text-align:center;padding:64px 0 30px;border-bottom:1px solid var(--line)}
.browse-hero::before{content:"";position:absolute;inset:0;z-index:-1;background:url('assets/hero.jpg') center/cover no-repeat;filter:grayscale(1) brightness(.26);opacity:.55;-webkit-mask-image:linear-gradient(180deg,#000,transparent);mask-image:linear-gradient(180deg,#000,transparent)}
.browse-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:700}
.browse-hero p{color:var(--muted);margin-top:8px}
.browse-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:24px 0 18px}
.bcat{font-size:14px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:9px 18px;cursor:pointer;transition:.2s;font-family:inherit}
.bcat:hover{color:var(--text)}
.bcat.active{background:var(--accent);border-color:var(--accent);color:#fff}
.browse-search{max-width:560px;margin:0 auto;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:0 16px;height:48px;color:var(--muted-2)}
.browse-search input{flex:1;background:none;border:0;outline:0;color:var(--text);font-size:15px;font-family:inherit}
.browse-search input::placeholder{color:var(--muted-2)}
.browse-section{padding-top:36px}
.browse-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.browse-h2{font-size:1.5rem;font-weight:700}
.browse-count{color:var(--muted-2);font-weight:500;font-size:1rem}
.browse-controls{display:flex;gap:10px;flex-wrap:wrap}
#browseSort,.price-in{background:var(--surface);border:1px solid var(--line);border-radius:10px;color:var(--text);font-family:inherit;font-size:13px;height:40px;padding:0 12px;outline:0;cursor:pointer}
#browseSort:focus,.price-in:focus{border-color:var(--accent)}
.price-in{width:96px;cursor:text}
.browse-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.bcard:hover{border-color:rgba(124,92,255,.5);transform:translateY(-4px)}
.bcard-thumb{position:relative;aspect-ratio:16/10;display:grid;place-items:center;border-bottom:1px solid var(--line);background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.16),transparent 66%),var(--surface-2)}
.bcard-thumb.t2{background:radial-gradient(110% 90% at 50% 6%,rgba(59,130,246,.18),transparent 66%),var(--surface-2)}
.bcard-thumb.t3{background:radial-gradient(110% 90% at 50% 6%,rgba(124,92,255,.1),transparent 66%),var(--surface-2)}
.bcard-thumb.t4{background:radial-gradient(110% 90% at 50% 6%,rgba(224,81,143,.14),transparent 66%),var(--surface-2)}
.bcard-emoji{font-size:46px;opacity:.92;filter:drop-shadow(0 8px 16px rgba(0,0,0,.45))}
.bcard-badge{position:absolute;top:10px;left:10px;font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:100px;color:#fff}
.bcard-badge.hot{background:linear-gradient(120deg,#f59e0b,#ef4444)}
.bcard-badge.new{background:var(--accent)}
.bcard-cat{position:absolute;top:10px;right:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:rgba(10,10,13,.6);backdrop-filter:blur(6px);border:1px solid var(--line);padding:3px 8px;border-radius:7px}
.bcard-body{padding:14px 16px;display:flex;flex-direction:column;gap:10px;flex:1}
.bcard-title h3{font-size:1.05rem;font-weight:600}
.bcard-rate{display:flex;align-items:center;gap:7px}
.bcard-rate .rnum{font-size:12px;font-weight:600;color:var(--text)}
.bcard-rate .rcount{font-size:12px;color:var(--muted-2)}
.like{margin-left:auto;display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:8px;color:var(--muted);font-family:inherit;font-size:12px;font-weight:600;padding:5px 9px;cursor:pointer;transition:.2s}
.like:hover{color:var(--text)}
.like.on{color:var(--accent);border-color:rgba(124,92,255,.5);background:rgba(124,92,255,.1)}
.bcard-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:4px}
.bcard-author{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.bcard-av{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;background:var(--grad)}
.bcard-price{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:6px 12px;color:var(--text)}
.browse-empty{text-align:center;color:var(--muted);padding:40px 0}
@media(max-width:1080px){.browse-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.browse-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.browse-grid{grid-template-columns:1fr}}

/* ===== Bloc avis ===== */
.reviews-block{margin-top:54px;padding-top:34px;border-top:1px solid var(--line)}
.rv-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.rv-head h2{font-size:1.4rem;font-weight:600}
.rv-summary{display:flex;align-items:center;gap:10px}
.rv-avg{font-family:'Space Grotesk',sans-serif;font-size:1.6rem;font-weight:700}
.rv-summary .rv-stars{font-size:16px}
.rv-count{font-size:13px;color:var(--muted-2)}
.rv-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;margin-bottom:28px}
.rv-form h3{font-size:1.05rem;font-weight:600;margin-bottom:14px}
.rv-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.rv-input{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;color:var(--text);font-family:inherit;font-size:14px;padding:11px 14px;outline:0}
.rv-input:focus{border-color:var(--accent)}
#rvName{flex:1;min-width:180px}
.rv-textarea{width:100%;resize:vertical;line-height:1.5}
.rv-rating{display:inline-flex;gap:2px;font-size:26px;line-height:1}
.rv-rating button{background:none;border:0;color:#3a3a48;cursor:pointer;padding:0 2px;transition:.15s;font-family:inherit}
.rv-rating button:hover,.rv-rating button.on{color:#fbbf24}
.rv-actions{display:flex;align-items:center;justify-content:flex-end;gap:14px;margin-top:14px}
.rv-error{color:#ef6b6b;font-size:13px;margin-right:auto}
.rv-list{display:flex;flex-direction:column;gap:14px}
.rv-none{color:var(--muted);font-size:.95rem}
.rv-item{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.rv-item-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.rv-ava{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;background:var(--grad)}
.rv-name{font-weight:600;font-size:14px}
.rv-item-stars{font-size:13px}
.rv-ago{margin-left:auto;font-size:12px;color:var(--muted-2)}
.rv-text{color:var(--muted);font-size:.95rem;line-height:1.6}

/* ===== DA sombre — sharp & éditorial (anti "template IA") ===== */
/* Coins quasi droits partout (fini le trop arrondi) */
.btn,.pill,.kicker,.chip,.bcat,.like,.util,.nav-search,.browse-search,#browseSort,.price-in,
.rv-input,.p-badge,.bcard-badge,.sc-badge,.bcard-cat,.bcard-price,.spec-tag,.hv-tag,.cnav{border-radius:2px}
.product,.bcard,.cat-card,.feature-card,.faq-item,.rv-item,.rv-form,.spec-card,.cta-box,.bundle-banner,.bb-icons span,.cat-ic,.ts-ic,.sc-ic{border-radius:3px}
/* Hover net : pas de halo mou ni de rebond, barre d'accent franche */
.product,.bcard,.cat-card,.spec-card,.feature-card{box-shadow:none;transition:border-color .2s,box-shadow .2s}
.product:hover,.bcard:hover{transform:none;border-color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}
.cat-card:hover{transform:none;border-color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}
/* Marqueur nav carré */
.nav-links a::after{border-radius:0;height:2px}
/* Chiffres en chasse fixe (prix, notes) = vibe technique */
.p-price,.bcard-price,.pd-price,.rnum,.rv-avg{font-variant-numeric:tabular-nums}
/* Boutons : libellé compact et tranché */
.btn{letter-spacing:.01em}

/* Transition entre pages : panneau qui balaie avec liseré accent */
#pt{position:fixed;inset:0;z-index:9999;pointer-events:none;background:var(--bg-2);transform:translateY(0);
  animation:ptReveal .55s cubic-bezier(.76,0,.24,1) forwards}
#pt::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--accent);box-shadow:0 0 22px var(--accent)}
@keyframes ptReveal{0%{transform:translateY(0)}100%{transform:translateY(101%)}}
@keyframes ptCover{0%{transform:translateY(-101%)}100%{transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){#pt{display:none}}

/* Avatar Discord dans le bouton Connexion */
.dc-ava{width:20px;height:20px;border-radius:50%;object-fit:cover;display:inline-block}
[data-discord="login"]{gap:8px}

/* Spotlight curseur + tilt 3D des cartes */
.spotlight{position:fixed;left:50%;top:50%;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:-1;opacity:0;transform:translate(-50%,-50%);transition:opacity .3s;background:radial-gradient(circle,rgba(124,92,255,.12),transparent 60%)}
.product,.bcard,.cat-card{transition:transform .12s ease,border-color .2s,box-shadow .2s;transform-style:preserve-3d}
