/* ================================================================
   DOPA INDEX · 紅白機 / Famicom 風
   低飽和復古 · 米色紙感 · 磚紅/芥末金 · 保留硬邊與階梯陰影
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700;900&family=Noto+Serif+TC:wght@400;500;700;900&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  /* paper / ink */
  --bg:       #f2ece0;   /* 紙感米白 */
  --bg-2:     #ebe3d3;   /* 次階米白 */
  --panel:    #fdfaf2;   /* 卡片底 */
  --panel-2:  #ece3d0;   /* 卡片內嵌 */
  --ink:      #2d231c;   /* 主要墨色 */
  --ink-2:    #5a4c40;   /* 次要墨色 */
  --mute:     #8a7a6a;
  --dim:      #b0a290;
  --line:     #d4c8b3;
  --line-2:   #b8a88e;

  /* retro accents */
  --red:      #b9453a;   /* 磚紅 Famicom */
  --red-soft: #d46a57;
  --red-deep: #8a3229;
  --gold:     #c89546;   /* 芥末金 */
  --gold-soft:#e2b879;
  --olive:    #6d7a3d;   /* 軍綠 / 苔綠 */
  --navy:     #3d5570;   /* 靛藍 */
  --plum:     #8a4565;
  --cream:    #ead9b3;

  /* semantic — 刻意去股票化：用深/淺灰區分 7D 漲降，而不是紅綠警示色 */
  --up:       #3a3028;   /* 深墨灰 */
  --down:     #8a7d6d;   /* 中墨灰 */

  --zh: 'Noto Sans TC', system-ui, sans-serif;
  --serif: 'Noto Serif TC', serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  /* radius — 圓潤復古 */
  --r-xs: 6px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 26px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--zh);
  font-size:14.5px;
  line-height:1.75;
  min-height:100vh;
  overflow-x:hidden;
  letter-spacing:.02em;
}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:0;background:none;color:inherit;font:inherit}
input,select,textarea{font:inherit;color:inherit}
img{image-rendering:auto}

/* 紙感 subtle grain */
.bg-grid{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(200,149,70,.06), transparent 70%),
    radial-gradient(ellipse 60% 40% at 0% 100%, rgba(185,69,58,.04), transparent 70%),
    var(--bg);
}
.bg-grid::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:
    radial-gradient(rgba(45,35,28,.06) 1px, transparent 1px);
  background-size:3px 3px;
}

/* ============== HEADER ============== */
.site-header{
  position:sticky;top:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:30px;
  padding:16px 30px;
  background:var(--panel);
  border-bottom:2px solid var(--ink);
  box-shadow: 0 3px 0 var(--red);
}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  display:grid;place-items:center;width:40px;height:40px;
  background:var(--red);color:var(--panel);
  font-family:var(--serif);font-size:20px;font-weight:700;
  border:2px solid var(--ink);
  border-radius:50%;
  box-shadow: 3px 3px 0 var(--ink);
}
.brand-txt{display:flex;flex-direction:column;line-height:1.1}
.brand-en{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.15em;color:var(--ink)}
.brand-zh{font-family:var(--zh);font-size:11px;color:var(--ink-2);margin-top:3px;letter-spacing:.25em}

.nav{display:flex;gap:6px;justify-content:center}
.nav a{
  font-size:13px;letter-spacing:.05em;color:var(--ink-2);
  padding:8px 16px;border:2px solid transparent;border-radius:999px;
  transition: background .1s, color .1s;
}
.nav a:hover{color:var(--ink);background:var(--bg-2)}
.nav a.on{color:var(--panel);background:var(--ink);border-color:var(--ink)}

.header-tail{display:flex;gap:8px;align-items:center}

/* ============== BUTTONS (stepped shadows, muted) ============== */
.btn-ghost, .btn-primary, .btn-search, .pd-btn, .sec-sort, .chart-range button{
  font-family:var(--zh);font-size:13px;letter-spacing:.03em;font-weight:500;
  padding:10px 16px;
  border:2px solid var(--ink);
  background:var(--panel);
  color:var(--ink);
  box-shadow: 3px 3px 0 var(--ink);
  transition: transform .12s, box-shadow .12s, background .12s, color .12s;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border-radius: var(--r-sm);
}
.btn-ghost:hover, .btn-primary:hover, .btn-search:hover, .pd-btn:hover, .sec-sort:hover, .chart-range button:hover{
  transform: translate(-2px,-2px);
  box-shadow: 5px 5px 0 var(--red);
}
.btn-ghost:active, .btn-primary:active, .btn-search:active, .pd-btn:active, .sec-sort:active, .chart-range button:active{
  transform: translate(1px,1px);
  box-shadow: 1px 1px 0 var(--ink);
}
.btn-primary, .pd-btn.primary{background:var(--red);color:var(--panel);border-color:var(--ink)}
.btn-primary:hover, .pd-btn.primary:hover{background:var(--red-deep);color:var(--panel)}

.sec-sort{padding:7px 13px;font-size:12px}
.sec-sort.on{background:var(--ink);color:var(--panel);border-color:var(--ink)}

