/* ═══════════════════════════════════════════
   OyunMod v2 - Ana CSS
   ═══════════════════════════════════════════ */

:root {
  --bg-deep: #060710;
  --bg-surface: #10111b;
  --bg-card: #141520;
  --bg-elevated: #1a1b2e;
  --bg-input: #0b0c14;
  --accent: #e85d26;
  --accent-hover: #ff7a45;
  --accent-glow: rgba(232, 93, 38, 0.15);
  --green: #22c55e;
  --blue: #3b82f6;
  --red: #ef4444;
  --yellow: #eab308;
  --purple: #a855f7;
  --text-primary: #e8eaef;
  --text-secondary: #a1a6bc;
  --text-muted: #9196ab;
  --text-dim: #8085a0;
  --border: rgba(255, 255, 255, 0.06);
  --border-m: rgba(255, 255, 255, 0.1);
  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.5);
  --shadow-glow: 0 0 30px var(--accent-glow);
  --transition-fast: 0.15s ease;
  --transition-normal: 0.25s ease;
  --transition-slow: 0.4s ease;
  --font-display: 'Rajdhani', sans-serif;
  --font-body: 'Exo 2', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; overflow-x: hidden; }

body {
  font-family: var(--font-body);
  background: var(--bg-deep);
  color: var(--text-primary);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; transition: color var(--transition-fast); }
img { max-width: 100%; height: auto; display: block; }

.container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ─── Scrollbar ─── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg-deep); }
::-webkit-scrollbar-thumb { background: var(--bg-elevated); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-dim); }

/* ═══ TOPBAR ═══ */
.topbar {
  background: rgba(6, 7, 16, 0.9);
  border-bottom: 1px solid var(--border);
  font-size: 0.75rem;
  padding: 6px 0;
  backdrop-filter: blur(10px);
}
.topbar-inner { display: flex; justify-content: space-between; align-items: center; }
.topbar-left, .topbar-right { display: flex; align-items: center; gap: 10px; }
.topbar-stat { color: var(--text-muted); display: flex; align-items: center; gap: 5px; }
.topbar-stat strong { color: var(--text-secondary); }
.topbar-divider { width: 1px; height: 12px; background: var(--border-m); }
.topbar-link { color: var(--text-muted); font-weight: 500; }
.topbar-link:hover { color: var(--text-primary); }
.topbar-link--accent { color: var(--accent) !important; }
.live-dot {
  width: 6px; height: 6px; background: var(--green); border-radius: 50%;
  animation: livePulse 2s ease-in-out infinite;
}
@keyframes livePulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ═══ NAVBAR ═══ */
.navbar {
  background: rgba(16, 17, 27, 0.85);
  backdrop-filter: blur(20px) saturate(1.2);
  border-bottom: 1px solid var(--border);
  padding: 0 0;
  position: sticky; top: 0; z-index: 1000;
  transition: all var(--transition-normal);
}
.navbar.scrolled { background: rgba(10, 11, 18, 0.95); box-shadow: var(--shadow-md); }
.navbar.hidden { transform: translateY(-100%); }
.navbar-inner { display: flex; align-items: center; height: 60px; gap: 24px; }
.navbar-brand { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.brand-text { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; letter-spacing: -0.5px; }
.brand-accent { color: var(--accent); }
.brand-badge {
  font-size: 0.55rem; font-weight: 700; color: var(--accent);
  background: var(--accent-glow); border: 1px solid rgba(232,93,38,0.2);
  padding: 1px 5px; border-radius: var(--radius-xs); letter-spacing: 0.5px;
}

.navbar-links { display: flex; gap: 4px; align-items: center; }
.nav-link {
  padding: 8px 14px; border-radius: var(--radius-sm); font-size: 0.85rem;
  font-weight: 500; color: var(--text-secondary); transition: all var(--transition-fast);
}
.nav-link:hover { color: var(--text-primary); background: rgba(255,255,255,0.04); }
.nav-link.active { color: var(--accent); background: var(--accent-glow); }

.navbar-actions { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.navbar-search {
  display: flex; align-items: center; gap: 8px; background: var(--bg-input);
  border: 1px solid var(--border); border-radius: var(--radius-full);
  padding: 6px 14px; transition: all var(--transition-fast); width: 240px;
}
.navbar-search:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); width: 300px; }
.search-icon { width: 16px; height: 16px; color: var(--text-dim); flex-shrink: 0; }
.search-input {
  background: none; border: none; color: var(--text-primary); font-family: inherit;
  font-size: 0.82rem; outline: none; width: 100%;
}
.search-input::placeholder { color: var(--text-dim); }
.search-kbd {
  font-family: var(--font-mono); font-size: 0.65rem; color: var(--text-secondary);
  background: var(--bg-deep); border: 1px solid var(--border);
  padding: 1px 5px; border-radius: 3px; flex-shrink: 0;
}

