*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#1a1a2e;
  --bg2:#16213e;
  --surface:#0f3460;
  --surface2:#1a4080;
  --border:rgba(255,255,255,.1);
  --text:#fff;
  --text2:#a8c8ff;
  --green:#00d26a;
  --green2:#00b85c;
  --red:#ff4757;
  --yellow:#ffc312;
  --blue:#1e90ff;
  --purple:#a855f7;
  --orange:#ff6b35;
  --pink:#ff6b9d;
  --cyan:#00d2ff;
  --card:#1e3a5f;
  --card-hover:#264d73;
  --radius:16px;
  --radius-lg:24px;
  --shadow:0 8px 32px rgba(0,0,0,.5);
}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  overflow-x:hidden;
  min-height:100vh;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(0,210,106,.06) 0%, transparent 50%),
    radial-gradient(circle at 90% 80%, rgba(30,144,255,.06) 0%, transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(168,85,247,.04) 0%, transparent 60%);
}

/* === HEADER === */
.header{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(135deg,#0f3460 0%,#1a1a2e 50%,#0f3460 100%);
  border-bottom:3px solid var(--green);
  padding:0 20px;
  height:76px;
  box-shadow:0 4px 20px rgba(0,210,106,.2);
}
.header-inner{
  max-width:1440px;margin:0 auto;height:100%;
  display:flex;align-items:center;gap:20px;
}
.logo{display:flex;align-items:center;gap:14px;cursor:pointer;flex-shrink:0;
  transition:transform .2s}
.logo:hover{transform:scale(1.05)}
.logo:active{transform:scale(.95)}
.lego-dots{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.lego-dots span{width:20px;height:20px;border-radius:50%;display:block;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.3),0 3px 10px rgba(0,0,0,.4);
  transition:transform .2s}
.logo:hover .lego-dots span{transform:scale(1.15)}
.logo-text strong{display:block;font-size:1.3rem;font-weight:900;letter-spacing:1px;color:#fff;
  text-shadow:0 2px 8px rgba(0,210,106,.4)}
.logo-text small{font-size:.75rem;color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:2px}

/* Search */
.search-wrap{position:relative;flex:1;max-width:380px}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text2);pointer-events:none}
.search-wrap input{
  width:100%;padding:12px 40px 12px 44px;
  background:var(--surface);border:3px solid var(--surface2);border-radius:50px;
  color:var(--text);font-size:1rem;font-weight:600;font-family:inherit;
  transition:all .3s ease;
}
.search-wrap input::placeholder{color:rgba(168,200,255,.5);font-weight:600}
.search-wrap input:focus{outline:none;border-color:var(--green);background:var(--bg2);
  box-shadow:0 0 20px rgba(0,210,106,.25)}