/* ============== FILTER BAR (series detail) ============== */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:14px 22px;align-items:flex-start;
  padding:14px 16px;margin:4px 0 22px;
  border:1.5px dashed var(--line-2);
  background:var(--panel-2, #fafaf5);
  border-radius:var(--r-sm);
}
.filter-group{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.filter-group-chars{flex-basis:100%}
.filter-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  color:var(--ink-2);text-transform:uppercase;font-weight:600;
  padding:6px 2px;min-width:38px;
}
.filter-pills{display:flex;flex-wrap:wrap;gap:6px}
.filter-pill{
  font-family:var(--zh);font-size:12px;padding:5px 11px;
  border:1.5px solid var(--ink);background:var(--panel);color:var(--ink);
  border-radius:999px;cursor:pointer;
  transition:background .1s,color .1s,transform .1s;
}
.filter-pill:hover{background:var(--ink);color:var(--panel)}
.filter-pill.on{background:var(--red);color:var(--panel);border-color:var(--red)}
.filter-clear{
  margin-left:auto;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  padding:5px 11px;border:1.5px solid var(--red);background:var(--panel);color:var(--red);
  border-radius:999px;cursor:pointer;font-weight:600;
}
.filter-clear:hover{background:var(--red);color:var(--panel)}
.result-count{
  display:inline-block;margin-left:10px;
  font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--ink-2);font-weight:500;
}
.chart-range button{padding:7px 13px;font-size:12px;font-family:var(--mono);letter-spacing:.08em}
.chart-range button.on{background:var(--red);color:var(--panel);border-color:var(--ink)}

/* ============== TYPOGRAPHY HELPERS ============== */
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--red);text-transform:uppercase;font-weight:500;display:inline-flex;align-items:center;gap:8px}
.h-en{font-family:var(--mono);font-size:34px;font-weight:700;letter-spacing:.06em;line-height:1;color:var(--ink)}
.h-zh{font-family:var(--serif);font-size:30px;font-weight:700;line-height:1.25;margin-top:10px;color:var(--ink)}
.mono{font-family:var(--mono)}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ============== HERO ============== */
.hero{padding:70px 30px 50px}
.hero .wrap{max-width:1180px;margin:0 auto}
.hero-head{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin-bottom:36px}
.hero h1{
  font-family:var(--serif);font-weight:900;font-size:54px;line-height:1.2;margin:16px 0 18px;
  color:var(--ink);letter-spacing:-.005em;
}
.hero h1 em{
  font-style:normal;
  color:var(--red);
  padding: 0 8px 4px;
  background:
    linear-gradient(to top, var(--cream) 0 12px, transparent 12px);
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.hero-sub{color:var(--ink-2);font-size:15px;max-width:520px;line-height:1.9}
.hero-sub b{color:var(--ink);font-weight:700;border-bottom:2px solid var(--gold);padding-bottom:1px}

/* stat boxes — 紅白機面板感 */
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stat-box{
  padding:18px 20px;
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-md);
  box-shadow: 4px 4px 0 var(--ink);
  position:relative;
}
.stat-box .k{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-2);font-weight:500;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase}
.stat-box .v{font-family:var(--mono);font-size:32px;font-weight:700;margin-top:8px;color:var(--red);line-height:1}
.stat-box .d{font-size:11.5px;color:var(--ink-2);margin-top:6px;letter-spacing:.02em}

/* ============== SEARCH BAR ============== */
.search-bar{
  display:grid;grid-template-columns:1fr auto auto;gap:0;align-items:stretch;
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: 999px;
  box-shadow: 5px 5px 0 var(--ink);
  overflow:hidden;
}
.search-bar input{
  background:transparent;border:0;outline:none;padding:16px 22px;
  font-size:15px;color:var(--ink);letter-spacing:.02em;
}
.search-bar input::placeholder{color:var(--mute)}
.search-bar select{
  background:var(--bg-2);border:0;outline:none;padding:0 16px;
  border-left:2px solid var(--ink);color:var(--ink);font-size:13px;
}
.search-bar .btn-search{
  border:0;border-left:2px solid var(--ink);margin:0;
  padding:14px 24px;box-shadow:none;font-family:var(--mono);font-size:12px;letter-spacing:.15em;
  background:var(--red);color:var(--panel);font-weight:500;
}
.search-bar .btn-search:hover{background:var(--red-deep);transform:none;box-shadow:none;color:var(--panel)}

.search-tags{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;align-items:center}
.search-tags span{font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.15em;font-weight:500}
.tag-chip{
  padding:6px 14px;border:2px solid var(--ink);background:var(--panel);
  font-size:12px;color:var(--ink);letter-spacing:.02em;
  border-radius:999px;
  transition: all .12s;
  box-shadow: 2px 2px 0 var(--ink);
}
.tag-chip:hover{background:var(--gold);border-color:var(--ink);transform:translate(-1px,-1px);box-shadow: 3px 3px 0 var(--ink)}

