/* ═══════════════════════════════════════════════════════
   resumo.css — estilo compartilhado para todos os resumos
   Pasta: resumos/
════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Tokens de cor */
:root {
  --bg: #0F172A; --card: #1E293B; --card2: #162032;
  --border: #2D3F55; --border2: #243044;
  --text: #E2E8F0; --muted: #94A3B8;
  --green: #739E8D; --green-d: #5CC4B0;
  --blue: #4EAED9; --orange: #FF9481;
  --purple: #9B59B6; --gold: #E8B400;
  --red: #E25E42; --head: #93C5FD;
  --shadow: rgba(0,0,0,.5);
}
[data-theme="light"] {
  --bg: #F8F9FB; --card: #FFFFFF; --card2: #EEF1F6;
  --border: #D6DBE5; --border2: #E4E8F0;
  --text: #0D1117; --muted: #374151;
  --green: #4A8C78; --green-d: #2E7D6A;
  --blue: #1A7BB8; --orange: #C94C2E;
  --purple: #7B3FA8; --gold: #9A7300;
  --red: #C94C2E; --head: #0D1B2E;
  --shadow: rgba(0,0,0,.12);
}

html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; background: var(--bg); color: var(--text); line-height: 1.6; transition: background .3s, color .3s; }

/* NAV */
nav { position: sticky; top: 0; z-index: 200; background: color-mix(in srgb, var(--bg) 88%, transparent); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); padding: 0 20px; }
.nav-inner { max-width: 960px; margin: 0 auto; height: 58px; display: flex; align-items: center; justify-content: center; gap: 14px; }
.nav-logo { font-family: 'Lora', serif; font-size: 16px; font-weight: 700; color: var(--head); display: flex; align-items: center; gap: 8px; }
.nav-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 8px var(--blue); }.nav-links { display: flex; gap: 24px; list-style: none; }
.nav-links a { font-size: 13px; font-weight: 500; color: var(--muted); text-decoration: none; transition: color .2s; white-space: nowrap; }
.nav-links a:hover { color: var(--text); }
.theme-btn { width: 38px; height: 38px; border-radius: 50%; background: var(--card2); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 17px; cursor: pointer; transition: background .2s; flex-shrink: 0; }
.theme-btn:hover { background: var(--border); }
.zoom-btn { height: 32px; padding: 0 10px; border-radius: 8px; background: var(--card2); border: 1px solid var(--border); font-family: 'DM Mono', monospace; font-size: 12px; font-weight: 600; color: var(--muted); cursor: pointer; transition: background .2s, color .2s; flex-shrink: 0; line-height: 1; }
.zoom-btn:hover { background: var(--border); color: var(--text); }

/* Layout */
section { padding: 72px 20px; }
.container { max-width: 960px; margin: 0 auto; }
.divider { height: 1px; background: linear-gradient(90deg, transparent, var(--border), transparent); }

/* Labels */
.sec-label { font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--blue); margin-bottom: 10px; }
.sublabel { font-family: 'DM Mono', monospace; font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.sublabel.blue { color: var(--blue); }

.sec-title { font-family: 'Lora', serif; font-size: clamp(22px, 4vw, 32px); font-weight: 700; color: var(--head); line-height: 1.25; margin-bottom: 14px; }
.sec-desc { font-size: 16px; color: var(--muted); line-height: 1.8; max-width: 680px; }

@media (max-width: 760px) { .nav-links { display: none; } }
@media (max-width: 600px) { .nav-inner { padding: 0 12px; } }

/* Artigo badge */
.art-badge { display: inline-block; font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 1px; padding: 3px 10px; border-radius: 20px; background: rgba(78,174,217,.12); color: var(--blue); border: 1px solid rgba(78,174,217,.25); margin-bottom: 16px; }

/* Cards de ponto */
.points-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; margin-top: 28px; }
.point-card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 20px 18px; transition: border-color .2s, transform .2s; }
.point-card:hover { border-color: var(--blue); transform: translateY(-2px); }
.point-card.green:hover { border-color: var(--green-d); }
.point-card.gold:hover  { border-color: var(--gold); }
.point-card.red:hover   { border-color: var(--red); }
.point-card.purple:hover{ border-color: var(--purple); }
.point-title { font-size: 15px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.point-body  { font-size: 15px; color: var(--muted); line-height: 1.7; }

/* KV list */
.kv-list { display: flex; flex-direction: column; gap: 8px; margin-top: 20px; }
.kv { display: flex; align-items: flex-start; gap: 12px; padding: 12px 14px; background: var(--card); border: 1px solid var(--border); border-radius: 10px; }
.kv-key { font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; white-space: nowrap; padding: 2px 8px; border-radius: 6px; flex-shrink: 0; margin-top: 1px; }
.kv-key.blue   { background: rgba(78,174,217,.15);  color: var(--blue); }
.kv-key.green  { background: rgba(115,158,141,.15); color: var(--green-d); }
.kv-key.gold   { background: rgba(232,180,0,.15);   color: var(--gold); }
.kv-key.red    { background: rgba(226,94,66,.15);   color: var(--red); }
.kv-key.purple { background: rgba(155,89,182,.15);  color: var(--purple); }
.kv-val { font-size: 15px; color: var(--text); line-height: 1.7; }

/* Tabela de prazos */
.prazo-table { width: 100%; border-collapse: collapse; margin-top: 24px; }
.prazo-table th { font-family: 'DM Mono', monospace; font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); padding: 10px 14px; text-align: left; border-bottom: 2px solid var(--border); }
.prazo-table td { padding: 12px 14px; font-size: 14px; border-bottom: 1px solid var(--border2); }
.prazo-table tr:last-child td { border-bottom: none; }
.prazo-table tr:hover td { background: rgba(78,174,217,.04); }
.td-bold { font-weight: 600; color: var(--head); }
.td-num  { font-family: 'DM Mono', monospace; font-size: 15px; font-weight: 700; color: var(--blue); }
.td-green { color: var(--green-d); }
.td-gold  { color: var(--gold); }
.td-red   { color: var(--red); }

