/* ==========================================================================
   My Account — Área do Cliente
   Agência Upgrade — https://agenciaupgrade.com.br
   ========================================================================== */

@layer components {

/* ── Layout: aside + conteúdo ── */

.cnp-myaccount {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cnp-space-xl);
  padding-block: var(--cnp-space-2xl);
  align-items: start;
  container-type: inline-size;
}

@container (min-width: 56rem) {
  .cnp-myaccount {
    grid-template-columns: 22rem 1fr;
  }
}

/* ── Sidebar ── */

.cnp-myaccount__sidebar {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--cnp-color-border);
  border-radius: var(--cnp-radius-m);
  overflow: hidden;
}

@container (min-width: 56rem) {
  .cnp-myaccount__sidebar {
    position: sticky;
    inset-block-start: calc(var(--cnp-header-height, 7rem) + var(--cnp-space-m));
  }
}

/* Greeting */

.cnp-myaccount__greeting {
  display: flex;
  align-items: center;
  gap: var(--cnp-space-s);
  padding: var(--cnp-space-m) var(--cnp-space-l);
  background-color: var(--cnp-color-primary);
  color: #fff;
}

.cnp-myaccount__greeting .cnp-ms {
  font-size: 3.2rem;
  opacity: 0.9;
  flex-shrink: 0;
}

.cnp-myaccount__greeting-info {
  display: flex;
  flex-direction: column;
  gap: var(--cnp-space-3xs);
  min-inline-size: 0;
}

.cnp-myaccount__greeting-name {
  font-size: var(--cnp-font-size-base);
  font-weight: var(--cnp-font-weight-bold);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cnp-myaccount__greeting-email {
  font-size: var(--cnp-font-size-xs);
  opacity: 0.85;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Nav links */

.cnp-myaccount__nav {
  display: flex;
  flex-direction: column;
}

.cnp-myaccount__nav-link {
  display: flex;
  align-items: center;
  gap: var(--cnp-space-s);
  padding-block: var(--cnp-space-m);
  padding-inline: var(--cnp-space-l);
  color: var(--cnp-color-text);
  text-decoration: none;
  font-size: var(--cnp-font-size-base);
  border-block-end: 1px solid var(--cnp-color-border);
  border-inline-start: 3px solid transparent;
  transition:
    background-color var(--cnp-transition-fast),
    color var(--cnp-transition-fast),
    border-color var(--cnp-transition-fast);
}

.cnp-myaccount__nav-link:last-child {
  border-block-end: none;
}

.cnp-myaccount__nav-link:hover {
  background-color: var(--cnp-color-background-alt);
  color: var(--cnp-color-primary);
}

.cnp-myaccount__nav-link--active {
  background-color: var(--cnp-color-background-alt);
  color: var(--cnp-color-primary);
  font-weight: var(--cnp-font-weight-bold);
  border-inline-start-color: var(--cnp-color-primary);
}

.cnp-myaccount__nav-link--admin {
  color: var(--cnp-color-text-muted);
  font-size: var(--cnp-font-size-sm);
}

.cnp-myaccount__nav-link--logout {
  color: var(--cnp-color-danger);
}

.cnp-myaccount__nav-link--logout:hover {
  color: var(--cnp-color-danger);
  background-color: rgb(220 53 69 / 0.08);
}

/* ── Conteúdo ── */

.cnp-myaccount__content {
  min-inline-size: 0;
}

/* Section header */

.cnp-myaccount__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cnp-space-m);
  margin-block-end: var(--cnp-space-xl);
  padding-block-end: var(--cnp-space-m);
  border-block-end: 1px solid var(--cnp-color-border);
}

.cnp-myaccount__section-title {
  font-size: var(--cnp-font-size-xl);
  font-weight: var(--cnp-font-weight-bold);
  color: var(--cnp-color-text);
  margin: 0;
}

/* ── Badges ── */

.cnp-myaccount__account-badge {
  margin-block-end: var(--cnp-space-l);
}

.cnp-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--cnp-space-2xs);
  padding-block: var(--cnp-space-2xs);
  padding-inline: var(--cnp-space-s);
  border-radius: var(--cnp-radius-full, 99rem);
  font-size: var(--cnp-font-size-sm);
  font-weight: var(--cnp-font-weight-medium);
}

