/* ============================================================
   MINESITE — seeds.css
   Fonts + tokens synced with style.css (homepage)
   Fully responsive for all devices
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=DM+Mono:wght@400;500&display=swap');

/* ── Minecraft (default) variables ── */
:root {
  --bg:           #060b06;
  --bg-2:         #0d160d;
  --bg-3:         #131f13;
  --bg-card:      #0f1a0f;
  --bg-elevated:  #172417;
  --border:       #1f3320;
  --border-2:     #2e5030;
  --border-focus: #4ade80;
  --green:        #4ade80;
  --mc:           #4ade80;
  --green-dim:    #34c265;
  --mc-dim:       #34c265;
  --green-muted:  #2a9e52;
  --green-glow:   rgba(74,222,128,0.18);
  --mc-glow:      rgba(74,222,128,0.12);
  --green-soft:   rgba(74,222,128,0.08);
  --gold:         #f59e0b;
  --cyan:         #06b6d4;
  --danger:       #f87171;
  --text:         #e2f0e2;
  --text-2:       #9dbe9d;
  --text-3:       #5e7e5e;
  --text-inv:     #060b06;
  --sans:   'DM Sans', system-ui, -apple-system, sans-serif;
  --mono:   'DM Mono', 'Courier New', monospace;
  --pixel:  'Press Start 2P', cursive;
  --radius:      6px;
  --radius-lg:   12px;
  --radius-xl:   18px;
  --sidebar-w:   272px;
  --header-h:    68px;
  --bar-h:       48px;
  --sticky-top:  calc(var(--header-h) + var(--bar-h));
  --dur-fast:    0.15s;
  --dur-base:    0.22s;
  --dur-slow:    0.4s;
  --ease:        cubic-bezier(0.22, 1, 0.36, 1);
  --transition:  all var(--dur-base) var(--ease);
  /* Active accent — switches per game */
  --accent:      var(--green);
  --accent-dim:  var(--green-dim);
  --accent-glow: var(--green-glow);
  /* Hytale palette (used when body.hytale-mode) */
  --hy:          #a78bfa;
  --hy-dim:      #7c3aed;
  --hy-bright:   #c4b5fd;
  --hy-glow:     rgba(167,139,250,0.15);
  --hy-border:   rgba(124,58,237,0.3);
}

/* ── Hytale mode overrides ── */
body.hytale-mode {
  --accent:      var(--hy);
  --accent-dim:  var(--hy-dim);
  --accent-glow: var(--hy-glow);
  --text:        #e2d9f3;
  --text-2:      #9d84c9;
  --text-3:      #5b4a8a;
  --bg:          #080412;
  --bg-2:        #0d0620;
  --bg-3:        #120830;
  --bg-card:     #0a0318;
  --bg-elevated: #150535;
  --border:      #1e1040;
  --border-2:    #2d1860;
  background-image:
    linear-gradient(rgba(124,58,237,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,0.04) 1px, transparent 1px) !important;
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  :root { --dur-fast:0ms; --dur-base:0ms; --dur-slow:0ms; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Reset & base ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html {
  scroll-behavior:smooth;
  font-size:16px;
  overflow-x: hidden;
}
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background-image:
    linear-gradient(rgba(74,222,128,0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(74,222,128,0.018) 1px, transparent 1px);
  background-size: 32px 32px;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.4s, color 0.4s;
  overflow-x: hidden;
}

:focus-visible { outline:2px solid var(--accent); outline-offset:3px; border-radius:var(--radius); }

.pixel     { font-family: var(--pixel); letter-spacing: 0.05em; }
.mono      { font-family: var(--mono); }
.container { max-width:1280px; margin:0 auto; padding:0 1.5rem; width:100%; }

.skip-link {
  position:absolute; top:-60px; left:1rem;
  background:var(--green); color:var(--bg);
  padding:10px 20px; font-weight:700; font-size:0.9rem;
  text-decoration:none; z-index:9999;
  border-radius:0 0 var(--radius) var(--radius);
  transition:top 0.2s;
}
.skip-link:focus { top:0; }

/* ============================================================
   GAME PICKER POPUP – fully responsive
   ============================================================ */
.game-picker-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,0.92); backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center; padding:1rem;
  animation:overlayIn 0.3s ease both;
}
@keyframes overlayIn { from{opacity:0} to{opacity:1} }
.game-picker-overlay.closing { animation:overlayOut 0.3s ease forwards; }
@keyframes overlayOut { to{opacity:0} }

