/* ================================================================
   PLANO 30 DIAS — Estilos específicos
   ================================================================ */

/* ── Barra de progresso ── */
.progresso-bar-wrap {
  margin-top: 2.5rem;
  max-width: 480px;
}
.progresso-bar-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 0.6rem;
}
.progresso-bar-label span:last-child {
  color: var(--gold);
  font-family: var(--font-serif);
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
}
.progresso-bar-bg {
  height: 3px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
  overflow: hidden;
}
.progresso-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold));
  border-radius: 2px;
  width: 0%;
  transition: width 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── Cabeçalho de semana ── */
.semana-header {
  margin-bottom: 2.5rem;
}
.semana-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #080808;
  background: var(--gold);
  padding: 0.22rem 0.75rem;
  margin-bottom: 0.9rem;
}
.semana-badge.s2 { background: var(--blue); }
.semana-badge.s3 { background: var(--green); }
.semana-badge.s4 { background: var(--amber); }

.semana-titulo {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 300;
  color: var(--text-1);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}
.semana-foco {
  font-size: 0.88rem;
  color: var(--text-3);
  font-style: italic;
}

/* ── Grid de dias ── */
.dias-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.25rem;
}

.dia-card {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.05);
  overflow: hidden;
  transition: border-color 0.25s var(--ease);
}
.dia-card:hover {
  border-color: var(--gold-line);
}

.dia-num {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  background: rgba(201,168,76,0.04);
}

.task-list {
  padding: 0.85rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.task-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  cursor: pointer;
  transition: opacity 0.2s;
}
.task-item:hover { opacity: 0.85; }

.task-item input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 1px solid rgba(255,255,255,0.15);
  background: transparent;
  flex-shrink: 0;
  margin-top: 2px;
  cursor: pointer;
  position: relative;
  transition: border-color 0.2s, background 0.2s;
}
.task-item input[type="checkbox"]:checked {
  background: var(--gold);
  border-color: var(--gold);
}
.task-item input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 4px;
  width: 5px;
  height: 8px;
  border: 2px solid #080808;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}
.task-item:hover input[type="checkbox"]:not(:checked) {
  border-color: var(--gold-dim);
}

.task-item span {
  font-size: 0.86rem;
  color: var(--text-2);
  line-height: 1.55;
}
.task-item.checked span {
  text-decoration: line-through;
  color: var(--text-3);
  opacity: 0.6;
}

/* ── Filtros de ideias ── */
.ideias-filter {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.filter-btn {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  background: transparent;
  border: 1px solid rgba(255,255,255,0.08);
  padding: 0.4rem 1rem;
  cursor: pointer;
  transition: all 0.2s var(--ease);
  border-radius: var(--radius);
}
.filter-btn:hover {
  color: var(--text-1);
  border-color: rgba(255,255,255,0.2);
}
.filter-btn.active {
  color: #080808;
  background: var(--gold);
  border-color: var(--gold);
}

/* ── Grid de ideias ── */
.ideias-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.25rem;
}
.ideia-card {
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,0.05);
  padding: 1.5rem;
  transition: all 0.25s var(--ease);
}
.ideia-card:hover {
  border-color: var(--gold-line);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.ideia-tipo {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.18rem 0.55rem;
  margin-bottom: 0.85rem;
  width: fit-content;
  border-radius: 1px;
}
.ideia-tipo.emocional  { color: var(--red);   background: var(--red-dim);   border: 1px solid var(--red-line); }
.ideia-tipo.ensinamento{ color: var(--blue);  background: var(--blue-dim);  border: 1px solid var(--blue-line); }
.ideia-tipo.historia   { color: var(--amber); background: var(--amber-dim); border: 1px solid var(--amber-line); }
.ideia-tipo.fe         { color: var(--gold);  background: var(--gold-ghost);border: 1px solid var(--gold-line); }

.ideia-card h4 {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 0.5rem;
  line-height: 1.3;
}
.ideia-card p {
  color: var(--text-2);
  font-size: 0.84rem;
  line-height: 1.7;
}

/* ── Rotina semanal ── */
.rotina-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1px;
  background: var(--gold-line);
  border: 1px solid var(--gold-line);
}
.rotina-dia {
  background: var(--bg-alt);
  overflow: hidden;
  transition: background 0.2s;
}
.rotina-dia:hover { background: var(--bg-hover); }
.rotina-label {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #080808;
  background: var(--gold);
  padding: 0.4rem 1.25rem;
}
.rotina-content {
  padding: 1.5rem 1.25rem;
}
.rotina-content h4 {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 0.5rem;
}
.rotina-content p {
  color: var(--text-2);
  font-size: 0.85rem;
  line-height: 1.7;
}

/* ── Responsivo ── */
@media (max-width: 640px) {
  .dias-grid { grid-template-columns: 1fr; }
  .ideias-grid { grid-template-columns: 1fr; }
  .rotina-grid { grid-template-columns: 1fr; gap: 0; }
  .ideias-filter { gap: 0.35rem; }
}
