/* ── 제품 카드 ──────────────────── */
.product-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r4);overflow:hidden;
  display:flex;flex-direction:column;
  transition:box-shadow .2s,transform .2s,border-color .2s;
  color:var(--text-1);  /* a태그 기본색 재정의 */
}
.product-card:hover{box-shadow:var(--sh2);transform:translateY(-3px);border-color:var(--border-md)}

/* 썸네일 */
.card-thumb{
  height:72px;display:flex;align-items:center;
  justify-content:space-between;padding:0 var(--s4);
  position:relative;overflow:hidden;flex-shrink:0;
}
.card-thumb__icon{font-size:1.9rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.08));z-index:1}
.card-thumb__cat{
  font-size:.67rem;font-weight:600;
  padding:3px 8px;border-radius:var(--rx);
  background:rgba(255,255,255,.7);backdrop-filter:blur(4px);
  color:var(--text-2);z-index:1;white-space:nowrap;
}
.th-drink {background:linear-gradient(135deg,#dbeafe,#bfdbfe)}
.th-snack {background:linear-gradient(135deg,#fce7f3,#fbcfe8)}
.th-ice   {background:linear-gradient(135deg,#e0f2fe,#bae6fd)}
.th-bread {background:linear-gradient(135deg,#fef9c3,#fef08a)}
.th-dairy {background:linear-gradient(135deg,#dcfce7,#bbf7d0)}
.th-sauce {background:linear-gradient(135deg,#ffedd5,#fed7aa)}
.th-noodle{background:linear-gradient(135deg,#fae8ff,#f5d0fe)}
.th-cereal{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.th-etc   {background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}

/* 카드 본문 */
.card-body{
  padding:var(--s4);flex:1;
  display:flex;flex-direction:column;
  gap:var(--s2);
}
.card-name{
  font-size:.94rem;font-weight:700;line-height:1.35;color:var(--text-1);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.card-mfr-row{display:flex;align-items:center;gap:var(--s2);margin-top:2px}
.card-mfr{
  font-size:.75rem;color:var(--text-4);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ─── 배지 영역 ─────────────────────────
   핵심: 배지와 레이블이 한 줄씩 깔끔하게 */
.card-badges{
  margin-top:auto;padding-top:var(--s3);
  border-top:1px solid var(--border);     /* 선은 항상 배지 위 */
  display:flex;flex-direction:column;gap:6px;
}

.badge-line{
  display:flex;flex-wrap:wrap;
  align-items:center;gap:4px;
}
.badge-line-label{
  font-size:.63rem;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;color:var(--text-4);
  white-space:nowrap;flex-shrink:0;
  /* 레이블이 배지들과 같은 줄에서 앞에 정렬 */
  line-height:22px;
}

/* ── 배지 ──────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:var(--rx);
  font-size:.74rem;font-weight:500;border:1px solid;
  white-space:nowrap;line-height:1.3;flex-shrink:0;
}
a.badge{cursor:pointer;transition:opacity .1s;position:relative;z-index:2}
a.badge:hover{opacity:.75}
.badge__gi{font-family:var(--font-mono);font-size:.66rem;opacity:.65}

.badge--alc{background:var(--badge-alc-bg);color:var(--badge-alc-tx);border-color:var(--badge-alc-bd)}
.badge--art{background:var(--badge-art-bg);color:var(--badge-art-tx);border-color:var(--badge-art-bd)}
.badge--nat{background:var(--badge-nat-bg);color:var(--badge-nat-tx);border-color:var(--badge-nat-bd)}
.badge--oth{background:var(--badge-oth-bg);color:var(--badge-oth-tx);border-color:var(--badge-oth-bd)}
.badge--sug{background:var(--badge-sug-bg);color:var(--badge-sug-tx);border-color:var(--badge-sug-bd)}
.badge--non{background:var(--badge-non-bg);color:var(--badge-non-tx);border-color:var(--badge-non-bd)}
.badge--sm{padding:2px 7px;font-size:.69rem}
.badge--lg{padding:5px 14px;font-size:.875rem}

/* ── 필터 패널 ─────────────────────── */
.filter-panel{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r4);overflow:hidden;
  position:sticky;top:72px;
  max-height:calc(100vh - 90px);overflow-y:auto;
}
.filter-panel::-webkit-scrollbar{width:3px}
.filter-panel::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:2px}

.filter-sec{border-bottom:1px solid var(--border)}
.filter-sec:last-child{border-bottom:none}

.filter-sec__head{
  padding:11px var(--s4);
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:background .1s;user-select:none;gap:var(--s2);
}
.filter-sec__head:hover{background:var(--bg-subtle)}
.filter-sec__title{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.filter-sec__arrow{font-size:.6rem;color:var(--text-4);transition:transform .2s;flex-shrink:0}
.filter-sec__arrow.open{transform:rotate(180deg)}
.filter-sec__body{padding:2px var(--s2) var(--s2)}

.filter-item{
  display:flex;align-items:center;gap:var(--s2);
  width:100%;padding:6px var(--s2);border-radius:var(--r1);
  font-size:.82rem;color:var(--text-2);text-align:left;
  transition:background .1s,color .1s;
}
.filter-item:hover{background:var(--bg-subtle)}
.filter-item--active{background:var(--brand-soft);color:var(--brand);font-weight:700}
.filter-item__count{font-family:var(--font-mono);font-size:.68rem;color:var(--text-4);margin-left:auto;flex-shrink:0}
.filter-item--active .filter-item__count{color:var(--brand)}
.filter-item__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-alc{background:var(--badge-alc-tx)} .dot-art{background:var(--badge-art-tx)}
.dot-nat{background:var(--badge-nat-tx)} .dot-oth{background:var(--badge-oth-tx)}

.cls-tag{font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:var(--rx);border:1px solid}
.cls-tag-alc{background:var(--badge-alc-bg);color:var(--badge-alc-tx);border-color:var(--badge-alc-bd)}
.cls-tag-art{background:var(--badge-art-bg);color:var(--badge-art-tx);border-color:var(--badge-art-bd)}
.cls-tag-nat{background:var(--badge-nat-bg);color:var(--badge-nat-tx);border-color:var(--badge-nat-bd)}
.cls-tag-oth{background:var(--badge-oth-bg);color:var(--badge-oth-tx);border-color:var(--badge-oth-bd)}

.filter-reset-btn{
  display:block;width:calc(100% - 16px);margin:var(--s2) var(--s2) var(--s3);
  padding:7px;border:1px solid var(--border);border-radius:var(--r2);
  font-size:.75rem;color:var(--text-3);text-align:center;
  transition:all .15s;
}
.filter-reset-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}

/* ── 제조사 배너 ─────────────────── */
.mfr-banner{
  background:var(--brand-soft);border:1px solid var(--brand-dim);
  border-radius:var(--r3);padding:var(--s3) var(--s4);
  margin-bottom:var(--s4);font-size:.875rem;
  display:flex;align-items:center;justify-content:space-between;gap:var(--s3);
}
.mfr-banner strong{color:var(--brand)}
.mfr-banner a{font-size:.78rem;color:var(--brand);font-weight:600;white-space:nowrap}

/* ── 제품 상세 ───────────────────── */
.detail-hero{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r4);overflow:hidden;margin-bottom:var(--s5);
}
.detail-hero__thumb{
  height:100px;display:flex;align-items:center;
  padding:0 var(--s6);gap:var(--s4);
}
.detail-hero__icon{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}
.detail-hero__body{padding:var(--s5) var(--s6)}
.detail-breadcrumb{
  font-size:.72rem;color:var(--text-4);
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:var(--s3);
}
.detail-breadcrumb a:hover{color:var(--brand)}
.detail-breadcrumb__sep{color:var(--text-4);font-size:.65rem}
.detail-name{
  font-family:var(--font-ser);
  font-size:clamp(1.4rem,3vw,2rem);
  font-weight:700;letter-spacing:-.03em;line-height:1.2;
  color:var(--text-1);margin-bottom:var(--s2);
}
.detail-mfr-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.875rem;color:var(--brand);font-weight:600;
  padding:4px 12px;border-radius:var(--rx);
  background:var(--brand-soft);border:1px solid var(--brand-dim);
  transition:background .15s;
}
.detail-mfr-link:hover{background:var(--brand-dim)}
.detail-mfr-link__arrow{font-size:.7rem}

.detail-sec{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r4);padding:var(--s5);margin-bottom:var(--s4);
}
.detail-sec__title{
  font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-4);margin-bottom:var(--s4);
  padding-bottom:var(--s3);border-bottom:1px solid var(--border);
}

/* ── 영양성분 그리드 ─────────────── */
.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--s3)}
.nutrition-cell{background:var(--bg-subtle);border-radius:var(--r2);padding:var(--s3);text-align:center}
.nutrition-cell__label{font-size:.67rem;color:var(--text-4);margin-bottom:4px;font-weight:600;letter-spacing:.02em}
.nutrition-cell__val{font-family:var(--font-mono);font-size:1.05rem;font-weight:700;color:var(--text-1)}
.nutrition-cell__unit{font-size:.62rem;color:var(--text-4);margin-left:2px}
.nutrition-serving{font-size:.75rem;color:var(--text-4);margin-bottom:var(--s3)}

/* ── 원재료 ──────────────────────── */
.raw-mtrl{
  font-size:.85rem;color:var(--text-2);line-height:1.9;
  background:var(--bg-subtle);padding:var(--s4);
  border-radius:var(--r2);border:1px solid var(--border);
}

/* ── 연관/제조사 그리드 ─────────── */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--s3)}
.related-card{
  border:1px solid var(--border);border-radius:var(--r3);
  overflow:hidden;transition:box-shadow .15s,border-color .15s;
  background:var(--bg-card);display:block;
}
.related-card:hover{box-shadow:var(--sh1);border-color:var(--border-md)}
.related-card__thumb{height:48px;display:flex;align-items:center;padding:0 var(--s3);gap:var(--s2)}
.related-card__icon{font-size:1.3rem}
.related-card__body{padding:var(--s3)}
.related-card__name{font-size:.8rem;font-weight:700;color:var(--text-1);margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-card__badges{display:flex;flex-wrap:wrap;gap:3px}

/* ── GI 시각화 ───────────────────── */
.gi-card{
  display:flex;align-items:center;gap:var(--s5);
  padding:var(--s4);background:var(--bg-subtle);
  border-radius:var(--r3);border:1px solid var(--border);
}
.gi-score{text-align:center;min-width:60px}
.gi-num{display:block;font-family:var(--font-mono);font-size:2.2rem;font-weight:700;line-height:1}
.gi-label{font-size:.68rem;color:var(--text-4);font-weight:600;margin-top:3px}
.gi--low .gi-num{color:var(--gi-low)} .gi--mid .gi-num{color:var(--gi-mid)} .gi--high .gi-num{color:var(--gi-high)}
.gi-bar-wrap{flex:1}
.gi-bar{height:10px;background:var(--border);border-radius:var(--rx);overflow:hidden;margin-bottom:6px}
.gi-bar__fill{height:100%;border-radius:var(--rx);transition:width .5s cubic-bezier(.4,0,.2,1)}
.gi--low .gi-bar__fill{background:var(--gi-low)} .gi--mid .gi-bar__fill{background:var(--gi-mid)} .gi--high .gi-bar__fill{background:var(--gi-high)}
.gi-scale{display:flex;justify-content:space-between;font-size:.62rem;color:var(--text-4);font-family:var(--font-mono)}
.gi-note{font-size:.72rem;color:var(--text-4);margin-top:var(--s3);line-height:1.55}

/* ── 분류 카드 ───────────────────── */
.cls-card{
  border:1px solid var(--border);border-radius:var(--r4);padding:var(--s5);
  transition:box-shadow .15s,border-color .15s;display:block;
  background:var(--bg-card);
}
.cls-card:hover{box-shadow:var(--sh1);border-color:var(--border-md)}
.cls-card--alc{border-left:4px solid var(--badge-alc-tx)}
.cls-card--art{border-left:4px solid var(--badge-art-tx)}
.cls-card--nat{border-left:4px solid var(--badge-nat-tx)}
.cls-card--oth{border-left:4px solid var(--badge-oth-tx)}
.cls-card__title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:var(--s2)}
.cls-card__desc{font-size:.82rem;color:var(--text-3);line-height:1.6;margin-bottom:var(--s3)}
.cls-card__tags{display:flex;flex-wrap:wrap;gap:4px}
.cls-card__count{font-size:.75rem;color:var(--text-4);margin-bottom:var(--s3)}

/* ── 감미료 테이블 ───────────────── */
.sw-table{width:100%;border-collapse:collapse;font-size:.875rem}
.sw-table th{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:var(--s2) var(--s3);text-align:left;border-bottom:2px solid var(--border)}
.sw-table td{padding:var(--s3);border-bottom:1px solid var(--border);vertical-align:middle}
.sw-table tr:last-child td{border-bottom:none}
.sw-table tr:hover td{background:var(--bg-subtle)}
.sw-table__name{font-weight:700;color:var(--text-1)}
.sw-table__gi{font-family:var(--font-mono);font-weight:700}
.gi-tx--low{color:var(--gi-low)} .gi-tx--mid{color:var(--gi-mid)} .gi-tx--high{color:var(--gi-high)}

/* ── 키워드 칩 ───────────────────── */
.kw{display:inline-block;padding:2px 8px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--rx);font-family:var(--font-mono);font-size:.71rem;color:var(--text-3)}

/* ── 카테고리 칩 ─────────────────── */
.cat-chip{
  padding:7px 14px;border:1.5px solid var(--border);border-radius:var(--rx);
  font-size:.84rem;font-weight:500;color:var(--text-2);background:var(--bg-card);
  transition:all .15s;display:inline-flex;align-items:center;gap:6px;
}
.cat-chip:hover{border-color:var(--brand);color:var(--brand)}
.cat-chip--active{background:var(--brand);border-color:var(--brand);color:#fff}
.cat-chip__count{font-family:var(--font-mono);font-size:.68rem;opacity:.65}
