/* ── Reset & Base ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --red:         #E24B4A;
  --red-light:   #FCEBEB;
  --red-border:  #F7C1C1;
  --red-dark:    #A32D2D;
  --green:       #0F6E56;
  --green-light: #E1F5EE;
  --bg:          #ffffff;
  --bg-2:        #F7F7F5;
  --bg-3:        #F0EEE8;
  --text:        #1A1A18;
  --text-2:      #5A5A56;
  --text-3:      #9A9A94;
  --border:      rgba(0,0,0,0.10);
  --border-2:    rgba(0,0,0,0.18);
  --radius:      8px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --shadow:      0 1px 4px rgba(0,0,0,0.06);
  --topbar-h:    52px;
  --bottom-nav-h:62px;
  --sidebar-w:   200px;
  --detail-w:    260px;
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
}
html, body { height: 100%; font-family: var(--font); font-size: 14px; color: var(--text); background: var(--bg-2); -webkit-tap-highlight-color: transparent; }

/* ── Pokeball Icon ──────────────────────────────────────────────────────── */
.pokeball-icon { width: 26px; height: 26px; border-radius: 50%; background: var(--red); border: 2.5px solid var(--border-2); position: relative; flex-shrink: 0; }
.pokeball-icon::after  { content:''; position:absolute; top:50%; left:0; right:0; height:1.5px; background:rgba(0,0,0,0.2); transform:translateY(-50%); }
.pokeball-icon::before { content:''; position:absolute; top:50%; left:50%; width:7px; height:7px; border-radius:50%; background:#fff; border:1.5px solid var(--border-2); transform:translate(-50%,-50%); z-index:1; }
.pokeball-icon.sm { width:20px; height:20px; }

/* ── Topbar ─────────────────────────────────────────────────────────────── */
#topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: var(--topbar-h);
  display: flex; align-items: center; gap: 12px;
  padding: 0 16px;
  background: var(--bg);
  border-bottom: 0.5px solid var(--border);
}
.topbar-left { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.app-title { font-size: 15px; font-weight: 500; }
.topbar-center { flex: 1; }
.topbar-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.total-badge { display: flex; flex-direction: column; align-items: flex-end; }
.total-label { font-size: 10px; color: var(--text-3); line-height: 1; }
.total-value { font-size: 15px; font-weight: 500; color: var(--green); }

/* ── Search Box ─────────────────────────────────────────────────────────── */
.search-box {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-2); border: 0.5px solid var(--border);
  border-radius: var(--radius); padding: 6px 10px;
  width: 100%;
}
.search-box input {
  border: none; background: transparent; font-size: 13px; color: var(--text);
  flex: 1; outline: none; font-family: var(--font);
}
.search-box input::placeholder { color: var(--text-3); }
.search-icon-svg { width: 14px; height: 14px; flex-shrink: 0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239A9A94' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3C/svg%3E") no-repeat center/contain; }
.clear-search { background: none; border: none; color: var(--text-3); cursor: pointer; font-size: 13px; padding: 0 2px; }

/* ── Scan Button ────────────────────────────────────────────────────────── */
.scan-btn {
  display: flex; align-items: center; gap: 6px;
  background: var(--red); color: #fff; border: none;
  border-radius: var(--radius); padding: 7px 14px;
  font-size: 13px; font-weight: 500; cursor: pointer;
  font-family: var(--font); white-space: nowrap;
}
.scan-btn:active { opacity: 0.85; }

/* ── Layout ─────────────────────────────────────────────────────────────── */
#app { display: flex; flex-direction: column; height: 100vh; }
#main-layout { display: flex; flex: 1; padding-top: var(--topbar-h); overflow: hidden; }

/* ── Sidebar ────────────────────────────────────────────────────────────── */
#sidebar {
  width: var(--sidebar-w); flex-shrink: 0;
  border-right: 0.5px solid var(--border);
  background: var(--bg);
  overflow-y: auto; padding: 12px 0;
}
.sidebar-section { padding-bottom: 4px; }
.sidebar-section-label { font-size: 10px; font-weight: 500; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.08em; padding: 4px 16px 4px; }
.sidebar-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 16px; font-size: 13px; color: var(--text-2);
  cursor: pointer; border-left: 2px solid transparent;
}
.sidebar-item:hover { background: var(--bg-2); }
.sidebar-item.active { background: var(--bg-2); color: var(--text); font-weight: 500; border-left-color: var(--red); }
.sidebar-divider { height: 0.5px; background: var(--border); margin: 6px 0; }
.badge { font-size: 10px; background: var(--bg-3); border: 0.5px solid var(--border); border-radius: 10px; padding: 1px 6px; color: var(--text-3); }
.sidebar-item.active .badge { background: var(--red-light); border-color: var(--red-border); color: var(--red-dark); }

