/* ═══════════════════════════════════════
   GLP1 Tables - Frontend CSS v2
   Mobile-first, fully responsive
═══════════════════════════════════════ */
:root {
  --glp1-navy:   #3d5068;
  --glp1-orange: #e8622a;
  --glp1-gold:   #e6a817;
  --glp1-red:    #c0392b;
  --glp1-green:  #27ae60;
  --glp1-radius: 8px;
}

.glp1-ranking-outer,
.glp1-comparison-wrap,
.glp1-ec-outer {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  margin: 24px 0;
  box-sizing: border-box;
}
*, *::before, *::after { box-sizing: inherit; }

/* ═══════ CTA BUTTON ═══════ */
.glp1-cta-btn, .glp1-ec-cta-btn {
  display: inline-block;
  background: var(--glp1-orange);
  color: #fff !important;
  padding: 10px 18px;
  border-radius: 6px;
  font-weight: 700;
  font-size: .88rem;
  text-decoration: none !important;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  transition: background .15s;
  text-align: center;
}
.glp1-cta-btn:hover, .glp1-ec-cta-btn:hover { background: #cf5521; }

/* ═══════ CHECKLIST ═══════ */
.glp1-check-list { list-style: none; margin: 0; padding: 0; }
.glp1-check-list li { padding: 2px 0 2px 20px; position: relative; font-size: .82rem; }
.glp1-check-list li::before { content: '✔'; position: absolute; left: 0; color: var(--glp1-green); font-size: .78rem; }

/* ═══════ STARS ═══════ */
.glp1-stars { display: flex; align-items: center; gap: 2px; margin: 6px 0; flex-wrap: wrap; }
.glp1-star  { color: #ddd; font-size: 1.1rem; }
.glp1-star.filled { color: var(--glp1-gold); }
.glp1-star-score { font-size: .82rem; color: #666; margin-left: 4px; }

/* ═══════ EDITOR BADGE ═══════ */
.glp1-editors-badge {
  display: inline-block;
  background: var(--glp1-gold);
  color: #5a3a00;
  font-size: .75rem;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 0 0 6px 6px;
  margin-bottom: 0;
  letter-spacing: .03em;
}

/* ═══════ BADGES ═══════ */
.glp1-badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: .72rem; font-weight: 600; white-space: nowrap; }
.badge-yes      { background: #d4edda; color: #155724; }
.badge-no       { background: #f8d7da; color: #721c24; }
.badge-included { background: #d1ecf1; color: #0c5460; }
.badge-none, .badge-not { background: #e2e3e5; color: #383d41; }
.badge-optional { background: #fff3cd; color: #856404; }

/* ═══════════════════════════════
   RANKING TABLE
═══════════════════════════════ */
.glp1-ranking-outer {
  border: 2px solid var(--glp1-gold);
  border-radius: var(--glp1-radius);
  overflow: hidden;
}

/* Desktop table — hidden on mobile */
.glp1-ranking-table {
  width: 100%;
  border-collapse: collapse;
  display: table;
}
.glp1-ranking-table thead tr { background: var(--glp1-navy); }
.glp1-ranking-table thead th { color: #fff; padding: 12px 14px; text-align: left; font-size: .8rem; font-weight: 700; white-space: nowrap; }
.glp1-ranking-table tbody td { padding: 12px 14px; border-bottom: 1px solid #eee; vertical-align: middle; font-size: .82rem; }
.glp1-ranking-table tbody tr:last-child td { border-bottom: none; }

.glp1-rank-num { font-weight: 800; color: #aaa; font-size: 1.1rem; }
.glp1-provider-name { font-weight: 700; color: var(--glp1-red); font-size: .9rem; }
.glp1-price { font-weight: 700; color: var(--glp1-navy); }

/* Mobile cards for ranking — shown only on mobile */
.glp1-ranking-cards { display: none; }
.glp1-rank-card {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin: 12px 0;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.07);
}
.glp1-rank-card.top-card { border-color: var(--glp1-gold); background: #fffbf0; }
.glp1-rank-card-header {
  background: var(--glp1-navy);
  color: #fff;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.glp1-rank-card-header .rank-num { font-size: 1rem; font-weight: 800; opacity: .7; }
.glp1-rank-card-header .provider { font-weight: 700; font-size: .95rem; color: #ffd; }
.glp1-rank-card.top-card .glp1-rank-card-header { background: var(--glp1-gold); color: #5a3a00; }
.glp1-rank-card.top-card .glp1-rank-card-header .provider { color: #5a3a00; }
.glp1-rank-card-body { padding: 12px 14px; }
.glp1-rank-card-row { display: flex; justify-content: space-between; padding: 4px 0; font-size: .82rem; border-bottom: 1px solid #f0f0f0; }
.glp1-rank-card-row:last-of-type { border-bottom: none; }
.glp1-rank-card-row .label { color: #888; font-weight: 600; flex-shrink: 0; margin-right: 8px; }
.glp1-rank-card-footer { padding: 10px 14px 14px; }
.glp1-rank-card-footer .glp1-cta-btn { width: 100%; display: block; text-align: center; padding: 12px; font-size: .9rem; }

/* ═══════════════════════════════
   COMPARISON TABLE
═══════════════════════════════ */
.glp1-comparison-wrap { overflow: hidden; }

.glp1-table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.glp1-comp-table {
  width: 100%;
  min-width: 600px;
  border-collapse: collapse;
}
.glp1-comp-table thead tr { background: var(--glp1-navy); }
.glp1-comp-table thead th { color: #fff; padding: 12px 14px; font-size: .8rem; font-weight: 700; text-align: left; white-space: nowrap; }
.glp1-comp-table tbody td { padding: 10px 14px; border-bottom: 1px solid #eee; font-size: .8rem; vertical-align: top; }
.glp1-comp-table tbody tr:nth-child(even) td { background: #f9f9f9; }

.glp1-clinic-name { font-weight: 700; color: var(--glp1-red); }
.glp1-top-badge { display: inline-block; background: var(--glp1-gold); color: #5a3a00; font-size: .68rem; font-weight: 800; padding: 2px 8px; border-radius: 10px; margin-top: 4px; }

/* Mobile card stack for comparison */
.glp1-card-stack { display: none; }
.glp1-clinic-card {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin-bottom: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.07);
}
.glp1-card-header {
  background: var(--glp1-navy);
  color: #fff;
  padding: 10px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.glp1-card-clinic-name { font-weight: 700; font-size: .92rem; color: #ffd; }
.glp1-card-body { padding: 10px 14px; }
.glp1-card-row { display: flex; padding: 6px 0; border-bottom: 1px solid #f0f0f0; font-size: .82rem; }
.glp1-card-row:last-child { border-bottom: none; }
.glp1-card-label { color: #888; font-weight: 600; width: 120px; flex-shrink: 0; }
.glp1-card-val { flex: 1; }

/* ═══════════════════════════════
   EDITOR'S CHOICE CARD
═══════════════════════════════ */
.glp1-ec-outer {
  border: 2px solid var(--glp1-gold);
  border-radius: var(--glp1-radius);
  overflow: hidden;
}
.glp1-ec-inner { padding: 20px; }
.glp1-ec-title { font-size: 1.1rem; font-weight: 800; color: var(--glp1-navy); margin-bottom: 6px; }

.glp1-ec-body {
  display: flex;
  gap: 20px;
  margin-top: 14px;
  align-items: flex-start;
  flex-wrap: wrap;
}
.glp1-ec-img-col { flex: 0 0 140px; text-align: center; }
.glp1-ec-product-img { max-width: 130px; border-radius: 6px; margin-bottom: 6px; }
.glp1-ec-img-placeholder { width: 130px; height: 130px; background: #f0f0f0; border-radius: 6px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #aaa; font-size: .75rem; text-align: center; margin-bottom: 6px; }
.glp1-ec-img-label { font-size: .72rem; color: #888; display: block; }
.glp1-ec-label-col { flex: 0 0 160px; font-size: .82rem; color: #555; line-height: 1.6; }
.glp1-ec-benefits-col { flex: 1; min-width: 180px; }
.glp1-ec-cta-wrap { margin-top: 14px; }
.glp1-ec-cta-btn { display: block; text-align: center; padding: 13px; font-size: .9rem; }
.glp1-ec-disclaimer { display: block; font-size: .72rem; color: #999; margin-top: 6px; text-align: center; }

/* ═══════════════════════════════
   MOBILE — max 640px
═══════════════════════════════ */
@media (max-width: 640px) {

  /* Ranking: hide table, show cards */
  .glp1-ranking-table { display: none !important; }
  .glp1-ranking-cards { display: block !important; }

  /* Comparison: hide table, show card stack */
  .glp1-table-scroll { display: none !important; }
  .glp1-card-stack   { display: block !important; }

  /* Editor's Choice: stack vertically */
  .glp1-ec-body { flex-direction: column; }
  .glp1-ec-img-col  { flex: none; width: 100%; display: flex; align-items: center; gap: 12px; }
  .glp1-ec-label-col { flex: none; width: 100%; }
  .glp1-ec-benefits-col { flex: none; width: 100%; }
  .glp1-ec-cta-btn { width: 100%; display: block; padding: 14px; font-size: 1rem; }
}