.cnp-badge--primary {
  background-color: var(--cnp-color-primary-tint);
  color: var(--cnp-color-primary-dark);
}

.cnp-badge--secondary {
  background-color: var(--cnp-color-background-alt);
  color: var(--cnp-color-text-muted);
}

/* ── Grid de dados de billing ── */

.cnp-myaccount__billing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cnp-space-l);
  margin-block-end: var(--cnp-space-2xl);
}

@container (min-width: 40rem) {
  .cnp-myaccount__billing-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--cnp-space-m) var(--cnp-space-xl);
  }
}

.cnp-myaccount__billing-item {
  display: flex;
  flex-direction: column;
  gap: var(--cnp-space-3xs);
}

.cnp-myaccount__billing-item--full {
  grid-column: 1 / -1;
}

.cnp-myaccount__billing-label {
  font-size: var(--cnp-font-size-xs);
  font-weight: var(--cnp-font-weight-medium);
  color: var(--cnp-color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.cnp-myaccount__billing-value {
  font-size: var(--cnp-font-size-base);
  color: var(--cnp-color-text);
  line-height: 1.5;
}

/* ── Accordion de senha ── */

.cnp-myaccount__accordion {
  border: 1px solid var(--cnp-color-border);
  border-radius: var(--cnp-radius-s);
}

.cnp-myaccount__accordion-trigger {
  display: flex;
  align-items: center;
  gap: var(--cnp-space-s);
  padding: var(--cnp-space-m) var(--cnp-space-l);
  cursor: pointer;
  font-size: var(--cnp-font-size-base);
  font-weight: var(--cnp-font-weight-medium);
  color: var(--cnp-color-text);
  -webkit-user-select: none;
  user-select: none;
  list-style: none;
}

.cnp-myaccount__accordion-trigger::-webkit-details-marker {
  display: none;
}

.cnp-myaccount__accordion-chevron {
  margin-inline-start: auto;
  transition: rotate var(--cnp-transition-fast);
}

.cnp-myaccount__accordion[open] .cnp-myaccount__accordion-chevron {
  rotate: 180deg;
}

.cnp-myaccount__accordion-content {
  padding: var(--cnp-space-l);
  border-block-start: 1px solid var(--cnp-color-border);
}

.cnp-myaccount__password-form {
  display: flex;
  flex-direction: column;
  max-inline-size: 44rem;
}

/* ── Tabela de pedidos ── */

.cnp-myaccount__table-wrap {
  overflow-x: auto;
}

.cnp-myaccount__orders-table {
  inline-size: 100%;
  border-collapse: collapse;
  font-size: var(--cnp-font-size-base);
}

.cnp-myaccount__orders-table th,
.cnp-myaccount__orders-table td {
  padding-block: var(--cnp-space-m);
  padding-inline: var(--cnp-space-m);
  border-block-end: 1px solid var(--cnp-color-border);
  text-align: start;
  white-space: nowrap;
}

.cnp-myaccount__orders-table th {
  font-size: var(--cnp-font-size-xs);
  font-weight: var(--cnp-font-weight-medium);
  color: var(--cnp-color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.cnp-myaccount__order-row:last-child td {
  border-block-end: none;
}

.cnp-myaccount__order-link {
  font-weight: var(--cnp-font-weight-bold);
  color: var(--cnp-color-primary);
  text-decoration: none;
}

.cnp-myaccount__order-link:hover {
  text-decoration: underline;
}

.cnp-myaccount__order-total {
  font-weight: var(--cnp-font-weight-bold);
}

/* ── Status badges de pedido ── */

.cnp-order-status {
  display: inline-block;
  padding-block: var(--cnp-space-3xs);
  padding-inline: var(--cnp-space-xs);
  border-radius: var(--cnp-radius-full, 99rem);
  font-size: var(--cnp-font-size-xs);
  font-weight: var(--cnp-font-weight-medium);
  background-color: var(--cnp-color-background-alt);
  color: var(--cnp-color-text-muted);
}

.cnp-order-status--processing,
.cnp-order-status--on-hold {
  background-color: rgb(245 158 11 / 0.15);
  color: #92400e;
}

.cnp-order-status--completed {
  background-color: rgb(40 167 69 / 0.15);
  color: #155724;
}

.cnp-order-status--cancelled,
.cnp-order-status--failed,
.cnp-order-status--refunded {
  background-color: rgb(220 53 69 / 0.12);
  color: #721c24;
}

.cnp-order-status--pending {
  background-color: var(--cnp-color-primary-tint);
  color: var(--cnp-color-primary-dark);
}

/* ── Estado vazio (sem pedidos) ── */

.cnp-myaccount__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cnp-space-m);
  padding-block: var(--cnp-space-2xl);
  text-align: center;
}

.cnp-myaccount__empty-icon {
  font-size: 4.8rem;
  color: var(--cnp-color-text-muted);
}

.cnp-myaccount__empty-text {
  font-size: var(--cnp-font-size-base);
  color: var(--cnp-color-text-muted);
  margin: 0;
}

/* ── Tela de login (usuário não autenticado) ── */

.cnp-login {
  display: flex;
  justify-content: center;
  padding-block: var(--cnp-space-2xl);
}

.cnp-login__card {
  inline-size: min(100%, 44rem);
  display: flex;
  flex-direction: column;
  gap: var(--cnp-space-xl);
}

.cnp-login__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cnp-space-xs);
  text-align: center;
}