.navbar-burger { display: none; background: none; border: none; cursor: pointer; padding: 4px; }
.navbar-burger span {
  display: block; width: 20px; height: 2px; background: var(--text-secondary);
  margin: 4px 0; transition: all var(--transition-fast); border-radius: 2px;
}

/* ═══ HERO SECTION ═══ */
.hero {
  padding: 80px 0 60px;
  background: radial-gradient(ellipse at 50% 0%, rgba(232,93,38,0.08), transparent 60%), var(--bg-deep);
  text-align: center; position: relative; overflow: hidden;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h1v1H0z' fill='%23ffffff' fill-opacity='0.015'/%3E%3C/svg%3E");
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent-glow); border: 1px solid rgba(232,93,38,0.2);
  padding: 5px 14px; border-radius: var(--radius-full);
  font-size: 0.78rem; font-weight: 600; color: var(--accent); margin-bottom: 20px;
}
.hero h1 {
  font-family: var(--font-display); font-size: 3rem; font-weight: 700;
  line-height: 1.1; margin-bottom: 16px; letter-spacing: -1px;
}
.hero h1 span {
  background: linear-gradient(135deg, var(--accent), #ff9a56);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.hero-desc { font-size: 1.05rem; color: var(--text-secondary); max-width: 560px; margin: 0 auto 28px; }

.hero-search {
  display: flex; max-width: 560px; margin: 0 auto 20px; background: var(--bg-surface);
  border: 1px solid var(--border-m); border-radius: var(--radius-lg); overflow: hidden;
}
.hero-search input {
  flex: 1; background: none; border: none; padding: 14px 18px; color: var(--text-primary);
  font-family: inherit; font-size: 0.95rem; outline: none;
}
.hero-search input::placeholder { color: var(--text-dim); }
.hero-search button {
  background: var(--accent); color: #fff; border: none; padding: 0 24px;
  font-family: inherit; font-weight: 600; font-size: 0.9rem; cursor: pointer;
  transition: background var(--transition-fast);
}
.hero-search button:hover { background: var(--accent-hover); }

.hero-tags { display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
.hero-tag {
  padding: 5px 12px; border-radius: var(--radius-full); font-size: 0.78rem;
  background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  color: var(--text-secondary); cursor: pointer; transition: all var(--transition-fast);
}
.hero-tag:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }

.hero-stats { display: flex; justify-content: center; gap: 40px; }
.hero-stat-item { text-align: center; }
.hero-stat-value { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; color: var(--accent); }
.hero-stat-label { font-size: 0.75rem; color: var(--text-muted); }

/* ═══ SECTION STYLES ═══ */
.section { padding: 48px 0; }
.section-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; gap: 10px; flex-wrap: wrap;
}
.section-title {
  font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
  display: flex; align-items: center; gap: 10px;
}
.section-title svg { width: 22px; height: 22px; color: var(--accent); }
.section-link { font-size: 0.85rem; color: var(--accent); font-weight: 500; }
.section-link:hover { color: var(--accent-hover); }

/* ═══ GAME CARDS ═══ */
.games-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.games-grid--all { grid-template-columns: repeat(4, 1fr); }
.game-card-name { font-size: clamp(0.8rem, 1.5vw, 1rem); word-break: break-word; }
.game-card {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  aspect-ratio: 3/4; cursor: pointer; transition: all var(--transition-normal);
  border: 1px solid var(--border);
}
.game-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--border-m); }
.game-card-bg { position: absolute; inset: 0; transition: transform var(--transition-slow); }
.game-card:hover .game-card-bg { transform: scale(1.05); }
.game-card-content {
  position: absolute; bottom: 0; left: 0; right: 0; padding: 16px;
  background: linear-gradient(transparent, rgba(0,0,0,0.9));
}
.game-card-name { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; }
.game-card-count { font-size: 0.75rem; color: var(--text-muted); }

