/* PeptidePay crypto — on-site pay page styles. Scoped under .ppay-crypto /
   #ppay-crypto-root so they don't leak into the merchant theme. */

#ppay-crypto-root { max-width: 560px; margin: 24px auto; font-size: 15px; line-height: 1.5; }
#ppay-crypto-root * { box-sizing: border-box; }

.ppay-crypto-loading,
.ppay-crypto-error,
.ppay-crypto-msg { text-align: center; padding: 16px; border-radius: 10px; }
.ppay-crypto-loading { color: #475569; }
.ppay-crypto-error,
.ppay-crypto-msg--error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b; }
.ppay-crypto-msg--info { background: #f1f5f9; border: 1px solid #e2e8f0; color: #334155; }
.ppay-crypto-confirmed { text-align: center; padding: 16px; border-radius: 10px; background: #ecfdf5; border: 1px solid #a7f3d0; color: #065f46; font-weight: 600; margin: 16px 0; }

/* Coin picker */
.ppay-crypto-head { text-align: center; margin-bottom: 18px; }
.ppay-crypto-head h2 { margin: 0 0 6px; font-size: 20px; }
.ppay-crypto-head p { margin: 0; color: #64748b; font-size: 14px; }
.ppay-crypto-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.ppay-coin {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  padding: 14px 16px; border: 1px solid #e2e8f0; border-radius: 12px;
  background: #fff; cursor: pointer; text-align: left; transition: border-color .15s, box-shadow .15s, transform .05s;
}
.ppay-coin:hover { border-color: #6366f1; box-shadow: 0 2px 10px rgba(99,102,241,.12); }
.ppay-coin:active { transform: translateY(1px); }
.ppay-coin__sym { font-weight: 700; font-size: 15px; color: #0f172a; }
.ppay-coin__label { font-size: 13px; color: #334155; }
.ppay-coin__net { font-size: 11px; color: #94a3b8; }

/* Pay box */
.ppay-pay { border: 1px solid #e2e8f0; border-radius: 16px; padding: 22px; background: #fff; }
.ppay-pay__head { text-align: center; margin-bottom: 14px; }
.ppay-pay__head h2 { margin: 8px 0 6px; font-size: 20px; }
.ppay-pay__head p { margin: 0; color: #64748b; font-size: 14px; }
.ppay-pill { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 600; background: #fef3c7; color: #92400e; }

.ppay-warning { margin: 0 0 16px; padding: 12px 14px; border: 1px solid #dc2626; background: #fef2f2; border-radius: 8px; color: #991b1b; font-size: 13px; line-height: 1.45; }

.ppay-qr { display: flex; align-items: center; justify-content: center; min-height: 200px; margin: 4px auto 10px; }
.ppay-qr img, .ppay-qr canvas { max-width: 200px; height: auto; }
.ppay-qr__fallback { color: #94a3b8; font-size: 13px; }
.ppay-scan-hint { text-align: center; font-size: 12.5px; color: #64748b; margin: 0 0 16px; }

.ppay-field { margin-bottom: 14px; }
.ppay-field__label { display: block; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: #94a3b8; margin-bottom: 4px; }
.ppay-field__row { display: flex; align-items: center; gap: 8px; }
.ppay-field__val { flex: 1; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 14px; word-break: break-all; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; padding: 8px 10px; color: #0f172a; }
.ppay-field__unit { font-weight: 700; color: #334155; }
.ppay-field__note { display: block; font-size: 11.5px; color: #94a3b8; margin-top: 5px; }

.ppay-copy { border: 1px solid #e2e8f0; background: #fff; border-radius: 8px; padding: 8px 12px; font-size: 12px; font-weight: 600; cursor: pointer; color: #4f46e5; white-space: nowrap; }
.ppay-copy:hover { background: #f5f3ff; }
.ppay-copy.is-copied { color: #059669; border-color: #a7f3d0; }

.ppay-status { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 6px 0 4px; padding: 10px; border-radius: 8px; font-size: 13px; font-weight: 600; }
.ppay-status--waiting { background: #fffbeb; color: #92400e; }
.ppay-status__dot { width: 8px; height: 8px; border-radius: 50%; background: currentColor; animation: ppay-pulse 1.2s infinite; }
@keyframes ppay-pulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

.ppay-pay__summary { margin-top: 14px; padding-top: 14px; border-top: 1px solid #f1f5f9; display: grid; gap: 6px; }
.ppay-meta-item { display: flex; justify-content: space-between; font-size: 13px; }
.ppay-meta-item span { color: #94a3b8; }
.ppay-meta-item strong { color: #0f172a; }

.ppay-crypto-back { display: block; margin: 16px auto 0; background: none; border: none; color: #6366f1; font-size: 13px; font-weight: 600; cursor: pointer; }
.ppay-crypto-back:hover { text-decoration: underline; }

/* ── Checkout coin chooser (classic + block) ─────────────────────────────────
   Rendered inside the checkout payment box, NOT under #ppay-crypto-root, so
   these selectors are deliberately unscoped. */
.ppay-crypto-block-desc { margin: 0 0 10px; color: #475569; font-size: 14px; }
.ppay-crypto-coins { display: grid; gap: 8px; margin: 10px 0 4px; }
.ppay-crypto-coin {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border: 1px solid #e2e8f0; border-radius: 10px;
  background: #fff; cursor: pointer; transition: border-color .15s, box-shadow .15s, background .15s;
}
.ppay-crypto-coin:hover { border-color: #6366f1; }
.ppay-crypto-coin:has(input[type=radio]:checked),
.ppay-crypto-coin.is-selected { border-color: #6366f1; box-shadow: 0 0 0 1px #6366f1 inset; background: #f5f3ff; }
.ppay-crypto-coin input[type=radio] { margin: 0; flex-shrink: 0; width: auto; }
.ppay-crypto-coin__sym { font-weight: 700; color: #0f172a; min-width: 46px; }
.ppay-crypto-coin__label { flex: 1; color: #334155; font-size: 14px; }
.ppay-crypto-coin__net { font-size: 11px; color: #94a3b8; white-space: nowrap; }

/* "I've sent the payment" button */
.ppay-sent-btn {
  display: block; width: 100%; margin: 16px 0 4px; padding: 13px 16px;
  border: none; border-radius: 10px; background: #4f46e5; color: #fff;
  font-size: 15px; font-weight: 700; cursor: pointer; transition: background .15s;
}
.ppay-sent-btn:hover { background: #4338ca; }
.ppay-sent-btn:disabled { background: #a5b4fc; cursor: default; }

/* on-hold / confirming states */
.ppay-pill--hold { background: #dbeafe; color: #1e40af; }
.ppay-status--pending { background: #eff6ff; color: #1e40af; }
.ppay-pay--awaiting .ppay-pay__head p { color: #475569; }
