/* Chaping frontend surface styles.
 * Uses tokens from chaping-tokens.css.
 */

.chaping-form {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
  padding: var(--s-6);
  margin: var(--s-4) auto;
}

.chaping-form--login {
  max-width: 460px;
}

.chaping-form form {
  margin: 0;
}

.chaping-form__row {
  margin-bottom: var(--s-3);
}

.chaping-form__label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
}

.chaping-form__input,
.chaping-form__select,
.chaping-form__textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--ink);
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-fast) var(--ease-out);
}

.chaping-form__textarea {
  min-height: 96px;
  resize: vertical;
}

.chaping-form__input:focus,
.chaping-form__select:focus,
.chaping-form__textarea:focus {
  border-color: var(--ch-orange);
  box-shadow: var(--ch-focus);
}

.chaping-form__help {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--fg-subtle);
}

.chaping-form__checkbox,
.chaping-form__radio {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin-right: var(--s-3);
}

.chaping-form__submit,
#chaping-login-form .button,
#chaping-login-form input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  background: var(--ch-orange);
  color: var(--surface);
  cursor: pointer;
  text-decoration: none;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 13px;
  line-height: 1;
  padding: 10px 16px;
  transition: background var(--dur-fast) var(--ease-out),
    transform 80ms var(--ease-out);
}

.chaping-form__submit:hover,
#chaping-login-form .button:hover,
#chaping-login-form input[type="submit"]:hover {
  background: var(--ch-orange-press);
}

.chaping-form__submit:active,
#chaping-login-form .button:active,
#chaping-login-form input[type="submit"]:active {
  transform: scale(.985);
}

.chaping-form--submit-left .chaping-form__submit {
  margin-right: auto;
}

.chaping-form--submit-center .chaping-form__submit {
  margin-left: auto;
  margin-right: auto;
}

.chaping-form--submit-right .chaping-form__submit {
  margin-left: auto;
}

.chaping-form__message {
  margin: 0 0 var(--s-3);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  background: var(--surface-2);
  padding: var(--s-3) var(--s-4);
  color: var(--fg);
}

.chaping-form__message--success {
  border-color: var(--success);
  background: var(--success-wash);
  color: var(--success);
}

.chaping-form__message--error {
  border-color: var(--danger);
  background: var(--danger-wash);
  color: var(--danger);
}

.chaping-form__resend {
  margin-bottom: var(--s-4);
  padding: var(--s-3);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: var(--surface-2);
}

.chaping-form__resend-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  align-items: flex-end;
}

.chaping-form__resend-form .chaping-form__input {
  min-width: 220px;
  flex: 1;
}

#chaping-login-form p {
  margin: 0 0 var(--s-3);
}

#chaping-login-form label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
}

#chaping-login-form input[type="text"],
#chaping-login-form input[type="password"],
#chaping-login-form input[type="email"] {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.4;
}

#chaping-login-form input[type="text"]:focus,
#chaping-login-form input[type="password"]:focus,
#chaping-login-form input[type="email"]:focus {
  border-color: var(--ch-orange);
  box-shadow: var(--ch-focus);
  outline: none;
}

.chaping-dashboard-filter-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  align-items: flex-end;
  margin: 0 0 var(--s-3);
}

.chaping-dashboard-field-inline {
  margin-right: var(--s-2);
}

.chaping-dashboard-field-inline .chaping-input,
.chaping-dashboard-field-inline .chaping-select {
  margin-top: 6px;
  min-width: 180px;
}

.chaping-dashboard__section {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  box-shadow: var(--shadow-1);
}

.chaping-dashboard__section h2 {
  margin: 0 0 var(--s-4);
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.3;
}

.chaping-dashboard__card {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-4);
  background: var(--surface-2);
  margin-bottom: var(--s-3);
}

.chaping-dashboard__nav {
  list-style: none;
  margin: 0;
  padding: 0;
}

.chaping-dashboard__nav-item {
  margin: 0;
}

.chaping-dashboard__nav-link {
  display: flex;
  align-items: center;
  padding: 9px 10px;
  border-radius: var(--r-sm);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  color: var(--fg);
  transition: background var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out);
}

.chaping-dashboard__nav-link:hover {
  background: var(--surface-sunken);
  color: var(--ink);
}

.chaping-dashboard__nav-link.is-active {
  background: var(--ch-orange-wash);
  color: var(--ch-orange-ink);
  font-weight: 600;
}

.chaping-tbl-wrap {
  margin-top: var(--s-3);
}

