/* Calendario Lunar */
.cl-app { max-width: 680px; margin: 0 auto; }

.cl-nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.cl-nav-btn {
  background: #2c2348; border: 1px solid #5a4790; color: #e8cf86;
  border-radius: 8px; padding: .4rem .9rem; cursor: pointer; font-size: 1.1rem; line-height: 1;
}
.cl-nav-btn:hover { background: #3a2c5a; }
.cl-month-title { margin: 0; color: #e8cf86; text-transform: capitalize; text-align: center; flex: 1; }

.cl-loader { text-align: center; padding: 1.5rem 0; }
.cl-spinner { display: inline-block; width: 28px; height: 28px; border-radius: 50%; border: 3px solid #4a3a7a; border-top-color: #e8cf86; animation: cl-spin .8s linear infinite; }
@keyframes cl-spin { to { transform: rotate(360deg); } }

/* Today panel */
.cl-today {
  display: flex; align-items: center; gap: 1rem;
  background: linear-gradient(160deg, #241b3c, #1a1530);
  border: 1px solid #4a3a7a; border-radius: 14px; padding: 1rem 1.2rem; margin-bottom: 1.2rem;
}
.cl-today-emoji { font-size: 2.8rem; line-height: 1; }
.cl-today-info { display: flex; flex-direction: column; gap: .1rem; }
.cl-today-label { font-size: .8rem; color: #b9a8e0; text-transform: uppercase; letter-spacing: .05em; }
.cl-today-phase { font-weight: 700; font-size: 1.15rem; color: #f4eede; }
.cl-today-illum { font-size: .9rem; color: #d9c9ff; }
.cl-today-desc { margin: .3rem 0 0; font-size: .9rem; color: #e7ddf5; line-height: 1.5; }

/* Weekday header + grid */
.cl-weekdays, .cl-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: .4rem; }
.cl-weekdays { margin-bottom: .4rem; }
.cl-wd { text-align: center; font-size: .78rem; color: #b9a8e0; font-weight: 600; text-transform: uppercase; }
.cl-cell {
  display: flex; flex-direction: column; align-items: center; gap: .1rem;
  background: linear-gradient(160deg, #1f1836, #161126);
  border: 1px solid #3a2c5a; border-radius: 10px; padding: .45rem .2rem .35rem; min-height: 64px;
}
.cl-blank { background: none; border: none; }
.cl-day { font-size: .8rem; color: #b9a8e0; }
.cl-moon { font-size: 1.5rem; line-height: 1; }
.cl-illum { font-size: .68rem; color: #8a7ad0; }
.cl-cell.is-today { border-color: #e8cf86; box-shadow: 0 0 0 2px #e8cf86; }
.cl-cell.is-today .cl-day { color: #e8cf86; font-weight: 700; }

/* Principal phases */
.cl-principals { margin-top: 1.4rem; }
.cl-princ-title { color: #e8cf86; font-size: 1rem; margin: 0 0 .6rem; text-transform: capitalize; }
.cl-princ-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem; }
.cl-princ-list li {
  display: flex; align-items: center; gap: .5rem;
  background: rgba(255,255,255,0.03); border: 1px solid #3a2c5a; border-radius: 8px; padding: .5rem .7rem;
}
.cl-princ-emoji { font-size: 1.3rem; }
.cl-princ-name { flex: 1; color: #e7ddf5; font-size: .9rem; }
.cl-princ-day { font-weight: 700; color: #e8cf86; }

.cl-error { margin-top: 1rem; color: #ff8a8a; text-align: center; }

@media (max-width: 520px) {
  .cl-cell { min-height: 54px; padding: .35rem .1rem; }
  .cl-moon { font-size: 1.25rem; }
  .cl-illum { font-size: .6rem; }
  .cl-princ-list { grid-template-columns: 1fr; }
}
