/* Ascendente */
.asc-app { max-width: 620px; margin: 0 auto; }

.asc-form {
  background: linear-gradient(160deg, #241b3c, #1a1530);
  border: 1px solid #4a3a7a; border-radius: 16px; padding: 1.6rem 1.4rem;
}
.asc-field { margin-bottom: 1.1rem; }
.asc-label { display: block; font-weight: 600; color: #d9c9ff; margin-bottom: .5rem; }
.asc-row { display: flex; gap: .7rem; flex-wrap: wrap; }
.asc-select {
  appearance: none; flex: 1 1 120px;
  background: #15101f url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23e8cf86' d='M1 1l5 5 5-5'/%3E%3C/svg%3E") no-repeat right .9rem center;
  color: #f4eede; border: 1px solid #5a4790; border-radius: 10px;
  padding: .65rem 2.1rem .65rem .9rem; font-size: 1rem; cursor: pointer;
}
.asc-select:focus { outline: 2px solid #e8cf86; outline-offset: 1px; }
.asc-hint { font-size: .8rem; color: #b9a8e0; margin: .5rem 0 0; }
.asc-calc { width: 100%; margin-top: .3rem; }

.asc-result {
  margin-top: 1.6rem;
  background: linear-gradient(160deg, #1f1836, #161126);
  border: 1px solid #4a3a7a; border-radius: 16px; padding: 1.8rem 1.4rem; text-align: center;
}
.asc-cards { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.asc-card {
  flex: 1 1 180px; max-width: 240px;
  background: rgba(255,255,255,0.03); border: 1px solid #3a2c5a; border-radius: 14px; padding: 1.1rem .8rem;
  display: flex; flex-direction: column; align-items: center; gap: .25rem;
}
.asc-card-asc { border-color: #e8cf86; box-shadow: 0 0 0 1px #e8cf86 inset; }
.asc-card-label { font-size: .78rem; text-transform: uppercase; letter-spacing: .05em; color: #b9a8e0; }
.asc-emoji { font-size: 2.6rem; line-height: 1; color: #e8cf86; }
.asc-sign { font-weight: 700; font-size: 1.15rem; color: #f4eede; }
.asc-desc {
  margin-top: 1.3rem; line-height: 1.6; color: #e7ddf5;
  background: rgba(232,207,134,0.06); border-left: 3px solid #e8cf86; border-radius: 8px; padding: 1rem 1.1rem; text-align: left;
}
.asc-restart { margin-top: 1.3rem; }
.asc-error { margin-top: 1rem; color: #ff8a8a; text-align: center; }
.asc-note { margin-top: 1rem; font-size: .8rem; color: #8a7ad0; text-align: center; }
