/* modded.pw — style.css */

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

:root {
  --bg:            #0f0f12;
  --bg-surface:    #161619;
  --bg-card:       #1c1c22;
  --bg-card-hover: #22222a;
  --bg-input:      #14141a;
  --border:        rgba(255,255,255,0.08);
  --border-mid:    rgba(255,255,255,0.13);
  --border-bright: rgba(255,255,255,0.22);

  --accent:        #5D38D6;
  --accent-light:  #7a5ae8;
  --accent-bright: #9b82f5;
  --accent-dim:    rgba(93,56,214,0.14);
  --accent-glow:   rgba(93,56,214,0.35);

  --text-1:        #eeeef2;
  --text-2:        #8e8ea8;
  --text-3:        #50505e;
  --tag-bg:        rgba(93,56,214,0.13);
  --tag-text:      #a892ff;
  --green:         #4adeaa;
  --green-bg:      rgba(74,222,170,0.1);
  --red:           #ff6060;

  --ps3:           #3d7fff;
  --ps3-dim:       rgba(61,127,255,0.14);
  --ps3-text:      #7aafff;
  --x360:          #52c452;
  --x360-dim:      rgba(82,196,82,0.14);
  --x360-text:     #78d878;

  --mono:          'JetBrains Mono', monospace;
  --sans:          'Syne', sans-serif;
  --r-sm:          6px;
  --r-md:          9px;
  --r-lg:          13px;
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text-1);
  font-family: var(--sans);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border-mid); border-radius: 3px; }

/* ── HEADER ── */
header {
  position: sticky; top: 0; z-index: 200;
  background: rgba(15,15,18,0.9);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  height: 62px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2rem;
}

.logo {
  font-family: var(--mono); font-size: 15px; font-weight: 600;
  color: var(--text-1); text-decoration: none;
  display: flex; align-items: center; gap: 9px; letter-spacing: -0.02em;
}
.logo-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 14px var(--accent-glow);
  animation: pulse 3s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.3} }

.header-right { display: flex; align-items: center; gap: 12px; }
.header-count { font-family: var(--mono); font-size: 11px; color: var(--text-3); letter-spacing: 0.05em; }

.yt-btn {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 11px; color: var(--text-2);
  text-decoration: none; border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 6px 11px; transition: all 0.18s;
}
.yt-btn:hover { color: var(--text-1); border-color: var(--border-mid); background: var(--bg-card); }
.yt-btn svg { width: 13px; height: 13px; fill: var(--red); flex-shrink: 0; }

/* ── HERO ── */
.hero { max-width: 1300px; margin: 0 auto; padding: 4rem 2rem 2.5rem; }
.hero-eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; color: var(--accent-bright); text-transform: uppercase; margin-bottom: 1rem; }
.hero h1 { font-size: clamp(2rem, 5vw, 3.1rem); font-weight: 700; line-height: 1.08; letter-spacing: -0.03em; margin-bottom: 1rem; color: var(--text-1); }
.hero h1 em { font-style: normal; background: linear-gradient(90deg, #5D38D6 0%, #9b82f5 55%, #c4b5ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero p { font-size: 15px; color: var(--text-2); max-width: 500px; line-height: 1.65; }

/* ── FILTER PANEL ── */
.filter-panel { max-width: 1300px; margin: 0 auto; padding: 0 2rem 1.5rem; display: flex; flex-direction: column; gap: 10px; }
.filter-row { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.filter-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--text-3); text-transform: uppercase; min-width: 60px; flex-shrink: 0; }

.search-wrap { position: relative; flex: 1; min-width: 180px; }
.search-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--text-3); pointer-events: none; }
#search {
  width: 100%; background: var(--bg-input);
  border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 9px 13px 9px 34px;
  font-family: var(--mono); font-size: 12px; color: var(--text-1);
  outline: none; transition: border-color 0.2s;
}
#search::placeholder { color: var(--text-3); }
#search:focus { border-color: var(--accent); }

.hr-thin { height: 1px; background: var(--border); }

.chip {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  padding: 6px 13px; border-radius: var(--r-sm);
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-2); cursor: pointer; transition: all 0.16s; white-space: nowrap; user-select: none;
}
.chip:hover { border-color: var(--border-mid); color: var(--text-1); }
.chip-ps3.on  { background: var(--ps3-dim);  border-color: rgba(61,127,255,0.45);  color: var(--ps3-text); }
.chip-x360.on { background: var(--x360-dim); border-color: rgba(82,196,82,0.45);   color: var(--x360-text); }
.chip-game.on { background: var(--accent-dim); border-color: rgba(93,56,214,0.5);  color: var(--accent-bright); }

