﻿@font-face { font-family:'Outfit'; font-style:normal; font-weight:300 900; font-display:swap; src:url('../fonts/outfit-latin.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Outfit'; font-style:normal; font-weight:300 900; font-display:swap; src:url('../fonts/outfit-ext.woff2') format('woff2'); unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root {
  --bg: #0a1222;
  --surface: #10182e;
  --surface2: #151e38;
  --blue: #3b82f6;
  --blue-light: #60a5fa;
  --blue-bright: #93c5fd;
  --cyan: #06b6d4;
  --green: #10b981;
  --red: #ef4444;
  --orange: #f59e0b;
  --cream: #e0e8f4;
  --text: #8898b8;
  --text-dim: #3e4e6a;
  --text-muted: #1e2840;
  --border: rgba(59,130,246,.07);
  --border-h: rgba(59,130,246,.18);
}
html { background: var(--bg); scroll-behavior: smooth; scrollbar-width: thin; scrollbar-color: rgba(59,130,246,.12) var(--bg) }
body { background: var(--bg); background-image:
  radial-gradient(circle at 15% 12%, rgba(59,130,246,.18) 0%, transparent 20%),
  radial-gradient(circle at 85% 8%, rgba(168,85,247,.16) 0%, transparent 16%),
  radial-gradient(circle at 8% 55%, rgba(16,185,129,.14) 0%, transparent 18%),
  radial-gradient(circle at 75% 45%, rgba(59,130,246,.12) 0%, transparent 22%),
  radial-gradient(circle at 45% 85%, rgba(168,85,247,.12) 0%, transparent 17%),
  radial-gradient(circle at 92% 70%, rgba(16,185,129,.1) 0%, transparent 14%),
  radial-gradient(circle at 35% 35%, rgba(56,189,248,.08) 0%, transparent 24%),
  radial-gradient(circle at 60% 25%, rgba(192,132,252,.08) 0%, transparent 15%);
  color: var(--text); font-family: 'Outfit', sans-serif; -webkit-font-smoothing: antialiased; margin: 0; overflow-x: hidden; min-height: 100vh }
::-webkit-scrollbar { width: 3px }
::-webkit-scrollbar-track { background: var(--bg) }
::-webkit-scrollbar-thumb { background: rgba(59,130,246,.15); border-radius: 2px }
.grain { position: fixed; inset: 0; pointer-events: none; z-index: 9999; opacity: .03;
  background-image: url('../img/noise.svg');
  background-repeat: repeat; background-size: 180px }
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 18px 36px; display: flex; align-items: center; justify-content: space-between;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); background: rgba(6,8,16,.5); border-bottom: 1px solid rgba(255,255,255,.025); transition: all .3s }
.nav.scrolled { padding: 12px 36px; background: rgba(6,8,16,.85) }
.nav-back { display: flex; align-items: center; gap: 8px; text-decoration: none; color: var(--text-dim); font-size: .7rem; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; transition: color .3s }
.nav-back:hover { color: var(--blue) }
.nav-back svg { transition: transform .3s }
.nav-back:hover svg { transform: translateX(-3px) }
.nav-brand { font-weight: 800; font-size: .65rem; letter-spacing: 5px; text-transform: uppercase; color: var(--text-muted) }
.hero { position: relative; z-index: 1; padding: 140px 60px 60px; max-width: 1400px; margin: 0 auto; text-align: center }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 28px; animation: fadeUp .7s both }
.hero-eyebrow .bar { width: 48px; height: 3px; background: var(--blue); border-radius: 2px }
.hero-eyebrow span { font-size: clamp(2.2rem, 5vw, 3.5rem); font-weight: 900; letter-spacing: -1px; text-transform: uppercase; color: var(--blue-light) }
.hero-title { font-size: clamp(2.8rem, 7vw, 5.5rem); font-weight: 900; line-height: .9; letter-spacing: -2px; margin-bottom: 20px; animation: fadeUp .7s .08s both }
.hero-title .grad { background: linear-gradient(135deg, var(--blue), var(--blue-light), var(--blue-bright)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text }
.hero-cycle { position: relative; min-height: 2.4em; max-width: 560px; margin: 0 auto; animation: fadeUp .7s .15s both }
.hero-desc { font-size: 1.1rem; font-weight: 500; color: var(--text); line-height: 1.7; text-align: center }
.cycle-text { position: absolute; top: 0; left: 0; right: 0; opacity: 0; transition: opacity .8s ease }
.cycle-text.visible { opacity: 1 }
.warn-banner { max-width: 720px; margin: 44px auto 0; padding: 22px 32px; border-radius: 14px;
  background: linear-gradient(135deg, rgba(245,158,11,.06), rgba(251,191,36,.03));
  border: 1px solid rgba(245,158,11,.18); animation: fadeUp .7s .25s both;
  box-shadow: 0 0 40px rgba(245,158,11,.04), inset 0 1px 0 rgba(255,255,255,.03) }
.warn-top { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 10px }
.warn-icon { width: 22px; height: 22px; border-radius: 50%; background: linear-gradient(135deg, rgba(245,158,11,.2), rgba(251,191,36,.1));
  display: flex; align-items: center; justify-content: center;
  font-size: .7rem; color: var(--orange); font-weight: 800; box-shadow: 0 0 12px rgba(245,158,11,.15) }
.warn-title { font-size: .85rem; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  background: linear-gradient(135deg, #f59e0b, #fbbf24); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text }
.warn-text { font-size: .9rem; font-weight: 500; color: rgba(245,180,80,.5); line-height: 1.6; text-align: center }
.controls { max-width: 1400px; margin: 50px auto 0; padding: 0 60px; animation: fadeUp .7s .3s both }
.controls-top { display: flex; align-items: center; gap: 16px; flex-wrap: wrap }
.search-wrap { flex: 1; min-width: 250px; position: relative }
.search-wrap svg { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--text-muted); pointer-events: none }
.search-input { width: 100%; padding: 12px 16px 12px 44px; border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface); color: var(--cream); font-family: 'Outfit', sans-serif; font-size: .85rem; font-weight: 500;
  outline: none; transition: all .3s }
.search-input::placeholder { color: var(--text-muted) }
.search-input:focus { border-color: var(--border-h); box-shadow: 0 0 20px rgba(59,130,246,.06) }
.filter-btn { display: inline-flex; align-items: center; gap: 7px; padding: 12px 18px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--surface); color: var(--text-dim); font-family: 'Outfit', sans-serif;
  font-size: .8rem; font-weight: 600; cursor: pointer; transition: all .3s; letter-spacing: .5px }