/* ============== SECTIONS ============== */
.section{padding:56px 30px;position:relative}
.section .wrap{max-width:1180px;margin:0 auto}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:26px;gap:24px;
  padding-bottom:14px;border-bottom: 2px dashed var(--line-2);flex-wrap:wrap;
}
.sec-head h2{font-family:var(--serif);font-size:26px;font-weight:700;margin:6px 0 0;color:var(--ink);line-height:1.3}
.sec-head .en{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--red);font-weight:500}
.sec-head .jp{font-family:var(--zh);font-size:12.5px;color:var(--ink-2);margin-top:6px}
.sec-head-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* LED — 軟版 */
.led{
  display:inline-block;width:9px;height:9px;background:var(--olive);
  border:1.5px solid var(--ink);border-radius:50%;
  box-shadow:0 0 0 1.5px var(--panel);
  animation: ledBlink 1.6s ease-in-out infinite;
  vertical-align:middle;
}
@keyframes ledBlink{0%,100%{opacity:1}50%{opacity:.35}}

/* ============== RANK TABLE ============== */
.rank-table{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 5px 5px 0 var(--ink);
  overflow:hidden;
}
.rank-row{
  display:grid;grid-template-columns:50px 64px 1fr 130px 90px 130px 130px;
  gap:14px;align-items:center;padding:14px 20px;
  border-bottom:1.5px solid var(--line);
  transition: background .1s;cursor:pointer;
}
.rank-row:last-child{border-bottom:0}
.rank-row:hover{background:var(--bg-2)}
.rank-row.head{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--ink-2);
  padding:10px 20px;cursor:default;
  background:var(--panel-2);border-bottom:2px solid var(--ink);font-weight:500;
}
.rank-row.head:hover{background:var(--panel-2)}
.rank-no{font-family:var(--mono);font-size:19px;font-weight:700;color:var(--ink-2);letter-spacing:.03em}
.rank-no.top3{color:var(--red)}

.rank-img{
  width:64px;height:64px;
  background:var(--bg-2);
  border:2px solid var(--ink);
  border-radius: var(--r-md);
  box-shadow: 2px 2px 0 var(--ink);
  display:grid;place-items:center;font-size:28px;
  overflow:hidden;
}
.rank-meta .series{font-family:var(--mono);font-size:10px;color:var(--red);letter-spacing:.12em;margin-bottom:4px;font-weight:500;text-transform:uppercase}
.rank-meta .name{font-size:14px;font-weight:500;color:var(--ink);line-height:1.5}
.rank-meta .sub{font-family:var(--mono);font-size:11px;color:var(--ink-2);margin-top:3px;letter-spacing:.1em}

.rank-price{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink)}
.rank-price small{display:block;font-size:9px;letter-spacing:.15em;color:var(--mute);font-weight:500;margin-top:2px;text-transform:uppercase}
.rank-change{font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.02em}
.rank-change.up{color:var(--up)}
.rank-change.down{color:var(--down)}
.rank-spark{width:120px;height:36px}

/* ============== CARD GRID ============== */
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pc{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 4px 4px 0 var(--ink);
  cursor:pointer;
  transition: transform .12s, box-shadow .12s;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.pc:hover{
  transform: translate(-2px,-2px);
  box-shadow: 6px 6px 0 var(--red);
}
.pc-img{
  aspect-ratio:1/1;
  background:
    radial-gradient(circle at 30% 30%, var(--gold-soft) 0%, var(--cream) 50%, var(--bg-2) 100%);
  display:grid;place-items:center;font-size:58px;
  border-bottom:2px solid var(--ink);
  position:relative;
  overflow:hidden;
}
.pc-tag{
  position:absolute;top:10px;left:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;font-weight:500;
  padding:5px 11px;
  background:var(--ink);color:var(--panel);
  text-transform:uppercase;
  border-radius:999px;
}
.pc-tag.new{background:var(--red);color:var(--panel)}
.pc-new-badge{
  position:absolute;top:10px;right:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;font-weight:700;
  padding:5px 10px;background:var(--red);color:var(--panel);
  border:1.5px solid var(--ink);border-radius:var(--r-sm);
  box-shadow:2px 2px 0 var(--ink);
}
.pc-first-seen{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em;font-weight:500}

.empty-state{
  margin-top:14px;padding:36px 20px;text-align:center;
  border:1.5px dashed var(--line-2);border-radius:var(--r-md);
  background:var(--panel-2,#fafaf5);
}
.empty-k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--red);margin-bottom:10px;font-weight:700}
.empty-msg{font-size:14px;color:var(--ink-2);line-height:1.6;max-width:420px;margin:0 auto}

