.r19-row-sticky {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 99990;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  padding: 12px 16px;
  background: #fff;
  border: 1px solid #d7d7d7;
  box-shadow: 0 8px 28px rgba(0,0,0,.14);
  border-radius: 12px;
}
.r19-row-sticky span { max-width: 720px; }
.r19-row-footer-link { text-align: center; margin: 24px 0; }
.r19-row-link { background: none; border: 0; padding: 0; text-decoration: underline; cursor: pointer; color: inherit; }
.r19-row-modal { display: none; position: fixed; inset: 0; z-index: 100000; }
.r19-row-modal.is-open { display: block; }
.r19-row-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.55); }
.r19-row-dialog {
  position: relative;
  width: min(720px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  overflow: auto;
  margin: 24px auto;
  padding: 24px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
}
.r19-row-x { position: absolute; right: 14px; top: 10px; font-size: 28px; line-height: 1; border: 0; background: none; cursor: pointer; }
.r19-row-form input[type="text"], .r19-row-form input[type="email"], .r19-row-form input[type="number"], .r19-row-form select { width: 100%; max-width: 420px; }
.r19-row-message { margin: 10px 0; padding: 10px 12px; border-radius: 8px; display: none; }
.r19-row-message:not(:empty) { display: block; }
.r19-row-message.is-error { background: #ffe9e9; border: 1px solid #d63638; }
.r19-row-message.is-success { background: #efffed; border: 1px solid #00a32a; }
.r19-row-item { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 10px 0; border-bottom: 1px solid #eee; }
.r19-row-item small { grid-column: 1 / -1; opacity: .75; }
.r19-row-item.is-excluded { opacity: .55; }
.r19-row-item-total { white-space: nowrap; }
.r19-row-qty-label { display: flex; gap: 6px; align-items: center; }
.r19-row-qty-label input { width: 72px !important; }
.r19-row-legal-note { font-size: .95em; background: #f7f7f7; padding: 10px 12px; border-radius: 8px; }
body.r19-row-modal-open { overflow: hidden; }
@media (max-width: 680px) {
  .r19-row-sticky { flex-direction: column; align-items: stretch; text-align: center; }
  .r19-row-item { grid-template-columns: 1fr; }
}

.r19-row-order-banner {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: flex-start;
  margin: 24px 0;
  padding: 18px 20px;
  border: 1px solid #d7d7d7;
  background: #f8fafc;
  border-radius: 12px;
}
.r19-row-order-banner__content { min-width: 0; width: 100%; }
.r19-row-order-banner .r19-row-open { margin-top: 2px; }
.r19-row-order-banner h3 { margin: 0 0 8px; }
.r19-row-order-banner p { margin: 0; }
.r19-row-order-banner small { opacity: .8; }
.r19-row-order-banner--requested { background: #fff8e5; border-color: #e0b341; }
.r19-row-order-banner--completed { background: #efffed; border-color: #00a32a; }
.r19-row-order-banner--rejected { background: #ffe9e9; border-color: #d63638; }
@media (max-width: 680px) {
  .r19-row-order-banner { align-items: stretch; }
}
.r19-row-field-note {
  display: block;
  max-width: 520px;
  margin-top: 6px;
  opacity: .78;
  line-height: 1.4;
}
