/* PokeSnipe — Pokémon deal-radar. Mobiel-first, deep navy + officieel geel/blauw. */
:root{
  --pk-yellow:#FFCB05; --pk-yellow-d:#e0b000;
  --pk-blue:#003A70; --pk-blue-m:#3D7DCA; --pk-blue-l:#6aa6e6;
  --bg:#0a1424; --bg2:#0f1d33; --card:#13243f; --card2:#16294a;
  --line:#1e3556; --txt:#eaf1fb; --muted:#94a8c6; --muted2:#6f86a8;
  --good:#2ec26a; --good-d:#1f9d52; --warn:#ffb020; --bad:#ff5d5d;
  --hot:#ff7a3d;
  --r:14px; --r-sm:10px;
  --maxw:1080px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 480px at 50% -200px, #143a6e 0%, rgba(20,58,110,0) 60%),
    var(--bg);
  color:var(--txt);
  font:16px/1.5 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  min-height:100vh;
  -webkit-text-size-adjust:100%;
  padding-bottom:env(safe-area-inset-bottom);
}
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.01em}
p{margin:0}
button{font-family:inherit;cursor:pointer}
a{color:var(--pk-blue-l);text-decoration:none}
.hidden{display:none !important}
.muted{color:var(--muted)}
.small{font-size:13px}