.pc-body{padding:14px 16px;flex:1;display:flex;flex-direction:column}
.pc-series{font-family:var(--mono);font-size:10px;color:var(--red);letter-spacing:.14em;margin-bottom:6px;font-weight:500;text-transform:uppercase}
.pc-name{font-size:14px;font-weight:500;line-height:1.55;color:var(--ink);margin:0 0 14px}
.pc-price-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:auto;gap:8px}
.pc-price{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--ink);letter-spacing:.01em}
.pc-price small{font-size:10px;letter-spacing:.12em;color:var(--mute);margin-right:3px;font-weight:500}
.pc-change{font-family:var(--mono);font-size:13px;font-weight:700}
.pc-change.up{color:var(--up)}
.pc-change.down{color:var(--down)}
.pc-change.flat,.rank-change.flat,.lst-delta.flat,.pd-price-change.flat{color:var(--dim);font-weight:500}
.pc-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px;margin:12px -16px -14px;
  border-top:1.5px dashed var(--line-2);
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.1em;
  background:var(--panel-2);
}

/* ============== SERIES CHIPS ============== */
.series-row{display:flex;gap:14px;overflow-x:auto;padding:4px 2px 12px;scrollbar-width:thin}
.series-chip{
  flex-shrink:0;min-width:180px;padding:16px 20px;
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-md);
  box-shadow: 3px 3px 0 var(--ink);
  cursor:pointer;
  transition: transform .12s, box-shadow .12s;
}
.series-chip:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--red)}
.series-chip .jp{font-family:var(--zh);font-size:12px;color:var(--ink-2);letter-spacing:.03em}
.series-chip .zh{font-family:var(--serif);font-size:17px;font-weight:700;margin-top:3px;color:var(--ink)}
.series-chip .count{font-family:var(--mono);font-size:11px;color:var(--red);margin-top:10px;letter-spacing:.12em;font-weight:500}

/* ============== PRODUCT DETAIL ============== */
.pd-hero{padding:44px 30px 24px}
.pd-hero .wrap{max-width:1180px;margin:0 auto}
.pd-breadcrumb{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.12em;margin-bottom:22px}
.pd-breadcrumb a{color:var(--ink-2)}
.pd-breadcrumb a:hover{color:var(--red)}
.pd-breadcrumb .sep{margin:0 8px;color:var(--dim)}

.pd-top{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start}
.pd-img{
  aspect-ratio:1/1;
  background:
    radial-gradient(circle at 40% 30%, var(--gold-soft) 0%, var(--cream) 45%, var(--bg-2) 100%);
  display:grid;place-items:center;font-size:140px;
  border:2px solid var(--ink);
  border-radius: var(--r-xl);
  box-shadow: 6px 6px 0 var(--ink);
  position:relative;
  overflow:hidden;
}

/* real-image rendering inside product thumbnails */
.rank-img img, .pc-img img, .pd-img img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.rank-img .emoji-fallback, .pc-img .emoji-fallback, .pd-img .emoji-fallback{
  display:grid;place-items:center;width:100%;height:100%;
}

.pd-info .pd-series{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--red);font-weight:500;text-transform:uppercase}
.pd-info h1{
  font-family:var(--serif);font-size:34px;font-weight:900;line-height:1.25;
  margin:10px 0 6px;letter-spacing:-.003em;color:var(--ink);
}
.pd-info .pd-jp{font-size:14px;color:var(--ink-2);margin-bottom:18px;letter-spacing:.03em}
.pd-tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:20px}
.pd-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;font-weight:500;
  padding:5px 12px;text-transform:uppercase;
  background:var(--panel);color:var(--ink);border:2px solid var(--ink);
  border-radius:999px;
  box-shadow: 2px 2px 0 var(--ink);
}
.pd-tag.gold{background:var(--gold);color:var(--panel);border-color:var(--ink)}

/* price cabinet — 紅白機風面板 */
.pd-price-card{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 6px 6px 0 var(--ink);
  padding:24px 28px;margin-bottom:18px;
  position:relative;
}
.pd-price-card::before{
  content:"LIVE PRICE";
  position:absolute;top:-12px;left:22px;
  background:var(--red);color:var(--panel);
  font-family:var(--mono);font-size:10px;font-weight:700;padding:4px 12px;letter-spacing:.2em;
  border:2px solid var(--ink);
  border-radius:999px;
}
.pd-price-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-2);margin-top:6px;font-weight:500;text-transform:uppercase}
.pd-price-main{display:flex;align-items:baseline;gap:14px;margin-top:6px;flex-wrap:wrap}
.pd-price-value{
  font-family:var(--mono);font-size:52px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.005em;
}
.pd-price-value .c{font-size:18px;color:var(--ink-2);margin-right:4px;font-weight:500}
.pd-price-change{font-family:var(--mono);font-size:16px;font-weight:700}
.pd-price-change.up{color:var(--up)}
.pd-price-change.down{color:var(--down)}
.pd-price-range{display:flex;gap:22px;margin-top:20px;padding-top:18px;border-top:1.5px dashed var(--line-2);flex-wrap:wrap}
.pd-pr-item .l{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--ink-2);font-weight:500;text-transform:uppercase}
.pd-pr-item .v{font-family:var(--mono);font-weight:700;margin-top:4px;font-size:16px;color:var(--ink)}

.pd-actions{display:flex;gap:10px;flex-wrap:wrap}
.pd-btn{flex:1;min-width:140px;padding:13px 16px;font-size:12.5px}