.filter-btn:hover { border-color: var(--border-h); color: var(--cream) }
.filter-btn.active { border-color: rgba(59,130,246,.35); color: var(--blue-light); background: rgba(59,130,246,.05) }
.filter-btn svg { width: 14px; height: 14px }
.store-count { font-size: .9rem; font-weight: 600; color: var(--text); margin-top: 16px; letter-spacing: .5px }
.store-count em { font-style: normal; color: var(--blue-light) }
.filter-panel { display: none; margin-top: 16px; padding: 20px; border-radius: 12px; background: var(--surface); border: 1px solid var(--border) }
.filter-panel.open { display: flex; gap: 20px; flex-wrap: wrap }
.fp-group { flex: 1; min-width: 180px }
.fp-label { font-size: .6rem; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px }
.fp-options { display: flex; flex-wrap: wrap; gap: 6px }
.fp-chip { padding: 6px 12px; border-radius: 100px; border: 1px solid var(--border); background: none; color: var(--text-dim);
  font-family: 'Outfit', sans-serif; font-size: .72rem; font-weight: 600; cursor: pointer; transition: all .25s }
.fp-chip:hover { border-color: var(--border-h); color: var(--cream) }
.fp-chip.active { border-color: rgba(59,130,246,.4); color: var(--blue-light); background: rgba(59,130,246,.06) }
.table-layout { position: relative; max-width: 1400px; margin: 24px auto 80px; padding: 0 60px; animation: fadeUp .7s .35s both }
.table-bart { position: absolute; left: -140px; top: 40px; pointer-events: none }
.bart-img { width: 160px; height: auto; filter: drop-shadow(0 0 20px rgba(59,130,246,.15)) }
.table-enemy { position: absolute; right: -140px; top: 40px; pointer-events: none }
.enemy-img { width: 160px; height: auto; filter: drop-shadow(0 0 20px rgba(239,68,68,.15)) }
.table-wrap { width: 100%; max-width: 100%; overflow-x: auto; border-radius: 14px }
@media(max-width:1300px){ .table-bart,.table-enemy{display:none} }
@media(max-width:900px){ .table-layout{padding:0 28px} }
.store-table { width: 100%; min-width: 1180px; border-collapse: separate; border-spacing: 0; border-radius: 14px; overflow: visible;
  border: 1px solid var(--border); background: var(--surface) }
