/* ──────────────────────────────────────────────────────────────────────────
   Habito Diario — Streak + Questao do dia (estilo Dossie, mobile-first).
   Tom equilibrado: sinais claros, sem exageros. Acentos da forca via var(--c).
   ────────────────────────────────────────────────────────────────────────── */

/* ===== Streak card ===== */
.streakc {
  margin: 14px 18px 0; border: 1px solid var(--line-2); border-radius: 16px;
  background: var(--card); padding: 16px; box-shadow: 0 3px 12px rgba(26, 29, 34, .05);
}
.streakc .top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.streakc .lead { display: flex; align-items: center; gap: 13px; }
.streakc .flame {
  width: 48px; height: 48px; border-radius: 14px; flex: 0 0 auto;
  background: linear-gradient(160deg, #FBEBCB, #F1D6A2); color: var(--wine);
  border: 1px solid var(--gold); display: flex; align-items: center; justify-content: center;
}
.streakc .flame svg { width: 27px; height: 27px; }
.streakc.zero .flame { background: var(--paper-2); color: var(--ink-3); border-color: var(--line-2); }
.streakc .big { line-height: 1; }
.streakc .big b { font-family: var(--font-display); font-size: 40px; font-weight: 400; color: var(--ink); }
.streakc .big span { display: block; font-size: 12.5px; color: var(--ink-2); margin-top: 2px; }
.streakc .rec {
  text-align: right; flex: 0 0 auto; padding-top: 2px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3);
}
.streakc .rec b { display: block; font-size: 16px; color: var(--ink); letter-spacing: 0; margin-top: 3px; }

.streakc .marco { margin-top: 15px; }
.streakc .marco .pb { height: 7px; background: var(--paper-2); border: 1px solid var(--line-2); border-radius: 99px; overflow: hidden; }
.streakc .marco .pb i { display: block; height: 100%; width: 0; background: linear-gradient(90deg, var(--gold), #E2B65C); transition: width .6s var(--ease); }
.streakc .marco .lbl { display: flex; justify-content: space-between; margin-top: 8px; font-family: var(--font-mono); font-size: 10px; color: var(--ink-3); }

.streakc .foot {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--line);
}
.streakc .today { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--ink-2); min-width: 0; }
.streakc .today .ck {
  width: 21px; height: 21px; border-radius: 7px; flex: 0 0 auto;
  background: var(--paper-2); border: 1px solid var(--line-2); color: var(--ink-3);
  display: flex; align-items: center; justify-content: center;
}
.streakc .today .ck svg { width: 13px; height: 13px; }
.streakc .today.done .ck { background: var(--c); border-color: var(--ink); color: var(--c-on); }
.streakc .actions { display: flex; align-items: center; gap: 9px; flex: 0 0 auto; }
.streakc .gelo {
  display: inline-flex; align-items: center; gap: 5px; white-space: nowrap;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .03em;
  color: var(--c-deep); background: var(--c-soft); border: 1px solid var(--c-line); border-radius: 99px; padding: 4px 9px;
}
.streakc .gelo svg { width: 12px; height: 12px; }
.streakc .gelo.off { color: var(--ink-3); background: var(--paper-2); border-color: var(--line-2); }
.streakc .cal-link {
  display: inline-flex; align-items: center; gap: 4px; flex: 0 0 auto;
  font-family: var(--font-mono); font-size: 10px; color: var(--c);
}
.streakc .cal-link.locked { color: var(--ink-3); }
.streakc .cal-link svg { width: 13px; height: 13px; }