/* ============== CHART ============== */
.pd-section{padding:40px 30px}
.pd-section .wrap{max-width:1180px;margin:0 auto}
.chart-card{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 5px 5px 0 var(--ink);
  padding:22px 26px;
}
.chart-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px;gap:16px;flex-wrap:wrap}
.chart-head h3{font-family:var(--serif);font-size:22px;font-weight:700;margin:0;color:var(--ink)}
.chart-head .k{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--red);font-weight:500;text-transform:uppercase}
.chart-range{display:flex;gap:6px}
.chart-box{height:280px;position:relative}
.chart-legend{
  display:flex;gap:22px;font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em;
  margin-top:14px;padding-top:14px;border-top:1.5px dashed var(--line-2);flex-wrap:wrap;text-transform:uppercase;font-weight:500;
}
.chart-legend span::before{content:"●";margin-right:6px;font-size:11px}
.chart-legend .low::before{color:var(--olive)}
.chart-legend .mid::before{color:var(--red)}
.chart-legend .high::before{color:var(--navy)}
.chart-legend span.bar::before{content:"■";color:var(--ink)}
.chart-legend span.bar-mid::before{content:"■";color:#f6c945}
.chart-legend span.mid-line::before{content:"┊";color:var(--red);font-weight:900}
.chart-stats{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.04em}

/* ============== PRICE ANCHOR (buy/sell dual card) ============== */
.price-anchor{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius:var(--r-lg);
  box-shadow:5px 5px 0 var(--ink);
  padding:22px 26px;
}
.pa-head{margin-bottom:18px}
.pa-head .k{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--red);font-weight:500;text-transform:uppercase;margin-bottom:4px}
.pa-head h3{font-family:var(--serif);font-size:22px;font-weight:700;margin:0;color:var(--ink)}
.pa-split{display:grid;grid-template-columns:1fr 1.3fr;gap:0;border:1.5px solid var(--ink);border-radius:var(--r-md);overflow:hidden}
@media (max-width:820px){.pa-split{grid-template-columns:1fr}}
.pa-col{padding:20px 22px;position:relative}
.pa-col + .pa-col{border-left:1.5px dashed var(--line-2)}
@media (max-width:820px){.pa-col + .pa-col{border-left:none;border-top:1.5px dashed var(--line-2)}}
.pa-buy{background:#fbf7ed}
.pa-sell{background:var(--panel)}
.pa-col-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--red);font-weight:500;text-transform:uppercase;margin-bottom:4px}
.pa-col-h{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--ink-2);margin-bottom:14px}
.pa-price-big{font-family:var(--mono);font-size:34px;font-weight:700;letter-spacing:.02em;color:var(--ink);line-height:1}
.pa-price-sub{margin-top:8px;margin-bottom:16px}
.pa-save{display:inline-block;font-family:var(--mono);font-size:11.5px;font-weight:700;letter-spacing:.08em;padding:5px 10px;border:1.5px solid var(--ink);background:#f6c945;color:var(--ink);border-radius:999px}
.pa-save.flat{background:var(--panel);color:var(--dim)}
.pa-meta{display:grid;grid-template-columns:1fr;gap:7px;font-family:var(--mono);font-size:12px;color:var(--ink-2);margin-bottom:14px}
.pa-meta em{font-style:normal;font-size:9.5px;letter-spacing:.16em;color:var(--dim);font-weight:500;margin-right:6px;text-transform:uppercase}
.pa-cta{
  display:inline-block;padding:10px 16px;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.1em;
  border:2px solid var(--ink);background:var(--ink);color:var(--panel);border-radius:var(--r-sm);
  box-shadow:3px 3px 0 var(--ink);text-transform:uppercase;transition:all .12s;
}
.pa-cta:hover{background:var(--red);border-color:var(--ink);transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.pa-anchors{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:12px}
.pa-anchor{border:1.5px solid var(--ink);border-radius:var(--r-sm);padding:11px 12px;background:var(--cream)}
.pa-anchor.mid{background:#fbecb1}
.pa-anchor em{font-style:normal;display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;color:var(--dim);font-weight:500;text-transform:uppercase;margin-bottom:5px}
.pa-anchor-v{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--ink);letter-spacing:.01em}
.pa-anchor-note{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;color:var(--ink-2);margin-top:3px}
.pa-tail{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--dim);border-top:1.5px dashed var(--line-2);padding-top:10px}

.chart-stats em{font-style:normal;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;color:var(--red);margin-right:5px;font-weight:500;text-transform:uppercase}

/* ============== LISTINGS ============== */
.listings{margin-top:24px}
.listings-tbl{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 5px 5px 0 var(--ink);
  overflow:hidden;
}
.lst-row{
  display:grid;grid-template-columns:96px 1fr 88px 120px 92px;
  gap:14px;align-items:center;padding:14px 18px;
  border-bottom:1.5px solid var(--line);
}
.lst-row:last-child{border-bottom:0}
.lst-row.head{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--ink-2);
  background:var(--panel-2);padding:10px 18px;border-bottom:2px solid var(--ink);font-weight:500;text-transform:uppercase;
}
.col-num{text-align:right}
.lst-sold{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink-2);text-align:right}
.lst-platform{
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;
  padding:5px 12px;display:inline-block;border:1.5px solid var(--ink);text-transform:uppercase;
  border-radius:999px;
}
.lst-platform.shopee    {background:#e8785a;color:var(--panel)}
.lst-platform.ruten     {background:var(--gold);color:var(--panel)}
.lst-platform.ccarousell{background:var(--plum);color:var(--panel)}
.lst-platform.suruga    {background:var(--navy);color:var(--panel)}
.lst-platform.amiami    {background:var(--olive);color:var(--panel)}
.lst-platform.yahoo     {background:#6f4db0;color:var(--panel)}
.lst-title{font-size:13px;line-height:1.5;color:var(--ink)}
.lst-cond{font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.08em}
.lst-price{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--ink)}
.lst-delta{font-family:var(--mono);font-size:13px;font-weight:700}
.lst-delta.up{color:var(--up)}
.lst-delta.down{color:var(--down)}
.lst-btn{
  padding:7px 12px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.12em;
  border:1.5px solid var(--ink);color:var(--ink);background:var(--panel);
  border-radius: var(--r-sm);
  box-shadow: 2px 2px 0 var(--ink);text-align:center;text-transform:uppercase;
  transition:all .12s;
}
.lst-btn:hover{background:var(--ink);color:var(--panel);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--red)}