/* ── PILL BAR ── */
.pill-bar { max-width: 1300px; margin: 0 auto; padding: 0 2rem 1.1rem; display: flex; align-items: center; gap: 7px; flex-wrap: wrap; min-height: 30px; }
.pill-hint { font-family: var(--mono); font-size: 10px; color: var(--text-3); letter-spacing: 0.04em; }
.pill { display: flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; padding: 3px 9px; border-radius: 20px; border: 1px solid; }
.pill-ps3  { background: var(--ps3-dim);   border-color: rgba(61,127,255,0.35); color: var(--ps3-text); }
.pill-x360 { background: var(--x360-dim);  border-color: rgba(82,196,82,0.35);  color: var(--x360-text); }
.pill-game { background: var(--accent-dim); border-color: rgba(93,56,214,0.3);  color: var(--tag-text); }
.pill-x { cursor: pointer; opacity: 0.6; font-size: 13px; line-height: 1; }
.pill-x:hover { opacity: 1; }
.clear-btn { font-family: var(--mono); font-size: 10px; color: var(--text-3); border: 1px solid var(--border); border-radius: 20px; padding: 3px 9px; cursor: pointer; background: transparent; transition: all 0.15s; letter-spacing: 0.04em; }
.clear-btn:hover { color: var(--text-1); border-color: var(--border-mid); }

/* ── STATS ── */
.stats-bar { max-width: 1300px; margin: 0 auto; padding: 0 2rem 1.25rem; display: flex; align-items: center; gap: 2rem; font-family: var(--mono); font-size: 11px; color: var(--text-3); flex-wrap: wrap; }
.stats-bar span { display: flex; align-items: center; gap: 4px; }
.stats-bar strong { color: var(--text-2); }
.stats-bar-right { margin-left: auto; display: flex; align-items: center; gap: 10px; }

/* per-page selector */
.per-page-wrap { display: flex; align-items: center; gap: 7px; }
.per-page-label { font-family: var(--mono); font-size: 10px; color: var(--text-3); letter-spacing: 0.08em; }
#per-page-select {
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-2); font-family: var(--mono); font-size: 11px;
  padding: 4px 8px; border-radius: var(--r-sm); cursor: pointer;
  outline: none; transition: border-color 0.15s;
}
#per-page-select:hover, #per-page-select:focus { border-color: var(--border-mid); color: var(--text-1); }

/* view toggle buttons */
.view-toggle { display: flex; gap: 3px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 3px; }
.view-btn {
  width: 28px; height: 28px; border-radius: 5px;
  background: transparent; border: none; cursor: pointer;
  color: var(--text-3); display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.view-btn:hover { color: var(--text-1); background: var(--bg-surface); }
.view-btn.on { background: var(--accent-dim); color: var(--accent-bright); }

/* ── TABLE VIEW ── */
.table-wrap { max-width: 1300px; margin: 0 auto; padding: 0 2rem; }

.files-table {
  width: 100%; border-collapse: collapse;
  border: 1px solid var(--border); border-radius: var(--r-lg);
  overflow: hidden; font-family: var(--mono); font-size: 12px;
}

.files-table thead tr {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-mid);
}
.files-table th {
  padding: 11px 14px; text-align: left;
  font-size: 10px; letter-spacing: 0.12em; color: var(--text-3);
  text-transform: uppercase; font-weight: 500; white-space: nowrap;
}