/* ═══ MOD CARDS ═══ */
.mods-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.mod-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  overflow: hidden; transition: all var(--transition-normal); display: flex; flex-direction: column;
}
.mod-card:hover { border-color: var(--border-m); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.mod-card-thumb {
  height: 160px; background: var(--bg-elevated); position: relative; overflow: hidden; flex-shrink: 0;
}
.mod-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.mod-card:hover .mod-card-thumb img { transform: scale(1.05); }
.mod-card-badge {
  position: absolute; top: 8px; left: 8px; padding: 3px 8px;
  border-radius: var(--radius-xs); font-size: 0.68rem; font-weight: 700;
}
.badge-featured { background: rgba(232,93,38,0.9); color: #fff; }
.badge-new { background: rgba(34,197,94,0.9); color: #fff; }
.badge-editors { background: rgba(234,179,8,0.9); color: #000; }
.mod-card-game {
  position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,0.7);
  padding: 3px 8px; border-radius: var(--radius-xs); font-size: 0.68rem;
  color: var(--text-secondary); backdrop-filter: blur(4px);
}
.mod-card-body { padding: 14px; flex: 1; }
.mod-card-title { font-weight: 600; font-size: 0.95rem; margin-bottom: 4px; line-height: 1.3; }
.mod-card-title a:hover { color: var(--accent); }
.mod-card-desc { font-size: 0.8rem; color: var(--text-muted); margin-bottom: 10px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mod-card-meta { display: flex; justify-content: space-between; align-items: center; font-size: 0.75rem; color: var(--text-dim); }
.mod-card-author { color: var(--accent); font-weight: 500; }
.mod-card-stats { display: flex; gap: 10px; }
.mod-card-stats span { display: flex; align-items: center; gap: 3px; }

/* ═══ UPDATED LIST ═══ */
.updated-list { display: flex; flex-direction: column; gap: 2px; }
.updated-item {
  display: flex; align-items: center; gap: 12px; padding: 10px 14px;
  background: var(--bg-card); border-radius: var(--radius-sm);
  transition: background var(--transition-fast); font-size: 0.85rem;
}
.updated-item:hover { background: var(--bg-elevated); }
.updated-thumb { width: 40px; height: 40px; border-radius: var(--radius-xs); background: var(--bg-elevated); overflow: hidden; flex-shrink: 0; }
.updated-thumb img { width: 100%; height: 100%; object-fit: cover; }
.updated-info { flex: 1; min-width: 0; }
.updated-title { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.updated-game { font-size: 0.75rem; color: var(--text-muted); }
.updated-version { color: var(--green); font-family: var(--font-mono); font-size: 0.75rem; }
.updated-downloads { color: var(--text-muted); font-size: 0.75rem; }
.updated-time { color: var(--text-muted); font-size: 0.72rem; white-space: nowrap; }

/* ═══ SIDEBAR ═══ */
.content-layout { display: grid; grid-template-columns: 1fr 320px; gap: 24px; }
.sidebar-widget {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 18px; margin-bottom: 16px;
}
.sidebar-widget-title {
  font-family: var(--font-display); font-size: 1rem; font-weight: 700;
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.trending-list { display: flex; flex-direction: column; gap: 10px; }
.trending-item { display: flex; align-items: center; gap: 10px; font-size: 0.84rem; }
.trending-rank {
  width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-size: 0.7rem; font-weight: 700; flex-shrink: 0;
  background: var(--bg-elevated); color: var(--text-dim);
}
.trending-item:nth-child(1) .trending-rank { background: var(--accent-glow); color: var(--accent); }
.trending-item:nth-child(2) .trending-rank { background: rgba(139,143,160,0.15); color: var(--text-secondary); }
.trending-item:nth-child(3) .trending-rank { background: rgba(139,143,160,0.1); color: var(--text-muted); }
.trending-title { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.trending-game { font-size: 0.7rem; color: var(--text-muted); }
.trending-dl { font-size: 0.72rem; color: var(--text-muted); white-space: nowrap; }

.category-list { display: flex; flex-direction: column; gap: 6px; }
.category-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 7px 10px; border-radius: var(--radius-sm); font-size: 0.84rem;
  color: var(--text-secondary); transition: all var(--transition-fast);
}
.category-item:hover { background: rgba(255,255,255,0.03); color: var(--text-primary); }
.category-count {
  font-size: 0.72rem; color: var(--text-dim); background: var(--bg-elevated);
  padding: 1px 7px; border-radius: var(--radius-full);
}

/* ═══ CTA BANNER ═══ */
.cta-banner {
  background: linear-gradient(135deg, rgba(232,93,38,0.12), rgba(168,85,247,0.08));
  border: 1px solid rgba(232,93,38,0.15); border-radius: var(--radius-xl);
  padding: 48px; margin: 48px 0; text-align: center;
}
.cta-title { font-family: var(--font-display); font-size: 1.8rem; font-weight: 700; margin-bottom: 12px; }
.cta-desc { color: var(--text-secondary); margin-bottom: 24px; max-width: 500px; margin-left: auto; margin-right: auto; }
.cta-features { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 28px; }
.cta-feature {
  background: rgba(0,0,0,0.3); border-radius: var(--radius-md); padding: 16px; text-align: center;
}
.cta-feature-icon { font-size: 1.5rem; margin-bottom: 6px; }
.cta-feature-title { font-weight: 600; font-size: 0.85rem; margin-bottom: 3px; }
.cta-feature-desc { font-size: 0.72rem; color: var(--text-muted); }

/* ═══ BUTTONS ═══ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 20px; border-radius: var(--radius-md); font-family: inherit;
  font-size: 0.88rem; font-weight: 600; border: none; cursor: pointer;
  transition: all var(--transition-fast); text-decoration: none;
}
.btn-primary { background: #d04f1a; color: #fff; }
.btn-primary:hover { background: var(--accent-hover); box-shadow: var(--shadow-glow); transform: translateY(-1px); }
.btn-secondary { background: var(--bg-elevated); color: var(--text-primary); border: 1px solid var(--border); }
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
.btn-ghost { background: transparent; color: var(--text-secondary); border: 1px solid var(--border); padding: 8px 16px; }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); }

/* ═══ ALERTS ═══ */
.alert {
  padding: 12px 18px; border-radius: var(--radius-md); font-size: 0.85rem; margin-bottom: 12px;
}
.alert-success { background: rgba(34,197,94,0.1); border: 1px solid rgba(34,197,94,0.2); color: var(--green); }
.alert-error { background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.2); color: var(--red); }
.alert-warning { background: rgba(234,179,8,0.1); border: 1px solid rgba(234,179,8,0.2); color: var(--yellow); }
.alert-info { background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.2); color: var(--blue); }

/* ═══ PAGINATION ═══ */
.pagination { display: flex; justify-content: center; gap: 4px; margin-top: 32px; }
.page-link {
  padding: 8px 14px; border-radius: var(--radius-sm); font-size: 0.84rem; font-weight: 500;
  background: var(--bg-card); border: 1px solid var(--border); color: var(--text-secondary);
  transition: all var(--transition-fast);
}
.page-link:hover { border-color: var(--accent); color: var(--accent); }
.page-link.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.page-link.disabled { opacity: 0.3; pointer-events: none; }

/* ═══ BREADCRUMB ═══ */
.breadcrumb {
  padding: 14px 0; font-size: 0.8rem; color: var(--text-dim);
  border-bottom: 1px solid var(--border);
}
.breadcrumb a { color: var(--text-muted); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb-sep { margin: 0 8px; }
.breadcrumb-current { color: var(--text-secondary); }

/* ═══ AUTH FORMS ═══ */
.auth-wrap {
  max-width: 420px; margin: 60px auto; padding: 0 20px;
}
.auth-box {
  background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius-xl);
  padding: 36px;
}
.auth-title { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; margin-bottom: 6px; text-align: center; }
.auth-sub { font-size: 0.85rem; color: var(--text-muted); text-align: center; margin-bottom: 24px; }
.auth-form .form-group { margin-bottom: 16px; }
.auth-form .form-label { display: block; font-size: 0.8rem; font-weight: 600; color: var(--text-secondary); margin-bottom: 5px; }
.auth-form .form-input {
  width: 100%; background: var(--bg-input); border: 1px solid var(--border); border-radius: var(--radius-md);
  padding: 11px 14px; color: var(--text-primary); font-family: inherit; font-size: 0.88rem; outline: none;
  transition: border-color var(--transition-fast);
}
.auth-form .form-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.auth-form .form-input::placeholder { color: var(--text-dim); }
.auth-footer { text-align: center; margin-top: 18px; font-size: 0.82rem; color: var(--text-muted); }
.auth-footer a { color: var(--accent); font-weight: 600; }

/* ═══ MOD DETAIL PAGE ═══ */
.mod-banner{margin-bottom:20px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);max-height:360px;background:var(--bg-card);text-align:center}
.mod-banner img{max-width:100%;max-height:360px;object-fit:contain;display:block;margin:0 auto}
.mod-detail-header { padding: 32px 0; }
.mod-detail-title { font-family: var(--font-display); font-size: 2rem; font-weight: 700; margin-bottom: 8px; }
.mod-detail-meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: 0.85rem; color: var(--text-secondary); }
.mod-detail-stat { display: flex; align-items: center; gap: 5px; }

.mod-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; }
.mod-gallery-item{display:block;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:all .2s}
.mod-gallery-item:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.mod-gallery img { width:100%;height:auto;display:block;cursor: pointer; transition: opacity var(--transition-fast); }
.mod-gallery img:hover { opacity: 0.9; }
.lightbox-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center;cursor:zoom-out;padding:24px}
.lightbox-overlay.active{display:flex}
.lightbox-overlay img{max-width:95%;max-height:90vh;border-radius:var(--radius-md);object-fit:contain;cursor:default}
.lightbox-close{position:fixed;top:16px;right:20px;color:#fff;font-size:2rem;cursor:pointer;z-index:10000;background:rgba(0,0,0,.5);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none}
.lightbox-close:hover{background:rgba(255,255,255,.15)}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);color:#fff;font-size:2rem;cursor:pointer;z-index:10000;background:rgba(0,0,0,.5);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none}
.lightbox-nav:hover{background:rgba(255,255,255,.15)}
.lightbox-prev{left:16px}
.lightbox-next{right:16px}