.game-picker {
  max-width:860px; width:100%; text-align:center;
  animation:pickerIn 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes pickerIn {
  from{opacity:0;transform:scale(0.9) translateY(20px)}
  to  {opacity:1;transform:scale(1)   translateY(0)}
}
.picker-label { font-family:var(--pixel); font-size:0.8rem; color:#fff; letter-spacing:0.15em; margin-bottom:0.5rem; }
.picker-sub   { font-size:0.85rem; color:rgba(255,255,255,0.45); margin-bottom:2.5rem; font-family:var(--sans); }

.picker-cards {
  display:grid; grid-template-columns:1fr auto 1fr;
  gap:1rem; align-items:stretch; margin-bottom:1.5rem;
}
.picker-card {
  position:relative; background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08); border-radius:16px;
  padding:2.5rem 1.5rem 2rem; cursor:pointer; overflow:hidden;
  transition:transform 0.25s, border-color 0.25s, box-shadow 0.25s;
  text-align:center; display:flex; flex-direction:column; align-items:center;
}
.picker-card:hover { transform:translateY(-6px); }
#pickMinecraft:hover { border-color:rgba(74,222,128,0.5); box-shadow:0 20px 60px rgba(74,222,128,0.15); }
#pickHytale:hover   { border-color:rgba(124,58,237,0.6); box-shadow:0 20px 60px rgba(124,58,237,0.2); }
.picker-card-bg { position:absolute; inset:0; pointer-events:none; opacity:0; transition:opacity 0.3s; border-radius:16px; }
.picker-card:hover .picker-card-bg { opacity:1; }
.picker-bg-mc { background:radial-gradient(ellipse at 50% 0%, rgba(74,222,128,0.12) 0%, transparent 70%); }
.picker-bg-hy { background:radial-gradient(ellipse at 50% 0%, rgba(124,58,237,0.15) 0%, transparent 70%); }
.picker-card-inner { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:0.75rem; width:100%; }
.picker-logo { width:88px; height:88px; display:flex; align-items:center; justify-content:center; }
.picker-game-title { font-family:var(--pixel); font-size:0.65rem; color:#fff; letter-spacing:0.1em; }
.picker-game-desc  { font-size:0.82rem; color:rgba(255,255,255,0.5); line-height:1.6; font-family:var(--sans); }
.picker-new-wrap   { display:flex; justify-content:center; }
.picker-new-badge  { font-family:var(--pixel); font-size:0.45rem; background:rgba(167,139,250,0.15); border:1px solid rgba(167,139,250,0.4); color:#a78bfa; padding:0.3rem 0.7rem; border-radius:4px; }
.picker-tags { display:flex; gap:0.4rem; flex-wrap:wrap; justify-content:center; }
.picker-tag  { font-size:0.68rem; padding:0.2rem 0.6rem; border-radius:4px; border:1px solid; font-family:var(--mono); }
.mc-tag { border-color:rgba(74,222,128,0.3); color:rgba(74,222,128,0.8); background:rgba(74,222,128,0.06); }
.hy-tag { border-color:rgba(167,139,250,0.3); color:rgba(167,139,250,0.8); background:rgba(167,139,250,0.06); }
.picker-enter-btn { font-family:var(--pixel); font-size:0.48rem; letter-spacing:0.08em; padding:0.65rem 1.5rem; border-radius:var(--radius); margin-top:0.5rem; }
.mc-btn { background:rgba(74,222,128,0.12); color:#4ade80; border:1px solid rgba(74,222,128,0.4); }
.hy-btn { background:rgba(167,139,250,0.12); color:#a78bfa; border:1px solid rgba(167,139,250,0.4); }
.picker-divider { display:flex; align-items:center; justify-content:center; }
.picker-divider span { font-size:0.7rem; color:rgba(255,255,255,0.2); font-family:var(--mono); }
.picker-footer-note { font-size:0.72rem; color:rgba(255,255,255,0.2); font-family:var(--sans); }

/* ============================================================
   HEADER – sticky, responsive
   ============================================================ */
.site-header {
  position:sticky; top:0; z-index:200;
  background:rgba(6,11,6,0.9);
  backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--border);
}
.nav-container {
  display:flex; align-items:center;
  justify-content:space-between; height:68px; gap:1rem;
}
.logo {
  display:flex; align-items:center; gap:0.7rem;
  text-decoration:none; flex-shrink:0; transition:var(--transition);
}
.logo-icon-svg { width:34px; height:34px; border-radius:8px; border:1px solid var(--border-2); }
.logo-text {
  font-family:var(--pixel); font-size:0.65rem;
  color:var(--green); letter-spacing:0.1em;
  text-shadow:0 0 16px rgba(74,222,128,0.55);
  transition:color var(--dur-base) var(--ease);
}
.logo:hover .logo-text { color:#b9f5d0; }

.main-nav ul { display:flex; gap:1.5rem; list-style:none; align-items:center; }
.main-nav a {
  font-family:var(--sans); font-size:0.875rem; font-weight:500;
  color:var(--text-2); text-decoration:none; letter-spacing:0.01em;
  transition:color var(--dur-base) var(--ease);
  position:relative; padding-bottom:2px;
}
.main-nav a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:2px; background:var(--green); border-radius:1px;
  transition:width var(--dur-base) var(--ease);
}
.main-nav a:hover        { color:var(--text); }
.main-nav a:hover::after { width:100%; }
.main-nav a.active       { color:var(--green); }
.main-nav a.active::after{ width:100%; }

.nav-cta {
  background:var(--green-soft) !important; border:1px solid var(--border-2) !important;
  border-radius:999px !important; padding:0.42rem 1.1rem !important;
  color:var(--green) !important; font-size:0.82rem !important; font-weight:600 !important;
}
.nav-cta:hover { background:rgba(74,222,128,0.14) !important; border-color:var(--green-muted) !important; color:#b9f5d0 !important; }
.nav-cta::after { display:none !important; }

.mobile-menu-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:1px solid transparent; cursor:pointer;
  padding:0.5rem; border-radius:var(--radius);
  transition:border-color var(--dur-base) var(--ease);
  min-width:44px; min-height:44px; align-items:center; justify-content:center;
}
.mobile-menu-toggle:hover { border-color:var(--border-2); }
.burger-line { display:block; width:22px; height:2px; background:var(--text-2); border-radius:2px; transition:var(--transition); }

/* ============================================================
   GAME BAR
   ============================================================ */
.game-bar {
  background:var(--bg-2); border-bottom:1px solid var(--border);
  height:var(--bar-h); position:sticky; top:var(--header-h); z-index:90;
  display:flex; align-items:center;
}
.game-bar-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; height:100%; }
.game-explain { font-size:0.8rem; color:var(--text-3); font-family:var(--sans); }
.game-toggle { display:flex; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.game-btn {
  display:flex; align-items:center; gap:0.45rem;
  padding:0.45rem 1rem; background:transparent; border:none;
  border-right:1px solid var(--border); color:var(--text-3);
  font-family:var(--sans); font-size:0.82rem; font-weight:500; cursor:pointer; white-space:nowrap;
  transition:var(--transition);
}
.game-btn:last-child { border-right:none; }
.game-btn:hover { color:var(--text-2); background:var(--bg-3); }
.game-btn.active { background:rgba(74,222,128,0.07); color:var(--green); }
body.hytale-mode .game-btn.active { background:rgba(167,139,250,0.08); color:var(--hy); }
.new-badge { font-family:var(--pixel); font-size:0.38rem; background:rgba(167,139,250,0.15); border:1px solid rgba(167,139,250,0.4); color:#a78bfa; padding:0.15rem 0.45rem; border-radius:3px; }

/* ============================================================
   LAYOUT + SIDEBAR
   ============================================================ */
.layout { display:flex; flex:1; }
.sidebar {
  width:var(--sidebar-w); min-width:var(--sidebar-w);
  background:var(--bg-2); border-right:1px solid var(--border);
  padding:1.75rem 1.25rem;
  position:sticky; top:var(--sticky-top);
  height:calc(100vh - var(--sticky-top)); overflow-y:auto;
  display:flex; flex-direction:column; gap:1.5rem;
}
.sidebar::-webkit-scrollbar { width:4px; }
.sidebar::-webkit-scrollbar-thumb { background:var(--border-2); border-radius:2px; }

.sidebar-title { font-family:var(--pixel); font-size:0.48rem; color:var(--text-3); letter-spacing:0.2em; text-transform:uppercase; padding-bottom:1rem; border-bottom:1px solid var(--border); }

.search-box { position:relative; }
.search-box svg { position:absolute; left:0.75rem; top:50%; transform:translateY(-50%); color:var(--text-3); pointer-events:none; }
.search-input {
  width:100%; padding:0.65rem 0.75rem 0.65rem 2.2rem;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text); border-radius:var(--radius);
  font-family:var(--sans); font-size:0.85rem;
  transition:var(--transition);
}
.search-input:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-glow); }
.search-input::placeholder { color:var(--text-3); }

.filter-section-label { font-family:var(--pixel); font-size:0.48rem; color:var(--text-3); letter-spacing:0.15em; text-transform:uppercase; margin-bottom:0.6rem; }

.edition-filters, .cat-filters { display:flex; flex-direction:column; gap:0.3rem; }
.edition-btn, .cat-btn {
  padding:0.5rem 0.75rem; background:transparent;
  border:1px solid var(--border); color:var(--text-2);
  font-family:var(--sans); font-size:0.82rem; font-weight:500;
  cursor:pointer; border-radius:var(--radius);
  text-align:left; display:flex; align-items:center; gap:0.6rem;
  transition:var(--transition);
}
.edition-btn:hover, .cat-btn:hover { border-color:var(--border-2); color:var(--text); }
.edition-btn.active-all     { border-color:var(--green);  color:var(--green);  background:rgba(74,222,128,0.07); }
.edition-btn.active-java    { border-color:var(--cyan);   color:var(--cyan);   background:rgba(6,182,212,0.07); }
.edition-btn.active-bedrock { border-color:var(--gold);   color:var(--gold);   background:rgba(245,158,11,0.07); }
.cat-btn.active             { border-color:var(--hy);     color:var(--hy);     background:rgba(167,139,250,0.07); }

.edition-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.dot-all     { background:var(--green); }
.dot-java    { background:var(--cyan); }
.dot-bedrock { background:var(--gold); }

.filter-group { display:flex; flex-direction:column; gap:0.2rem; }
.filter-label {
  display:flex; align-items:center; gap:0.65rem;
  padding:0.4rem 0.5rem; cursor:pointer; border-radius:var(--radius);
  font-size:0.82rem; color:var(--text-2); font-family:var(--sans);
  transition:var(--transition);
}
.filter-label:hover { background:var(--bg-3); color:var(--text); }
.filter-checkbox {
  appearance:none; width:15px; height:15px;
  border:1px solid var(--border-2); background:var(--bg);
  border-radius:3px; cursor:pointer; flex-shrink:0; position:relative;
  transition:var(--transition);
}
.filter-checkbox:checked { background:var(--accent); border-color:var(--accent); }
.filter-checkbox:checked::after { content:'✓'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:var(--bg); font-size:9px; font-weight:700; }
.filter-tag-name { flex:1; }
.filter-count { font-size:0.65rem; color:var(--text-3); background:var(--bg-3); border:1px solid var(--border); padding:0.08rem 0.38rem; border-radius:10px; min-width:22px; text-align:center; font-family:var(--mono); }

.sidebar-footer { margin-top:auto; }
.reset-btn {
  width:100%; padding:0.55rem 1rem; background:transparent;
  border:1px solid var(--border); color:var(--text-3);
  font-family:var(--sans); font-size:0.8rem; cursor:pointer;
  border-radius:var(--radius); transition:var(--transition);
}
.reset-btn:hover { border-color:var(--border-2); color:var(--text-2); background:var(--bg-3); }

/* ============================================================
   MAIN CONTENT
   ============================================================ */
.main { flex:1; padding:2rem; min-width:0; display:flex; flex-direction:column; gap:1.25rem; }

.page-header { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.page-title    { font-family:var(--pixel); font-size:0.75rem; color:var(--accent); letter-spacing:0.08em; line-height:1.6; margin-bottom:0.35rem; text-shadow:0 0 20px var(--accent-glow); }
.page-subtitle { font-size:0.9rem; color:var(--text-2); margin-bottom:0.25rem; }
.page-count    { font-size:0.8rem; color:var(--text-3); font-family:var(--mono); white-space:nowrap; }
.page-count span { color:var(--accent); font-weight:600; }

.sort-bar { display:flex; align-items:center; gap:0.75rem; padding-bottom:0.75rem; border-bottom:1px solid var(--border); flex-wrap:wrap; }
.sort-label  { font-size:0.8rem; color:var(--text-3); white-space:nowrap; }
.sort-select {
  padding:0.42rem 0.85rem; background:var(--bg-card);
  border:1px solid var(--border); color:var(--text);
  font-family:var(--sans); font-size:0.82rem; border-radius:var(--radius);
  cursor:pointer; transition:var(--transition);
}
.sort-select:focus { outline:none; border-color:var(--accent); }

/* ── Seed grid — 2 columns, responsive ── */
.seed-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; flex:1; }

/* ── Seed card — 16:9 with hover-reveal overlay ── */
.seed-card {
  position:relative; overflow:hidden;
  aspect-ratio:16/9;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  text-decoration:none; color:inherit;
  display:block;
  transition:border-color var(--dur-base) var(--ease),
             box-shadow var(--dur-base) var(--ease),
             transform var(--dur-base) var(--ease);
  cursor:pointer;
}
.seed-card:hover { border-color:var(--border-2); transform:translateY(-4px); }
body:not(.hytale-mode) .seed-card:hover { box-shadow:0 16px 48px rgba(0,0,0,0.6),0 0 0 1px rgba(74,222,128,0.1); }
body.hytale-mode        .seed-card:hover { box-shadow:0 16px 48px rgba(0,0,0,0.6),0 0 0 1px rgba(124,58,237,0.2); }
body.hytale-mode .seed-card { border-color:var(--hy-border); }

/* Image fills entire card */
.card-img-wrap {
  position:absolute; inset:0;
  width:100%; height:100%;
}
.card-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform 0.55s var(--ease), filter 0.55s var(--ease);
  filter:brightness(0.75) saturate(0.8);
}
.seed-card:hover .card-img { transform:scale(1.07); filter:brightness(0.55) saturate(0.9); }
.hytale-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:2.5rem; background:linear-gradient(135deg,#0d0520,#1a0840); }

/* Badges always on top */
.game-tag { position:absolute; top:0.65rem; left:0.65rem; z-index:4; font-family:var(--pixel); font-size:0.38rem; background:rgba(7,12,7,0.88); padding:0.25rem 0.55rem; border-radius:var(--radius); border:1px solid; letter-spacing:0.05em; }
.game-tag.minecraft { color:var(--mc);  border-color:var(--mc-dim); }
.game-tag.hytale    { color:var(--hy);  border-color:var(--hy-dim); }
.card-badge { position:absolute; top:0.65rem; right:0.65rem; z-index:4; font-family:var(--pixel); font-size:0.4rem; background:rgba(7,12,7,0.88); border:1px solid var(--accent-dim); color:var(--accent); padding:0.25rem 0.55rem; border-radius:var(--radius); letter-spacing:0.05em; }

/* ── Card body: a panel anchored to the bottom of the 16:9 card.
   Default: gradient strip — shows only the title line peeking up.
   Hover:   expands to reveal seed code, description, and tags.         ── */
.card-body {
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  /* Start: tall enough for gradient fade + one title line */
  padding:3.5rem 1.1rem 0.9rem;
  background:linear-gradient(transparent, rgba(5,9,5,0.96) 52%);
  max-height:4.2rem;          /* clips everything below the title */
  overflow:hidden;
  display:flex; flex-direction:column; gap:0.42rem;
  transition: max-height  0.42s var(--ease),
              padding     0.38s var(--ease),
              background  0.3s,
              backdrop-filter 0.3s;
  backdrop-filter:blur(0px);
}
body.hytale-mode .card-body { background:linear-gradient(transparent, rgba(8,4,18,0.96) 52%); }

.seed-card:hover .card-body {
  max-height:80%;
  padding:0.9rem 1.1rem 1rem;
  background:rgba(5,9,5,0.95);
  backdrop-filter:blur(8px);
}
body.hytale-mode .seed-card:hover .card-body { background:rgba(8,4,18,0.96); }

/* Accent top-line fades in when panel opens */
.card-body::before {
  content:''; display:block; height:2px; flex-shrink:0;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:0;
  margin-bottom:0.3rem;
  transition:opacity 0.3s 0.18s;
}
.seed-card:hover .card-body::before { opacity:0.75; }

/* Title — always the first visible thing */
.card-title { font-family:var(--pixel); font-size:0.46rem; line-height:1.8; color:#e8f5e8; flex-shrink:0; }
.seed-card:hover .card-title { color:var(--accent); }

/* Details fade in after the panel has opened */
.card-code, .card-desc, .card-zone, .card-tags {
  opacity:0;
  transform:translateY(5px);
  transition:opacity 0.22s 0.22s, transform 0.22s 0.22s;
}
.seed-card:hover .card-code,
.seed-card:hover .card-desc,
.seed-card:hover .card-zone,
.seed-card:hover .card-tags  { opacity:1; transform:translateY(0); }

.card-code  { font-size:0.78rem; color:var(--accent); font-family:var(--mono); display:flex; align-items:center; gap:0.4rem; flex-shrink:0; }
.card-code-label { font-size:0.62rem; color:var(--text-3); }
.card-desc  { font-size:0.82rem; color:var(--text-2); line-height:1.6; }
.card-zone  { font-size:0.72rem; color:var(--hy); font-family:var(--mono); flex-shrink:0; }
.card-tags  { display:flex; flex-wrap:wrap; gap:0.35rem; margin-top:auto; }
.tag { font-size:0.58rem; padding:0.15rem 0.5rem; border:1px solid var(--border-2); color:var(--text-3); border-radius:3px; text-transform:uppercase; letter-spacing:0.08em; transition:var(--transition); font-family:var(--mono); }
body:not(.hytale-mode) .seed-card:hover .tag { border-color:rgba(74,222,128,0.25); color:var(--text-2); }
body.hytale-mode        .seed-card:hover .tag { border-color:rgba(124,58,237,0.35); color:#c4b5fd; }

/* Hytale card */
.seed-card.hy-card { border-left:3px solid var(--zone-colour,#a78bfa); background:#130625; border-color:#2a1560; border-left-color:var(--zone-colour,#a78bfa); }
.seed-card.hy-card:hover { border-color:#a78bfa; border-left-color:var(--zone-colour,#a78bfa); }
.seed-card.hy-card .card-body::before { background:linear-gradient(90deg, transparent, var(--zone-colour,#a78bfa), transparent); }
.hy-card .card-zone { font-size:0.68rem; font-weight:600; }

/* State / empty */
.state-msg { grid-column:1/-1; padding:3rem; text-align:center; color:var(--text-3); font-size:0.9rem; border:1px dashed var(--border-2); border-radius:var(--radius-lg); }
.state-msg .state-icon { font-size:2rem; display:block; margin-bottom:1rem; }

/* Skeleton — roughly matches the card visual at typical column widths */
.skeleton-card {
  background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-3) 50%,var(--bg-card) 75%);
  background-size:200% 100%; animation:shimmer 1.5s infinite;
  border-radius:var(--radius-lg); aspect-ratio:16/9; border:1px solid var(--border);
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* Pagination */
.pagination { display:flex; justify-content:center; align-items:center; gap:1rem; margin-top:2.5rem; padding-top:2rem; border-top:1px solid var(--border); flex-wrap:wrap; }
.page-btn {
  background:transparent; border:1px solid var(--border); color:var(--text-2);
  padding:0.6rem 1.1rem; font-family:var(--sans); font-size:0.82rem; font-weight:500;
  cursor:pointer; border-radius:var(--radius); transition:var(--transition);
  min-width:44px; min-height:44px; display:inline-flex; align-items:center; justify-content:center;
}
.page-btn:hover:not(:disabled) { border-color:var(--accent-dim); color:var(--accent); }
.page-btn:disabled { opacity:0.3; cursor:not-allowed; }
.page-info { font-size:0.78rem; color:var(--text-3); font-family:var(--mono); }
.page-info span { color:var(--text-2); }

/* Mobile filter FAB */
.mobile-filter-btn {
  display:none; position:fixed; bottom:1.5rem; right:1.5rem;
  background:var(--accent); color:var(--bg); border:none;
  padding:0.65rem 1.2rem; font-family:var(--pixel); font-size:0.48rem;
  border-radius:40px; cursor:pointer; z-index:90;
  box-shadow:0 4px 16px var(--accent-glow); transition:var(--transition);
  min-width:44px; min-height:44px;
}

/* ============================================================
   FOOTER — matches homepage
   ============================================================ */
.site-footer { background:var(--bg-2); border-top:1px solid var(--border); margin-top:auto; }
.footer-inner-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr; gap:3rem; padding:3.5rem 0 3rem; }
.footer-brand { display:flex; flex-direction:column; gap:1rem; }
.footer-logo  { font-family:var(--pixel); font-size:0.7rem; color:var(--green); letter-spacing:0.1em; text-shadow:0 0 12px rgba(74,222,128,0.4); }
.footer-brand p { font-size:0.85rem; color:var(--text-3); line-height:1.7; max-width:280px; }
.footer-col h4  { font-family:var(--pixel); font-size:0.5rem; color:var(--text-2); letter-spacing:0.12em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col ul  { list-style:none; display:flex; flex-direction:column; gap:0.55rem; }
.footer-col a   { font-size:0.85rem; color:var(--text-3); text-decoration:none; transition:color var(--dur-base) var(--ease); display:inline-block; padding:0.2rem 0; }
.footer-col a:hover { color:var(--green); }
.footer-bottom-bar   { border-top:1px solid var(--border); padding:1rem 0; background:rgba(6,11,6,0.6); }
.footer-bottom-inner { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.footer-bottom-inner small { font-size:0.78rem; color:var(--text-3); }

/* ============================================================
   RESPONSIVE – enhanced for all devices
   ============================================================ */

/* Tablet and smaller (≤ 1024px) – adjust sidebar width, spacing */
@media (max-width: 1024px) {
  :root {
    --sidebar-w: 260px;
  }
  .seed-grid { gap: 1rem; }
  .main { padding: 1.5rem; }
}

/* Landscape phones & small tablets (≤ 900px) */
@media (max-width: 900px) {
  .mobile-menu-toggle { display:flex; }
  .main-nav {
    position:fixed; top:68px; left:0; right:0;
    background:rgba(6,11,6,0.98); backdrop-filter:blur(20px);
    padding:1.5rem; visibility: hidden; opacity: 0; pointer-events: none;
    transition: opacity var(--dur-base) var(--ease), visibility var(--dur-base) var(--ease);
    border-bottom:1px solid var(--border); z-index:199;
  }
  .main-nav.open { visibility: visible; opacity: 1; pointer-events: auto; }
  .main-nav ul { flex-direction:column; gap:1.2rem; align-items:stretch; }
  .main-nav a  { display:block; text-align:center; padding:0.5rem 0; }
  .nav-cta     { text-align:center; }

  .game-bar { position:static; }
  .game-bar-inner { flex-direction:column; align-items:flex-start; height:auto; padding:0.75rem 0; }
  .game-explain { display:none; }

  /* Sidebar becomes full-width drawer */
  .sidebar {
    position:fixed; left:-100%; top:0; width:min(85vw, 300px);
    height:100vh; z-index:150; transition:left 0.3s ease;
    box-shadow:4px 0 24px rgba(0,0,0,0.5);
    border-right: none; border-radius:0 var(--radius-lg) var(--radius-lg) 0;
    overflow-y: auto;
  }
  .sidebar.open { left:0; }
  .mobile-filter-btn { display:flex; }

  .main { padding:1.5rem; }
  .seed-grid { grid-template-columns:1fr; }

  /* Card becomes static (always expanded) on mobile */
  .seed-card { aspect-ratio:unset; }
  .card-img-wrap { position:relative; height:195px; }
  .card-body {
    position:static; transform:none !important;
    background:rgba(6,11,6,0.97); max-height:none;
    border-top:1px solid var(--border);
    padding:1rem;
    backdrop-filter: none;
  }
  body.hytale-mode .card-body { background:rgba(8,4,18,0.97); }
  .card-body::before { display:none; }
  .card-title { color:var(--accent); }
  .card-code, .card-desc, .card-zone, .card-tags {
    opacity:1; transform:translateY(0);
    transition: none;
  }
  .card-code { margin-top:0.25rem; }

  /* Game picker – single column */
  .picker-cards { grid-template-columns:1fr; grid-template-rows:auto; gap:1rem; }
  .picker-divider { display:none; }

  /* Footer stack */
  .footer-inner-grid { grid-template-columns:1fr; gap:2rem; text-align:center; }
  .footer-brand { align-items:center; }
  .footer-brand p { max-width:100%; }
  .footer-col ul { align-items:center; }
  .footer-bottom-inner { flex-direction:column; text-align:center; }
}

/* Small phones (≤ 600px) */
@media (max-width: 600px) {
  .container { padding:0 1rem; }
  .nav-container { height:60px; }
  .logo-text { font-size:0.55rem; }
  .logo-icon-svg { width:28px; height:28px; }
  .game-btn { padding:0.35rem 0.7rem; font-size:0.7rem; gap:0.3rem; }
  .new-badge { font-size:0.32rem; padding:0.1rem 0.35rem; }

  .sidebar { width:min(85vw, 280px); padding:1rem; }
  .search-input { font-size:16px; } /* prevents zoom on iOS */
  .edition-btn, .cat-btn { padding:0.4rem 0.6rem; font-size:0.75rem; }

  .main { padding:1rem; gap:1rem; }
  .page-header { flex-direction:column; align-items:flex-start; gap:0.5rem; }
  .page-title { font-size:0.6rem; }
  .page-subtitle { font-size:0.8rem; }
  .page-count { font-size:0.7rem; white-space:normal; }
  .sort-bar { gap:0.5rem; }
  .sort-label { font-size:0.7rem; }
  .sort-select { padding:0.35rem 0.7rem; font-size:0.75rem; }

  .seed-grid { gap:0.9rem; }
  .card-img-wrap { height:170px; }
  .card-body { padding:0.75rem; }
  .card-title { font-size:0.42rem; }
  .card-code { font-size:0.7rem; }
  .card-desc { font-size:0.75rem; }
  .tag { font-size:0.5rem; padding:0.1rem 0.4rem; }

  .pagination { gap:0.5rem; margin-top:1.5rem; }
  .page-btn { padding:0.4rem 0.8rem; font-size:0.7rem; min-width:40px; min-height:40px; }
  .page-info { font-size:0.7rem; }

  .mobile-filter-btn { bottom:1rem; right:1rem; padding:0.5rem 1rem; font-size:0.42rem; }

  .footer-inner-grid { gap:1.5rem; padding:2rem 0 1.5rem; }
  .footer-col h4 { font-size:0.45rem; margin-bottom:0.8rem; }
  .footer-col a { font-size:0.75rem; }
  .footer-bottom-inner small { font-size:0.7rem; }

  /* Game picker compact */
  .picker-card { padding:1.5rem 1rem; }
  .picker-logo { width:64px; height:64px; }
  .picker-game-title { font-size:0.55rem; }
  .picker-game-desc { font-size:0.7rem; }
  .picker-enter-btn { padding:0.5rem 1rem; font-size:0.42rem; }
}

/* Touch devices: increase tap targets */
@media (hover: none) and (pointer: coarse) {
  .edition-btn, .cat-btn, .reset-btn, .game-btn, .page-btn, .nav-cta,
  .filter-label, .picker-card {
    min-height: 44px;
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
  }
  .filter-label { padding:0.6rem 0.5rem; }
  .game-btn { padding:0.6rem 0.8rem; }
}

/* Ensure content never overflows horizontally */
img, svg, video, iframe { max-width:100%; height:auto; }

/* Prevent body scroll when mobile menu is open */
body.menu-open { overflow: hidden; }

/* ═══════════════════════════════════════════════════
   MOBILE OVERFLOW — FINAL GUARD
═══════════════════════════════════════════════════ */
@media (max-width: 768px) {
  html, body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }
  .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  img, video, iframe, canvas {
    max-width: 100% !important;
  }
}