.files-table tbody tr {
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
  transition: background 0.12s;
}
.files-table tbody tr:last-child { border-bottom: none; }
.files-table tbody tr:hover { background: var(--bg-card-hover); }
.files-table tbody tr.paid-row { background: linear-gradient(90deg, #1e1b14 0%, var(--bg-card) 100%); }
.files-table tbody tr.paid-row:hover { background: linear-gradient(90deg, #242018 0%, var(--bg-card-hover) 100%); }

.files-table td { padding: 11px 14px; vertical-align: middle; }

/* name cell */
.tbl-name { font-family: var(--sans); font-size: 13px; font-weight: 600; color: var(--text-1); letter-spacing: -0.01em; display: flex; align-items: center; gap: 8px; }
.tbl-name-inner { display: flex; flex-direction: column; gap: 2px; }
.tbl-paid-badge { font-family: var(--mono); font-size: 8px; font-weight: 600; letter-spacing: 0.06em; padding: 1px 5px; border-radius: 3px; background: linear-gradient(135deg, #2a1f00, #3d2d00); color: #ffd700; border: 1px solid rgba(255,215,0,0.4); white-space: nowrap; align-self: flex-start; }

/* ft badge in table */
.tbl-ft { width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 7px; font-weight: 600; flex-shrink: 0; }

/* games cell */
.tbl-games { display: flex; gap: 4px; flex-wrap: wrap; }
.tbl-game-chip {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em;
  padding: 3px 8px; border-radius: 20px;
  background: var(--accent-dim); border: 1px solid rgba(93,56,214,0.3);
  color: var(--tag-text); white-space: nowrap;
}

/* console icons in table */
.tbl-consoles { display: flex; gap: 6px; align-items: center; }
.tbl-console-badge { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: 0.05em; padding: 2px 7px; border-radius: 4px; border: 1px solid; }

/* filename cell */
.tbl-filename { color: var(--text-2); font-size: 11px; letter-spacing: 0.02em; }

/* size cell */
.tbl-size { color: var(--text-3); white-space: nowrap; }

/* actions cell */
.tbl-actions { display: flex; gap: 5px; }
.tbl-btn {
  display: flex; align-items: center; gap: 4px;
  font-family: var(--mono); font-size: 9px; font-weight: 500;
  letter-spacing: 0.04em; padding: 5px 9px;
  border-radius: var(--r-sm); border: 1px solid var(--border);
  background: transparent; color: var(--text-2);
  cursor: pointer; transition: all 0.15s; text-decoration: none;
  white-space: nowrap;
}
.tbl-btn:hover { background: var(--bg-surface); border-color: var(--border-mid); color: var(--text-1); }
.tbl-btn.tbl-dl { background: var(--accent-dim); border-color: rgba(93,56,214,0.35); color: var(--accent-bright); }
.tbl-btn.tbl-dl:hover { background: rgba(93,56,214,0.22); border-color: rgba(93,56,214,0.6); color: #c0b0ff; }
.tbl-btn.tbl-paid-dl { background: linear-gradient(135deg, rgba(255,160,0,0.18), rgba(255,215,0,0.12)); border-color: rgba(255,200,0,0.4); color: #ffd700; }
.tbl-btn.tbl-paid-dl:hover { border-color: rgba(255,215,0,0.7); color: #ffe555; }
.tbl-btn.tbl-copy.ok { color: var(--green); border-color: rgba(74,222,170,0.3); background: var(--green-bg); }
.tbl-btn.tbl-yt:hover { color: var(--red); border-color: rgba(255,96,96,0.35); background: rgba(255,96,96,0.06); }

/* table entry animation */
@keyframes row-appear { from{opacity:0;transform:translateX(-6px)} to{opacity:1;transform:none} }
.files-table tbody tr.animating { animation: row-appear 0.2s ease forwards; }
.files-table tbody tr.animating:nth-child(1)  { animation-delay: 0ms; }
.files-table tbody tr.animating:nth-child(2)  { animation-delay: 25ms; }
.files-table tbody tr.animating:nth-child(3)  { animation-delay: 50ms; }
.files-table tbody tr.animating:nth-child(4)  { animation-delay: 75ms; }
.files-table tbody tr.animating:nth-child(5)  { animation-delay: 100ms; }
.files-table tbody tr.animating:nth-child(6)  { animation-delay: 125ms; }
.files-table tbody tr.animating:nth-child(7)  { animation-delay: 150ms; }
.files-table tbody tr.animating:nth-child(8)  { animation-delay: 175ms; }
.files-table tbody tr.animating:nth-child(9)  { animation-delay: 200ms; }
.files-table tbody tr.animating:nth-child(n+10) { animation-delay: 225ms; }

.table-empty { display: none; padding: 3rem 2rem; text-align: center; }
.table-empty.show { display: block; }
.table-empty p { font-family: var(--mono); font-size: 13px; color: var(--text-3); }
.table-empty span { font-size: 11px; color: var(--text-3); display: block; margin-top: 5px; opacity: 0.6; }

@media (max-width: 760px) {
  .files-table th:nth-child(4),
  .files-table td:nth-child(4) { display: none; }
}
@media (max-width: 580px) {
  .stats-bar-right { width: 100%; justify-content: flex-end; }
}

/* ── GRID ── */
.grid-wrap { max-width: 1300px; margin: 0 auto; padding: 0 2rem; }
.grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }

/* ── CARD ── */
.card { background: var(--bg-card); padding: 1.2rem 1.35rem; display: flex; flex-direction: column; gap: 10px; transition: background 0.15s; position: relative; }
.card:hover { background: var(--bg-card-hover); }
.card.hidden { display: none; }

@keyframes card-appear {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}
.card.animating {
  animation: card-appear 0.22s ease forwards;
}
/* Stagger each card slightly based on its position in the visible set */
.card.animating:nth-child(1)  { animation-delay: 0ms; }
.card.animating:nth-child(2)  { animation-delay: 30ms; }
.card.animating:nth-child(3)  { animation-delay: 60ms; }
.card.animating:nth-child(4)  { animation-delay: 90ms; }
.card.animating:nth-child(5)  { animation-delay: 120ms; }
.card.animating:nth-child(6)  { animation-delay: 150ms; }
.card.animating:nth-child(7)  { animation-delay: 180ms; }
.card.animating:nth-child(8)  { animation-delay: 210ms; }
.card.animating:nth-child(9)  { animation-delay: 240ms; }

.card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; }
.card.ps3::before  { background: rgba(61,127,255,0.7); }
.card.x360::before { background: rgba(82,196,82,0.7); }
.card.both::before { background: linear-gradient(180deg, rgba(61,127,255,0.7) 50%, rgba(82,196,82,0.7) 50%); }

.card-top { display: flex; align-items: flex-start; gap: 10px; }

.ft-badge { width: 34px; height: 34px; border-radius: 7px; border: 1px solid var(--border); background: var(--bg); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: var(--mono); font-size: 8px; font-weight: 600; letter-spacing: 0.03em; }
.ft-mod { color: #9b80ff; border-color: rgba(155,128,255,0.28); background: rgba(155,128,255,0.07); }
.ft-zip { color: #ffc46b; border-color: rgba(255,196,107,0.22); background: rgba(255,196,107,0.06); }
.ft-dll { color: #ff7878; border-color: rgba(255,120,120,0.22); background: rgba(255,120,120,0.06); }
.ft-exe { color: #6ab8ff; border-color: rgba(106,184,255,0.22); background: rgba(106,184,255,0.06); }
.ft-gsc { color: #ffaa6b; border-color: rgba(255,170,107,0.22); background: rgba(255,170,107,0.06); }
.ft-cfg { color: #5ee8a8; border-color: rgba(94,232,168,0.22);  background: rgba(94,232,168,0.06); }

.card-meta { flex: 1; min-width: 0; }
.card-title-row { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; min-width: 0; }
.card-title { font-size: 13px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.01em; flex: 1; min-width: 0; }
.card-desc  { font-size: 11px; color: var(--text-2); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ── PAID BADGE ── */
.paid-badge {
  flex-shrink: 0;
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.06em; padding: 2px 7px;
  border-radius: 4px;
  background: linear-gradient(135deg, #2a1f00, #3d2d00);
  color: #ffd700;
  border: 1px solid rgba(255,215,0,0.4);
  text-shadow: 0 0 8px rgba(255,215,0,0.6);
  white-space: nowrap;
  pointer-events: none;
}

/* ── PAID CARD — gold border + animated shine ── */
.card.paid {
  border-left: none;   /* override platform stripe — paid gets full border */
  outline: 1px solid rgba(255,200,0,0.25);
  background: linear-gradient(145deg, #1c1c22 0%, #1e1b14 100%);
  overflow: hidden;
}
.card.paid::before {
  background: linear-gradient(180deg, #ffd700 0%, #ff8c00 100%) !important;
  width: 2px !important;
}
.card.paid:hover { background: linear-gradient(145deg, #22222a 0%, #241f18 100%); }

/* Subtle top-edge gold glow line */
.card.paid::after {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,215,0,0.5), rgba(255,160,0,0.6), rgba(255,215,0,0.5), transparent);
  pointer-events: none;
}

/* Shine sweep element injected by JS */
.paid-shine {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(
    105deg,
    transparent 35%,
    rgba(255,215,0,0.04) 50%,
    transparent 65%
  );
  background-size: 200% 100%;
  animation: paid-sweep 4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes paid-sweep {
  0%   { background-position: 200% 0; }
  60%  { background-position: -50% 0; }
  100% { background-position: -50% 0; }
}

/* Gold download button for paid items */
.btn-paid-dl {
  background: linear-gradient(135deg, rgba(255,160,0,0.18), rgba(255,215,0,0.12));
  border-color: rgba(255,200,0,0.4);
  color: #ffd700;
  text-shadow: 0 0 8px rgba(255,215,0,0.4);
}
.btn-paid-dl:hover {
  background: linear-gradient(135deg, rgba(255,160,0,0.28), rgba(255,215,0,0.2));
  border-color: rgba(255,215,0,0.7);
  color: #ffe555;
}

/* ── GAME BADGES ── */
.card-plats-games { display: flex; align-items: center; justify-content: space-between; pointer-events: none; }
.card-games { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; pointer-events: none; }
.game-badge {
  font-family: var(--mono); font-size: 9px; font-weight: 500;
  letter-spacing: 0.06em; padding: 2px 6px;
  border-radius: 4px; border: 1px solid var(--border-mid);
  background: var(--bg-surface); color: var(--text-3);
  pointer-events: none; white-space: nowrap;
}

.card-thumb { width: 100%; height: 106px; border-radius: var(--r-sm); border: 1px solid var(--border); overflow: hidden; cursor: pointer; position: relative; background: #0d0d12; flex-shrink: 0; }
.card-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; filter: brightness(0.8); }
.card-thumb:hover img { transform: scale(1.05); filter: brightness(1); }
.thumb-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.38); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.2s; }
.card-thumb:hover .thumb-overlay { opacity: 1; }
.thumb-zoom { width: 30px; height: 30px; border-radius: 50%; background: rgba(93,56,214,0.88); display: flex; align-items: center; justify-content: center; }
.thumb-zoom svg { width: 13px; height: 13px; fill: #fff; }
.thumb-label { position: absolute; bottom: 5px; left: 7px; font-family: var(--mono); font-size: 9px; color: rgba(255,255,255,0.4); letter-spacing: 0.06em; pointer-events: none; }

.card-plats { display: flex; gap: 5px; pointer-events: none; }
.plat-badge { font-family: var(--mono); font-size: 9px; font-weight: 600; letter-spacing: 0.05em; padding: 2px 7px; border-radius: 4px; border: 1px solid; pointer-events: none; }
.pb-ps3  { background: var(--ps3-dim);  border-color: rgba(61,127,255,0.35); color: var(--ps3-text); }
.pb-x360 { background: var(--x360-dim); border-color: rgba(82,196,82,0.35);  color: var(--x360-text); }

.card-tags { display: flex; gap: 4px; flex-wrap: wrap; pointer-events: none; }
.tag { font-family: var(--mono); font-size: 9px; letter-spacing: 0.04em; padding: 2px 6px; border-radius: 4px; background: var(--tag-bg); color: var(--tag-text); border: 1px solid rgba(93,56,214,0.18); white-space: nowrap; pointer-events: none; cursor: default; }

.card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 9px; border-top: 1px solid var(--border); }
.card-info { font-family: var(--mono); font-size: 9px; color: var(--text-3); display: flex; gap: 9px; }
.card-actions { display: flex; gap: 4px; }

.btn { display: flex; align-items: center; gap: 4px; font-family: var(--mono); font-size: 9px; font-weight: 500; letter-spacing: 0.04em; padding: 5px 9px; border-radius: var(--r-sm); border: 1px solid var(--border); background: transparent; color: var(--text-2); cursor: pointer; transition: all 0.15s; text-decoration: none; white-space: nowrap; }
.btn svg { width: 10px; height: 10px; flex-shrink: 0; }
.btn:hover { background: var(--bg-surface); border-color: var(--border-mid); color: var(--text-1); }
.btn-copy.ok { color: var(--green); border-color: rgba(74,222,170,0.3); background: var(--green-bg); }
.btn-dl { background: var(--accent-dim); border-color: rgba(93,56,214,0.35); color: var(--accent-bright); }
.btn-dl:hover { background: rgba(93,56,214,0.22); border-color: rgba(93,56,214,0.6); color: #c0b0ff; }
.btn-yt:hover { color: var(--red); border-color: rgba(255,96,96,0.35); background: rgba(255,96,96,0.06); }

/* ── EMPTY ── */
.empty { display: none; grid-column: 1/-1; padding: 4rem 2rem; text-align: center; }
.empty.show { display: block; }
.empty p    { font-family: var(--mono); font-size: 13px; color: var(--text-3); }
.empty span { font-size: 11px; color: var(--text-3); display: block; margin-top: 5px; opacity: 0.6; }

/* ── PAGINATION ── */
.pagination { max-width: 1300px; margin: 1.75rem auto 0; padding: 0 2rem 3rem; display: flex; align-items: center; justify-content: center; gap: 7px; }
.pg-btn { width: 36px; height: 36px; border-radius: 7px; background: var(--bg-card); border: 1px solid var(--border); font-family: var(--mono); font-size: 12px; color: var(--text-2); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.18s; user-select: none; }
.pg-btn:hover { border-color: var(--border-mid); color: var(--text-1); }
.pg-btn.on { background: var(--accent-dim); border-color: rgba(93,56,214,0.5); color: var(--accent-bright); }
.pg-arrow { width: 36px; height: 36px; border-radius: 7px; background: var(--bg-card); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); transition: all 0.18s; }
.pg-arrow:hover:not(:disabled) { border-color: var(--border-mid); color: var(--text-1); }
.pg-arrow:disabled { opacity: 0.22; cursor: not-allowed; }

/* ── DONATE ── */
.donate-wrap { max-width: 1300px; margin: 0 auto; padding: 0 2rem 4rem; }
.donate-card { background: var(--bg-surface); border: 1px solid var(--border-mid); border-radius: var(--r-lg); padding: 2.5rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; position: relative; overflow: hidden; }
.donate-card::after { content: ''; position: absolute; top: -80px; right: -80px; width: 260px; height: 260px; border-radius: 50%; background: radial-gradient(circle, rgba(93,56,214,0.07) 0%, transparent 70%); pointer-events: none; }
.donate-eyebrow { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--accent-bright); text-transform: uppercase; margin-bottom: 0.6rem; }
.donate-title { font-size: 1.3rem; font-weight: 700; letter-spacing: -0.02em; color: var(--text-1); margin-bottom: 0.5rem; }
.donate-body { font-size: 13px; color: var(--text-2); line-height: 1.65; max-width: 420px; }
.donate-actions { display: flex; gap: 10px; flex-shrink: 0; flex-wrap: wrap; }
.d-btn { display: flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: 12px; font-weight: 600; letter-spacing: 0.04em; padding: 10px 20px; border-radius: var(--r-md); text-decoration: none; transition: all 0.18s; cursor: pointer; border: none; white-space: nowrap; }
.d-btn-primary { background: var(--accent); color: #fff; box-shadow: 0 0 24px rgba(93,56,214,0.3); }
.d-btn-primary:hover { background: var(--accent-light); box-shadow: 0 0 36px rgba(93,56,214,0.45); }
.d-btn-secondary { background: transparent; color: var(--text-2); border: 1px solid var(--border-mid); }
.d-btn-secondary:hover { color: var(--text-1); border-color: var(--border-bright); background: var(--bg-card); }

/* ── LIGHTBOX ── */
.lightbox { display: none; position: fixed; inset: 0; z-index: 500; background: rgba(0,0,0,0.85); backdrop-filter: blur(14px); align-items: center; justify-content: center; padding: 2rem; }
.lightbox.open { display: flex; }
.lb-box { position: relative; max-width: 840px; width: 100%; background: var(--bg-card); border: 1px solid var(--border-mid); border-radius: var(--r-lg); overflow: hidden; animation: lb-pop 0.2s ease; }
@keyframes lb-pop { from{opacity:0;transform:scale(0.95)} to{opacity:1;transform:scale(1)} }

/* media container — image or yt embed */
.lb-media { position: relative; width: 100%; background: #000; line-height: 0; }
.lb-img { width: 100%; }
.lb-img img { width: 100%; max-height: 480px; object-fit: contain; display: block; }

.lb-yt-wrap { width: 100%; position: relative; padding-top: 56.25%; background: #000; }
.lb-yt-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.lb-yt-label { position: absolute; top: 10px; left: 12px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: rgba(255,255,255,0.5); background: rgba(0,0,0,0.5); padding: 3px 8px; border-radius: 4px; pointer-events: none; }

/* nav arrows */
.lb-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px;
  background: rgba(0,0,0,0.55); border: 1px solid var(--border-mid);
  color: var(--text-1); font-size: 22px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border-radius: 50%; transition: all 0.15s;
  z-index: 10; padding: 0;
}
.lb-nav:hover:not(:disabled) { background: rgba(0,0,0,0.85); border-color: var(--border-bright); }
.lb-nav:disabled { opacity: 0.25; cursor: not-allowed; }
.lb-nav-prev { left: 10px; }
.lb-nav-next { right: 10px; }

/* dots */
.lb-dots {
  padding: 8px 0 4px;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  background: var(--bg-card); border-top: 1px solid var(--border);
}
.lb-dot {
  width: 24px; height: 24px;
  background: transparent; border: 1px solid var(--border-mid);
  border-radius: 5px; cursor: pointer; font-size: 9px;
  color: var(--text-3); display: flex; align-items: center; justify-content: center;
  transition: all 0.15s; padding: 0;
}
.lb-dot:hover { border-color: var(--border-bright); color: var(--text-2); }
.lb-dot.active { background: var(--accent-dim); border-color: rgba(93,56,214,0.5); color: var(--accent-bright); }

.lb-foot { padding: 1rem 1.35rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; border-top: 1px solid var(--border); }
.lb-title-text { font-size: 14px; font-weight: 600; color: var(--text-1); }
.lb-meta-row { display: flex; align-items: center; gap: 6px; margin-top: 5px; flex-wrap: wrap; }
.lb-sub { font-family: var(--mono); font-size: 11px; color: var(--text-3); }
.lb-actions { display: flex; gap: 7px; flex-shrink: 0; }
.lb-close { position: absolute; top: 10px; right: 10px; width: 30px; height: 30px; border-radius: 50%; background: rgba(0,0,0,0.6); border: 1px solid var(--border-mid); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-2); transition: all 0.18s; z-index: 20; }
.lb-close:hover { color: var(--text-1); background: rgba(0,0,0,0.9); }
.lb-close svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2.5; stroke-linecap: round; }

/* ── FOOTER ── */
.site-footer { border-top: 1px solid var(--border); max-width: 1300px; margin: 0 auto; padding: 1.5rem 2rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.site-footer span { font-family: var(--mono); font-size: 11px; color: var(--text-3); }
.site-footer a { color: var(--accent-bright); text-decoration: none; }
.site-footer a:hover { color: var(--accent-bright); opacity: 0.8; }

svg.i { fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }

/* ── SHOWCASE SECTION ── */
.showcase-wrap { max-width: 1300px; margin: 0 auto; padding: 0 2rem 3rem; }

.showcase-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-mid);
  border-radius: var(--r-lg);
  padding: 3rem 3rem 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
  align-items: end;
  overflow: hidden;
  position: relative;
  min-height: 380px;
}

/* subtle accent radial behind text */
.showcase-card::before {
  content: '';
  position: absolute;
  top: -60px; left: -60px;
  width: 340px; height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(93,56,214,0.09) 0%, transparent 70%);
  pointer-events: none;
}

.showcase-text { padding-bottom: 3rem; }

.showcase-eyebrow {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  color: var(--accent-bright); text-transform: uppercase; margin-bottom: 0.8rem;
}
.showcase-title {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 700; letter-spacing: -0.02em;
  color: var(--text-1); line-height: 1.15; margin-bottom: 0.9rem;
}
.showcase-title em {
  font-style: normal;
  background: linear-gradient(90deg, #5D38D6 0%, #9b82f5 55%, #c4b5ff 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.showcase-body {
  font-size: 14px; color: var(--text-2); line-height: 1.7;
  max-width: 380px; margin-bottom: 1.75rem;
}
.showcase-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.sc-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em; padding: 9px 18px;
  border-radius: var(--r-md); text-decoration: none;
  transition: all 0.18s; cursor: pointer; border: none; white-space: nowrap;
}
.sc-btn-primary {
  background: var(--accent); color: #fff;
  box-shadow: 0 0 22px rgba(93,56,214,0.28);
}
.sc-btn-primary:hover { background: var(--accent-light); box-shadow: 0 0 32px rgba(93,56,214,0.42); }
.sc-btn-secondary {
  background: transparent; color: var(--text-2);
  border: 1px solid var(--border-mid);
}
.sc-btn-secondary:hover { color: var(--text-1); border-color: var(--border-bright); background: var(--bg-card); }

/* skewed floating screenshot */
.showcase-img-wrap {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.showcase-img {
  width: 100%;
  max-width: 100%;
  border-radius: 10px 10px 0 0;
  border: 1px solid var(--border-mid);
  border-bottom: none;
  transform: perspective(1100px) rotateY(-10deg) rotateX(3deg) translateY(1px);
  transform-origin: bottom center;
  transition: transform 0.4s ease;
  box-shadow:
    -16px 16px 48px rgba(0,0,0,0.55),
    0 0 0 1px rgba(93,56,214,0.15);
  display: block;
}

.showcase-img-wrap:hover .showcase-img {
  transform: perspective(1100px) rotateY(-4deg) rotateX(1deg) translateY(1px);
}

@media (max-width: 860px) {
  .showcase-card {
    grid-template-columns: 1fr;
    padding: 2.5rem 2rem 0;
    min-height: unset;
  }
  .showcase-text { padding-bottom: 0; }
  .showcase-img {
    max-width: 100%;
    transform: perspective(900px) rotateY(0deg) rotateX(4deg) translateY(1px);
  }
  .showcase-img-wrap:hover .showcase-img {
    transform: perspective(900px) rotateY(0deg) rotateX(2deg) translateY(1px);
  }
}

@media (max-width: 1100px) {
  .grid { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 760px) {
  .grid { grid-template-columns: repeat(2,1fr); }
  .donate-card { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 520px) {
  .grid { grid-template-columns: 1fr; }
  header { padding: 0 1.25rem; }
  .hero,.filter-panel,.pill-bar,.stats-bar,.grid-wrap,.pagination,.donate-wrap,.showcase-wrap { padding-left: 1.25rem; padding-right: 1.25rem; }
  .site-footer { flex-direction: column; gap: 6px; text-align: center; }
  .showcase-card { padding: 2rem 1.25rem 0; }
}

/* ── PAGE-LOAD ANIMATION (triggers after loader dismisses) ─────────── */
/* Nothing is hidden before load — the #loader overlay covers everything */

/* Header slides in from top */
@keyframes hdr-in {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: none; }
}

/* Hero text rises in */
@keyframes hero-in {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: none; }
}

/* Content blocks fade up */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}

/* Showcase image glides in from right */
@keyframes slide-left {
  from { opacity: 0; transform: perspective(1100px) rotateY(-10deg) rotateX(3deg) translateY(1px) translateX(30px); }
  to   { opacity: 1; transform: perspective(1100px) rotateY(-10deg) rotateX(3deg) translateY(1px) translateX(0); }
}

body.page-loaded header        { animation: hdr-in  0.45s cubic-bezier(0.22,1,0.36,1) forwards; }
body.page-loaded .hero         { animation: hero-in 0.55s cubic-bezier(0.22,1,0.36,1) 0.1s both; }
body.page-loaded .showcase-wrap { animation: fade-up 0.55s cubic-bezier(0.22,1,0.36,1) 0.15s both; }
body.page-loaded .showcase-img { animation: slide-left 0.7s cubic-bezier(0.22,1,0.36,1) 0.2s both; }
body.page-loaded .filter-panel { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.2s both; }
body.page-loaded .pill-bar     { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.25s both; }
body.page-loaded .stats-bar    { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.28s both; }
body.page-loaded .grid-wrap,
body.page-loaded .table-wrap   { animation: fade-up 0.55s cubic-bezier(0.22,1,0.36,1) 0.32s both; }
body.page-loaded .pagination   { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.38s both; }
body.page-loaded .donate-wrap  { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.42s both; }
body.page-loaded .site-footer  { animation: fade-up 0.5s cubic-bezier(0.22,1,0.36,1) 0.46s both; }

/* ── ERROR TOAST ─────────────────────────────────────────────────── */
.error-toast {
  position: fixed;
  bottom: 24px; right: 24px;
  z-index: 9000;
  display: flex; align-items: flex-start; gap: 12px;
  background: #1a0d0d;
  border: 1px solid rgba(255,80,80,0.35);
  border-left: 3px solid #ff4444;
  border-radius: var(--r-lg);
  padding: 14px 16px;
  max-width: 340px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,80,80,0.1);
  animation: toast-in 0.35s cubic-bezier(0.22,1,0.36,1) forwards;
}
.error-toast.out {
  animation: toast-out 0.35s ease forwards;
}

@keyframes toast-in {
  from { opacity: 0; transform: translateY(16px) scale(0.96); }
  to   { opacity: 1; transform: none; }
}
@keyframes toast-out {
  from { opacity: 1; transform: none; }
  to   { opacity: 0; transform: translateY(8px) scale(0.97); }
}

.error-toast-icon {
  flex-shrink: 0; color: #ff6060; margin-top: 1px;
}
.error-toast-text { flex: 1; min-width: 0; }
.error-toast-title {
  font-family: var(--sans); font-size: 13px; font-weight: 600;
  color: #ffcccc; letter-spacing: -0.01em; margin-bottom: 3px;
}
.error-toast-body {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.03em;
  color: rgba(255,180,180,0.65); line-height: 1.55;
}
.error-toast-close {
  flex-shrink: 0; background: none; border: none;
  color: rgba(255,150,150,0.5); font-size: 18px; line-height: 1;
  cursor: pointer; padding: 0; margin-top: -2px; transition: color 0.15s;
}
.error-toast-close:hover { color: #ff6060; }

@media (max-width: 520px) {
  .error-toast { left: 16px; right: 16px; max-width: none; bottom: 16px; }
}

/* ── INTRO LOADER ─────────────────────────────────────────────────── */
#loader {
  position: fixed; inset: 0; z-index: 99999;
  background: var(--bg);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 28px;
  pointer-events: all;
  transition: opacity 0.55s ease, visibility 0.55s ease;
}
#loader.done { opacity: 0; visibility: hidden; pointer-events: none; }

/* logo mark */
.ld-logo {
  font-family: var(--mono); font-size: 18px; font-weight: 600;
  letter-spacing: 0.2em; color: var(--text-1);
  display: flex; align-items: center; gap: 10px;
  animation: ld-logo-in 0.5s cubic-bezier(0.22,1,0.36,1) both;
}
.ld-logo-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 18px var(--accent-glow);
  animation: ld-dot-pulse 1.2s ease-in-out infinite;
}
@keyframes ld-dot-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }
@keyframes ld-logo-in   { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }

/* progress bar */
.ld-bar-wrap {
  width: 180px; height: 2px;
  background: rgba(93,56,214,0.12);
  border-radius: 2px; overflow: hidden;
  animation: ld-logo-in 0.4s cubic-bezier(0.22,1,0.36,1) 0.1s both;
}
.ld-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-bright));
  box-shadow: 0 0 12px var(--accent-glow);
  border-radius: 2px;
  width: 0%;
  transition: width 0.12s ease;
}

/* status text */
.ld-status {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; color: var(--text-3);
  text-transform: uppercase;
  min-height: 14px;
  animation: ld-logo-in 0.4s cubic-bezier(0.22,1,0.36,1) 0.15s both;
}

/* horizontal scan line that sweeps during load */
.ld-scan {
  position: absolute; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(93,56,214,0.5), transparent);
  animation: ld-sweep 1.4s ease-in-out infinite;
  pointer-events: none;
}
@keyframes ld-sweep {
  0%   { top: 0%; opacity: 0; }
  5%   { opacity: 1; }
  95%  { opacity: 0.6; }
  100% { top: 100%; opacity: 0; }
}

/* ── CARD HIGHLIGHT (for shared link scroll-to) ────────────────────── */
.card.highlighted {
  outline: 2px solid var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent), 0 0 24px rgba(93,56,214,0.25);
  animation: highlight-pulse 0.6s ease 3;
}
@keyframes highlight-pulse {
  0%,100% { box-shadow: inset 0 0 0 1px var(--accent), 0 0 12px rgba(93,56,214,0.2); }
  50%     { box-shadow: inset 0 0 0 1px var(--accent), 0 0 36px rgba(93,56,214,0.5); }
}

.copy-popup {
  position: fixed;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #1b7741;
  color: #fff;
  padding: 12px 20px;
  border-radius: 8px;
  font-weight: bold;
  font-size: 14px; /* bigger text */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
  z-index: 9999;
}

.copy-popup.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}