.store-table thead tr:first-child th:first-child { border-top-left-radius: 14px }
.store-table thead tr:first-child th:last-child { border-top-right-radius: 14px }
.store-table tbody tr:last-child td:first-child { border-bottom-left-radius: 14px }
.store-table tbody tr:last-child td:last-child { border-bottom-right-radius: 14px }
.store-table thead th { padding: 18px 20px; font-size: .82rem; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--blue-light); text-align: left; background: var(--surface2); border-bottom: 1px solid var(--border);
  white-space: nowrap; position: sticky; top: 0; z-index: 2 }
.store-table thead th.sortable { cursor: pointer; user-select: none; transition: color .2s }
.store-table thead th.sortable:hover { color: var(--blue-light) }
.store-table thead th .sort-arrow { display: inline-block; margin-left: 4px; opacity: .3; font-size: .5rem }
.store-table thead th.sorted .sort-arrow { opacity: 1; color: var(--blue-light) }
.store-table tbody tr { transition: background .2s }
.store-table tbody tr:hover { background: rgba(59,130,246,.02) }
.store-table tbody tr.pinned-row td {
  background: rgba(180,140,20,.18);
  border-bottom: 1px solid rgba(251,191,36,.35);
  border-top: 1px solid rgba(251,191,36,.35);
  animation: pinBorderPulse 3s ease-in-out infinite;
}
@keyframes pinBorderPulse {
  0%,100% { border-top-color: rgba(251,191,36,.2); border-bottom-color: rgba(251,191,36,.2) }
  50% { border-top-color: rgba(251,191,36,.5); border-bottom-color: rgba(251,191,36,.5) }
}
.store-table tbody tr.pinned-row td:first-child { border-left: 1px solid rgba(251,191,36,.35); animation-name: pinBorderPulse, pinBorderPulseLeft }
.store-table tbody tr.pinned-row td:last-child { border-right: 1px solid rgba(251,191,36,.35); animation-name: pinBorderPulse, pinBorderPulseRight }
.store-table tbody tr.pinned-row td:first-child, .store-table tbody tr.pinned-row td:last-child { animation-duration: 3s, 3s; animation-timing-function: ease-in-out, ease-in-out; animation-iteration-count: infinite, infinite }
@keyframes pinBorderPulseLeft { 0%,100%{border-left-color:rgba(251,191,36,.2)} 50%{border-left-color:rgba(251,191,36,.5)} }
@keyframes pinBorderPulseRight { 0%,100%{border-right-color:rgba(251,191,36,.2)} 50%{border-right-color:rgba(251,191,36,.5)} }
.store-table tbody tr.pinned-row + tr.pinned-row td { border-top: none }
.store-table tbody tr td { padding: 16px 20px; font-size: .95rem; font-weight: 500; color: var(--cream);
  border-bottom: 1px solid rgba(255,255,255,.08); white-space: nowrap; vertical-align: middle }
