@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --cover-ratio:2/1;
  --bg:#0a0a0f; --surface:#111118; --card:#16161f;
  --accent:#e8ff47; --text:#f0f0f5; --muted:#6b6b80;
  --border:rgba(255,255,255,0.07);
}
[data-theme="light"] {
  --bg:#f4f4f0; --surface:#eaeae4; --card:#e2e2da;
  --accent:#5c7f00; --text:#1a1a1a; --muted:#777770;
  --border:rgba(0,0,0,0.10);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:300;min-height:100vh;overflow-x:hidden;transition:background .25s,color .25s}

/* noise */
body::before{content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.03;pointer-events:none;z-index:9999}

/* header */
header{position:relative;padding:64px 56px 44px;overflow:hidden}
header::after{content:'';position:absolute;top:-120px;right:-80px;width:460px;height:460px;
  background:radial-gradient(circle,rgba(232,255,71,.11) 0%,transparent 70%);pointer-events:none}
.header-label{font-size:10px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
  color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.header-label::before{content:'';display:inline-block;width:22px;height:1px;background:var(--accent)}
.header-label a:hover{text-decoration:underline;text-underline-offset:3px}
h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(52px,7vw,100px);line-height:.9;letter-spacing:.02em}
h1 span{color:var(--accent)}
.header-meta{margin-top:22px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.badge{background:var(--card);border:1px solid var(--border);padding:4px 13px;border-radius:100px;font-size:12px;color:var(--text)}
.badge strong{color:var(--accent)}

/* toolbar */
.toolbar{padding:0 56px 36px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.search-input{flex:1;min-width:200px;max-width:380px;background:var(--card);border:1px solid var(--border);
  border-radius:7px;padding:11px 18px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);outline:none;transition:border-color .2s}
.search-input::placeholder{color:var(--muted)}
.search-input:focus{border-color:rgba(232,255,71,.4)}
.filter-select{background:var(--card);border:1px solid var(--border);border-radius:7px;
  padding:11px 14px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text);outline:none;cursor:pointer}
.filter-select:focus{border-color:rgba(232,255,71,.4)}

/* divider */
.divider{height:1px;background:var(--border);margin:0 56px 0}

/* alphabet nav */
.alpha-nav{padding:12px 56px 0;display:flex;flex-wrap:wrap;gap:4px}
.alpha-btn{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:.05em;
  padding:3px 8px;border-radius:3px;cursor:pointer;border:none;background:transparent;
  color:var(--muted);transition:background .15s,color .15s}
.alpha-btn:hover,.alpha-btn.active{background:rgba(232,255,71,.12);color:var(--accent)}
.alpha-btn.disabled{opacity:.2;cursor:default;pointer-events:none}
.alpha-letter-anchor{scroll-margin-top:20px}

/* list */
.game-list{padding:0 56px 80px}
.game-row{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--border);
  text-decoration:none;color:inherit;transition:background .18s;border-radius:6px;
  animation:fadeUp .4s both;cursor:pointer}
.game-row:hover{background:rgba(255,255,255,.03);padding-left:10px;padding-right:10px;margin:0 -10px}
.game-row:hover .row-title{color:var(--accent)}
.game-row:hover .row-arrow{opacity:1;transform:translateX(0)}

.row-thumb{width:128px;height:auto;aspect-ratio:var(--cover-ratio);border-radius:4px;object-fit:cover;flex-shrink:0;background:#0e0e15;display:block}
.row-thumb-ph{width:128px;height:auto;aspect-ratio:var(--cover-ratio);border-radius:4px;flex-shrink:0;background:#1a1a28;
  display:flex;align-items:center;justify-content:center;font-size:24px}
.row-body{flex:1;min-width:0}
.row-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.04em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .18s}
.row-meta{display:flex;flex-direction:column;gap:4px;margin-top:5px}
.tag{font-size:10px;letter-spacing:.08em;padding:2px 7px;border-radius:3px;
  background:rgba(255,255,255,.06);color:var(--muted);white-space:nowrap}