/* ── Content Area ───────────────────────────────────────────────────────── */
#content { flex: 1; overflow-y: auto; background: var(--bg-2); display: flex; flex-direction: column; }
#mobile-search-row { display: none; padding: 10px 12px 0; }
#mobile-filter-chips { display: none; padding: 8px 12px; gap: 6px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
#mobile-filter-chips::-webkit-scrollbar { display: none; }

/* ── Stats Bar ──────────────────────────────────────────────────────────── */
#stats-bar {
  display: flex; background: var(--bg);
  border-bottom: 0.5px solid var(--border);
  flex-shrink: 0;
}
.stat-cell { flex: 1; padding: 10px 8px; text-align: center; border-right: 0.5px solid var(--border); }
.stat-cell:last-child { border-right: none; }
.stat-value { font-size: 16px; font-weight: 500; line-height: 1.2; }
.stat-value.green { color: var(--green); }
.stat-label { font-size: 10px; color: var(--text-3); margin-top: 2px; }

/* ── Filter Bar ─────────────────────────────────────────────────────────── */
#filter-bar {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: var(--bg); border-bottom: 0.5px solid var(--border);
  flex-shrink: 0; flex-wrap: wrap;
}
#rarity-chips { display: flex; gap: 5px; flex: 1; overflow-x: auto; -webkit-overflow-scrolling: touch; }
#rarity-chips::-webkit-scrollbar { display: none; }
#sort-select { font-size: 12px; border: 0.5px solid var(--border); border-radius: var(--radius); padding: 5px 8px; background: var(--bg-2); color: var(--text-2); font-family: var(--font); cursor: pointer; flex-shrink: 0; }

/* ── Chips ──────────────────────────────────────────────────────────────── */
.chip { display: inline-flex; align-items: center; flex-shrink: 0; font-size: 12px; border: 0.5px solid var(--border); border-radius: 20px; padding: 5px 11px; background: var(--bg); color: var(--text-2); cursor: pointer; white-space: nowrap; }
.chip:active { background: var(--bg-3); }
.chip.active { background: var(--red-light); border-color: var(--red-border); color: var(--red-dark); }
.chip.sm { font-size: 11px; padding: 3px 9px; }

/* ── Cards Grid ─────────────────────────────────────────────────────────── */
#cards-grid {
  flex: 1; padding: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  align-content: start;
}

.card-tile {
  background: var(--bg); border-radius: var(--radius-lg);
  border: 0.5px solid var(--border);
  overflow: hidden; cursor: pointer;
  transition: border-color 0.15s;
}
.card-tile:hover { border-color: var(--border-2); }
.card-tile.selected { border-color: var(--red); border-width: 1.5px; }