.store-table thead th:nth-child(n+2), .store-table tbody tr td:nth-child(n+2) { text-align: center }
.store-table tbody tr:last-child td { border-bottom: none }
.store-name { display: flex; align-items: center; gap: 12px }
.store-name-inner { display: flex; flex-direction: column; gap: 3px }
.store-logo { width: 32px; height: 32px; border-radius: 6px; object-fit: contain; padding: 0 }
img.store-logo { display: block }
.store-logo.logo-hidden { display: none }
.store-initial { width: 32px; height: 32px; border-radius: 6px; background: rgba(255,255,255,.06); display: flex; align-items: center; justify-content: center; font-size: .8rem; font-weight: 700; color: var(--text-dim) }
.store-label { font-weight: 700; color: var(--cream); font-size: .95rem; display: inline-flex; align-items: center; gap: 6px }
.pin-icon { flex-shrink: 0; filter: drop-shadow(0 0 4px rgba(251,191,36,.5)) }
.tag-list { display: flex; flex-wrap: wrap; gap: 4px }
.tag-badge { display: inline-flex; align-items: center; gap: 3px; padding: 1px 8px; border-radius: 4px; font-size: .65rem; font-weight: 600; line-height: 1.5 }
.tag-badge.tag-popular { background: rgba(245,158,11,.12); color: #fbbf24; border: 1px solid rgba(245,158,11,.25) }
.tag-badge.tag-popular svg { width: 9px; height: 9px }
.tag-badge.tag-triple-dip { background: rgba(139,92,246,.1); color: #a78bfa; border: 1px solid rgba(139,92,246,.2) }
.tag-badge.tag-double-dip { background: rgba(59,130,246,.1); color: #60a5fa; border: 1px solid rgba(59,130,246,.2) }
.tag-badge.tag-apple { background: rgba(16,185,129,.1); color: #34d399; border: 1px solid rgba(16,185,129,.2) }
.cflag-img.cflag-globe { width: 28px; height: 28px; object-fit: contain; border-radius: 50% }
.fee-pct { color: var(--green) }
.fee-minorder { color: var(--red) }
.empty-msg { text-align: center; padding: 60px 20px; color: var(--text-dim); font-size: 1rem }
.loading-msg { text-align: center; padding: 60px 20px; color: var(--text-dim); font-size: .9rem; animation: pulse 1.5s infinite }
.country-flags { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; justify-content: center }
.cflag-img { width: 32px; height: 22px; object-fit: cover; border-radius: 3px }
.chip-flag { width: 16px; height: 11px; object-fit: cover; border-radius: 1px; vertical-align: middle }
.rate-bar { display: flex; align-items: center; gap: 8px; justify-content: center }
.rate-track { width: 50px; height: 4px; border-radius: 2px; background: rgba(255,255,255,.04); overflow: hidden }
.rate-fill { height: 100%; border-radius: 2px }
.rate-fill.high { background: var(--green) }
.rate-fill.med { background: var(--orange) }
.rate-fill.low { background: var(--red) }
.rate-val { font-size: .9rem; font-weight: 700 }
.rate-val.high { color: var(--green) }
.rate-val.med { color: var(--orange) }
.rate-val.low { color: var(--red) }
.status-tick { font-size: 1.1rem }
.status-tick.on { color: var(--green) }
.status-tick.off { color: var(--red) }
.status-icon { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 6px }
.status-icon.on { color: var(--green); background: rgba(16,185,129,.12) }
.status-icon.off { color: var(--red); background: rgba(239,68,68,.12) }
.fees-tier { white-space: nowrap; font-size: .95rem; font-weight: 600; color: var(--cream) }
.fees-tier+.fees-tier { margin-top: 2px }
.price-cell { font-weight: 700; color: var(--blue-light); font-size: .95rem }
.items-cell { font-weight: 600; color: var(--cream); font-size: .95rem }
.time-cell { font-weight: 600; color: var(--cream); font-size: .95rem }
.fees-cell { font-weight: 600; color: var(--cream); font-size: .95rem }
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px) } to { opacity: 1; transform: translateY(0) } }
@keyframes pulse { 0%,100% { opacity: 1 } 50% { opacity: .4 } }
@media (max-width: 900px) {
  .hero { padding: 120px 24px 40px }
  .controls { padding: 0 24px }
  .table-wrap { padding: 0 16px; overflow-x: auto }
  .store-table { min-width: 900px }
}
@media (max-width: 600px) {
  .hero-title { font-size: 2.2rem; letter-spacing: -1px }
  .controls-top { flex-direction: column }
  .search-wrap { min-width: 100% }
}