.tag-clickable{cursor:pointer;transition:background .18s,color .18s}
.tag-clickable:hover{background:rgba(232,255,71,.18);color:var(--accent)}
.tag-lang{background:rgba(255,255,255,.04)}
.row-line{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.row-line-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);min-width:60px}
.row-desc{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.row-arrow{font-size:14px;color:var(--muted);opacity:0;transform:translateX(-4px);transition:opacity .2s,transform .2s;flex-shrink:0}

/* grid view */
.game-list.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;padding-top:24px}
.game-list.grid-view .game-row{flex-direction:column;align-items:stretch;gap:0;padding:0;border-bottom:none;
  border-radius:10px;overflow:hidden;background:var(--card);border:1px solid var(--border)}
.game-list.grid-view .game-row:hover{padding:0;margin:0;transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.game-list.grid-view .row-thumb{width:100%;height:auto;aspect-ratio:var(--cover-ratio);border-radius:0}
.game-list.grid-view .row-thumb-ph{width:100%;height:auto;aspect-ratio:var(--cover-ratio);border-radius:0;font-size:32px}
.game-list.grid-view .row-body{padding:10px 12px 12px}
.game-list.grid-view .row-title{font-size:14px;white-space:normal;line-height:1.2;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.game-list.grid-view .row-arrow{display:none}
.game-list.grid-view .row-desc{display:none}
.game-list.grid-view .row-line-label{display:none}
/* toolbar view toggle btn */
.view-btn{background:var(--card);border:1px solid var(--border);border-radius:7px;
  padding:9px 13px;font-size:16px;cursor:pointer;color:var(--muted);transition:color .18s,background .18s;line-height:1}
.view-btn.active{color:var(--accent);background:rgba(232,255,71,.08);border-color:rgba(232,255,71,.3)}
/* theme toggle */
.theme-btn{background:var(--card);border:1px solid var(--border);border-radius:7px;
  padding:9px 13px;font-size:15px;cursor:pointer;color:var(--muted);transition:color .18s,background .18s;line-height:1;margin-left:auto}
.theme-btn:hover{color:var(--text)}

/* animation */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* empty */
.empty{padding:60px 20px;text-align:center;color:var(--muted);font-size:14px}
.empty-icon{font-size:40px;margin-bottom:12px}

/* footer */
footer{border-top:1px solid var(--border);padding:20px 56px;display:flex;align-items:center;
  justify-content:space-between;color:var(--muted);font-size:11px}
.dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin-right:7px}

@media(min-width:1400px){
  .game-list.grid-view{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
  header{padding:80px 80px 56px}
  .alpha-nav{padding:12px 80px 0}
  .toolbar{padding:0 80px 40px}
  .divider{margin:0 80px}
  .game-list{padding:0 80px 80px}
  footer{padding:22px 80px}
  h1{font-size:120px}
  .row-thumb{width:160px;height:auto;aspect-ratio:var(--cover-ratio)}
  .row-thumb-ph{width:160px;height:auto;aspect-ratio:var(--cover-ratio);font-size:28px}
  .row-title{font-size:22px}
  .row-desc{font-size:14px;-webkit-line-clamp:unset;overflow:visible;display:block}
  .tag{font-size:12px;padding:3px 10px}
  .badge{font-size:14px}
}
@media(max-width:640px){
  header,.toolbar,.game-list,footer{padding-left:18px;padding-right:18px}
  .divider{margin-left:18px;margin-right:18px}
  .row-line-label{display:none}
  .game-list.grid-view{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
}

/* index — éléments ponctuels */
.header-label-link{color:inherit;text-decoration:none}
.result-count{font-size:12px;color:var(--muted);display:none}
.reset-btn{display:none;background:rgba(232,255,71,.1);border:1px solid rgba(232,255,71,.3);color:var(--accent);border-radius:6px;padding:8px 14px;font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;letter-spacing:.05em}
.toolbar-right{display:flex;gap:6px;margin-left:auto;align-items:center}
.rapport-link{color:var(--muted);text-decoration:none;letter-spacing:.05em;font-size:11px}
