/* ============================================================
   Pokopia 圖鑑 - 樣式
   ============================================================ */
:root {
  --bg:       #0d0f18;
  --bg2:      #161923;
  --bg3:      #1e2235;
  --bg4:      #252a3d;
  --border:   #2c3148;
  --text:     #e2e8f0;
  --text2:    #7c8db5;
  --text3:    #4a5580;
  --accent:   #6c63ff;
  --accent2:  #8b83ff;
  --green:    #22c55e;
  --orange:   #f97316;
  --r:        10px;
  --shadow:   0 8px 32px rgba(0,0,0,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Noto Sans TC","PingFang TC",sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* ── Header ── */
header{background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 2px 20px rgba(0,0,0,.4)}
.header-inner{max-width:1440px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between}
.header-left{display:flex;align-items:center;gap:10px}
header h1{font-size:1.25rem;font-weight:800;color:#fff;letter-spacing:-.3px}
.header-badge{background:var(--bg4);border:1px solid var(--border);color:var(--text2);font-size:.72rem;padding:2px 10px;border-radius:20px}
.header-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:6px 14px;border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .15s}
.header-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── Panel ── */
.panel{max-width:1440px;margin:14px auto 0;padding:0 16px}
.search-row{display:flex;gap:8px;margin-bottom:10px}
.search-wrap{flex:1;position:relative}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text3)}
#searchInput{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px 10px 36px;font-size:.9rem;color:var(--text);outline:none;transition:border-color .2s}
#searchInput:focus{border-color:var(--accent)}
.clear-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:10px 16px;border-radius:var(--r);cursor:pointer;font-size:.82rem;white-space:nowrap;transition:all .15s}
.clear-btn:hover{background:#ef4444;color:#fff;border-color:#ef4444}

.toggle-row{display:flex;gap:18px;margin-bottom:10px;flex-wrap:wrap;align-items:center}
.toggle{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;font-size:.83rem;color:var(--text2)}
.toggle input{cursor:pointer;accent-color:var(--accent)}
.toggle:hover{color:var(--text)}
.filter-toggle-btn{
  margin-left:auto;display:flex;align-items:center;gap:5px;
  background:var(--bg3);border:1px solid var(--border);color:var(--text2);
  padding:4px 12px;border-radius:8px;cursor:pointer;font-size:.78rem;
  transition:all .15s;
}
.filter-toggle-btn svg{width:14px;height:14px;transition:transform .25s}
.filter-toggle-btn:hover{background:var(--bg4);color:var(--text);border-color:var(--accent2)}
.filter-toggle-btn.collapsed svg{transform:rotate(180deg)}

/* ── Filters ── */
.filters{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;display:flex;flex-direction:column;gap:8px;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .25s ease}
.filters.collapsed{max-height:0!important;padding-top:0;padding-bottom:0;opacity:0;border-color:transparent;margin:0}
.filter-row{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap}
.filter-row-label{font-size:.7rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;min-width:36px;padding-top:4px;flex-shrink:0}
.chips{display:flex;flex-wrap:wrap;gap:5px;flex:1}

.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;font-size:.75rem;font-weight:600;user-select:none;transition:all .12s;white-space:nowrap}
.chip img{width:14px;height:14px;object-fit:contain;filter:brightness(.7)}
.chip:hover{border-color:var(--accent2);color:var(--text);background:var(--bg4)}
.chip:hover img{filter:brightness(1)}
.chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.chip.active img{filter:brightness(1)}

