/* ─────────────────────────────────────────
   SHARE OVERLAY
───────────────────────────────────────── */
#share-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.88);
  z-index: 400;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 14px;
  padding: 20px 16px 32px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
#share-overlay.show { display: flex; }

/* ── Overlay controls ── */
.share-controls {
  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

.share-theme-toggle {
  display: flex;
  gap: 0;
  border: 1px solid #333;
  border-radius: 3px;
  overflow: hidden;
}
.sc-theme-btn {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 8px 16px;
  border: none;
  background: transparent;
  color: #666;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.sc-theme-btn.on { background: #fff; color: #080808; }
.sc-theme-btn:first-child { border-right: 1px solid #333; }

.share-btns {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.share-btn {
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 10px 22px;
  border: 1px solid #333;
  background: transparent;
  color: #fff;
  cursor: pointer;
  border-radius: 3px;
  transition: opacity .15s;
}
.share-btn:hover { opacity: .7; }
.share-btn.primary { background: #e8001a; border-color: #e8001a; }

/* ─────────────────────────────────────────
   SHARE CARD — 2:3 ratio (540 × 810px)
───────────────────────────────────────── */
#share-card {
  /* 2:3 portrait — scale×3 = 1620×2430px output */
  width: 540px;
  max-width: calc(100vw - 32px);
  height: 810px;
  overflow: hidden;
  flex-shrink: 0;

  font-family: 'DM Mono', monospace;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;

  /* ── CSS variables: dark theme (default) ── */
  --sc-bg:       #080808;
  --sc-fg:       #ffffff;
  --sc-sub:      #666;
  --sc-dim:      #444;
  --sc-muted:    #333;
  --sc-rule:     #1e1e1e;
  --sc-item-nm:  #ddd;
  --sc-item-tm:  #777;
  --sc-pack:     #aaa;
  --sc-pack-qty: #fff;
  --sc-course:   #999;
  --sc-accent:   #e8001a;

  background: var(--sc-bg);
  color: var(--sc-fg);
}

/* Mobile: let card grow to fit all content — no clipping */
@media (max-width: 600px) {
  #share-card {
    height: auto;
    overflow: visible;
  }
}

/* ── Light theme ── */
#share-card[data-theme="light"] {
  --sc-bg:       #ffffff;
  --sc-fg:       #080808;
  --sc-sub:      #777;
  --sc-dim:      #aaa;
  --sc-muted:    #c0c0c0;
  --sc-rule:     #e0e0e0;
  --sc-item-nm:  #222;
  --sc-item-tm:  #888;
  --sc-pack:     #666;
  --sc-pack-qty: #111;
  --sc-course:   #888;
}

/* ── Header ── */
.sc-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 10px;
  flex-shrink: 0;
}
.sc-brand {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--sc-fg);
}
.sc-dot { color: var(--sc-accent); }
.sc-title {
  font-size: 9px;
  letter-spacing: .22em;
  color: var(--sc-dim);
  text-transform: uppercase;
}

/* ── Dividers ── */
.sc-rule {
  height: 1px;
  background: var(--sc-rule);
  margin: 0 0 8px;
  flex-shrink: 0;
}
.sc-rule-bot { margin: 8px 0 0; }

/* ── Athlete block ── */
.sc-athlete { margin-bottom: 6px; flex-shrink: 0; }
.sc-ath-main {
  font-size: 12px;
  letter-spacing: .09em;
  text-transform: uppercase;
  line-height: 1.4;
  margin-bottom: 2px;
  color: var(--sc-fg);
}
.sc-ath-sub {
  font-size: 9px;
  letter-spacing: .1em;
  color: var(--sc-sub);
  text-transform: uppercase;
  line-height: 1.55;
}
.sc-ath-course { color: var(--sc-course); margin-top: 3px; }

/* ── Section label ── */
.sc-section {
  font-size: 8.5px;
  font-weight: 500;
  letter-spacing: .22em;
  color: var(--sc-accent);
  text-transform: uppercase;
  margin: 7px 0 4px;
  flex-shrink: 0;
}

/* ── Items (3-col grid) ── */
.sc-item {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 6px;
  align-items: baseline;
  padding: 1px 0;
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  line-height: 1.4;
}
.sc-item-lbl { color: var(--sc-accent); }
.sc-item-nm  { color: var(--sc-item-nm); }
.sc-item-tm  {
  color: var(--sc-item-tm);
  font-size: 9.5px;
  letter-spacing: .08em;
  white-space: nowrap;
}
.sc-item-caf {
  display: inline-block;
  font-size: 7.5px;
  letter-spacing: .1em;
  background: var(--sc-accent);
  color: #fff;
  padding: 1px 4px;
  border-radius: 2px;
  vertical-align: middle;
  margin-left: 5px;
  line-height: 1.4;
}
.sc-item-dim .sc-item-nm,
.sc-item-dim .sc-item-lbl { color: var(--sc-dim); }

/* ── Pack list ── */
.sc-pack { margin-top: 2px; margin-bottom: 2px; flex-shrink: 0; }
.sc-pack-row {
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
  line-height: 1.5;
  color: var(--sc-pack);
}
.sc-pack-qty { color: var(--sc-pack-qty); }

/* ── KPI row ── */
.sc-kpi {
  display: flex;
  gap: 4px;
  border-top: 1px solid var(--sc-rule);
  border-bottom: 1px solid var(--sc-rule);
  padding: 9px 0;
  margin: 6px 0 0;
  flex-shrink: 0;
}
.sc-kpi-cell { flex: 1; min-width: 0; text-align: center; }
.sc-kpi-val {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: .03em;
  line-height: 1;
  margin-bottom: 4px;
  white-space: nowrap;
  color: var(--sc-fg);
}
.sc-kpi-lbl {
  font-size: 7px;
  letter-spacing: .17em;
  color: var(--sc-dim);
  text-transform: uppercase;
}

/* ── Spacer (pushes footer to bottom) ── */
.sc-spacer { flex: 1; }

/* ── Footer ── */
.sc-footer {
  font-size: 8.5px;
  letter-spacing: .14em;
  color: var(--sc-dim);
  text-transform: uppercase;
  padding-top: 10px;
  border-top: 1px solid var(--sc-rule);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-shrink: 0;
}
.sc-footer-brand { color: var(--sc-accent); }