/* Alert boxes */
.alert-box { border-radius: 12px; padding: 16px 18px; margin-top: 16px; display: flex; gap: 14px; align-items: flex-start; }
.alert-box.red   { background: rgba(226,94,66,.08);  border: 1px solid rgba(226,94,66,.25); }
.alert-box.gold  { background: rgba(232,180,0,.08);  border: 1px solid rgba(232,180,0,.25); }
.alert-box.green { background: rgba(92,196,176,.08); border: 1px solid rgba(92,196,176,.25); }
.alert-box.blue  { background: rgba(78,174,217,.08); border: 1px solid rgba(78,174,217,.25); }
.alert-icon { font-size: 20px; flex-shrink: 0; }
.alert-content { flex: 1; }
.alert-title { font-size: 14px; font-weight: 600; margin-bottom: 5px; }
.alert-title.red   { color: var(--red); }
.alert-title.gold  { color: var(--gold); }
.alert-title.green { color: var(--green-d); }
.alert-title.blue  { color: var(--blue); }
.alert-body { font-size: 15px; color: var(--muted); line-height: 1.75; }

/* Princípios */
.princ-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; margin-top: 24px; }
.princ-item { background: var(--card2); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; display: flex; gap: 12px; align-items: flex-start; }
.princ-num { width: 28px; height: 28px; border-radius: 50%; background: rgba(78,174,217,.15); border: 1px solid rgba(78,174,217,.3); display: flex; align-items: center; justify-content: center; font-family: 'Lora', serif; font-size: 12px; font-weight: 700; color: var(--blue); flex-shrink: 0; }
.princ-text { font-size: 14px; line-height: 1.55; }
.princ-text strong { display: block; color: var(--text); font-weight: 600; margin-bottom: 3px; }
.princ-text span { color: var(--muted); font-size: 13px; }

/* Excecao box */
.excecao-block { background: var(--card2); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-top: 24px; }
.excecao-title { font-family: 'DM Mono', monospace; font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.excecao-item { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 10px; }
.excecao-item:last-child { margin-bottom: 0; }
.exc-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); flex-shrink: 0; margin-top: 6px; }
.exc-text { font-size: 15px; color: var(--text); line-height: 1.7; }
.exc-text span { color: var(--muted); }

