:root{
  --bg:#0b0e14; --card:#111521; --muted:#98a2b3; --text:#e5e7eb; --brand:#7c3aed; --brand-2:#22d3ee; --ring:#334155;
}
:root[data-theme="light"]{
  --bg:#f7f8fb; --card:#ffffff; --muted:#667085; --text:#0b1220; --brand:#6d28d9; --brand-2:#0891b2; --ring:#e5e7eb;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif; background:linear-gradient(180deg, var(--bg) 0%, rgba(0,0,0,0) 400px), var(--bg); color:var(--text)}
img{max-width:100%; display:block}
.container{max-width:1200px; margin:0 auto; padding:16px}

.header{position:sticky; top:0; z-index:20; backdrop-filter:saturate(160%) blur(6px); background:color-mix(in oklab, var(--bg) 85%, transparent); border-bottom:1px solid var(--ring)}
.nav{display:flex; align-items:center; gap:12px; padding:12px 0}
.logo{display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:.2px}
.logo .dot{width:10px; height:10px; border-radius:999px; background:conic-gradient(from 180deg, var(--brand), var(--brand-2)); box-shadow:0 0 18px color-mix(in oklab, var(--brand) 70%, transparent)}
.logo .sub{opacity:.8}
.nav-right{margin-left:auto; display:flex; align-items:center; gap:10px}

.btn{background:linear-gradient(135deg, var(--brand), var(--brand-2)); color:#0b0e14; padding:10px 14px; border-radius:12px; border:none; font-weight:700; cursor:pointer; text-decoration:none; display:inline-block}
.btn.secondary{background:transparent; color:var(--text); border:1px solid var(--ring)}
.btn.active{outline:2px solid var(--brand)}

.hero{display:grid; grid-template-columns:1.2fr .8fr; gap:20px; padding:18px 0 6px}
.hero-card{position:relative; overflow:hidden; border-radius:18px; border:1px solid var(--ring); background:linear-gradient(180deg,#0f172a,#0b0e14)}
:root[data-theme="light"] .hero-card{background:linear-gradient(180deg,#eef2ff,#ffffff)}
.hero-media{height:280px; background:url('https://images.unsplash.com/photo-1517602302552-471fe67acf66?q=80&w=1200&auto=format&fit=crop') center/cover no-repeat}
.hero-content{position:absolute; inset:auto 0 0 0; padding:18px; background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.65) 65%, rgba(0,0,0,.85) 100%); color:#fff}
:root[data-theme="light"] .hero-content{background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.65) 65%, rgba(255,255,255,.85) 100%); color:#0b1220}
.pill{display:inline-flex; align-items:center; gap:8px; background:rgba(34,211,238,.15); color:#a5f3fc; padding:6px 10px; border-radius:999px; border:1px solid rgba(34,211,238,.3); font-size:12px}
.muted{color:var(--muted); font-size:14px}
.search{background:color-mix(in oklab, var(--bg) 85%, #0000); border:1px solid var(--ring); display:flex; gap:8px; padding:10px; border-radius:12px}
.search input{flex:1; background:transparent; border:none; outline:none; color:var(--text)}
.chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px}
.chip{font-size:12px; padding:6px 10px; border-radius:999px; border:1px solid var(--ring); background:color-mix(in oklab, var(--bg) 92%, #0000); cursor:pointer}
.chip.active{border-color:transparent; background:linear-gradient(135deg, color-mix(in oklab, var(--brand) 25%, #0000), color-mix(in oklab, var(--brand-2) 25%, #0000))}

.section{margin:18px 0}
.section-head{display:flex; align-items:center; gap:10px}
.section-head h2{margin:0; font-size:18px}
.grid{display:grid; grid-template-columns:repeat(6,1fr); gap:14px}
.card{position:relative; background:var(--card); border:1px solid var(--ring); border-radius:14px; overflow:hidden; transition:transform .15s ease}
.card:hover{transform:translateY(-2px)}
.thumb{aspect-ratio:16/9; background:#0b0e14; object-fit:cover; width:100%}
.card .meta{padding:10px}
.title{font-size:14px; font-weight:600; line-height:1.2}
.sub{font-size:12px; color:var(--muted); margin-top:4px}
.badge{position:absolute; top:8px; left:8px; font-size:11px; background:rgba(0,0,0,.6); color:#fff; padding:4px 8px; border-radius:999px; border:1px solid rgba(255,255,255,.15)}
.badge.right{left:auto; right:8px}
.progress-wrap{position:absolute; left:0; right:0; bottom:0; height:4px; background:rgba(255,255,255,.06)}
.progress{height:100%; width:0; background:linear-gradient(90deg, var(--brand), var(--brand-2))}

/* Détail */
.detail{display:grid; grid-template-columns: 1.1fr .9fr; gap:18px; margin-top:16px}
.poster{border-radius:16px; border:1px solid var(--ring); min-height:360px; background-size:cover; background-position:center}
.info .title{font-size:28px}
.tags{display:flex; flex-wrap:wrap; gap:8px}

/* Stats bar */
.stats{display:flex; flex-wrap:wrap; gap:12px; align-items:center; padding:10px; border:1px solid var(--ring); border-radius:12px; background:color-mix(in oklab, var(--bg) 92%, #0000)}
.stats > div{display:flex; align-items:center; gap:6px; font-size:14px}

/* Commentaires */
.comments{margin-top:14px}
.comment-form{display:grid; gap:10px; margin:10px 0}
.comment-form .row{display:flex; gap:8px}
.comment-form input, .comment-form textarea{flex:1; background:transparent; border:1px solid var(--ring); color:var(--text); border-radius:10px; padding:10px}
#starWrap{gap:6px}
#starWrap button{background:#0c1324; border:1px solid var(--ring); color:#aaa; border-radius:8px; padding:6px 10px; cursor:pointer}
#starWrap button.active{color:#ffd256; border-color:#ffd256}
.comment{border:1px solid var(--ring); border-radius:12px; padding:10px; background:color-mix(in oklab, var(--bg) 92%, #0000); margin-bottom:10px}
.comment-head{display:flex; align-items:center; gap:8px}
.stars{color:#ffd256}

.footer{margin:30px 0 40px; color:var(--muted); font-size:12px; text-align:center}

@media (max-width:1100px){
  .grid{grid-template-columns:repeat(4,1fr)}
  .hero{grid-template-columns:1fr}
  .detail{grid-template-columns:1fr}
  .hero-media{height:220px}
}
@media (max-width:700px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .hero-media{height:180px}
}

/* Lisibilité des catégories en mode sombre */
:root[data-theme="dark"] .chip {
  color: var(--text);
  font-weight: 600;
  background: #0f162b;
  border-color: #4b5563;
}

:root[data-theme="dark"] .chip.active {
  color: var(--text);
  border-color: transparent;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--brand) 40%, #0000),
    color-mix(in oklab, var(--brand-2) 40%, #0000)
  );
}
