/* Patch Me Up — reusable component primitives.
   Use these classes when you've already loaded colors_and_type.css. */

/* --- Buttons --- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 600;
  font-size: 15px; letter-spacing: -0.005em;
  padding: 12px 20px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--duration-base) var(--ease-standard),
              color var(--duration-base) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.btn .icon { width: 18px; height: 18px; }

.btn-primary    { background: var(--pmu-teal); color: var(--pmu-wall); }
.btn-primary:hover { background: var(--pmu-teal-700); }

.btn-action     { background: var(--pmu-clay); color: var(--pmu-wall); }
.btn-action:hover { background: var(--pmu-clay-700); }

.btn-secondary  { background: var(--pmu-wall); color: var(--pmu-teal); border-color: var(--pmu-teal); }
.btn-secondary:hover { background: var(--pmu-teal-100); }

.btn-ghost      { background: transparent; color: var(--pmu-teal); padding: 12px 14px; }
.btn-ghost:hover { background: var(--pmu-teal-100); }

.btn-on-dark    { background: var(--pmu-wall); color: var(--pmu-teal); }
.btn-on-dark:hover { background: #fff; }

.btn-sm { padding: 8px 14px; font-size: 13px; }
.btn-lg { padding: 16px 24px; font-size: 17px; }

/* --- Inputs --- */
.input, .textarea, .select {
  font-family: var(--font-body); font-size: 15px;
  background: var(--pmu-paper);
  color: var(--fg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  width: 100%;
  box-sizing: border-box;
  transition: border-color var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
}
.input::placeholder { color: var(--fg-subtle); }
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--pmu-teal);
  box-shadow: var(--focus-ring);
}
.field-label {
  display:block;
  font-family: var(--font-body); font-weight: 600;
  font-size: 13px; color: var(--fg);
  margin-bottom: 6px;
}
.field-hint {
  font-family: var(--font-body); font-size: 12px;
  color: var(--fg-muted);
  margin-top: 6px;
}

/* --- Badge / Chip --- */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-weight: 600;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid currentColor;
  background: transparent;
}
.badge-proof    { color: var(--pmu-proof-700); background: var(--pmu-proof-100); border-color: var(--pmu-proof); }
.badge-action   { color: var(--pmu-clay-700); background: var(--pmu-clay-100); border-color: var(--pmu-clay); }
.badge-info     { color: var(--pmu-teal);     background: var(--pmu-teal-100); border-color: var(--pmu-teal); }
.badge-gold     { color: #7A6620;             background: var(--pmu-gold-100); border-color: var(--pmu-gold-700); }
.badge-graphite { color: var(--pmu-graphite); background: var(--pmu-plaster);  border-color: var(--pmu-graphite); }
.badge-solid {
  background: var(--pmu-proof); color: var(--pmu-wall); border-color: transparent;
}
.badge .dot { width: 6px; height: 6px; border-radius: 999px; background: currentColor; }

/* --- Card / Patch frame --- */
.card-patch {
  background: var(--pmu-paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-card);
}

/* --- Service tile --- */
.service-tile {
  background: var(--pmu-paper);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px;
  transition: border-color var(--duration-base) var(--ease-standard),
              transform var(--duration-base) var(--ease-out-soft);
}
.service-tile:hover { border-color: var(--pmu-teal); transform: translateY(-2px); }
.service-tile .ico-wrap {
  width: 40px; height: 40px;
  background: var(--pmu-teal-100);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  color: var(--pmu-teal);
  margin-bottom: 12px;
}
.service-tile .ico-wrap svg { width: 22px; height: 22px; }
.service-tile h4 { margin-bottom: 4px; }
.service-tile p { font-size: 14px; color: var(--fg-muted); line-height: 1.45; }

/* --- Proof stamp (visual) --- */
.proof-stamp {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-weight: 600;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--pmu-proof-700);
  padding: 8px 14px;
  border: 1.5px solid var(--pmu-proof);
  border-radius: 6px;
  background: var(--pmu-proof-100);
  position: relative;
}
.proof-stamp::before {
  content: ""; width: 8px; height: 8px; border-radius: 999px;
  background: var(--pmu-proof);
}