/* Type chip colors */
.chip[data-type="normal"].active  {background:#9e9e9e;border-color:#9e9e9e}
.chip[data-type="fire"].active    {background:#ef5350;border-color:#ef5350}
.chip[data-type="water"].active   {background:#42a5f5;border-color:#42a5f5}
.chip[data-type="grass"].active   {background:#66bb6a;border-color:#66bb6a}
.chip[data-type="electric"].active{background:#ffca28;border-color:#ffca28;color:#333}
.chip[data-type="ice"].active     {background:#80deea;border-color:#80deea;color:#333}
.chip[data-type="fighting"].active{background:#e57373;border-color:#e57373}
.chip[data-type="poison"].active  {background:#ab47bc;border-color:#ab47bc}
.chip[data-type="ground"].active  {background:#a1887f;border-color:#a1887f}
.chip[data-type="flying"].active  {background:#90caf9;border-color:#90caf9;color:#333}
.chip[data-type="psychic"].active {background:#f06292;border-color:#f06292}
.chip[data-type="bug"].active     {background:#aed581;border-color:#aed581;color:#333}
.chip[data-type="rock"].active    {background:#bcaaa4;border-color:#bcaaa4;color:#333}
.chip[data-type="ghost"].active   {background:#7e57c2;border-color:#7e57c2}
.chip[data-type="dragon"].active  {background:#5c6bc0;border-color:#5c6bc0}
.chip[data-type="dark"].active    {background:#546e7a;border-color:#546e7a}
.chip[data-type="steel"].active   {background:#78909c;border-color:#78909c}
.chip[data-type="fairy"].active   {background:#f48fb1;border-color:#f48fb1}

/* Area chip colors */
.chip[data-area="palette-town"].active     {background:#4caf50;border-color:#4caf50}
.chip[data-area="withered-wasteland"].active{background:#ff9800;border-color:#ff9800}
.chip[data-area="bleak-beach"].active      {background:#03a9f4;border-color:#03a9f4}
.chip[data-area="rocky-ridges"].active     {background:#795548;border-color:#795548}
.chip[data-area="sparkling-skylands"].active{background:#9c27b0;border-color:#9c27b0}
.chip[data-area="none"].active             {background:#546e7a;border-color:#546e7a}

/* ── Results Bar ── */
.results-bar{max-width:1440px;margin:10px auto 8px;padding:0 16px;display:flex;align-items:center;justify-content:space-between}
#resultCount{font-size:.82rem;color:var(--text2)}
.view-btns{display:flex;gap:4px}
.vbtn{background:var(--bg2);border:1px solid var(--border);color:var(--text2);padding:5px 10px;border-radius:7px;cursor:pointer;transition:all .15s;display:flex;align-items:center}
.vbtn svg{width:16px;height:16px}
.vbtn:hover,.vbtn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── Grid ── */
#pokemonGrid{max-width:1440px;margin:0 auto 60px;padding:0 16px}
.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.list-view{display:flex;flex-direction:column;gap:6px}

/* ── Pokemon Card (Grid) ── */
.poke-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  padding:12px 10px 10px;cursor:pointer;transition:all .16s;
  position:relative;text-align:center;user-select:none;overflow:hidden;
}
.poke-card:hover{transform:translateY(-2px);border-color:var(--accent2);box-shadow:0 6px 24px rgba(108,99,255,.2)}
.poke-card.owned{border-color:var(--green)}
.poke-card .event-badge{position:absolute;top:6px;left:6px;background:var(--orange);color:#fff;font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:5px}
.card-id{font-size:.68rem;color:var(--text3);margin-bottom:2px}
.card-img-wrap{width:96px;height:96px;margin:0 auto 6px;display:flex;align-items:center;justify-content:center}
.card-img{width:100%;height:100%;object-fit:contain}
.card-name{font-size:.85rem;font-weight:700;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Card type badges */
.card-types{display:flex;justify-content:center;gap:4px;flex-wrap:wrap;margin-bottom:5px}
.type-icon{width:22px;height:22px;border-radius:4px;overflow:hidden}
.type-icon img{width:100%;height:100%;object-fit:contain}

/* Card icons row */
.card-icons{display:flex;justify-content:center;gap:3px;flex-wrap:wrap;margin-bottom:4px}
.icon-sm{width:18px;height:18px;object-fit:contain;opacity:.75;transition:opacity .15s}
.poke-card:hover .icon-sm{opacity:1}

/* Card habitats */
.card-habitats{display:flex;justify-content:center;gap:3px;flex-wrap:wrap;margin-top:5px;padding-top:5px;border-top:1px solid var(--border)}
.hab-thumb{width:28px;height:28px;border-radius:5px;overflow:hidden;border:1px solid var(--border)}
.hab-thumb img{width:100%;height:100%;object-fit:cover}

/* ── Card pokeball button ── */
.card-ball-btn{
  position:absolute;top:7px;right:7px;
  width:26px;height:26px;border-radius:50%;
  background:transparent;border:none;padding:0;cursor:pointer;
  z-index:5;transition:transform .15s;
}
.card-ball-btn:hover{transform:scale(1.15)}
.ball-icon{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(180deg,#888 50%,#ddd 50%);
  border:2.5px solid #555;position:relative;overflow:hidden;
  transition:all .15s;
}
.ball-icon::before{
  content:'';position:absolute;width:100%;height:2.5px;
  background:#555;top:calc(50% - 1.25px);
}
.ball-icon::after{
  content:'';position:absolute;width:8px;height:8px;border-radius:50%;
  background:#ddd;border:2px solid #555;
  top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;
}
/* Owned = red pokeball */
.card-ball-btn.owned .ball-icon{
  background:linear-gradient(180deg,#e53935 50%,#fff 50%);
  border-color:#222;
}
.card-ball-btn.owned .ball-icon::before{background:#222}
.card-ball-btn.owned .ball-icon::after{background:#fff;border-color:#222}

/* ── Card area wrap ── */
.card-area-wrap{display:flex;align-items:center;gap:5px;margin-top:6px}

/* 已製作按鈕 */
.card-craft-btn{
  flex-shrink:0;width:22px;height:22px;border-radius:4px;
  border:1.5px solid var(--border);background:var(--bg3);
  color:var(--text3);font-size:.75rem;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.card-craft-btn:hover:not(.crafted){border-color:var(--green);color:var(--green)}
.card-craft-btn.crafted{background:var(--green);border-color:var(--green);color:#fff}

/* Select + pin wrapper */
.card-area-sel-wrap{position:relative;flex:1;max-width:88px}
.card-pin{
  position:absolute;left:6px;top:50%;transform:translateY(-50%);
  width:11px;height:11px;pointer-events:none;z-index:1;
  display:none;
}
.card-pin.show{display:block}

/* ── Card area select ── */
.card-area-select{
  width:100%;
  background:var(--bg3);border:1.5px solid var(--border);
  color:var(--text2);border-radius:7px;padding:4px 6px;
  font-size:.72rem;cursor:pointer;outline:none;
  transition:border-color .15s,color .15s;
  appearance:auto;
}
.card-area-select:focus{border-color:var(--accent)}
.card-area-select.has-value{
  appearance:none;-webkit-appearance:none;
  border-radius:12px;font-weight:700;
  background:transparent;padding:3px 6px 3px 20px;cursor:pointer;
}

/* Area tag on card */
.card-area-tag{
  display:inline-block;font-size:.62rem;font-weight:700;padding:1px 7px;border-radius:10px;
  margin-top:4px;color:#fff;background:var(--bg4);border:1px solid var(--border);
}

/* ── Pokemon Row (List) ── */
.poke-row{
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  display:grid;grid-template-columns:48px 52px 1fr auto;align-items:center;gap:10px;
  padding:8px 12px;cursor:pointer;transition:all .12s;
}
.poke-row:hover{border-color:var(--accent2);background:var(--bg3)}
.poke-row.owned{border-color:var(--green)}
.poke-row .row-id{font-size:.72rem;color:var(--text3);text-align:right}
.poke-row .row-img{width:44px;height:44px;object-fit:contain}
.poke-row .row-name{font-size:.88rem;font-weight:700;margin-bottom:3px}
.poke-row .row-icons{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.poke-row .row-icons img{width:16px;height:16px;object-fit:contain;opacity:.75}
.poke-row .row-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.poke-row .row-habitats{display:flex;gap:2px}
.poke-row .row-habitats img{width:22px;height:22px;border-radius:3px;object-fit:cover}

/* ── Modal ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:center;justify-content:center;padding:16px}
.modal-overlay.open{display:flex}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow)}
.modal-close{position:sticky;top:0;float:right;background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:50%;width:30px;height:30px;font-size:.85rem;cursor:pointer;margin:12px 12px 0 0;z-index:10;transition:all .15s}
.modal-close:hover{background:#ef4444;color:#fff}

/* Detail header */
.detail-header{text-align:center;padding:8px 24px 18px;position:relative}
.detail-img-wrap{position:relative;display:inline-block}
.detail-img{width:150px;height:150px;object-fit:contain;filter:drop-shadow(0 4px 16px rgba(108,99,255,.3))}
.detail-id{font-size:.78rem;color:var(--text2);margin-bottom:2px}
.detail-name{font-size:1.7rem;font-weight:900;color:#fff;margin-bottom:8px}
.detail-types{display:flex;justify-content:center;gap:6px;margin-bottom:8px}
.detail-type-badge{display:flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:.8rem;font-weight:700;color:#fff}
.detail-type-badge img{width:16px;height:16px}
.detail-obtain{display:inline-block;font-size:.78rem;color:var(--text2);background:var(--bg3);border:1px solid var(--border);padding:2px 10px;border-radius:8px;margin-bottom:8px}

/* Owned + area controls */
.detail-controls{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.btn-owned{padding:6px 18px;border-radius:20px;border:2px solid var(--border);background:transparent;color:var(--text2);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s}
.btn-owned.owned{background:var(--green);border-color:var(--green);color:#fff}
.btn-owned:hover:not(.owned){border-color:var(--green);color:var(--green)}
.btn-crafted{padding:6px 18px;border-radius:20px;border:2px solid var(--border);background:transparent;color:var(--text2);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s}
.btn-crafted.crafted{background:#7c3aed;border-color:#7c3aed;color:#fff}
.btn-crafted:hover:not(.crafted){border-color:#7c3aed;color:#7c3aed}

.area-select{background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:6px 10px;font-size:.8rem;cursor:pointer;outline:none;transition:border-color .2s}
.area-select:focus{border-color:var(--accent)}

/* Detail body */
.detail-body{padding:0 20px 24px}
.d-section{background:var(--bg3);border-radius:10px;padding:12px 14px;margin-bottom:10px}
.d-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:10px}
.d-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:7px;font-size:.83rem}
.d-row:last-child{margin-bottom:0}
.d-label{color:var(--text2);min-width:58px;flex-shrink:0;font-size:.78rem}
.d-val{display:flex;flex-wrap:wrap;gap:5px;align-items:center}

/* Icon chip */
.i-chip{display:inline-flex;align-items:center;gap:4px;background:var(--bg2);border:1px solid var(--border);padding:3px 8px;border-radius:7px;font-size:.78rem}
.i-chip img{width:16px;height:16px;object-fit:contain}

/* Habitats in modal */
.habitat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
.habitat-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.habitat-card img{width:100%;height:70px;object-fit:cover;display:block}
.habitat-card .hab-info{padding:5px 7px}
.habitat-card .hab-name{font-size:.75rem;font-weight:700;margin-bottom:2px}
.habitat-card .hab-materials{font-size:.65rem;color:var(--text2);line-height:1.4;display:flex;flex-wrap:wrap;gap:3px}
.habitat-card .hab-materials-text{font-size:.62rem;color:var(--text3);line-height:1.4;margin-bottom:2px}
.hab-area-badge{display:inline-flex;align-items:center;font-size:.6rem;font-weight:700;padding:1px 7px;border-radius:10px;border:1px solid;margin-bottom:3px;white-space:nowrap}
.mat-item{display:inline-flex;align-items:center;gap:3px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:2px 5px;font-size:.68rem;color:var(--text2);white-space:nowrap}
.mat-item img{width:18px;height:18px;object-fit:contain;flex-shrink:0}
.hab-modal-materials{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.rarity-bar{height:3px;width:100%}
.rarity-bar.common   {background:#9e9e9e}
.rarity-bar.rare     {background:#42a5f5}
.rarity-bar.very-rare{background:#ffd700}

/* Obtain details */
.obtain-details{font-size:.8rem;color:var(--text2);line-height:1.6;background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:8px 10px;margin-top:6px}

/* Favorites */
.fav-chips{display:flex;flex-wrap:wrap;gap:4px}
.fav-chip{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:.74rem;color:var(--text2)}

/* ── Collection Stats ── */
.stats-box{max-width:480px}
.stats-box #statsContent{padding:20px 24px 24px}
.stats-title{font-size:1.1rem;font-weight:800;margin-bottom:16px;color:#fff}
.stats-total{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.stats-total .big{font-size:2rem;font-weight:900;color:var(--accent2)}
.stats-total .label{font-size:.8rem;color:var(--text2);line-height:1.4}
.progress-bar-wrap{background:var(--bg3);border-radius:6px;overflow:hidden;height:10px;margin-bottom:12px}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:6px;transition:width .4s}
.stats-areas{display:flex;flex-direction:column;gap:6px}
.area-stat{display:flex;align-items:center;gap:10px}
.area-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.area-label{font-size:.82rem;flex:1}
.area-count{font-size:.78rem;color:var(--text2)}
.area-progress{flex:2;background:var(--bg3);border-radius:4px;overflow:hidden;height:6px}
.area-progress-fill{height:100%;border-radius:4px}

/* ── Hab thumb clickable ── */
.hab-thumb{cursor:pointer;transition:opacity .12s}
.hab-thumb:hover{opacity:.75}
.clickable-hab{cursor:pointer;transition:all .15s}
.clickable-hab:hover{border-color:var(--accent2);transform:translateY(-1px)}

/* ── Habitat Detail Modal ── */
.hab-modal-box{max-width:680px}
.hab-modal-header{display:flex;gap:16px;padding:16px 20px 12px;align-items:flex-start;border-bottom:1px solid var(--border)}
.hab-modal-img{width:120px;height:80px;object-fit:cover;border-radius:8px;border:1px solid var(--border);flex-shrink:0}
.hab-modal-info{flex:1}
.hab-modal-name{font-size:1.1rem;font-weight:800;color:#fff;margin-bottom:5px}
.hab-modal-materials{font-size:.78rem;color:var(--text2);margin-bottom:5px;line-height:1.4}
.hab-modal-count{font-size:.72rem;color:var(--text3);background:var(--bg3);display:inline-block;padding:2px 8px;border-radius:6px;border:1px solid var(--border)}
.hab-modal-body{padding:12px 16px 20px}
.hab-body-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.hab-rarity-legend{display:flex;gap:10px;font-size:.7rem;color:var(--text2)}
.rarity-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:3px}
.rarity-dot.very-rare{background:#ffd700}
.rarity-dot.rare{background:#42a5f5}
.rarity-dot.common{background:#9e9e9e}

.hab-poke-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.hab-poke-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  overflow:hidden;cursor:pointer;transition:all .14s;text-align:center;padding-bottom:6px;
}
.hab-poke-card:hover{border-color:var(--accent2);transform:translateY(-2px);box-shadow:0 4px 14px rgba(108,99,255,.2)}
.hab-poke-img{width:60px;height:60px;object-fit:contain;display:block;margin:6px auto 3px}
.hab-poke-id{font-size:.6rem;color:var(--text3)}
.hab-poke-name{font-size:.72rem;font-weight:700;padding:0 4px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hab-poke-types{display:flex;justify-content:center;gap:3px;margin-bottom:3px}
.hab-poke-rarity{font-size:.6rem;color:var(--text3)}

/* ── Empty ── */
.empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--text2)}
.empty .emoji{font-size:3rem;margin-bottom:10px}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ── Responsive ── */
@media(max-width:640px){
  .grid-view{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}
  .poke-row{grid-template-columns:36px 44px 1fr}
  .poke-row .row-right{display:none}
  .filter-row-label{min-width:28px}
  header h1{font-size:1rem}

  /* 手機：篩選欄展開時限高 + 內部捲動 */
  .filters:not(.collapsed){
    max-height:52vh !important;
    overflow-y:auto;
  }
  /* 手機：預設收合（由 JS 控制），調整按鈕讓它更明顯 */
  .filter-toggle-btn{
    padding:6px 14px;
    font-size:.82rem;
  }
}
