/* --- Base container --- */
.wpwp-container { max-width: 920px; margin: 0 auto; padding: 18px; }

/* --- Form --- */
.wpwp-form { max-width: 560px; margin: 0 auto 24px; background:#f9fafb; border:1px solid #e5e7eb; border-radius: 16px; padding: 18px; }
.wpwp-title { margin: 4px 0 14px; font-size: 22px; }
.wpwp-form h3 { margin: 18px 0 6px; font-size: 18px; }
.wpwp-form label { display:block; margin-top: 12px; font-weight: 600; color:#111827; }
.wpwp-form input, .wpwp-form select {
  width: 100%;
  padding: 10px 12px;
  margin-top: 6px;
  border: 1px solid #d1d5db;
  border-radius: 12px;
  background: #fff;
  font-size: 16px;
}
.wpwp-form input:disabled { background:#f3f4f6; color:#6b7280; }

.wpwp-checkbox { display:flex; gap:10px; align-items:center; margin-top: 10px; font-weight: 600; }
.wpwp-checkbox input { width:auto; margin:0; }

.wpwp-button {
  width: 100%;
  margin-top: 18px;
  padding: 12px 14px;
  font-size: 16px;
  border-radius: 14px;
  border: none;
  cursor: pointer;
  background: #2f7da1;
  color: #fff;
}
.wpwp-button--secondary { background:#334155; }
.wpwp-busy { opacity:.7; cursor:not-allowed; }

.wpwp-note { margin-top: 10px; font-size: 13px; color:#6b7280; }
.wpwp-note--small { font-size: 12px; }

/* --- Error box --- */
.wpwp-error {
  max-width: 760px;
  margin: 16px auto;
  background: #fdecea;
  color: #7f1d1d;
  padding: 14px 16px;
  border-left: 4px solid #b91c1c;
  border-radius: 14px;
}
.wpwp-error ul { margin: 0; padding-left: 18px; }

/* --- Report --- */
.wpwp-report { max-width: 760px; margin: 18px auto; font-size: 16px; line-height: 1.5; }
.wpwp-report__header { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; }
.wpwp-muted { color:#667085; font-size: 13px; margin: 6px 0 0; }

.wpwp-badges { display:flex; flex-wrap:wrap; gap:8px; }
.wpwp-badge { background:#eef2f6; color:#334155; padding:6px 10px; border-radius:999px; font-size:12px; }

.wpwp-cards { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:12px; margin: 14px 0; }
@media (max-width: 700px) { .wpwp-cards { grid-template-columns: 1fr; } }

.wpwp-card { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:14px 16px; box-shadow: 0 1px 2px rgba(16,24,40,.04); }
.wpwp-card__label { color:#667085; font-size: 12px; text-transform: uppercase; letter-spacing:.06em; }
.wpwp-card__value { font-size: 22px; font-weight: 800; margin-top: 6px; color:#0f172a; }
.wpwp-card--accent { border-color:#b7d7e6; background: #f2fbff; }
.wpwp-card--good { border-color:#b7e4c7; background: #f2fff7; }

.wpwp-section { margin-top: 22px; padding-top: 14px; border-top: 1px solid #e5e7eb; }
.wpwp-section h4 { margin:0 0 12px; font-size: 18px; }

.wpwp-dl { display:grid; grid-template-columns: 1fr 1fr; gap: 10px 18px; margin: 0; }
@media (max-width: 700px) { .wpwp-dl { grid-template-columns: 1fr; } }
.wpwp-dl > div { background:#fff; border:1px solid #eef2f6; border-radius: 12px; padding: 10px 12px; }
.wpwp-dl dt { font-size: 12px; color:#667085; text-transform: uppercase; letter-spacing:.06em; }
.wpwp-dl dd { margin: 4px 0 0; font-weight: 700; color:#0f172a; }

.wpwp-formula { background:#0b1220; color:#e5e7eb; border-radius: 16px; padding: 14px 16px; margin: 12px 0; }
.wpwp-formula__title { font-size: 12px; color:#93c5fd; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px; }
.wpwp-formula code { display:block; white-space: pre-wrap; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 13px; }

.wpwp-highlight { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap:12px; margin: 14px 0; }
@media (max-width: 700px) { .wpwp-highlight { grid-template-columns: 1fr; } }
.wpwp-highlight > div { background:#fff; border:1px solid #e5e7eb; border-radius: 14px; padding: 12px 14px; }
.wpwp-highlight__label { color:#667085; font-size: 12px; }
.wpwp-highlight__value { font-size: 20px; font-weight: 800; color:#0f172a; margin-top: 6px; }

.wpwp-disclaimer { margin-top: 14px; background:#fff7ed; border:1px solid #fed7aa; border-radius:14px; padding: 12px 14px; color:#7c2d12; font-size: 13px; }