.mod-description { line-height: 1.8; color: var(--text-secondary); }
.mod-description h2, .mod-description h3 { color: var(--text-primary); margin: 20px 0 8px; }
.mod-description p { margin-bottom: 12px; }
.mod-description ul, .mod-description ol { margin: 8px 0 8px 20px; }
.mod-description a { color: var(--accent); }
.mod-description a:hover { text-decoration: underline; }
.mod-description code { font-family: var(--font-mono); background: var(--bg-elevated); padding: 2px 6px; border-radius: 3px; font-size: 0.85em; }

.mod-sidebar-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 20px; margin-bottom: 16px;
}

.download-btn {
  width: 100%; padding: 14px; background: var(--accent); color: #fff; border: none;
  border-radius: var(--radius-md); font-family: inherit; font-size: 1rem; font-weight: 700;
  cursor: pointer; transition: all var(--transition-fast); display: flex; align-items: center;
  justify-content: center; gap: 8px;
}
.download-btn:hover { background: var(--accent-hover); box-shadow: var(--shadow-glow); transform: translateY(-1px); }

/* ═══ REVIEWS ═══ */
.review-item {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 16px; margin-bottom: 10px;
}
.review-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.review-author { font-weight: 600; color: var(--accent); }
.review-stars { color: var(--yellow); }
.review-text { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.6; }
.review-date { font-size: 0.75rem; color: var(--text-dim); margin-top: 8px; }