/* ============== PLATFORM BREAKDOWN ============== */
.platform-breakdown{margin-top:36px}
.plat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:18px}
.plat-card{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius:var(--r-md);
  box-shadow:3px 3px 0 var(--ink);
  padding:14px 16px;
}
.plat-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.plat-count{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-2);font-weight:500}
.plat-card-prices{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.plat-pr{text-align:left}
.plat-pr .l{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;color:var(--dim);margin-bottom:3px}
.plat-pr .v{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink)}

.plat-jump{
  display:block;margin-top:10px;text-align:center;
  padding:7px 10px;font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.1em;
  border:1.5px solid var(--ink);background:var(--cream);color:var(--ink);
  border-radius:var(--r-sm);box-shadow:2px 2px 0 var(--ink);
  text-transform:uppercase;transition:all .12s;
}
.plat-jump:hover{background:var(--red);color:var(--panel);border-color:var(--ink);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}

/* ============== SEARCH / MOVERS CONTROLS ============== */
.search-controls{display:flex;flex-direction:column;gap:10px;padding:14px 16px;margin-bottom:18px;border:1.5px dashed var(--line-2);background:var(--panel-2,#fafaf5);border-radius:var(--r-sm)}
.search-filter-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sec-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-2);font-weight:500;text-transform:uppercase;margin-right:6px;min-width:34px}
.sec-pill{font-family:var(--zh);font-size:12px;padding:5px 11px;border:1.5px solid var(--ink);background:var(--panel);color:var(--ink);border-radius:999px;cursor:pointer;transition:background .1s,color .1s}
.sec-pill:hover{background:var(--ink);color:var(--panel)}
.sec-pill.on{background:var(--red);color:var(--panel);border-color:var(--red)}
.sec-pill.clear{margin-left:auto;border-color:var(--red);color:var(--red);background:var(--panel);font-family:var(--mono);font-size:11px;letter-spacing:.08em}
.sec-pill.clear:hover{background:var(--red);color:var(--panel)}

/* ============== TIER ============== */
.tier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;margin-top:18px}
.tier-card{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-md);
  box-shadow: 3px 3px 0 var(--ink);
  padding:14px 16px;
  transition:transform .12s, box-shadow .12s;
}
.tier-card:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--red)}
.tier-card.top{background:var(--cream)}
.tier-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.tier-letter{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--red);line-height:1;letter-spacing:.02em}
.tier-letter.small{color:var(--mute)}
.tier-qty{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-2);font-weight:500}
.tier-name{font-size:12.5px;color:var(--ink);font-weight:500;margin-bottom:10px;line-height:1.5}
.tier-price{font-family:var(--mono);font-weight:700;color:var(--ink);font-size:16px}
.tier-price small{font-size:9px;color:var(--mute);margin-left:4px;font-weight:500;letter-spacing:.12em;text-transform:uppercase}

/* ============== INSIGHT ============== */
.insight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.insight-card{
  background:var(--panel);
  border:2px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: 4px 4px 0 var(--ink);
  padding:20px 22px;
  transition:transform .12s, box-shadow .12s;
}
.insight-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--red)}
.insight-card .k{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--red);margin-bottom:10px;font-weight:500;text-transform:uppercase}
.insight-card h4{font-family:var(--serif);font-size:17px;margin:0 0 8px;font-weight:700;color:var(--ink)}
.insight-card p{margin:0;color:var(--ink-2);font-size:13px;line-height:1.8}