.cnp-login__icon {
  font-size: 4.8rem;
  color: var(--cnp-color-primary);
}

.cnp-login__title {
  font-size: var(--cnp-font-size-xl);
  font-weight: var(--cnp-font-weight-bold);
  color: var(--cnp-color-text);
  margin: 0;
}

.cnp-login__subtitle {
  font-size: var(--cnp-font-size-sm);
  color: var(--cnp-color-text-muted);
  margin: 0;
}

.cnp-login__form {
  display: flex;
  flex-direction: column;
  gap: var(--cnp-space-m);
}

.cnp-login__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--cnp-space-m);
  flex-wrap: wrap;
}

.cnp-login__remember {
  display: flex;
  align-items: center;
  gap: var(--cnp-space-xs);
  font-size: var(--cnp-font-size-sm);
  color: var(--cnp-color-text);
  cursor: pointer;
}

.cnp-login__remember-check {
  accent-color: var(--cnp-color-primary);
  inline-size: 1.6rem;
  block-size: 1.6rem;
  flex-shrink: 0;
}

.cnp-login__lost-password {
  font-size: var(--cnp-font-size-sm);
  color: var(--cnp-color-primary);
  text-decoration: none;
  margin-inline-start: auto;
}

.cnp-login__lost-password:hover {
  text-decoration: underline;
}

/* ── Abas login / cadastro ── */

.cnp-login__tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--cnp-color-border);
  border-radius: var(--cnp-radius-s);
  overflow: hidden;
}

.cnp-login__tab {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--cnp-space-2xs);
  padding-block: var(--cnp-space-s);
  padding-inline: var(--cnp-space-m);
  font-size: var(--cnp-font-size-base);
  font-weight: var(--cnp-font-weight-medium);
  color: var(--cnp-color-text-muted);
  background: none;
  border: none;
  cursor: pointer;
  transition:
    background-color var(--cnp-transition-fast),
    color var(--cnp-transition-fast);
}

.cnp-login__tab:first-child {
  border-inline-end: 1px solid var(--cnp-color-border);
}

.cnp-login__tab:hover {
  background-color: var(--cnp-color-background-alt);
  color: var(--cnp-color-text);
}

.cnp-login__tab--active {
  background-color: var(--cnp-color-primary);
  color: #fff;
}

.cnp-login__tab--active:hover {
  background-color: var(--cnp-color-primary-dark);
  color: #fff;
}

/* ── Aviso de validação de cadastro ── */

.cnp-login__register-notice {
  display: flex;
  align-items: flex-start;
  gap: var(--cnp-space-xs);
  padding: var(--cnp-space-s) var(--cnp-space-m);
  background-color: var(--cnp-color-primary-tint);
  border-radius: var(--cnp-radius-s);
  font-size: var(--cnp-font-size-sm);
  color: var(--cnp-color-text-muted);
  margin: 0;
}

.cnp-login__register-notice .cnp-ms {
  flex-shrink: 0;
  font-size: 1.6rem;
  color: var(--cnp-color-primary);
  margin-block-start: 0.1rem;
}

} /* end @layer components */

@layer utilities {

  @media (prefers-reduced-motion: reduce) {
    .cnp-myaccount__accordion-chevron {
      transition: none;
    }
  }

}
