/* ═══════════════════════════════════════════════════
   FILE: static/css/shortcodes.css
   Styles for all Hugo shortcodes.
   Loaded on every page via layouts/_default/baseof.html
   Uses the same design tokens as the rest of the site.
════════════════════════════════════════════════════ */

/* ── HIGHLIGHT ───────────────────────────────────── */
.hl {
  padding: 1px 5px;
  border-radius: 3px;
  font-weight: 500;
}
.hl--orange { background: #fff5ec; color: var(--hl-5); }
.hl--teal   { background: #e6f9f9; color: var(--hl-2); }
.hl--cyan   { background: #e0faf9; color: var(--hl-3); }
.hl--red    { background: #fff0ed; color: var(--hl-1); }
.hl--light  { background: var(--bg-light); color: var(--text-dark); }
.hl--dark   { background: var(--bg-dark);  color: var(--text-light); }

/* ── BADGE ───────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  border-radius: 100px;
  font-size: var(--t-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.8;
  vertical-align: middle;
}
.badge--orange { background: #fff5ec; color: var(--hl-5); border: 1px solid #ffd9b0; }
.badge--teal   { background: #e6f9f9; color: var(--hl-2); border: 1px solid #b0e4e4; }
.badge--cyan   { background: #e0faf9; color: var(--hl-3); border: 1px solid #9ef8ee; }
.badge--red    { background: #fff0ed; color: var(--hl-1); border: 1px solid #ffc4b5; }
.badge--light  { background: var(--bg-light); color: var(--text-dark); border: 1px solid #ccc; }
.badge--dark   { background: var(--bg-dark); color: var(--text-light); border: 1px solid #1e4444; }

/* ── CALLOUT ─────────────────────────────────────── */
.callout {
  display: flex;
  gap: 14px;
  padding: 16px 20px;
  border-radius: 8px;
  margin: 24px 0;
  font-size: var(--t-sm);
  line-height: 1.7;
}
.callout__icon { flex-shrink: 0; font-size: 16px; margin-top: 1px; }
.callout__title { display: block; font-weight: 700; margin-bottom: 4px; }
.callout__text p { margin: 0; }
.callout__text p + p { margin-top: 8px; }
.callout--info    { background: #eff8ff; border-left: 3px solid #60b4f6; color: #1a5f9c; }
.callout--tip     { background: #effff4; border-left: 3px solid #4ade80; color: #166534; }
.callout--warning { background: #fff8ec; border-left: 3px solid var(--hl-5); color: #7a4400; }
.callout--danger  { background: #fff0ed; border-left: 3px solid var(--hl-1); color: #8b1a00; }

/* ── COLUMNS ─────────────────────────────────────── */
.sc-columns { display: grid; gap: 40px; margin: 28px 0; align-items: start; }
.sc-columns--golden  { grid-template-columns: 61.8fr 38.2fr; }
.sc-columns--equal   { grid-template-columns: 1fr 1fr; }
.sc-columns--reverse { grid-template-columns: 38.2fr 61.8fr; }
.sc-columns__left p:last-child,
.sc-columns__right p:last-child { margin-bottom: 0; }

/* ── CARD ────────────────────────────────────────── */
.sc-card {
  padding: 28px 24px;
  border-radius: 10px;
  border: 1px solid #e8e8e8;
  margin: 20px 0;
  transition: box-shadow 0.2s, border-color 0.2s;
}
.sc-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.07); }
.sc-card--orange { border-top: 3px solid var(--hl-5); }
.sc-card--teal   { border-top: 3px solid var(--hl-2); }
.sc-card--cyan   { border-top: 3px solid var(--hl-3); }
.sc-card--red    { border-top: 3px solid var(--hl-1); }
.sc-card__icon  { font-size: var(--t-lg); margin-bottom: 12px; line-height: 1; }
.sc-card__title { font-size: var(--t-md); font-weight: 700; color: var(--text-dark); margin-bottom: 10px; letter-spacing: -0.01em; }
.sc-card__body  { font-size: var(--t-sm); line-height: 1.7; color: #555; }
.sc-card__body p:last-child { margin-bottom: 0; }

/* ── DIVIDER ─────────────────────────────────────── */
.sc-divider { height: 1px; background: #e8e8e8; margin: 40px 0; position: relative; }
.sc-divider--labelled { display: flex; align-items: center; gap: 16px; background: none; }
.sc-divider--labelled::before,
.sc-divider--labelled::after { content: ''; flex: 1; height: 1px; background: #e8e8e8; }
.sc-divider__label { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: #aaa; white-space: nowrap; }

/* ── KBD ─────────────────────────────────────────── */
.sc-kbd {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  background: #f5f5f5;
  border: 1px solid #d0d0d0;
  border-bottom-width: 2px;
  border-radius: 5px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--text-dark);
  box-shadow: 0 1px 0 #bbb;
  vertical-align: middle;
}

/* ── LEAD ────────────────────────────────────────── */
.sc-lead {
  font-size: var(--t-md);
  font-weight: 300;
  line-height: 1.65;
  color: #555;
  margin-bottom: 32px;
}