/* ===== Questao do dia ===== */
.qdia {
  margin: 14px 18px 0; border: 1px solid var(--line-2); border-radius: 16px;
  background: var(--card); overflow: hidden; box-shadow: 0 3px 12px rgba(26, 29, 34, .05);
}
.qdia .qhead { display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%; padding: 13px 16px; text-align: left; }
.qdia .qhead-l { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.qdia .qhead-r { display: flex; align-items: center; gap: 9px; flex: 0 0 auto; }
.qdia .qhead .ey {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--gold); display: flex; align-items: center; gap: 7px;
}
.qdia .qhead .ey svg { width: 14px; height: 14px; }
.qdia .qhead .tag {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .05em; text-transform: uppercase;
  color: var(--c-deep); background: var(--c-soft); border: 1px solid var(--c-line); border-radius: 99px; padding: 3px 9px; white-space: nowrap;
}
/* chevron + subtitulo de estado (visivel so quando colapsado) */
.qdia .qchev { color: var(--ink-3); display: flex; }
.qdia .qchev svg { width: 18px; height: 18px; }
.qdia .qchev .cu { display: none; }
.qdia:not(.collapsed) .qchev .cd { display: none; }
.qdia:not(.collapsed) .qchev .cu { display: flex; }
.qdia .qsub { display: none; align-items: center; gap: 6px; font-size: 11.5px; line-height: 1.2; }
.qdia.collapsed .qsub { display: flex; }
.qdia .qsub svg { width: 13px; height: 13px; flex: 0 0 auto; }
.qdia .qsub.go { color: var(--c); }
.qdia .qsub.ok { color: #3F7D4E; }
.qdia .qsub.no { color: var(--wine); }
/* corpo: escondido quando colapsado; separador quando aberto */
.qdia.collapsed .qbody { display: none; }
.qdia .qbody { padding: 0 16px 16px; }
.qdia:not(.collapsed) .qbody { border-top: 1px solid var(--line); margin: 0 16px; padding: 14px 0 16px; }
.qdia .qtext { font-family: var(--font-display); font-weight: 400; font-size: 19.5px; line-height: 1.28; color: var(--ink); margin: 0 0 14px; }
.qdia .qimg { display: block; width: 100%; border-radius: 11px; border: 1px solid var(--line-2); margin: 0 0 13px; }
.qdia .opts { display: flex; flex-direction: column; gap: 8px; }
.qdia .opt {
  display: flex; align-items: center; gap: 11px; width: 100%; text-align: left;
  padding: 12px 13px; border: 1px solid var(--line-2); border-radius: 12px; background: var(--paper);
  font-size: 14px; color: var(--ink); transition: border-color .15s, background .15s; line-height: 1.3;
}
.qdia .opt .mk {
  width: 25px; height: 25px; border-radius: 7px; flex: 0 0 auto;
  border: 1px solid var(--line-2); background: var(--card); color: var(--ink-3);
  display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 11px;
}
.qdia .opt .mk svg { width: 14px; height: 14px; }
.qdia .opt:active { background: var(--paper-2); }
.qdia .opt.correct { border-color: #3F7D4E; background: #EAF3EC; }
.qdia .opt.correct .mk { background: #3F7D4E; border-color: #3F7D4E; color: #fff; }
.qdia .opt.wrong { border-color: var(--wine); background: #F6EAEA; }
.qdia .opt.wrong .mk { background: var(--wine); border-color: var(--wine); color: #fff; }
.qdia .opt.dim { opacity: .5; }
.qdia .result { display: flex; align-items: center; gap: 9px; margin-top: 14px; font-size: 13.5px; font-weight: 600; }
.qdia .result svg { width: 18px; height: 18px; flex: 0 0 auto; }
.qdia .result.ok { color: #3F7D4E; }
.qdia .result.no { color: var(--wine); }
.qdia .qcta {
  display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 13px;
  padding: 12px; border-radius: 12px; background: var(--c); color: var(--c-on); font-weight: 600; font-size: 14px;
}
.qdia .qcta svg { width: 18px; height: 18px; }
.qdia .done-note { text-align: center; font-size: 12px; color: var(--ink-3); margin-top: 13px; }
.qdia .skel { height: 17px; border-radius: 6px; background: linear-gradient(90deg, var(--paper-2), var(--line) 40%, var(--paper-2) 80%); background-size: 200% 100%; animation: qsk 1.3s linear infinite; }
@keyframes qsk { to { background-position: -200% 0; } }

/* ===== Heatmap (Premium) — folha inferior ===== */
.hm-back {
  position: fixed; inset: 0; background: rgba(20, 20, 22, .5); z-index: 6000;
  opacity: 0; pointer-events: none; transition: opacity .25s;
  display: flex; align-items: flex-end; justify-content: center;
}
.hm-back.show { opacity: 1; pointer-events: auto; }
.hm-sheet {
  width: 100%; max-width: 480px; background: var(--paper); border-radius: 20px 20px 0 0;
  padding: 18px 18px calc(env(safe-area-inset-bottom, 0px) + 22px);
  transform: translateY(100%); transition: transform .32s var(--snap); max-height: 86vh; overflow: auto;
}
.hm-back.show .hm-sheet { transform: none; }
.hm-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.hm-head h3 { font-family: var(--font-display); font-weight: 400; font-size: 22px; margin: 0; }
.hm-x { width: 34px; height: 34px; border-radius: 9px; background: var(--card); border: 1px solid var(--line-2); color: var(--ink-3); display: flex; align-items: center; justify-content: center; }
.hm-x svg { width: 18px; height: 18px; }
.hm-stats { display: flex; gap: 22px; margin: 12px 0 16px; }
.hm-stats .s b { font-family: var(--font-mono); font-size: 21px; font-weight: 600; color: var(--ink); }
.hm-stats .s span { display: block; font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--ink-3); margin-top: 3px; }
.hm-grid { display: flex; gap: 4px; }
.hm-col { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.hm-cell { aspect-ratio: 1; border-radius: 4px; background: var(--paper-2); border: 1px solid var(--line-2); }
.hm-cell.l1 { background: var(--c-soft); border-color: var(--c-line); }
.hm-cell.l2 { background: var(--c); border-color: var(--c-deep); }
.hm-cell.empty { background: transparent; border-color: transparent; }
.hm-legend { display: flex; align-items: center; gap: 6px; justify-content: flex-end; margin-top: 13px; font-family: var(--font-mono); font-size: 9px; color: var(--ink-3); }
.hm-legend i { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.hm-legend i.l0 { background: var(--paper-2); border: 1px solid var(--line-2); }
.hm-legend i.l1 { background: var(--c-soft); border: 1px solid var(--c-line); }
.hm-legend i.l2 { background: var(--c); }

/* ===== Toast de marco (celebracao pontual) ===== */
.eqe-toast {
  position: fixed; left: 50%; bottom: calc(var(--bottom-nav-h, 76px) + 16px);
  transform: translateX(-50%) translateY(20px); z-index: 7000; max-width: 90vw;
  background: var(--ink); color: var(--paper); padding: 12px 18px; border-radius: 13px;
  font-size: 13.5px; font-weight: 600; box-shadow: 0 8px 30px rgba(0, 0, 0, .28);
  opacity: 0; transition: opacity .3s, transform .35s var(--snap); display: flex; align-items: center; gap: 9px;
}
.eqe-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.eqe-toast svg { width: 19px; height: 19px; color: var(--gold); flex: 0 0 auto; }