.clear-btn{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:var(--red);border:none;color:#fff;width:28px;height:28px;
  border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;
  transition:all .2s;font-weight:900;
}
.clear-btn:hover{background:#ff2e43;transform:translateY(-50%) scale(1.15)}

.header-stats{
  display:flex;align-items:center;gap:12px;
  margin-left:auto;
}
.lang-switcher{
  display:flex;gap:4px;
  background:rgba(0,0,0,.2);padding:4px;border-radius:12px;
  border:1px solid var(--border);
}
.lang-btn{
  background:transparent;border:none;color:var(--text2);
  padding:4px 8px;border-radius:8px;cursor:pointer;
  font-size:.7rem;font-weight:900;transition:all .2s;
}
.lang-btn:hover{color:#fff;background:rgba(255,255,255,.1)}
.lang-btn.active{background:var(--green);color:#fff;box-shadow:0 2px 8px rgba(0,210,106,.4)}

.nav-fav-btn{
  background:var(--surface);border:2px solid var(--surface2);
  color:#fff;padding:8px 16px;border-radius:50px;
  display:flex;align-items:center;gap:10px;cursor:pointer;
  transition:all .3s;position:relative;
}
.nav-fav-btn:hover{background:var(--card-hover);border-color:var(--red);transform:translateY(-2px)}
.nav-fav-btn.has-items{border-color:var(--red);box-shadow:0 0 20px rgba(255,71,87,.2)}
.nav-fav-count{font-weight:900;font-size:1.05rem;color:var(--red);text-shadow:0 0 10px rgba(255,107,157,.3)}

.stat-item{
  background:var(--surface);padding:8px 16px;border-radius:50px;
  border:2px solid var(--surface2);display:flex;align-items:center;gap:8px;
  font-weight:800;font-size:.85rem;color:var(--text2);
  transition:all .3s ease;
}
.stat-item[style*="cursor:pointer"]:hover{
  background:var(--card-hover);
  border-color:var(--green);
  transform:translateY(-2px);
  color:#fff;
}
.stat-icon{font-size:1.1rem}
.stat-text span{color:var(--green);font-weight:900}

/* === LAYOUT === */
.layout{display:flex;max-width:1440px;margin:0 auto;min-height:calc(100vh - 76px)}

/* Sidebar */
.sidebar{
  width:260px;flex-shrink:0;
  padding:16px 10px 16px 16px;
  border-right:2px solid var(--border);
  overflow-y:auto;position:sticky;top:76px;height:calc(100vh - 76px);
  background:rgba(15,52,96,.3);
}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:var(--green);border-radius:6px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar-title{
  font-size:.8rem;text-transform:uppercase;letter-spacing:3px;
  color:var(--green);margin-bottom:14px;font-weight:900;
  padding-left:14px;
}

#categoryList{list-style:none}
.cat-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;margin-bottom:5px;border-radius:14px;
  cursor:pointer;font-size:.88rem;font-weight:700;color:var(--text2);
  transition:all .25s ease;user-select:none;
  border:2px solid transparent;
}
.cat-item:hover{background:var(--surface);color:#fff;border-color:var(--surface2);
  transform:translateX(4px)}
.cat-item.active{
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff;font-weight:800;
  box-shadow:0 4px 20px rgba(0,210,106,.35);
  border-color:transparent;
  transform:translateX(4px);
}
.cat-item .emoji{margin-right:8px;font-size:1.2rem}
.cat-item .cnt{
  font-size:.75rem;background:rgba(255,255,255,.12);padding:3px 10px;border-radius:20px;
  min-width:30px;text-align:center;font-weight:800;
}
.cat-item.active .cnt{background:rgba(255,255,255,.25)}

/* === CONTENT === */
.content{flex:1;padding:20px 24px 60px;overflow-x:hidden}
.content-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.content-top h2{
  font-size:1.7rem;font-weight:900;
  background:linear-gradient(90deg,var(--green),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.view-toggle{display:flex;gap:6px}
.vt{
  background:var(--surface);border:2px solid var(--surface2);padding:8px 12px;border-radius:12px;
  cursor:pointer;color:var(--text2);display:flex;align-items:center;transition:all .2s;
  font-weight:700;
}
.vt.active,.vt:hover{color:var(--green);background:var(--bg2);border-color:var(--green)}

/* === GRID === */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:16px;
}
.grid.big-tiles{
  grid-template-columns:repeat(auto-fill,minmax(380px,1fr));
  gap:24px;
}
.grid.big-tiles .card-img{height:300px}
.grid.big-tiles .card-title{font-size:1.5rem}
.grid.big-tiles .card-cat{font-size:1rem}
.grid.big-tiles .play-badge{width:56px;height:56px;font-size:1.8rem}
.grid.big-tiles .fav-btn{width:48px;height:48px;font-size:1.5rem}

/* === CARD (Roblox game-tile style) === */
.card{
  background:var(--card);border-radius:var(--radius);overflow:hidden;
  text-decoration:none;color:inherit;
  border:3px solid transparent;
  transition:all .3s cubic-bezier(.25,.8,.25,1);
  display:flex;flex-direction:column;
  cursor:pointer;
  position:relative;
}
.card:hover{
  transform:translateY(-8px) scale(1.02);
  border-color:var(--green);
  box-shadow:0 12px 40px rgba(0,210,106,.2),0 0 0 1px rgba(0,210,106,.1);
  background:var(--card-hover);
}
.card:active{transform:translateY(-2px) scale(.98)}

/* Favorite Button on Card */
.fav-btn{
  position:absolute;top:10px;right:10px;z-index:10;
  background:rgba(0,0,0,.3);backdrop-filter:blur(5px);
  border:none;color:#fff;width:38px;height:38px;
  border-radius:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;transition:all .3s cubic-bezier(.175,.885,.32,1.275);
  opacity:0;transform:scale(.5);
}
.card:hover .fav-btn{opacity:1;transform:scale(1)}
.fav-btn.active{opacity:1;transform:scale(1);background:var(--red);text-shadow:0 0 10px rgba(255,255,255,.5)}
.fav-btn:hover{transform:scale(1.15);background:var(--red)}
.fav-btn:active{transform:scale(.9)}

/* Modal Favorite Button */
.modal-fav-btn{
  background:var(--surface2);color:#fff;
  border:none;padding:8px 16px;border-radius:12px;
  font-size:.9rem;font-weight:700;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  transition:all .2s;
  border:2px solid transparent;
  margin-left:auto; /* Push to right in the tags row */
}
.modal-fav-btn:hover{background:var(--card-hover);border-color:var(--red)}
.modal-fav-btn.active{background:var(--red);border-color:transparent;box-shadow:0 4px 15px rgba(255,71,87,.3)}
.modal-fav-btn span{font-size:1.1rem}

/* Flying Heart Animation */
.flying-heart {
  position: fixed;
  z-index: 9999;
  font-size: 3.5rem; /* Ще більше */
  pointer-events: none;
  filter: drop-shadow(0 0 25px rgba(255, 71, 87, 0.9));
  transition: all 1.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Повільніше */
}

.pulse {
  animation: navFavPulse 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes navFavPulse {
  0% { transform: scale(1); }
  40% { transform: scale(1.8); background: var(--red); box-shadow: 0 0 40px rgba(255, 71, 87, 0.8); }
  100% { transform: scale(1); }
}

/* Badges */
.trend-badge, .new-badge{
  position:absolute;top:12px;left:12px;z-index:10;
  padding:5px 12px;border-radius:10px;
  font-size:.75rem;font-weight:900;color:#fff;
  letter-spacing:1px;
  box-shadow:0 4px 15px rgba(0,0,0,.4);
  text-transform:uppercase;
  pointer-events:none;
}
.trend-badge{background:linear-gradient(135deg,var(--red),#ff7b00)}
.new-badge{background:linear-gradient(135deg,var(--cyan),var(--blue));left:auto;right:12px}
/* Offset if fav button is there */
.fav-btn + .new-badge{top:58px}

.card-img{
  width:100%;height:170px;
  background:linear-gradient(135deg,#e8f4f8,#fff);
  display:flex;align-items:center;justify-content:center;
  padding:5px;overflow:hidden;position:relative;
}
.card-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 60%,rgba(0,0,0,.08));
  pointer-events:none;
}
.card-img img{
  max-width:95%;max-height:95%;
  object-fit:contain;
  transition:transform .4s ease;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));
}
.grid.big-tiles .card-img img{
  max-width:100%;max-height:100%;
  transform:scale(1.6); /* Значно збільшуємо іконку */
}
.card:hover .card-img img{transform:scale(1.15)}
.grid.big-tiles .card:hover .card-img img{transform:scale(1.8)}
.card-img .no-img{
  color:var(--surface);font-size:.9rem;text-align:center;font-weight:700;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.no-img .no-img-icon{font-size:2.5rem}
.card-body{padding:12px 14px;flex:1;display:flex;flex-direction:column;justify-content:center}
.card-title{font-size:.95rem;font-weight:800;margin-bottom:3px;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-cat{font-size:.78rem;color:var(--text2);font-weight:700}

/* Play icon overlay */
.card .play-badge{
  position:absolute;top:10px;right:10px;
  background:var(--green);color:#fff;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:900;
  box-shadow:0 3px 12px rgba(0,210,106,.4);
  opacity:0;transition:all .3s;
  transform:scale(.7);
}
.card:hover .play-badge{opacity:1;transform:scale(1)}

/* List view card */
.grid.list-view .card{flex-direction:row;height:90px}
.grid.list-view .card-img{width:100px;height:100%;flex-shrink:0}
.grid.list-view .card-body{padding:10px 16px}
.grid.list-view .card .play-badge{top:auto;bottom:10px}

/* === HOME VIEW (HUB) === */
.home-view{padding-bottom:40px}
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;margin-top:30px;
}
.section-header h3{font-size:1.4rem;font-weight:900;color:var(--text)}

/* Scroll Controls */
.scroll-controls{display:flex;gap:8px}
.scroll-btn{
  background:var(--surface2);border:none;color:#fff;
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.5rem;font-weight:900;
  transition:all .2s;border:2px solid transparent;
}
.scroll-btn:hover{background:var(--green);transform:scale(1.1)}
.scroll-btn:active{transform:scale(.9)}

/* Hero Banner */
.hero-section{margin-bottom:30px}
.hero-banner{
  width:100%;height:180px;
  background:linear-gradient(45deg,var(--purple),var(--blue));
  border-radius:var(--radius-lg);
  display:flex;align-items:center;padding:0 40px;
  position:relative;overflow:hidden;
  border:4px solid rgba(255,255,255,.1);
  box-shadow:0 10px 30px rgba(0,0,0,.3);
}
.hero-banner::after{
  content:'🧱';position:absolute;right:20px;bottom:-10px;
  font-size:12rem;opacity:.15;transform:rotate(-15deg);
}
.hero-content h1{font-size:2.4rem;font-weight:900;margin-bottom:5px;text-shadow:0 3px 10px rgba(0,0,0,.3)}
.hero-content p{font-size:1.1rem;font-weight:700;opacity:.9}

/* Horizontal Scroll */
.horizontal-scroll, .genre-row{
  display:flex;gap:20px;overflow-x:auto;padding:10px 4px 30px;
  scrollbar-width:thin;
  scrollbar-color:var(--green) transparent;
  scroll-behavior:smooth;
  cursor: grab;
  user-select: none;
}
.horizontal-scroll.grabbing, .genre-row.grabbing {
  cursor: grabbing;
  scroll-behavior: auto;
}
.horizontal-scroll img, .genre-row img {
  pointer-events: none;
}
.horizontal-scroll::-webkit-scrollbar, .genre-row::-webkit-scrollbar{height:6px}
.horizontal-scroll::-webkit-scrollbar-thumb, .genre-row::-webkit-scrollbar-thumb{
  background:var(--green);border-radius:10px;
}
.horizontal-scroll .card{width:320px;flex-shrink:0}
.horizontal-scroll .card-img{height:220px}

/* Genre Grid (now also a row) */
.genre-row{
  display:flex;gap:16px;overflow-x:auto;padding:10px 4px 30px;
  scrollbar-width:none;-ms-overflow-style:none;
}
.genre-row::-webkit-scrollbar{display:none}
.genre-card{
  background:var(--surface);border:3px solid var(--surface2);
  border-radius:var(--radius);padding:24px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);
  width:200px;flex-shrink:0;
}
.genre-card:hover{
  transform:scale(1.05) translateY(-5px);
  border-color:var(--green);
  background:var(--card-hover);
  box-shadow:0 10px 25px rgba(0,210,106,.2);
}
.genre-emoji{font-size:3.8rem;margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}
.genre-name{font-size:1.1rem;font-weight:900;margin-bottom:6px;color:#fff;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}
.genre-count{font-size:.8rem;font-weight:700;color:var(--text2);text-transform:uppercase}

/* Trend Badge */
.trend-badge{
  position:absolute;top:12px;left:12px;
  background:linear-gradient(135deg,var(--red),#ff2e43);color:#fff;
  padding:6px 14px;border-radius:10px;
  font-size:.75rem;font-weight:900;
  box-shadow:0 4px 12px rgba(255,71,87,.4);
  z-index:5;letter-spacing:1px;
}

/* === MODAL (Fullscreen model preview) === */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(10,10,30,.92);
  backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:all .35s ease;
}
.modal-overlay.active{opacity:1;visibility:visible}

.modal{
  background:linear-gradient(145deg,var(--bg2),var(--surface));
  border-radius:var(--radius-lg);
  border:3px solid var(--green);
  box-shadow:0 20px 80px rgba(0,210,106,.2),0 0 120px rgba(0,210,106,.06);
  width:94vw;max-width:960px;
  max-height:94vh;overflow-y:auto;
  transform:scale(.85) translateY(30px);
  transition:all .4s cubic-bezier(.175,.885,.32,1.275);
  display:flex;flex-direction:column;
}
.modal-overlay.active .modal{transform:scale(1) translateY(0)}

.modal-close{
  position:absolute;top:16px;right:16px;z-index:10;
  background:var(--red);border:none;color:#fff;
  width:48px;height:48px;border-radius:50%;
  cursor:pointer;font-size:1.6rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
  box-shadow:0 4px 15px rgba(255,71,87,.4);
}
.modal-close:hover{background:#ff2e43;transform:scale(1.1) rotate(90deg)}

.modal-img{
  width:100%;height:55vh;
  background:linear-gradient(135deg,#e8f4f8,#fff);
  display:flex;align-items:center;justify-content:center;
  padding:24px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  overflow:hidden;position:relative;
}
.modal-img img{
  width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.2));
  animation:modalImgPop .5s ease .2s both;
}
@keyframes modalImgPop{
  from{transform:scale(.8);opacity:0}
  to{transform:scale(1);opacity:1}
}
.modal-img .no-img{
  color:var(--surface);font-size:1.1rem;text-align:center;font-weight:700;
}
.modal-img .no-img .no-img-icon{font-size:5rem}

.modal-info{
  padding:24px 28px 28px;
  display:flex;flex-direction:column;gap:14px;
  animation:modalInfoSlide .4s ease .15s both;
}
@keyframes modalInfoSlide{
  from{transform:translateY(20px);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.modal-title{
  font-size:1.8rem;font-weight:900;
  line-height:1.2;
}
.modal-cats{
  display:flex;flex-wrap:wrap;gap:8px;
}
.modal-cat-tag{
  background:var(--surface2);
  color:var(--text2);
  padding:6px 14px;
  border-radius:50px;
  font-size:.82rem;
  font-weight:700;
  border:2px solid rgba(255,255,255,.08);
}

.modal-open-btn{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:18px 32px;
  background:linear-gradient(135deg,var(--green),#00c964);
  color:#fff;
  border:none;border-radius:16px;
  font-size:1.25rem;font-weight:900;
  cursor:pointer;
  transition:all .25s ease;
  box-shadow:0 6px 25px rgba(0,210,106,.4);
  text-decoration:none;
  margin-top:6px;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.modal-open-btn:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 10px 40px rgba(0,210,106,.5);
  background:linear-gradient(135deg,#00e676,var(--green));
}
.modal-open-btn:active{transform:translateY(0) scale(.98)}
.modal-open-btn .btn-icon{font-size:1.6rem}

/* === EMPTY STATE === */
.empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:40vh;text-align:center;
}
.empty-emoji{font-size:5rem;margin-bottom:16px;
  animation:emptyBounce 2s ease infinite}
@keyframes emptyBounce{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
.empty h3{font-size:1.5rem;margin-bottom:8px;font-weight:900}
.empty p{color:var(--text2);font-weight:600}

/* === SCROLL TOP === */
.scroll-top{
  position:fixed;bottom:28px;right:28px;z-index:200;
  width:52px;height:52px;border-radius:16px;border:3px solid var(--green);
  background:linear-gradient(135deg,var(--surface),var(--bg2));color:var(--green);
  font-size:1.5rem;font-weight:900;cursor:pointer;
  box-shadow:0 6px 24px rgba(0,210,106,.3);
  transition:all .3s ease;
}
.scroll-top:hover{
  transform:scale(1.1);
  background:var(--green);color:#fff;
  box-shadow:0 8px 30px rgba(0,210,106,.5);
}

.cat-item.active{background:var(--green);color:#fff;transform:scale(1.02);box-shadow:0 8px 20px rgba(0,210,106,.3)}

/* Home Item Special Style */
.cat-item.home-item{
  background:linear-gradient(135deg,var(--purple),var(--blue));
  margin-bottom:18px;
  padding:16px 20px;
  font-size:1.1rem;
  border:2px solid rgba(255,255,255,.1);
}
.cat-item.home-item:hover{
  background:linear-gradient(135deg,#b16aff,var(--blue));
  transform:scale(1.05) translateY(-2px);
}
.cat-item.home-item.active{
  border-color:var(--green);
  box-shadow:0 10px 30px rgba(168,85,247,.4);
}
.cat-item.home-item .emoji{font-size:1.4rem}

.cat-item .cnt{display:none!important}

.hidden{display:none!important}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.card{animation:fadeUp .4s ease both}

/* === FUN PARTICLES (CSS only) === */
body::before{
  content:'';position:fixed;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:0;
  background-image:
    radial-gradient(2px 2px at 20% 30%,rgba(0,210,106,.15),transparent),
    radial-gradient(2px 2px at 80% 20%,rgba(30,144,255,.15),transparent),
    radial-gradient(2px 2px at 40% 70%,rgba(168,85,247,.1),transparent),
    radial-gradient(2px 2px at 60% 50%,rgba(255,195,18,.1),transparent),
    radial-gradient(3px 3px at 15% 85%,rgba(0,210,255,.1),transparent),
    radial-gradient(2px 2px at 90% 60%,rgba(255,107,53,.1),transparent);
}

/* === NEW FEATURES: RATING & BUILT === */
.modal-actions-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  background: rgba(255,255,255,0.05);
  padding: 12px 20px;
  border-radius: 16px;
  border: 1px solid var(--border);
  margin-top: 5px;
}

.rating-container {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.rating-label {
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.star-rating {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  gap: 4px;
}

.star {
  font-size: 1.8rem;
  color: rgba(255,255,255,0.1);
  cursor: pointer;
  transition: all 0.2s ease;
  line-height: 1;
}

.star:hover,
.star:hover ~ .star,
.star.active,
.star.active ~ .star {
  color: var(--yellow);
  text-shadow: 0 0 10px rgba(255,195,18,0.5);
  transform: scale(1.1);
}

.built-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  user-select: none;
}

.built-toggle input {
  display: none;
}

.toggle-slider {
  width: 50px;
  height: 26px;
  background: var(--surface2);
  border-radius: 30px;
  position: relative;
  transition: 0.3s;
  border: 2px solid var(--border);
}

.toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 4px;
  top: 2px;
  background: #fff;
  border-radius: 50%;
  transition: 0.3s;
}

.built-toggle input:checked + .toggle-slider {
  background: var(--green);
  border-color: var(--green);
}

.built-toggle input:checked + .toggle-slider::before {
  left: 24px;
}

.toggle-label {
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--text);
}

/* Built Badge on Card */
.built-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 10;
  background: var(--green);
  color: #fff;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 0.7rem;
  font-weight: 900;
  display: flex;
  align-items: center;
  gap: 4px;
  box-shadow: 0 4px 12px rgba(0,210,106,0.4);
  animation: badgeIn 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes badgeIn {
  from { transform: scale(0.5) rotate(-10deg); opacity: 0; }
  to { transform: scale(1) rotate(0); opacity: 1; }
}

.card-rating {
  position: absolute;
  bottom: 80px;
  right: 12px;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--yellow);
  display: flex;
  align-items: center;
  gap: 3px;
  z-index: 5;
}

/* Responsiveness for new row */
@media(max-width: 600px) {
  .modal-actions-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .modal-built-toggle {
    width: 100%;
    justify-content: space-between;
  }
}

/* === HERO RANDOM BUTTON === */
.hero-random-btn {
  margin-top: 15px;
  background: linear-gradient(135deg, var(--yellow), #ff9f1a);
  color: #fff;
  border: none;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: 1.1rem;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(255,195,18,0.4), inset 0 -3px 0 rgba(0,0,0,0.2);
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}
.hero-random-btn:hover {
  transform: translateY(-4px) scale(1.05);
  box-shadow: 0 10px 25px rgba(255,195,18,0.6), inset 0 -3px 0 rgba(0,0,0,0.2);
  background: linear-gradient(135deg, #ffd32a, var(--yellow));
}
.hero-random-btn:active {
  transform: translateY(0) scale(0.98);
  box-shadow: 0 2px 10px rgba(255,195,18,0.4);
}

/* === ROULETTE OVERLAY & MODAL === */
.roulette-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(10,10,30,0.95);
  backdrop-filter: blur(15px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s ease;
}
.roulette-overlay.active {
  opacity: 1;
  visibility: visible;
}

.roulette-modal {
  width: 90vw;
  max-width: 1000px;
  background: linear-gradient(145deg, var(--bg2), var(--surface));
  border-radius: var(--radius-lg);
  border: 4px solid var(--yellow);
  box-shadow: 0 0 50px rgba(255,195,18,0.3), inset 0 0 20px rgba(255,195,18,0.1);
  padding: 30px;
  text-align: center;
  position: relative;
  transform: scale(0.8) translateY(30px);
  transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.roulette-overlay.active .roulette-modal {
  transform: scale(1) translateY(0);
}

.roulette-title {
  font-size: 2.2rem;
  font-weight: 900;
  color: var(--yellow);
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 30px;
  text-shadow: 0 4px 15px rgba(255,195,18,0.4);
}

.roulette-window {
  width: 100%;
  height: 220px;
  background: rgba(0,0,0,0.4);
  border-radius: var(--radius);
  border: 3px solid var(--surface2);
  overflow: hidden;
  position: relative;
  box-shadow: inset 0 10px 30px rgba(0,0,0,0.5);
  margin-bottom: 30px;
  display: flex;
  align-items: center;
}

.roulette-window::before, .roulette-window::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 60px;
  z-index: 5;
  pointer-events: none;
}
.roulette-window::before {
  left: 0;
  background: linear-gradient(to right, rgba(0,0,0,0.8), transparent);
}
.roulette-window::after {
  right: 0;
  background: linear-gradient(to left, rgba(0,0,0,0.8), transparent);
}

.roulette-center-line {
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 6px;
  background: var(--red);
  z-index: 10;
  box-shadow: 0 0 15px var(--red);
}
.roulette-center-line::before, .roulette-center-line::after {
  content: '▼';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  color: var(--red);
  font-size: 1.5rem;
  text-shadow: 0 0 10px var(--red);
}
.roulette-center-line::before { top: -5px; }
.roulette-center-line::after { bottom: -5px; transform: translateX(-50%) rotate(180deg); }

.roulette-strip {
  display: flex;
  gap: 15px;
  height: 180px;
  padding: 0 50vw; /* padding to allow centering any item */
  will-change: transform;
  /* The transition is handled via JS for dynamic cubic-bezier and duration */
}

.roulette-card {
  width: 160px;
  height: 180px;
  flex-shrink: 0;
  background: var(--card);
  border-radius: var(--radius);
  border: 3px solid transparent;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: all 0.3s;
}
.roulette-card img {
  width: 100%;
  height: 120px;
  object-fit: contain;
  background: #fff;
  padding: 10px;
}
.roulette-card .no-img {
  width: 100%;
  height: 120px;
  background: #fff;
  color: var(--surface);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
}
.roulette-card-title {
  padding: 8px;
  font-size: 0.8rem;
  font-weight: 800;
  text-align: center;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  background: var(--card);
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.roulette-card.winner {
  border-color: var(--green);
  transform: scale(1.1);
  box-shadow: 0 0 30px rgba(0,210,106,0.8);
  z-index: 20;
  animation: winnerPulse 1s infinite alternate;
}
@keyframes winnerPulse {
  from { box-shadow: 0 0 20px rgba(0,210,106,0.6); }
  to { box-shadow: 0 0 40px rgba(0,210,106,1); transform: scale(1.15); }
}

.roulette-action {
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* === RESPONSIVE === */
@media(max-width:900px){
  .hero-banner{height:140px;padding:0 24px}
  .hero-content h1{font-size:1.6rem}
  .hero-content p{font-size:.9rem}
  .horizontal-scroll .card{width:160px}
  .genre-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .genre-emoji{font-size:2rem}
  .genre-name{font-size:.9rem}
  
  .layout{flex-direction:column}
  .sidebar{
    width:100%;height:auto;position:relative;top:0;
    border-right:none;border-bottom:2px solid var(--border);
    padding:12px;background:rgba(15,52,96,.5);
  }
  #categoryList{display:flex;overflow-x:auto;gap:8px;padding-bottom:8px;
    -webkit-overflow-scrolling:touch}
  .cat-item{white-space:nowrap;margin-bottom:0;flex-shrink:0}
  .cat-item:hover,.cat-item.active{transform:none}
  .sidebar-title{display:none}
  .content{padding:14px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
  .card-img{height:140px}
  .modal{width:95vw;max-height:95vh}
  .modal-img{min-height:160px;padding:20px}
  .modal-title{font-size:1.4rem}
  .modal-open-btn{font-size:1.1rem;padding:16px 24px}
}
@media(max-width:600px){
  .hero-banner{padding:0 16px;height:120px}
  .hero-content h1{font-size:1.3rem}
  .header{height:auto;padding:12px 14px}
  .header-inner{flex-direction:column;gap:12px;align-items:stretch}
  .logo{justify-content:center}
  .search-wrap{max-width:100%;order:3;width:100%}
  .header-stats{order:2;justify-content:center;margin:0}
  .grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
  .card-img{height:120px}
  .modal-info{padding:18px 20px 22px}
  .nav-fav-btn, .stat-item { padding: 6px 12px; font-size: 0.9rem; }
}

/* === DISCLAIMER MODAL === */
.disclaimer-overlay{
  position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,.85);
  backdrop-filter:blur(12px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:20px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.disclaimer-overlay.hidden{display:none}
.disclaimer-modal{
  background:linear-gradient(160deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);
  border-radius:24px;
  padding:30px 24px;
  max-width:560px;
  width:100%;
  border:3px solid var(--yellow);
  box-shadow:0 25px 80px rgba(0,0,0,.6), 0 0 40px rgba(255,193,18,.15);
  text-align:center;
  animation:disclaimerIn .5s ease;
  margin:auto;
}
@keyframes disclaimerIn{
  from{transform:scale(.8);opacity:0}
  to{transform:scale(1);opacity:1}
}
.disclaimer-icon{font-size:4rem;margin-bottom:12px}
.disclaimer-modal h2{
  font-size:1.6rem;font-weight:900;color:var(--yellow);
  margin-bottom:20px;
}
.disclaimer-text{
  text-align:left;
  color:var(--text2);
  font-size:.95rem;
  line-height:1.7;
  margin-bottom:24px;
}
.disclaimer-text p{margin-bottom:10px}
.disclaimer-text strong{color:#fff}
.disclaimer-text ul{
  margin:12px 0;padding-left:20px;
  list-style:none;
}
.disclaimer-text li{
  position:relative;padding-left:24px;margin-bottom:6px;
}
.disclaimer-text li::before{
  content:'✔';position:absolute;left:0;color:var(--green);font-weight:900;
}
.disclaimer-accept{
  background:linear-gradient(135deg,var(--green),#00c964);
  color:#fff;border:none;
  padding:16px 40px;border-radius:16px;
  font-size:1.15rem;font-weight:900;
  cursor:pointer;
  transition:all .25s;
  box-shadow:0 6px 25px rgba(0,210,106,.4);
  width:100%;
  text-transform:uppercase;
  letter-spacing:1px;
}
.disclaimer-accept:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 10px 35px rgba(0,210,106,.5);
}
.disclaimer-accept:active{transform:translateY(0) scale(.98)}

/* === FOOTER === */
.site-footer{
  background:linear-gradient(180deg,var(--bg) 0%,#0a0a1a 100%);
  border-top:2px solid var(--border);
  padding:40px 24px 32px;
  margin-top:20px;
}
.footer-inner{
  max-width:1200px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:24px;
  text-align:center;
}
.footer-brand{
  display:flex;align-items:center;gap:14px;
}
.footer-logo{font-size:2.2rem}
.footer-brand strong{display:block;color:#fff;font-size:1.1rem;font-weight:800}
.footer-brand small{color:var(--text2);font-size:.8rem;font-weight:600}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.footer-links a{
  color:var(--text2);text-decoration:none;
  padding:8px 18px;border-radius:12px;
  background:var(--surface);border:2px solid var(--border);
  font-weight:700;font-size:.85rem;
  transition:all .2s;
}
.footer-links a:hover{
  color:#fff;border-color:var(--green);background:var(--surface2);
  transform:translateY(-2px);
}
.footer-copy{color:var(--text2);font-size:.78rem;line-height:1.7;opacity:.85}
.footer-copy p{margin:2px 0}

/* === PWA UPDATE TOAST === */
.update-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface);
  border: 3px solid var(--green);
  border-radius: var(--radius);
  padding: 16px 24px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  z-index: 9999;
  display: flex;
  align-items: center;
  animation: toastIn 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes toastIn {
  from { bottom: -100px; opacity: 0; }
  to { bottom: 24px; opacity: 1; }
}

.toast-content {
  display: flex;
  align-items: center;
  gap: 16px;
}

.toast-content span {
  font-weight: 700;
  color: var(--text);
  font-size: 0.95rem;
}

.toast-content button {
  background: var(--green);
  color: #fff;
  border: none;
  padding: 8px 16px;
  border-radius: 8px;
  font-weight: 900;
  cursor: pointer;
  transition: all 0.2s;
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 1px;
}

.toast-content button:hover {
  transform: scale(1.05);
  box-shadow: 0 0 15px rgba(0,210,106,0.4);
}

/* Modal Share Button */
.modal-share-btn {
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  color: #fff;
  border: none;
  padding: 8px 20px;
  border-radius: 50px;
  font-size: .85rem;
  font-weight: 900;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow: 0 4px 15px rgba(30, 144, 255, 0.3);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.modal-share-btn:hover {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 8px 25px rgba(0, 210, 255, 0.5);
  filter: brightness(1.1);
}

.modal-share-btn:active {
  transform: translateY(0) scale(0.95);
}

.modal-share-btn span { font-size: 1.2rem; }

/* === Achievement System === */
.achievement-toast {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(30, 30, 30, 0.95);
    border: 2px solid #ffcf00;
    border-radius: 12px;
    padding: 12px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
    z-index: 10000;
    box-shadow: 0 0 20px rgba(255, 207, 0, 0.3), 0 10px 30px rgba(0,0,0,0.5);
    animation: ach-slide-in 0.5s cubic-bezier(0.18, 0.89, 0.32, 1.28) forwards;
    backdrop-filter: blur(10px);
    color: white;
    min-width: 280px;
}
.achievement-toast.out {
    animation: ach-slide-out 0.5s ease forwards;
}
@keyframes ach-slide-in {
    from { transform: translate(-50%, -100px); opacity: 0; }
    to { transform: translate(-50%, 0); opacity: 1; }
}
@keyframes ach-slide-out {
    from { transform: translate(-50%, 0); opacity: 1; }
    to { transform: translate(-50%, -100px); opacity: 0; }
}
.ach-icon { font-size: 32px; }
.ach-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: #ffcf00; font-weight: bold; }
.ach-title { font-size: 16px; font-weight: 800; }

.badges-container {
    grid-column: 1 / -1;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 20px;
    padding: 24px;
    margin-bottom: 30px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}
.badges-header {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.badges-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
}
.badge-item {
    background: rgba(0, 0, 0, 0.2);
    padding: 15px;
    border-radius: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
    transition: all 0.3s ease;
    border: 1px solid transparent;
}
.badge-item.unlocked {
    background: rgba(255, 207, 0, 0.1);
    border-color: rgba(255, 207, 0, 0.3);
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}
.badge-item.locked {
    opacity: 0.5;
    filter: grayscale(1);
}
.badge-emoji {
    font-size: 28px;
    position: relative;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.05);
    border-radius: 10px;
}
.badge-emoji .lock {
    position: absolute;
    bottom: -5px;
    right: -5px;
    font-size: 12px;
    filter: none;
}
.badge-title { font-weight: 700; font-size: 14px; margin-bottom: 2px; }
.badge-desc { font-size: 11px; opacity: 0.7; line-height: 1.2; }
.badge-item.unlocked:hover {
    transform: translateY(-3px);
    border-color: #ffcf00;
    box-shadow: 0 8px 25px rgba(255, 207, 0, 0.2);
}