/* ═══ FOOTER ═══ */
.footer {
  background: var(--bg-surface); border-top: 1px solid var(--border);
  padding: 48px 0 24px; margin-top: 60px;
}
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
.footer-logo { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; margin-bottom: 10px; }
.footer-logo span { color: var(--accent); }
.footer-logo small { font-size: 0.5rem; color: var(--accent); vertical-align: super; }
.footer-desc { font-size: 0.82rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 14px; }
.footer-social { display: flex; gap: 8px; }
.social-link {
  width: 36px; height: 36px; border-radius: 50%; background: var(--bg-elevated);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-muted); transition: all var(--transition-fast);
}
.social-link:hover { color: var(--accent); background: var(--accent-glow); }
.footer-col h3 { font-size: 0.85rem; font-weight: 700; margin-bottom: 14px; color: var(--text-primary); }
.footer-col a {
  display: block; font-size: 0.82rem; color: var(--text-muted); padding: 4px 0;
  transition: color var(--transition-fast);
}
.footer-col a:hover { color: var(--accent); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--border); padding-top: 20px;
  font-size: 0.78rem; color: var(--text-muted);
}
.footer-bottom-links { display: flex; gap: 16px; }
.footer-bottom-links a { color: var(--text-muted); }
.footer-bottom-links a:hover { color: var(--accent); }