/* ============== FOOTER ============== */
.site-footer{
  margin-top:80px;padding:50px 30px 22px;
  background:var(--panel);
  border-top:2px solid var(--ink);
  box-shadow: 0 -3px 0 var(--red);
}
.foot-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:30px}
.foot-mono{font-family:var(--mono);font-size:13px;letter-spacing:.18em;color:var(--red);font-weight:700}
.foot-tag{font-family:var(--serif);font-size:22px;font-weight:900;margin:12px 0 6px;color:var(--ink)}
.foot-sub{font-family:var(--mono);font-size:11px;letter-spacing:.15em;color:var(--ink-2);font-weight:500}
.foot-col .h{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--ink-2);margin-bottom:12px;font-weight:500;text-transform:uppercase}
.foot-col a{display:block;font-size:13px;color:var(--ink);padding:5px 0;transition:color .1s}
.foot-col a:hover{color:var(--red)}
.foot-bar{
  max-width:1180px;margin:0 auto;padding-top:20px;border-top:1.5px dashed var(--line-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-2);
}

/* ============== RESPONSIVE ==============
   breakpoints:
   - ≤1020px : tablet / landscape phone — collapse 2-col layouts, 2-up card grid
   - ≤640px  : mobile portrait — 1-up cards, stack rank-row & lst-row as cards
   - ≤380px  : narrow phone — shave padding & font-size a bit more
*/
@media (max-width: 1020px){
  .site-header{grid-template-columns:auto auto;padding:14px 18px;gap:14px}
  .nav{display:none}
  .hero{padding:44px 18px 32px}
  .hero-head{grid-template-columns:1fr;gap:28px}
  .hero h1{font-size:34px}
  .hero-stats{grid-template-columns:1fr 1fr 1fr;gap:8px}
  .stat-box{padding:12px}
  .stat-box .v{font-size:22px}
  .section{padding:36px 18px}
  .card-grid{grid-template-columns:1fr 1fr;gap:12px}
  .rank-row{grid-template-columns:38px 52px 1fr 100px 80px;padding:12px 14px;gap:10px}
  .rank-row .col-hide{display:none}
  .pd-top{grid-template-columns:1fr}
  .pd-hero{padding:26px 18px 14px}
  .pd-section{padding:28px 18px}
  .pd-info h1{font-size:24px}
  .pd-price-value{font-size:38px}
  .insight-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:24px}
  .lst-row{grid-template-columns:80px 1fr 64px 96px 72px;gap:10px;padding:10px 14px}
  .search-bar{grid-template-columns:1fr}
  .search-bar select{border-left:0;border-top:2px solid var(--ink)}
  .search-bar .btn-search{border-left:0;border-top:2px solid var(--ink)}
}

@media (max-width: 640px){
  /* hero / section padding tighten */
  .hero{padding:32px 14px 24px}
  .hero h1{font-size:28px;margin:12px 0 14px}
  .hero-sub{font-size:13.5px;line-height:1.8}
  .hero-stats{grid-template-columns:1fr 1fr;gap:8px}
  .stat-box{padding:12px 14px}
  .stat-box .v{font-size:20px}
  .stat-box .d{font-size:10.5px}
  .section{padding:28px 14px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:18px}
  .sec-head h2{font-size:20px}
  .sec-head-right{width:100%;justify-content:flex-start}

  /* card grid → 1-up on phones (2-up at 375px is too cramped) */
  .card-grid{grid-template-columns:1fr;gap:12px}
  .pc-img{aspect-ratio:16/10;font-size:38px}

  /* rank row → stacked card, 2-row layout */
  .rank-table{border-radius:var(--r-md);box-shadow:3px 3px 0 var(--ink)}
  .rank-row.head{display:none}
  .rank-row{
    grid-template-columns:52px 1fr auto;
    grid-template-areas:
      "img meta price"
      "img spark change";
    gap:6px 10px;padding:12px 12px;
  }
  .rank-img{grid-area:img;width:52px;height:52px}
  .rank-meta{grid-area:meta;min-width:0}
  .rank-meta .name{font-size:13px;line-height:1.4}
  .rank-price{grid-area:price;font-size:15px;text-align:right}
  .rank-spark{grid-area:spark;width:80px;height:24px;align-self:center}
  .rank-change{grid-area:change;font-size:12px;text-align:right;align-self:center}
  .rank-no{display:none}

  /* LIVE LISTINGS → stacked card (no grid cols) */
  .listings-tbl{border-radius:var(--r-md);box-shadow:3px 3px 0 var(--ink)}
  .lst-row.head{display:none}
  .lst-row{
    grid-template-columns:1fr auto;
    grid-template-areas:
      "plat btn"
      "title title"
      "sold price";
    gap:8px 10px;padding:14px 14px;
  }
  .lst-row > div:first-child{grid-area:plat}
  .lst-row > div:nth-child(2){grid-area:title}
  .lst-sold{grid-area:sold;text-align:left;font-size:12px;color:var(--ink-2)}
  .lst-sold::before{content:"SOLD · ";font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--dim);font-weight:500}
  .lst-price{grid-area:price;font-size:17px;text-align:right}
  .lst-row > div:last-child{grid-area:btn;align-self:start}
  .lst-btn{padding:6px 10px;font-size:10px}
  .lst-title{font-size:13.5px}

  /* product detail hero tightens */
  .pd-hero{padding:20px 14px 10px}
  .pd-section{padding:22px 14px}
  .pd-info h1{font-size:20px}
  .pd-price-card{padding:18px 16px}
  .pd-price-card::before{left:16px;font-size:9px;letter-spacing:.16em;padding:3px 10px}
  .pd-price-value{font-size:30px}
  .pd-price-range{gap:14px}
  .pd-actions{flex-direction:column}
  .pd-btn{width:100%;min-width:0}

  /* PRICE ANCHOR */
  .price-anchor{padding:18px 16px}
  .pa-head h3{font-size:18px}
  .pa-col{padding:16px 16px}
  .pa-price-big{font-size:26px}

  /* platform / tier cards */
  .plat-grid{grid-template-columns:1fr;gap:10px}
  .plat-card{padding:12px 14px}
  .tier-grid{grid-template-columns:1fr 1fr;gap:10px}

  /* chart card */
  .chart-card{padding:16px 14px}
  .chart-head h3{font-size:18px}
  .chart-box{height:220px}
  .chart-legend{gap:12px;font-size:10px}

  /* foot */
  .foot-grid{grid-template-columns:1fr;gap:20px;padding-bottom:22px}
  .site-footer{padding:32px 16px 18px}

  /* filter/search */
  .filter-bar{padding:12px 12px;gap:10px 14px}
  .search-controls{padding:12px 12px}
  .search-bar input{padding:14px 18px;font-size:14px}
  .search-bar .btn-search{padding:12px 18px}
}