.chaping-empty-state {
  text-align: center;
  color: var(--fg-subtle);
  padding: var(--s-4) !important;
}

.chaping-tbl .cell-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.chaping-status-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: var(--r-pill);
  line-height: 1;
  border: 1px solid transparent;
  text-transform: lowercase;
}

.chaping-status-badge--pending,
.chaping-status-badge--draft,
.chaping-status-badge--suspended {
  background: var(--neutral-wash);
  color: var(--ink-2);
}

.chaping-status-badge--sent,
.chaping-status-badge--processing,
.chaping-status-badge--approved,
.chaping-status-badge--pending_email_verification {
  background: var(--info-wash);
  color: var(--info);
}

.chaping-status-badge--viewed,
.chaping-status-badge--refunded {
  background: var(--ch-orange-wash);
  color: var(--ch-orange-ink);
}

.chaping-status-badge--converted,
.chaping-status-badge--completed,
.chaping-status-badge--paid,
.chaping-status-badge--active {
  background: var(--success-wash);
  color: var(--success);
}

.chaping-status-badge--on-hold,
.chaping-status-badge--pending_approval,
.chaping-status-badge--reversed {
  background: var(--warning-wash);
  color: var(--warning);
}

.chaping-status-badge--expired,
.chaping-status-badge--cancelled,
.chaping-status-badge--failed {
  background: var(--danger-wash);
  color: var(--danger);
}

.chaping-status-badge--void {
  background: var(--ink);
  color: var(--surface);
}

.chaping-pos__layout {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--s-4);
}

.chaping-pos__catalog,
.chaping-pos__cart {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-4);
  background: var(--surface);
}

.chaping-pos__cart h3,
.chaping-pos__catalog h3 {
  margin: 0 0 var(--s-3);
  font-size: 16px;
  color: var(--ink);
}

.chaping-pos__cart p {
  margin: 0 0 var(--s-3);
}

.chaping-pos__hint {
  color: var(--fg-subtle);
}

.chaping-feedback-actions {
  margin-top: var(--s-2);
}

.chaping-pos__cart label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-2);
}

.chaping-pos__qty {
  width: 70px;
  min-width: 70px;
  padding: 6px 8px;
}

.chaping-pos__check {
  accent-color: var(--ch-orange);
}

@media (max-width: 900px) {
  .chaping-pos__layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .chaping-form {
    padding: var(--s-4);
  }

  .chaping-form__resend-form {
    flex-direction: column;
    align-items: stretch;
  }

  .chaping-dashboard-filter-form {
    flex-direction: column;
    align-items: stretch;
  }

  .chaping-dashboard-field-inline {
    margin-right: 0;
  }

  .chaping-tbl-wrap {
    overflow-x: auto;
  }
}

/* ---- Dashboard KPI row (Inicio + Pagos) --------------------------------- */
.chaping-kpi-row--dash {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
@media (max-width: 600px) { .chaping-kpi-row--dash { grid-template-columns: repeat(2, 1fr); } }

/* ---- Referral link box -------------------------------------------------- */
.chaping-referral-link-box {
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  margin-bottom: var(--s-4);
}
.chaping-referral-link-box__label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--fg-subtle);
  margin: 0 0 var(--s-2);
}
.chaping-referral-link-box__row {
  display: flex;
  gap: var(--s-2);
  align-items: center;
  flex-wrap: wrap;
}
.chaping-referral-link-box__input {
  flex: 1;
  min-width: 0;
  font-family: var(--font-mono);
  font-size: 12px;
}

/* ---- Quick links under Inicio ------------------------------------------ */
.chaping-dashboard__quick-links {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
  margin-top: var(--s-3);
}

/* ---- Mi Cuenta form ------------------------------------------------------ */
.chaping-mi-cuenta-form {
  max-width: 640px;
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.chaping-fieldset {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.chaping-fieldset__legend {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  padding: 0 var(--s-2);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.chaping-fieldset__hint {
  font-size: 12px;
  color: var(--fg-muted);
  margin: 0;
}
.chaping-form-row--two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
}
@media (max-width: 480px) { .chaping-form-row--two { grid-template-columns: 1fr; } }
.chaping-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
}
.chaping-mi-cuenta-readonly {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
}
.chaping-mi-cuenta-readonly code {
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 4px 8px;
  color: var(--ink);
}

/* ---- Copy-to-clipboard button feedback ---------------------------------- */
.chaping-copy-btn.chaping-copy-btn--copied {
  background: var(--success-wash);
  border-color: #B6DFC1;
  color: #0F7A37;
}