/* ═══ NAVBAR DROPDOWN (nav-dd) ═══ */
.nav-dd{position:relative;display:flex;align-items:center}
.nav-dd>[data-dd-trigger]{display:flex;align-items:center;gap:4px;cursor:pointer}
.nav-dd>[data-dd-trigger] svg{transition:transform .2s}
.nav-dd.is-open>[data-dd-trigger] svg{transform:rotate(180deg)}

/* Panel */
.nav-dd-panel{
  display:none;position:absolute;top:calc(100% + 6px);left:0;
  min-width:200px;max-height:70vh;overflow-y:auto;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);
  box-shadow:0 12px 40px rgba(0,0,0,.6);z-index:9999;padding:6px 0
}
.nav-dd-panel--mega{width:380px;padding:14px}
.nav-dd.is-open .nav-dd-panel{display:block}

/* Kategori / basit dropdown item */
.nav-dd-item{display:block;padding:9px 18px;font-size:.84rem;color:var(--text-secondary);transition:all .15s;white-space:nowrap}
.nav-dd-item:hover{background:rgba(232,93,38,.1);color:var(--accent)}

/* Mega grid - oyunlar */
.nav-dd-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.nav-dd-game{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:.84rem;color:var(--text-secondary);transition:all .15s}
.nav-dd-game:hover{background:rgba(255,255,255,.05);color:var(--text-primary)}
.nav-dd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.nav-dd-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.nav-dd-count{font-size:.7rem;color:var(--text-dim);background:var(--bg-elevated);padding:2px 7px;border-radius:var(--radius-full);font-family:var(--font-mono)}
.nav-dd-all{display:block;text-align:center;padding:10px;margin-top:8px;border-top:1px solid var(--border);font-size:.8rem;color:var(--accent);font-weight:600}
.nav-dd-all:hover{text-decoration:underline}