/* Gabarito chips */
.gab-row  { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.gab-chip { background: var(--card2); border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; font-size: 12px; }
.gab-chip strong { color: var(--green-d); font-family: 'DM Mono', monospace; }
.gab-chip span   { color: var(--muted); }

/* Certo / Errado */
.ce-list { display: flex; flex-direction: column; gap: 8px; margin-top: 20px; }
.ce-item { display: flex; gap: 10px; align-items: flex-start; padding: 11px 14px; border-radius: 10px; }
.ce-item.certo  { background: rgba(92,196,176,.07); border: 1px solid rgba(92,196,176,.2); }
.ce-item.errado { background: rgba(226,94,66,.07);  border: 1px solid rgba(226,94,66,.2); }
.ce-badge { font-family: 'DM Mono', monospace; font-size: 9px; letter-spacing: 1px; padding: 2px 7px; border-radius: 5px; flex-shrink: 0; margin-top: 2px; }
.ce-item.certo  .ce-badge { background: rgba(92,196,176,.2);  color: var(--green-d); }
.ce-item.errado .ce-badge { background: rgba(226,94,66,.2);   color: var(--red); }
.ce-text { font-size: 15px; line-height: 1.7; }

/* Letra da Lei */
.lei-box { background: var(--card2); border: 1px solid var(--border); border-left: 4px solid var(--blue); border-radius: 0 12px 12px 0; padding: 22px 22px 22px 20px; margin-top: 24px; }
.lei-box.green { border-left-color: var(--green-d); }
.lei-box.gold  { border-left-color: var(--gold); }
.lei-label { font-family: 'DM Mono', monospace; font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blue); margin-bottom: 10px; }
.lei-label.green { color: var(--green-d); }
.lei-label.gold  { color: var(--gold); }
.lei-artigo { font-family: 'Lora', serif; font-size: 15px; font-weight: 400; color: var(--head); margin-bottom: 14px; line-height: 1.6; }
.lei-incisos { display: flex; flex-direction: column; gap: 8px; }
.lei-inc { display: flex; gap: 10px; align-items: flex-start; font-size: 15px; line-height: 1.7; }
.lei-num { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--blue); flex-shrink: 0; margin-top: 2px; min-width: 28px; }
.lei-num.green { color: var(--green-d); }
.lei-num.gold  { color: var(--gold); }
.lei-inc-text { color: var(--text); }
.lei-inc-text em { color: var(--muted); font-style: normal; }
.lei-par { font-size: 14px; color: var(--muted); margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border2); line-height: 1.7; font-style: italic; }

/* Tres Pilares */
.pilares-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; margin-top: 24px; }
.pilar-card { border-radius: 14px; padding: 20px 18px; display: flex; flex-direction: column; gap: 10px; }
.pilar-card.azul  { background: rgba(78,174,217,.08);  border: 1px solid rgba(78,174,217,.25); }
.pilar-card.verde { background: rgba(92,196,176,.08);  border: 1px solid rgba(92,196,176,.25); }
.pilar-card.roxo  { background: rgba(155,89,182,.08);  border: 1px solid rgba(155,89,182,.25); }
.pilar-icon  { font-size: 26px; }
.pilar-title { font-family: 'Lora', serif; font-size: 15px; font-weight: 700; }
.pilar-card.azul  .pilar-title { color: var(--blue); }
.pilar-card.verde .pilar-title { color: var(--green-d); }
.pilar-card.roxo  .pilar-title { color: var(--purple); }
.pilar-desc { font-size: 15px; color: var(--muted); line-height: 1.75; }

/* Responsabilidade timeline */
.resp-steps { display: flex; flex-direction: column; gap: 0; margin-top: 24px; }
.resp-step  { display: flex; gap: 18px; padding-bottom: 24px; position: relative; }
.resp-step:last-child { padding-bottom: 0; }
.resp-left  { display: flex; flex-direction: column; align-items: center; }
.resp-num   { width: 34px; height: 34px; border-radius: 50%; background: var(--card); border: 2px solid var(--blue); display: flex; align-items: center; justify-content: center; font-family: 'Lora', serif; font-size: 13px; font-weight: 700; color: var(--blue); flex-shrink: 0; }
.resp-line  { width: 2px; flex: 1; margin-top: 6px; background: linear-gradient(to bottom, var(--border), transparent); }
.resp-step:last-child .resp-line { display: none; }
.resp-body  { padding-top: 6px; }
.resp-title { font-size: 15px; font-weight: 600; margin-bottom: 4px; }
.resp-desc  { font-size: 15px; color: var(--muted); line-height: 1.75; }

/* STF box */
.stf-box { background: linear-gradient(135deg, rgba(155,89,182,.1) 0%, rgba(78,174,217,.08) 100%); border: 1px solid rgba(155,89,182,.3); border-radius: 14px; padding: 22px 20px; margin-top: 24px; }
.stf-label { font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--purple); margin-bottom: 10px; }
.stf-title { font-family: 'Lora', serif; font-size: 16px; font-weight: 700; color: var(--head); margin-bottom: 10px; }
.stf-body  { font-size: 15px; color: var(--muted); line-height: 1.8; }