/* ---------- header ---------- */
.top{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:calc(12px + env(safe-area-inset-top)) 16px 12px;
  background:linear-gradient(180deg,rgba(7,42,85,.96),rgba(8,22,42,.92));
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
  min-width:0;
}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.brand h1{font-size:20px;background:linear-gradient(92deg,#fff 10%,var(--pk-yellow) 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.05}
.brand p{font-size:12px;color:var(--pk-blue-l);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pokeball{
  width:30px;height:30px;border-radius:50%;flex:0 0 auto;
  background:
    radial-gradient(circle at 50% 50%, #fff 0 5px, #1a1a1a 5px 8px, #f7f7f7 8px 10px, transparent 10px),
    linear-gradient(180deg, #ee1c25 0 47%, #1a1a1a 47% 53%, #f7f7f7 53% 100%);
  border:2.5px solid #0a0a0a;
  box-shadow:0 2px 8px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.15);
}
.top-actions{display:flex;gap:8px;flex:0 0 auto}

/* ---------- buttons ---------- */
.btn{
  border:1px solid var(--line);background:var(--card2);color:var(--txt);
  padding:9px 14px;border-radius:11px;font-size:14px;font-weight:700;
  white-space:nowrap;transition:transform .06s ease,filter .15s ease,background .15s;
}
.btn:active{transform:translateY(1px)}
.btn-scan{background:linear-gradient(180deg,var(--pk-yellow),var(--pk-yellow-d));color:#231c00;border-color:#bb9300;box-shadow:0 3px 0 #9a7a00}
.btn-scan:active{box-shadow:0 1px 0 #9a7a00;transform:translateY(2px)}
.btn-scan:disabled{filter:grayscale(.5) brightness(.8);cursor:wait;box-shadow:none}
.btn-ghost{background:rgba(255,255,255,.04)}
.btn-ghost:hover{background:rgba(255,255,255,.09)}
.btn-scan.scanning{animation:pulse 1.1s ease-in-out infinite}
@keyframes pulse{50%{filter:brightness(1.12)}}

/* ---------- tabs ---------- */
.tabs{
  display:flex;gap:6px;max-width:var(--maxw);margin:14px auto 0;padding:0 12px;
}
.tab{
  flex:1 1 0;min-width:0;
  background:var(--card);border:1px solid var(--line);color:var(--muted);
  padding:11px 8px;border-radius:12px;font-size:14px;font-weight:700;
}
.tab.active{background:linear-gradient(180deg,var(--pk-blue-m),var(--pk-blue));color:#fff;border-color:var(--pk-blue-m);box-shadow:0 4px 14px rgba(61,125,202,.3)}

main{max-width:var(--maxw);margin:0 auto;padding:14px 12px 40px}
.tabpane{display:none;animation:fade .25s ease}
.tabpane.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---------- filters ---------- */
.filters{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{
  background:var(--card);border:1px solid var(--line);color:var(--muted);
  padding:8px 13px;border-radius:999px;font-size:13px;font-weight:700;
}
.chip.active{background:var(--pk-blue);border-color:var(--pk-blue-m);color:#fff}
.slider{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:10px 13px;font-size:13px;color:var(--muted);font-weight:600;
}
.slider b{color:var(--pk-yellow);font-size:15px;min-width:30px;text-align:right}
input[type=range]{
  -webkit-appearance:none;appearance:none;height:6px;border-radius:6px;flex:1 1 120px;min-width:90px;
  background:linear-gradient(90deg,var(--pk-blue-m),var(--pk-blue-l));outline:none;
}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--pk-yellow);border:2px solid #8a6d00;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.5)}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--pk-yellow);border:2px solid #8a6d00;cursor:pointer}
/* prijs-filter */
.price-range{
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:10px 13px;font-size:13px;color:var(--muted);font-weight:600;
}
.pr-lbl{font-weight:700}
.pr-grp{display:inline-flex;align-items:center;gap:5px;color:var(--pk-yellow);font-weight:800}
.pr-inp{
  width:74px;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:8px 10px;border-radius:9px;font-size:15px;font-weight:700;text-align:center;
  -webkit-appearance:none;-moz-appearance:textfield;appearance:textfield;
}
.pr-inp::-webkit-outer-spin-button,.pr-inp::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pr-inp::placeholder{color:var(--muted2);font-weight:600}
.pr-inp:focus{outline:none;border-color:var(--pk-blue-m);box-shadow:0 0 0 3px rgba(61,125,202,.18)}
.pr-dash{color:var(--muted2)}
.pr-clear{
  margin-left:auto;width:30px;height:30px;border-radius:8px;flex:0 0 auto;
  background:rgba(255,93,93,.1);border:1px solid rgba(255,93,93,.3);color:var(--bad);
  font-size:18px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center;
}

/* ---------- deal grid ---------- */
.grid{display:grid;grid-template-columns:1fr;gap:12px}
.deal{
  display:grid;grid-template-columns:88px 1fr;gap:0;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;min-width:0;position:relative;
  transition:transform .08s ease,border-color .15s ease;
}
.deal:active{transform:scale(.995)}
.deal.hot{border-color:var(--hot);box-shadow:0 0 0 1px rgba(255,122,61,.3)}
.deal-img{width:88px;height:100%;min-height:104px;object-fit:cover;background:var(--bg2);display:block}
.deal-noimg{display:flex;align-items:center;justify-content:center;font-size:30px;opacity:.4}
.deal-body{padding:11px 12px;min-width:0;display:flex;flex-direction:column;gap:6px}
.deal-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.deal-flag{font-size:14px}
.deal-score{
  font-size:12px;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:.02em;
  background:var(--good-d);color:#eafff2;
}
.deal-score.s-mid{background:#9a7a00;color:#fff5d6}
.deal-score.s-hot{background:var(--hot);color:#fff}
.deal-tier{font-size:11px;font-weight:800;color:var(--hot);text-transform:uppercase;letter-spacing:.04em}
.deal-title{
  font-size:14.5px;font-weight:700;line-height:1.3;color:var(--txt);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.deal-meta{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap;margin-top:auto}
.deal-price{font-size:19px;font-weight:800;color:var(--pk-yellow)}
.deal-profit{
  font-size:12px;font-weight:800;padding:3px 9px;border-radius:999px;
  letter-spacing:.01em;white-space:nowrap;align-self:center;cursor:help;
}
.deal-profit.precise{background:rgba(46,194,106,.16);color:#9cf3bf;border:1px solid var(--good-d)}
.deal-profit.approx{background:rgba(148,168,198,.1);color:var(--muted);border:1px solid var(--line)}
.deal-ref{font-size:12px;color:var(--muted)}
.deal-ref s{color:var(--muted2)}
.deal-sub{font-size:11.5px;color:var(--muted2);display:flex;gap:8px;flex-wrap:wrap}
.deal-suspect{color:var(--warn);font-weight:700}
.deal-reason{font-size:11.5px;color:var(--pk-blue-l);font-weight:600}
.deal a.deal-link{position:absolute;inset:0}

.empty{
  text-align:center;color:var(--muted);padding:40px 18px;
  background:var(--card);border:1px dashed var(--line);border-radius:var(--r);
}
.empty b{color:var(--pk-yellow)}

/* ---------- cards / forms ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:14px}
.card h2{font-size:16px;margin-bottom:8px;color:#fff}
.formcard h2{color:var(--pk-yellow)}
.inp{
  width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:12px 13px;border-radius:var(--r-sm);font-size:16px;margin:7px 0;
  -webkit-appearance:none;
}
.inp::placeholder{color:var(--muted2)}
.inp:focus{outline:none;border-color:var(--pk-blue-m);box-shadow:0 0 0 3px rgba(61,125,202,.18)}
.inp-sm{width:auto;min-width:120px}
select.inp{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 16px) 50%,calc(100% - 11px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:34px}
.row{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.row .inp{flex:1 1 140px;min-width:0}
.row .slider{flex:1 1 180px}
.toggles{display:flex;flex-direction:column;gap:9px}
.check{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--txt);padding:6px 0;cursor:pointer}
.check input{width:20px;height:20px;accent-color:var(--pk-yellow)}
.tog{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 13px}
.tog-label{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600}
.switch{position:relative;width:46px;height:26px;flex:0 0 auto}
.switch input{opacity:0;width:0;height:0;position:absolute}
.switch .sl{position:absolute;inset:0;background:#2a3f60;border-radius:999px;transition:.2s}
.switch .sl::before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .sl{background:var(--good)}
.switch input:checked + .sl::before{transform:translateX(20px)}

/* ---------- watch list ---------- */
.watchlist{display:flex;flex-direction:column;gap:11px;margin-top:14px}
.watch{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:13px 14px;
  display:flex;flex-direction:column;gap:8px;min-width:0;
}
.watch.hot{border-left:3px solid var(--hot)}
.watch-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.watch-label{font-size:15px;font-weight:800;min-width:0}
.watch-tier{font-size:10.5px;font-weight:800;padding:2px 7px;border-radius:999px;background:var(--card2);color:var(--muted);text-transform:uppercase;flex:0 0 auto}
.watch-tier.hot{background:var(--hot);color:#fff}
.watch-q{display:flex;flex-wrap:wrap;gap:5px}
.watch-q span{font-size:11.5px;background:var(--bg2);border:1px solid var(--line);color:var(--muted);padding:3px 8px;border-radius:999px}
.watch-info{font-size:12.5px;color:var(--muted)}
.watch-info b{color:var(--pk-yellow)}
.watch-del{align-self:flex-start;background:rgba(255,93,93,.1);border:1px solid rgba(255,93,93,.3);color:var(--bad);padding:6px 11px;border-radius:9px;font-size:12.5px;font-weight:700}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(4,10,20,.7);backdrop-filter:blur(4px)}
.modal-box{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-box h2{font-size:18px;margin-bottom:6px}
.err{color:var(--bad);font-size:13px;font-weight:600;margin-top:4px}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:calc(22px + env(safe-area-inset-bottom));transform:translateX(-50%);
  z-index:80;background:#0d2a4f;border:1px solid var(--pk-blue-m);
  color:#fff;padding:12px 18px;border-radius:12px;font-size:14px;font-weight:600;
  box-shadow:0 10px 34px rgba(0,0,0,.5);max-width:90vw;text-align:center;
  animation:toastIn .25s ease;
}
.toast.err{border-color:var(--bad)}
.toast.ok{border-color:var(--good)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}

/* ---------- desktop ---------- */
@media(min-width:680px){
  .brand h1{font-size:23px}
  .grid{grid-template-columns:1fr 1fr;gap:14px}
  .deal{grid-template-columns:104px 1fr}
  .deal-img{width:104px}
}
@media(min-width:1000px){
  .grid{grid-template-columns:1fr 1fr 1fr}
}