/* ═══ MOBİL MENÜ (navbar dışında) ═══ */
.mobile-menu{
  display:none;position:fixed;top:60px;left:0;right:0;bottom:0;
  background:var(--bg-surface);z-index:99999;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:12px 0;
}
.mobile-menu.open{display:block}
.mobile-menu-link{display:block;padding:12px 24px;font-size:.9rem;color:var(--text-secondary);text-decoration:none;transition:background .15s}
.mobile-menu-link:hover,.mobile-menu-link:active{background:rgba(255,255,255,.04);color:var(--text-primary)}
.mobile-menu-title{padding:16px 24px 6px;font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-weight:600}
.mobile-menu-divider{height:1px;background:var(--border);margin:8px 24px}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 1100px) {
  .games-grid { grid-template-columns: repeat(3, 1fr); }
  .games-grid--all { grid-template-columns: repeat(3, 1fr); }
  .content-layout { grid-template-columns: 1fr; }
  .cta-features { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
}
@media (max-width: 768px) {
  .topbar { display: none; }
  .navbar-links { display: none !important; }
  .navbar-burger { display: block; }
  .navbar-search { width: 140px; }
  
  .hero { padding: 40px 0 30px; }
  .hero h1 { font-size: 1.7rem; }
  .hero-desc { font-size: 0.88rem; }
  .hero-stats { gap: 16px; flex-wrap: wrap; justify-content: center; }
  .hero-stat-value { font-size: 1.2rem; }
  .hero-tags { gap: 6px; }
  .hero-tag { font-size: 0.72rem; padding: 4px 10px; }
  .hero-search input { font-size: 0.88rem; }

  .section { padding: 28px 0; }
  .section-header { gap: 8px; }
  .section-title { font-size: 1.15rem; gap: 6px; }
  .section-title svg { width: 18px; height: 18px; }
  .section-link { font-size: 0.78rem; }

  .games-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .games-grid--all { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .game-card { min-height: 120px; }
  .game-card-name { font-size: 0.82rem; }
  .game-card-count { font-size: 0.65rem; }
  
  /* Editörün Seçimi mobil */
  .editors-grid { grid-template-columns: 1fr; }
  .featured-card { flex-direction: column !important; }
  .featured-card-img { width: 100% !important; min-height: 140px !important; }

  .mods-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .mod-card-thumb { height: 130px; }
  .mod-card-body { padding: 10px; }
  .mod-card-title { font-size: 0.85rem; }
  .mod-card-desc { font-size: 0.72rem; margin-bottom: 6px; }
  .mod-card-meta { font-size: 0.68rem; }

  /* Updated list mobil */
  .updated-item { flex-wrap: wrap; gap: 8px; padding: 10px; }
  .updated-thumb { width: 40px; height: 40px; }
  .updated-version { font-size: 0.68rem; }
  .updated-downloads { font-size: 0.68rem; }
  .updated-time { font-size: 0.65rem; }

  /* Sidebar */
  .content-layout { gap: 24px; }
  .sidebar-widget { padding: 14px; }

  /* CTA */
  .cta-banner { padding: 24px 16px; }
  .cta-title { font-size: 1.3rem; }
  .cta-desc { font-size: 0.85rem; }
  .cta-features { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cta-feature { padding: 12px; }
  .cta-feature-icon { font-size: 1.2rem; }
  .cta-feature-title { font-size: 0.78rem; }
  .cta-feature-desc { font-size: 0.68rem; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 20px; }
  .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .auth-box { padding: 24px; }

  /* Game page mobil */
  .game-header { padding: 20px !important; }
  .game-header h1 { font-size: 1.4rem !important; }

  /* Mod detay mobil */
  .mod-detail-header { padding: 16px 0; }
  .mod-detail-title { font-size: 1.3rem; }
  .mod-detail-meta { font-size: 0.72rem; flex-wrap: wrap; gap: 6px; }
  .mod-banner { max-height: 200px; border-radius: var(--radius-md); }
  .mod-banner img { max-height: 200px; }
  .mod-gallery { grid-template-columns: 1fr 1fr; gap: 8px; }
  .mod-sidebar-card { padding: 14px; }
  .mod-description { font-size: 0.88rem; }
  .download-btn { padding: 12px; font-size: 0.9rem; }
  
  /* Benzer modlar mobil */
  .mods-grid[style*="repeat(2"] { grid-template-columns: 1fr 1fr !important; }

  /* Lightbox mobil */
  .lightbox-overlay { padding: 10px; }
  .lightbox-nav { width: 34px; height: 34px; font-size: 1.4rem; }
  .lightbox-prev { left: 6px; }
  .lightbox-next { right: 6px; }
  .lightbox-close { top: 8px; right: 8px; width: 32px; height: 32px; font-size: 1.4rem; }

  /* Profil mobil */
  .search-filters { flex-direction: column; }
  
  /* Pagination mobil */
  .pagination { flex-wrap: wrap; gap: 4px; }
  .page-link { padding: 6px 10px; font-size: 0.78rem; }
}
  .lightbox-close { top: 10px; right: 10px; width: 34px; height: 34px; font-size: 1.6rem; }

  /* Profil mobil */
  .section { padding: 20px 0; }
  
  /* Search results */
  .search-filters { flex-direction: column; }
}
@media (max-width: 480px) {
  .container { padding: 0 12px; }
  
  .hero { padding: 30px 0 24px; }
  .hero h1 { font-size: 1.3rem; line-height: 1.3; }
  .hero-desc { font-size: 0.82rem; margin-bottom: 16px; }
  .hero-badge { font-size: 0.72rem; padding: 5px 12px; }
  .hero-search { flex-direction: column; }
  .hero-search input { font-size: 0.85rem; }
  .hero-search button { padding: 12px; }
  .hero-tags { display: none; }
  .hero-stats { gap: 12px; }
  .hero-stat-value { font-size: 1rem; }
  .hero-stat-label { font-size: 0.65rem; }
  
  .navbar-search { width: 110px; }
  .search-kbd { display: none; }
  .navbar-brand .brand-text { font-size: 1.1rem; }
  
  .section { padding: 20px 0; }
  .section-title { font-size: 1rem; }
  .section-link { font-size: 0.72rem; }

  .games-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .games-grid--all { grid-template-columns: 1fr 1fr; gap: 8px; }
  .game-card { min-height: 100px; }
  .game-card-name { font-size: 0.75rem; }
  .game-card-count { font-size: 0.58rem; }
  
  .editors-grid { gap: 10px; }
  .featured-card .mod-card-body { padding: 10px; }
  
  .mods-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .mod-card-thumb { height: 110px; }
  .mod-card-body { padding: 8px; }
  .mod-card-title { font-size: 0.78rem; }
  .mod-card-desc { display: none; }
  .mod-card-meta { font-size: 0.65rem; }
  .mod-card-game { font-size: 0.6rem; padding: 2px 5px; }
  
  .updated-item { padding: 8px; }
  .updated-thumb { width: 36px; height: 36px; }
  .updated-title { font-size: 0.78rem; }
  .updated-game { font-size: 0.65rem; }
  .updated-version, .updated-downloads, .updated-time { font-size: 0.62rem; }
  
  .trending-item { padding: 8px; }
  .trending-rank { width: 22px; height: 22px; font-size: 0.68rem; }
  .trending-title { font-size: 0.78rem; }
  .trending-game { font-size: 0.65rem; }
  .trending-dl { font-size: 0.65rem; }

  .sidebar-widget { padding: 12px; }
  .sidebar-widget-title { font-size: 0.85rem; }
  .category-item { padding: 8px 10px; font-size: 0.78rem; }
  
  .cta-banner { padding: 20px 14px; }
  .cta-title { font-size: 1.1rem; }
  .cta-desc { font-size: 0.78rem; }
  .cta-features { grid-template-columns: 1fr 1fr; gap: 8px; }
  .cta-feature { padding: 10px; }
  .cta-feature-icon { font-size: 1rem; }
  .cta-feature-title { font-size: 0.72rem; }
  .cta-feature-desc { display: none; }

  /* Game page 480 */
  .game-header { padding: 16px !important; }
  .game-header h1 { font-size: 1.2rem !important; }
  
  /* Mod detay 480 */
  .mod-detail-title { font-size: 1.1rem; }
  .mod-detail-meta { font-size: 0.65rem; gap: 4px; }
  .mod-gallery { grid-template-columns: 1fr; }
  .mod-banner { max-height: 160px; }
  .mod-banner img { max-height: 160px; }
  .mod-description { font-size: 0.82rem; }
  
  /* Footer compact */
  .footer { padding: 28px 0 16px; }
  .footer-brand { text-align: center; }
  .footer-logo { font-size: 1.2rem; }
  .footer-social { justify-content: center; }
  .footer-col h3 { font-size: 0.82rem; }
  .footer-col a { font-size: 0.78rem; }
  .footer-desc { font-size: 0.75rem; }
  .footer-bottom { font-size: 0.7rem; }
  
  .pagination { gap: 3px; }
  .page-link { padding: 5px 8px; font-size: 0.72rem; }
}

/* ═══ EDITORS GRID & FEATURED CARD ═══ */
.editors-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.featured-card { display: flex; flex-direction: row; overflow: hidden; }
.featured-card-img { width: 200px; min-height: 160px; background: var(--bg-elevated); flex-shrink: 0; overflow: hidden; }
.featured-card-img img { width: 100%; height: 100%; object-fit: cover; }

/* ═══ GLOBAL OVERFLOW PREVENTION ═══ */
*, *::before, *::after { box-sizing: border-box; }
img, video, iframe { max-width: 100%; }
table { max-width: 100%; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ═══ GAMES GRID ALL ═══ */
.games-grid--all{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.games-grid--all{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.games-grid--all{grid-template-columns:repeat(2,1fr) !important}}
@media(max-width:480px){.games-grid--all{grid-template-columns:repeat(2,1fr) !important;gap:8px !important}}
