/* ============================================================
   MASTER COURSES — Component primitives
   components.css  (requires colors_and_type.css)
   ============================================================ */

/* ---------- BUTTONS ---------- */
.mcb {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 15px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: var(--r-pill);
  padding: 14px 26px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .12s cubic-bezier(.22,.61,.36,1),
              background .18s ease, color .18s ease, box-shadow .18s ease;
  text-decoration: none;
  white-space: nowrap;
}
.mcb:active { transform: scale(.97); }

/* Primary — solid yellow, black ink, signature outline */
.mcb-primary {
  background: var(--mc-yellow);
  color: var(--mc-ink);
  border-color: var(--mc-ink);
  box-shadow: var(--sh-yellow);
}
.mcb-primary:hover { background: var(--mc-yellow-deep); transform: translateY(-2px); }

/* Outline pill — inverts on hover */
.mcb-outline {
  background: transparent;
  color: var(--mc-ink);
  border-color: var(--mc-ink);
}
.mcb-outline:hover { background: var(--mc-ink); color: var(--mc-yellow); }

/* Orange — secondary heat */
.mcb-orange {
  background: var(--mc-orange);
  color: #fff;
  border-color: transparent;
}
.mcb-orange:hover { background: var(--mc-orange-deep); transform: translateY(-2px); }

/* Light outline — for dark / gradient backgrounds */
.mcb-light {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,.7);
}
.mcb-light:hover { background: #fff; color: var(--mc-ink); border-color: #fff; }

/* Ghost */
.mcb-ghost {
  background: transparent;
  color: var(--mc-ink);
  border-color: transparent;
  padding: 14px 16px;
}
.mcb-ghost:hover { color: var(--mc-orange); }

.mcb-sm { font-size: 13px; padding: 10px 18px; }
.mcb-lg { font-size: 17px; padding: 17px 32px; }

/* ---------- NAME / TAG PILL ---------- */
.mc-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  padding: 6px 14px; border-radius: var(--r-pill);
  background: var(--mc-yellow-soft); color: var(--mc-ink);
}
.mc-tag-outline { background: transparent; border: 1.5px solid var(--mc-line-strong); color: var(--mc-ink-2); }
.mc-tag-solid { background: var(--mc-yellow); color: var(--mc-ink); border: 2px solid var(--mc-ink); }

/* ---------- INPUTS ---------- */
.mc-field { display: flex; flex-direction: column; gap: 6px; }
.mc-label { font-family: var(--font-display); font-weight: 600; font-size: 13px; color: var(--mc-ink-2); }
.mc-input {
  font-family: var(--font-body); font-size: 15px; color: var(--mc-ink);
  background: #fff; border: 1.5px solid var(--mc-line-strong);
  border-radius: var(--r-sm); padding: 12px 14px; outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.mc-input::placeholder { color: var(--mc-ink-4); }
.mc-input:focus { border-color: var(--mc-yellow); box-shadow: 0 0 0 3px var(--mc-yellow-soft); }

/* ---------- CARD ---------- */
.mc-card {
  background: #fff; border: 1px solid var(--mc-line);
  border-radius: var(--r-lg); box-shadow: var(--sh-sm);
  overflow: hidden;
  transition: transform .2s cubic-bezier(.22,.61,.36,1), box-shadow .2s ease;
}
.mc-card-hover:hover { transform: translateY(-4px); box-shadow: var(--sh-md); }

/* ---------- BADGE / CHIP ---------- */
.mc-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-display); font-weight: 700; font-size: 11px;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
}
.mc-badge-yellow { background: var(--mc-yellow); color: var(--mc-ink); }
.mc-badge-orange { background: var(--mc-orange); color: #fff; }
.mc-badge-soft   { background: var(--mc-cream-3); color: var(--mc-ink-2); }
.mc-badge-success{ background: var(--mc-success-bg); color: var(--mc-success); }