@media (max-width: 380px){
  .hero h1{font-size:24px}
  .hero-stats{grid-template-columns:1fr 1fr}
  .sec-head h2{font-size:18px}
  .pd-info h1{font-size:18px}
  .pd-price-value{font-size:26px}
  .pa-price-big{font-size:22px}
}

/* ===== community reports block ========================================== */
.report-block{}
.rpt-agg:empty{display:none}
.rpt-agg-card{
  background:var(--cream);
  border:1px solid var(--line);
  padding:18px 20px;
  margin-bottom:16px;
  display:flex;flex-direction:column;gap:8px;
}
.rpt-agg-head{
  display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--dim);
}
.rpt-agg-date{text-transform:none;letter-spacing:.05em}
.rpt-agg-main{
  font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:.12em;
}
.rpt-agg-main .v{
  font-family:var(--serif);font-size:32px;color:var(--ink);letter-spacing:0;
  margin-left:4px;font-weight:700;
}
.rpt-agg-range{
  display:flex;gap:24px;font-family:var(--mono);font-size:11px;color:var(--dim);
  letter-spacing:.1em;
}
.rpt-agg-range b{color:var(--ink);font-weight:500}

.rpt-wrap{
  border:1px solid var(--line);
  background:#fff;
}
.rpt-toggle{
  cursor:pointer;
  padding:14px 18px;
  font-family:var(--mono);font-size:12px;letter-spacing:.15em;
  color:var(--ink);
  list-style:none;
  user-select:none;
}
.rpt-toggle::-webkit-details-marker{display:none}
.rpt-toggle:hover{background:var(--cream)}
details[open] .rpt-toggle{border-bottom:1px solid var(--line);background:var(--cream)}

.rpt-form{padding:18px;display:flex;flex-direction:column;gap:12px;position:relative}
.rpt-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rpt-field{display:flex;flex-direction:column;gap:4px}
.rpt-field .l{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--dim);
}
.rpt-field input,
.rpt-field select,
.rpt-field textarea{
  border:1px solid var(--line);
  background:#fff;
  padding:9px 11px;
  font:inherit;font-size:14px;color:var(--ink);
  font-family:var(--mono);
}
.rpt-field textarea{font-family:inherit;resize:vertical;min-height:44px}
.rpt-field input:focus,
.rpt-field select:focus,
.rpt-field textarea:focus{outline:none;border-color:var(--ink)}

.rpt-foot{display:flex;align-items:center;gap:14px;margin-top:4px}
.rpt-submit{
  border:1px solid var(--ink);
  background:var(--ink);
  color:#fff;
  padding:10px 22px;
  font-family:var(--mono);font-size:12px;letter-spacing:.15em;
  cursor:pointer;
}
.rpt-submit:hover{background:#000}
.rpt-submit:disabled{opacity:.4;cursor:not-allowed}
.rpt-msg{
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--dim);
}
.rpt-msg.ok{color:var(--up)}
.rpt-msg.err{color:var(--down)}

@media (max-width: 640px){
  .rpt-row{grid-template-columns:1fr}
  .rpt-agg-card{padding:14px 16px}
  .rpt-agg-main .v{font-size:26px}
  .rpt-form{padding:14px}
}

.rpt-hint{
  font-size:12px;color:var(--dim);
  line-height:1.6;
  border-left:2px solid var(--line);
  padding:2px 0 2px 10px;
  margin-top:2px;
}