.card-image {
  width: 100%; aspect-ratio: 2.5 / 3.5;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
}
.card-image img { width: 100%; height: 100%; object-fit: cover; }
.card-image .type-bg { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.type-bg.fire     { background: #FCEBEB; }
.type-bg.water    { background: #E6F1FB; }
.type-bg.grass    { background: #EAF3DE; }
.type-bg.electric { background: #FAEEDA; }
.type-bg.psychic  { background: #EEEDFE; }
.type-bg.fighting { background: #F5C4B3; }
.type-bg.dark     { background: #D3D1C7; }
.type-bg.metal    { background: #E6F1FB; }
.type-bg.trainer  { background: #E1F5EE; }
.type-bg.energy   { background: #FAEEDA; }
.type-bg.default  { background: #F0EEE8; }
.type-dot { width: 36px; height: 36px; border-radius: 50%; border: 2.5px solid rgba(255,255,255,0.6); opacity: 0.7; }

.card-meta { padding: 8px 10px; }
.card-name { font-size: 12px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.card-sub { font-size: 10px; color: var(--text-3); margin-top: 2px; display: flex; align-items: center; justify-content: space-between; }
.card-value { font-size: 11px; font-weight: 500; color: var(--green); margin-top: 3px; }
.lang-flag { font-size: 9px; background: var(--bg-2); border-radius: 3px; padding: 1px 4px; color: var(--text-3); border: 0.5px solid var(--border); text-transform: uppercase; }
.condition-row { margin-top: 5px; }
.condition-select { width: 100%; font-size: 10px; border: 0.5px solid var(--border); border-radius: 4px; padding: 3px 5px; background: var(--bg-2); color: var(--text-3); font-family: var(--font); cursor: pointer; }

/* ── Detail Panel ───────────────────────────────────────────────────────── */
#detail-panel {
  width: var(--detail-w); flex-shrink: 0;
  border-left: 0.5px solid var(--border);
  background: var(--bg);
  overflow-y: auto; padding: 16px;
}
#detail-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 300px; gap: 8px; }
#detail-placeholder p { font-size: 13px; color: var(--text-2); }
#detail-placeholder small { font-size: 11px; color: var(--text-3); text-align: center; }
.detail-placeholder-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--bg-3); position: relative; border: 2.5px solid var(--border); }
.detail-placeholder-icon::after  { content:''; position:absolute; top:50%; left:0; right:0; height:2px; background:var(--border-2); transform:translateY(-50%); }
.detail-placeholder-icon::before { content:''; position:absolute; top:50%; left:50%; width:10px; height:10px; border-radius:50%; background:var(--bg); border:2px solid var(--border-2); transform:translate(-50%,-50%); z-index:1; }

.detail-card-img { width: 100%; aspect-ratio: 2.5/3.5; border-radius: var(--radius); overflow: hidden; margin-bottom: 14px; background: var(--bg-3); display: flex; align-items: center; justify-content: center; }
.detail-card-img img { width: 100%; height: 100%; object-fit: cover; }
.detail-card-name { font-size: 15px; font-weight: 500; margin-bottom: 2px; }
.detail-card-set { font-size: 12px; color: var(--text-3); margin-bottom: 14px; }
.detail-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 0; border-bottom: 0.5px solid var(--border); font-size: 12px; }
.detail-row:last-child { border-bottom: none; }
.detail-key { color: var(--text-3); }
.detail-val { font-weight: 500; color: var(--text); }
.detail-val.green { color: var(--green); }
.detail-divider { height: 0.5px; background: var(--border); margin: 10px 0; }
.price-source-note { font-size: 10px; color: var(--text-3); text-align: right; margin-top: 6px; }
.detail-actions { display: flex; gap: 8px; margin-top: 14px; }
.btn-sm { flex: 1; padding: 7px 10px; border-radius: var(--radius); font-size: 12px; font-family: var(--font); cursor: pointer; font-weight: 500; border: 0.5px solid var(--border); }
.btn-sm.secondary { background: var(--bg-2); color: var(--text-2); }
.btn-sm.danger { background: var(--red-light); color: var(--red-dark); border-color: var(--red-border); }
.btn-sm.refresh { background: var(--green-light); color: var(--green); border-color: #9FE1CB; }

/* ── Mobile Bottom Nav ──────────────────────────────────────────────────── */
#bottom-nav { display: none; }

/* ── Empty / Loading ────────────────────────────────────────────────────── */
.empty-state, .loading-state {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 60px 20px; gap: 8px; color: var(--text-3);
}
.empty-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--bg-3); border: 2.5px solid var(--border); margin-bottom: 8px; position: relative; }
.empty-icon::after  { content:''; position:absolute; top:50%; left:0; right:0; height:2px; background:var(--border); transform:translateY(-50%); }
.empty-icon::before { content:''; position:absolute; top:50%; left:50%; width:10px; height:10px; border-radius:50%; background:var(--bg-2); border:2px solid var(--border); transform:translate(-50%,-50%); z-index:1; }
.empty-state p, .loading-state p { font-size: 14px; font-weight: 500; color: var(--text-2); }
.empty-state small, .loading-state small { font-size: 12px; }
.spinner { width: 28px; height: 28px; border: 2.5px solid var(--border); border-top-color: var(--red); border-radius: 50%; animation: spin 0.8s linear infinite; margin-bottom: 8px; }
.spinner.large { width: 40px; height: 40px; border-width: 3px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Modals ─────────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 500;
  background: rgba(0,0,0,0.45);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.modal-card {
  background: var(--bg); border-radius: var(--radius-xl);
  width: 100%; max-width: 400px;
  padding: 20px; display: flex; flex-direction: column; gap: 14px;
  max-height: 90vh; overflow-y: auto;
}
.modal-card.wide { max-width: 680px; }
.modal-card.tall { max-width: 460px; }
.modal-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.modal-header h2 { font-size: 16px; font-weight: 500; }
.modal-close { background: var(--bg-2); border: 0.5px solid var(--border); border-radius: 50%; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 12px; color: var(--text-2); }
.modal-desc { font-size: 13px; color: var(--text-2); }
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; }
.pw-error { font-size: 12px; color: var(--red-dark); }

input[type="password"], input[type="text"] {
  width: 100%; padding: 10px 12px; border: 0.5px solid var(--border-2);
  border-radius: var(--radius); font-size: 14px; font-family: var(--font);
  color: var(--text); background: var(--bg); outline: none;
}
input:focus { border-color: var(--red); }

select {
  font-family: var(--font); color: var(--text); background: var(--bg);
  border: 0.5px solid var(--border-2); border-radius: var(--radius);
  padding: 8px 10px; font-size: 13px; width: 100%; outline: none;
}

.btn-primary, .btn-secondary, .btn-danger {
  padding: 9px 18px; border-radius: var(--radius); font-size: 13px;
  font-weight: 500; cursor: pointer; font-family: var(--font); border: none;
}
.btn-primary   { background: var(--red); color: #fff; }
.btn-secondary { background: var(--bg-2); color: var(--text-2); border: 0.5px solid var(--border-2); }
.btn-danger    { background: var(--red-light); color: var(--red-dark); border: 0.5px solid var(--red-border); }
.btn-primary:active, .btn-secondary:active, .btn-danger:active { opacity: 0.8; }

/* ── Scan Modal ─────────────────────────────────────────────────────────── */
.camera-preview-wrapper { position: relative; width: 100%; border-radius: var(--radius-lg); overflow: hidden; background: #000; aspect-ratio: 3/4; max-height: 360px; }
#camera-video { width: 100%; height: 100%; object-fit: cover; }
.camera-frame { position: absolute; inset: 10%; border: 2px solid rgba(255,255,255,0.6); border-radius: var(--radius); pointer-events: none; }
.scan-controls { display: flex; align-items: center; justify-content: space-between; padding: 12px 0 4px; gap: 10px; }
.shutter-btn { width: 60px; height: 60px; border-radius: 50%; background: #fff; border: 3px solid var(--border-2); cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.shutter-inner { width: 44px; height: 44px; border-radius: 50%; background: var(--red); }
.shutter-btn:active .shutter-inner { opacity: 0.7; }
.upload-btn { display: flex; align-items: center; gap: 6px; padding: 8px 12px; border-radius: var(--radius); background: var(--bg-2); border: 0.5px solid var(--border-2); font-size: 12px; color: var(--text-2); cursor: pointer; }
.analyzing-animation { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 300px; gap: 10px; }
.analyzing-animation p { font-size: 14px; font-weight: 500; }
.analyzing-animation small { font-size: 12px; color: var(--text-3); }
.result-layout { display: flex; gap: 16px; }
.result-image-col { width: 140px; flex-shrink: 0; }
.result-image-col img { width: 100%; border-radius: var(--radius); }
.card-img-placeholder { width: 140px; aspect-ratio: 2.5/3.5; background: var(--bg-3); border-radius: var(--radius); border: 0.5px solid var(--border); }
.result-data-col { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.result-field { display: flex; flex-direction: column; gap: 3px; }
.result-field label { font-size: 10px; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.05em; }
.result-row { display: flex; gap: 10px; }
.result-row .result-field { flex: 1; }
.price-display { display: flex; flex-direction: column; }
.price-display span { font-size: 16px; font-weight: 500; color: var(--green); }
.price-display small { font-size: 10px; color: var(--text-3); }

/* ── Condition Select on Detail ─────────────────────────────────────────── */
.detail-condition-select { font-size: 12px; font-family: var(--font); padding: 4px 6px; border-radius: 5px; border: 0.5px solid var(--border-2); background: var(--bg-2); color: var(--text); }

/* ── TABLET: 768px – 1024px ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  :root { --detail-w: 220px; }
}

/* ── MOBILE: under 768px ────────────────────────────────────────────────── */
@media (max-width: 767px) {
  :root { --topbar-h: 48px; }

  .topbar-center { display: none; }
  .topbar-right .total-badge .total-label { display: none; }
  .total-value { font-size: 13px; }
  .scan-btn span { display: none; }
  #scan-btn-desktop { padding: 7px 10px; }

  #sidebar { display: none; }
  #detail-panel { display: none; }

  #mobile-search-row { display: block; }
  #mobile-filter-chips { display: flex; }

  #cards-grid {
    padding: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding-bottom: calc(var(--bottom-nav-h) + 10px);
  }

  #main-layout { overflow: hidden; }
  #content { overflow-y: auto; -webkit-overflow-scrolling: touch; }

  #bottom-nav {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
    height: var(--bottom-nav-h);
    background: var(--bg);
    border-top: 0.5px solid var(--border);
    padding-bottom: env(safe-area-inset-bottom);
  }
  .nav-item {
    flex: 1; display: flex; flex-direction: column; align-items: center;
    justify-content: center; gap: 3px; cursor: pointer;
    font-size: 10px; color: var(--text-3); padding: 8px 0;
  }
  .nav-item svg { stroke: var(--text-3); }
  .nav-item.active { color: var(--red-dark); }
  .nav-item.active svg { stroke: var(--red); }
  .nav-item.nav-scan { justify-content: flex-start; padding-top: 0; }
  .scan-fab {
    width: 48px; height: 48px; border-radius: 50%;
    background: var(--red); display: flex; align-items: center; justify-content: center;
    margin-bottom: 2px; margin-top: -16px;
    border: 3px solid var(--bg);
  }

  .stat-value { font-size: 13px; }
  .stat-label { font-size: 9px; }

  .modal-card.wide { padding: 16px; }
  .result-layout { flex-direction: column; }
  .result-image-col { width: 100%; }
  .result-image-col img { width: 100%; max-height: 200px; object-fit: contain; }
  .card-img-placeholder { width: 100%; max-height: 200px; }
}

/* ── iPad/Tablet specific tweaks ───────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1024px) {
  :root { --sidebar-w: 175px; --detail-w: 200px; }
  #cards-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 8px; padding: 10px; }
  .card-name { font-size: 11px; }
}

/* ── Scan Tabs ──────────────────────────────────────────────────────────── */
#scan-tabs { display: flex; gap: 0; border-bottom: 0.5px solid var(--border); margin-bottom: 14px; }
.scan-tab { flex: 1; text-align: center; padding: 9px 0; font-size: 13px; color: var(--text-3); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -0.5px; }
.scan-tab.active { color: var(--red); border-bottom-color: var(--red); font-weight: 500; }

/* ── Manual Search ──────────────────────────────────────────────────────── */
.manual-search-row { display: flex; gap: 8px; }
.manual-search-row input { flex: 1; }
.manual-search-row .btn-primary { flex-shrink: 0; }

/* ── TCG Result Cards ───────────────────────────────────────────────────── */
.tcg-result-card {
  width: 100px; cursor: pointer; border-radius: var(--radius-lg);
  border: 0.5px solid var(--border); overflow: hidden; background: var(--bg);
  flex-shrink: 0;
}
.tcg-result-card:hover { border-color: var(--red); }
.tcg-result-card.selected { border: 2px solid var(--red); }
.tcg-result-card img { width: 100%; display: block; }
.tcg-result-card .tcg-card-meta { padding: 5px 6px; }
.tcg-result-card .tcg-card-name { font-size: 10px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tcg-result-card .tcg-card-set  { font-size: 9px; color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tcg-no-results { font-size: 13px; color: var(--text-3); padding: 20px 0; text-align: center; }

/* ── Manual confirm bar ─────────────────────────────────────────────────── */
#manual-confirm-bar {
  display: none; margin-top: 12px; padding: 12px;
  background: var(--bg-2); border-radius: var(--radius-lg);
  border: 0.5px solid var(--border);
}
.manual-confirm-row { display: flex; gap: 10px; align-items: flex-start; }
.manual-confirm-img { width: 80px; flex-shrink: 0; border-radius: var(--radius); }
.manual-confirm-fields { flex: 1; display: flex; flex-direction: column; gap: 7px; }
.manual-confirm-fields .result-field label { font-size: 10px; color: var(--text-3); text-transform: uppercase; }

.auth-toggle-btn {
  width: 34px; height: 34px; border-radius: 8px;
  border: 0.5px solid rgba(0,0,0,0.18); background: #F7F7F5;
  cursor: pointer; flex-shrink: 0; font-size: 16px;
}
.auth-toggle-btn::after { content: '🔒'; }
.auth-toggle-btn.auth-off { background: #FCEBEB; border-color: #F7C1C1; }
.auth-toggle-btn.auth-off::after { content: '🔓'; }