/* Botoes de banca */
.banca-btn { display: inline-flex; align-items: center; justify-content: center; padding: 10px 22px; border-radius: 8px; font-family: 'DM Mono', monospace; font-size: 13px; font-weight: 600; letter-spacing: 1px; text-decoration: none; border: none; cursor: pointer; transition: opacity .2s, transform .15s; }
.banca-btn:hover { opacity: .85; transform: translateY(-1px); }
.banca-btn.fgv      { background: #1d293f; color: #fff; }
.banca-btn.fcc      { background: #8e2138; color: #fff; }
.banca-btn.cebraspe { background: #d5963c; color: #fff; }
.banca-btn.vunesp   { background: #4d0d13; color: #fff; }

/* Badge da banca nas questoes */
.questao-banca.fgv      { background: rgba(29,41,63,.12);   color: #1d293f; }
.questao-banca.fcc      { background: rgba(142,33,56,.12);  color: #8e2138; }
.questao-banca.cebraspe { background: rgba(213,150,60,.18); color: #9a6218; }
.questao-banca.vunesp   { background: rgba(77,13,19,.12);   color: #4d0d13; }
[data-theme="dark"] .questao-banca.fgv      { background: rgba(29,41,63,.4);    color: #8fafd4; }
[data-theme="dark"] .questao-banca.fcc      { background: rgba(142,33,56,.35);  color: #e07090; }
[data-theme="dark"] .questao-banca.cebraspe { background: rgba(213,150,60,.25); color: #d5963c; }
[data-theme="dark"] .questao-banca.vunesp   { background: rgba(77,13,19,.45);   color: #d47080; }

/* Botao Bizu no Ponto */
.dap-btn { display: inline-flex; align-items: center; gap: 9px; background: #0D1B2E; color: #fff; padding: 13px 28px; border-radius: 10px; font-size: 14px; font-weight: 600; border: none; cursor: pointer; text-decoration: none; transition: background .2s, transform .15s; }
.dap-btn:hover { background: #1d293f; transform: translateY(-1px); }

/* CTA */
#topo { text-align: center; padding: 100px 20px 60px; }
.cta-btn { display: inline-flex; align-items: center; gap: 8px; background: var(--blue); color: #fff; padding: 13px 30px; border-radius: 10px; font-size: 15px; font-weight: 600; text-decoration: none; border: none; cursor: pointer; transition: opacity .2s, transform .15s; }
.cta-btn:hover { opacity: .88; transform: translateY(-1px); }

footer { border-top: 1px solid var(--border); padding: 32px 20px; text-align: center; font-size: 12px; color: var(--muted); }

/* ══════════════════════════════════════════════════════
   QUESTOES
══════════════════════════════════════════════════════ */
.banca-section-header { display: flex; align-items: center; gap: 16px; margin-bottom: 32px; flex-wrap: wrap; }
.banca-logo { font-family: 'Lora', serif; font-size: 28px; font-weight: 700; color: var(--head); }
.banca-count { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--muted); padding: 3px 10px; border: 1px solid var(--border); border-radius: 20px; }

.questao { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 22px 20px; margin-bottom: 16px; }
.questao-header { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.questao-num  { font-family: 'DM Mono', monospace; font-size: 11px; background: var(--card2); border: 1px solid var(--border); border-radius: 6px; padding: 2px 9px; color: var(--muted); white-space: nowrap; }
.questao-banca { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--blue); font-weight: 600; }
.questao-tema  { font-size: 12px; color: var(--muted); }
.questao-enunciado { font-size: 15px; line-height: 1.75; margin-bottom: 16px; color: var(--text); }
.alt-list, .alts { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.alt { font-size: 15px; line-height: 1.65; padding: 9px 13px; border-radius: 8px; border: 1px solid var(--border2); background: var(--card2); color: var(--text); }
.alt.correta { border-color: rgba(46,125,106,.4); background: rgba(46,125,106,.07); }
[data-theme="dark"] .alt.correta { border-color: rgba(92,196,176,.35); background: rgba(92,196,176,.07); }
.gab-line { display: flex; align-items: center; padding: 12px 0 0; }
.questao-footer { display: flex; align-items: flex-start; gap: 12px; padding-top: 14px; border-top: 1px solid var(--border2); }
.gab-badge { font-family: 'DM Mono', monospace; font-size: 15px; font-weight: 700; color: var(--green-d); background: rgba(46,125,106,.1); border: 1px solid rgba(46,125,106,.3); border-radius: 8px; padding: 4px 14px; white-space: nowrap; flex-shrink: 0; }
[data-theme="dark"] .gab-badge { color: var(--green-d); background: rgba(92,196,176,.1); border-color: rgba(92,196,176,.3); }
.questao-comentario { font-size: 15px; color: var(--muted); line-height: 1.7; }
.questao-comentario strong { color: var(--text); }

/* ══════════════════════════════════════════════════════
   CLÁUSULA CARDS (NF-e e similares)
══════════════════════════════════════════════════════ */
.clausula-card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 24px 22px; margin-top: 20px; position: relative; }
.clausula-card::before { content: attr(data-clausula); position: absolute; top: -11px; left: 20px; font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blue); background: var(--card); border: 1px solid var(--border); border-radius: 20px; padding: 2px 12px; }
.clausula-titulo { font-family: 'Lora', serif; font-size: 17px; font-weight: 700; color: var(--head); margin-bottom: 14px; margin-top: 6px; }
.prosa { font-size: 15px; color: var(--muted); line-height: 1.8; margin-bottom: 16px; }

/* ══════════════════════════════════════════════════════
   VS GRID (comparativos lado a lado)
══════════════════════════════════════════════════════ */
.vs-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-top: 20px; }
.vs-col { background: var(--card2); border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; overflow: hidden; }
.vs-col.red    { border-left: 3px solid var(--red); }
.vs-col.green  { border-left: 3px solid var(--green-d); }
.vs-col.gold   { border-left: 3px solid var(--gold); }
.vs-col.purple { border-left: 3px solid var(--purple); }
.vs-title { font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; font-weight: 600; }
.vs-list { list-style: disc; padding-left: 18px; display: flex; flex-direction: column; gap: 6px; }
.vs-list li { font-size: 14px; color: var(--text); line-height: 1.6; padding-left: 2px; }

/* ══════════════════════════════════════════════════════
   MODAL GRID (contingência)
══════════════════════════════════════════════════════ */
.modal-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; margin-top: 24px; }
.modal-card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; }
.modal-header { font-family: 'DM Mono', monospace; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; font-weight: 700; padding: 10px 18px; }
.modal-header.svc  { background: rgba(78,174,217,.12);  color: var(--blue); border-bottom: 1px solid rgba(78,174,217,.2); }
.modal-header.epec { background: rgba(232,180,0,.12);   color: var(--gold); border-bottom: 1px solid rgba(232,180,0,.2); }
.modal-header.fsda { background: rgba(155,89,182,.12);  color: var(--purple); border-bottom: 1px solid rgba(155,89,182,.2); }
.modal-body { padding: 16px 18px; font-size: 14px; color: var(--muted); line-height: 1.8; display: flex; flex-direction: column; gap: 6px; }
.modal-body p { margin: 0; }
.modal-body strong { color: var(--text); }

/* ══════════════════════════════════════════════════════
   EVENTO GRID (lista de eventos da NF-e)
══════════════════════════════════════════════════════ */
.evento-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 10px; margin-top: 24px; }
.evento-card { background: var(--card2); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; display: flex; align-items: center; gap: 10px; }
.evento-card.auto { border-style: dashed; opacity: .75; }
.evento-num { font-family: 'DM Mono', monospace; font-size: 11px; font-weight: 700; color: var(--blue); flex-shrink: 0; min-width: 28px; }
.evento-desc { font-size: 13px; color: var(--text); line-height: 1.4; }

/* Pilar vermelho e dourado */
.pilar-card.vermelho { background: rgba(226,94,66,.08); border: 1px solid rgba(226,94,66,.25); }
.pilar-card.vermelho .pilar-title { color: var(--red); }
.pilar-card.dourado { background: rgba(232,180,0,.08); border: 1px solid rgba(232,180,0,.25); }
.pilar-card.dourado .pilar-title { color: var(--gold); }

/* ══════════════════════════════════════════════════════
   BLOCO EFD CARDS
══════════════════════════════════════════════════════ */
.bloco-efd-card { display: flex; gap: 20px; align-items: flex-start; background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 18px 20px; margin-top: 14px; }
.bloco-letra { font-family: 'DM Mono', monospace; font-size: 28px; font-weight: 700; color: var(--blue); flex-shrink: 0; width: 36px; text-align: center; line-height: 1; margin-top: 2px; }
.bloco-letra.gold   { color: var(--gold); }
.bloco-letra.purple { color: var(--purple); }
.bloco-letra.green  { color: var(--green-d); }
.bloco-letra.red    { color: var(--red); }
.bloco-titulo { font-family: 'Lora', serif; font-size: 15px; font-weight: 700; color: var(--head); margin-bottom: 6px; }
.bloco-desc { font-size: 14px; color: var(--muted); line-height: 1.7; }
.bloco-desc code { font-family: 'DM Mono', monospace; font-size: 12px; background: var(--card2); border: 1px solid var(--border); border-radius: 4px; padding: 1px 5px; color: var(--blue); }

/* Alert-box purple */
.alert-box.purple { background: rgba(155,89,182,.08); border: 1px solid rgba(155,89,182,.25); }
.alert-title.purple { color: var(--purple); }
