/* Mini Carta Natal */
.cn-app { max-width: 680px; margin: 0 auto; }

.cn-form {
  background: linear-gradient(160deg, #241b3c, #1a1530);
  border: 1px solid #4a3a7a; border-radius: 16px; padding: 1.6rem 1.4rem;
}
.cn-field { margin-bottom: 1.1rem; }
.cn-label { display: block; font-weight: 600; color: #d9c9ff; margin-bottom: .5rem; }
.cn-row { display: flex; gap: .7rem; flex-wrap: wrap; }
.cn-select {
  appearance: none; flex: 1 1 90px;
  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 .8rem center;
  color: #f4eede; border: 1px solid #5a4790; border-radius: 10px;
  padding: .65rem 2rem .65rem .85rem; font-size: 1rem; cursor: pointer;
}
.cn-select:focus { outline: 2px solid #e8cf86; outline-offset: 1px; }
.cn-hint { font-size: .8rem; color: #b9a8e0; margin: .5rem 0 0; }
.cn-calc { width: 100%; margin-top: .3rem; }

.cn-result {
  margin-top: 1.6rem;
  background: linear-gradient(160deg, #1f1836, #161126);
  border: 1px solid #4a3a7a; border-radius: 16px; padding: 1.6rem 1.4rem;
}
.cn-luminaries { display: flex; flex-direction: column; gap: 1rem; }
.cn-lum {
  display: grid; grid-template-columns: auto 1fr; grid-template-areas: "sign head" "sign desc";
  gap: .2rem 1rem; align-items: center;
  background: rgba(255,255,255,0.03); border: 1px solid #3a2c5a; border-radius: 14px; padding: 1.1rem 1.2rem;
}
.cn-lum-sun { border-left: 4px solid #ffcf5a; }
.cn-lum-moon { border-left: 4px solid #9fb6ff; }
.cn-lum-asc { border-left: 4px solid #e8cf86; }
.cn-lum-sign { grid-area: sign; display: flex; flex-direction: column; align-items: center; gap: .15rem; min-width: 78px; }
.cn-lum-emoji { font-size: 2.4rem; line-height: 1; color: #e8cf86; }
.cn-lum-name { font-weight: 700; font-size: .95rem; color: #f4eede; }
.cn-lum-head { grid-area: head; display: flex; flex-direction: column; align-self: end; }
.cn-lum-title { font-weight: 700; color: #e8cf86; font-size: 1.05rem; }
.cn-lum-meaning { font-size: .8rem; color: #b9a8e0; text-transform: uppercase; letter-spacing: .03em; }
.cn-lum-desc { grid-area: desc; margin: 0; align-self: start; line-height: 1.55; color: #e7ddf5; font-size: .95rem; }

.cn-restart { margin-top: 1.3rem; }
.cn-error { margin-top: 1rem; color: #ff8a8a; text-align: center; }
.cn-note { margin-top: 1rem; font-size: .8rem; color: #8a7ad0; text-align: center; }

@media (max-width: 460px) {
  .cn-lum { grid-template-columns: 1fr; grid-template-areas: "sign" "head" "desc"; justify-items: center; text-align: center; gap: .5rem; }
  .cn-lum-head { align-items: center; }
}
