/* Chapa de Base — estilo da interface e da memória de cálculo */

.volta-portal {
  display: inline-block;
  color: rgba(255,255,255,0.75);
  font-size: 12px;
  text-decoration: none;
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}
.volta-portal:hover { color: #fff; text-decoration: underline; }

:root {
  --azul: #1d4e89;
  --azul-claro: #eaf1f9;
  --cinza: #555;
  --borda: #d7dce3;
  --ok: #1a7f37;
  --nok: #c62828;
  --fundo: #f5f6f8;
  --bg: #fff;
  --texto: #222;
  --topo-bg: #1d4e89;
  --input-bg: #fff;
  --input-border: #d7dce3;
}
[data-tema="escuro"] {
  --azul: #5b9bd5;
  --azul-claro: #1a2940;
  --cinza: #99a;
  --borda: #3a4050;
  --fundo: #111111;
  --bg: #1a1a1a;
  --texto: #dde;
  --topo-bg: #0d0d0d;
  --input-bg: #232a38;
  --input-border: #3a4050;
  --ok: #3dbe5a;
  --nok: #f06060;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, Arial, sans-serif;
  font-size: 14px;
  color: var(--texto);
  background: var(--fundo);
}
input, select, textarea { background: var(--input-bg); color: var(--texto); border-color: var(--input-border); }

.topo {
  background: var(--topo-bg);
  color: #fff;
  padding: 14px 22px;
  position: relative;
}
.tema-btn {
  position: absolute; top: 10px; right: 16px;
  background: none; border: 1px solid rgba(255,255,255,.3);
  color: #fff; border-radius: 20px; padding: 3px 10px;
  cursor: pointer; font-size: 13px; opacity: .8;
}
.tema-btn:hover { opacity: 1; }
.topo-save-area{display:flex;gap:6px;margin-left:auto}
.btn-save{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;padding:5px 12px;cursor:pointer;font-size:12px;transition:background .2s;white-space:nowrap}
.btn-save:hover{background:rgba(255,255,255,.28)}
input#file-open{display:none}
.topo h1 { margin: 0; font-size: 20px; }
.topo .sub { margin: 3px 0 0; font-size: 12.5px; opacity: 0.9; }

.projeto {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 22px;
  background: var(--bg);
  border-bottom: 1px solid var(--borda);
}
.projeto label {
  display: flex;
  flex-direction: column;
  font-size: 11.5px;
  color: var(--cinza);
  flex: 1 1 180px;
}
.projeto input {
  margin-top: 2px;
  padding: 5px 7px;
  border: 1px solid var(--input-border);
  border-radius: 4px;
  font-size: 13px;
  background: var(--input-bg);
  color: var(--texto);
}

/* ── ABAS DE PROJETO (tabs-bar) ── */
.tabs-bar{display:flex;align-items:stretch;border-bottom:2px solid var(--azul);background:var(--fundo);overflow-x:auto;flex-shrink:0;min-height:36px}
.tab-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 11px 6px 13px;border:none;border-right:1px solid var(--borda);background:transparent;color:var(--cinza);cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s;line-height:1.2}
.tab-btn:hover{background:var(--azul-claro);color:var(--texto)}
.tab-btn.ativo{background:var(--azul-claro);color:var(--azul);font-weight:700;box-shadow:inset 0 -3px 0 var(--azul)}
.tab-fechar{background:none;border:none;cursor:pointer;color:var(--cinza);font-size:15px;padding:0 1px;line-height:1;vertical-align:middle}
.tab-fechar:hover{color:#e74c3c}
.tab-add{padding:6px 12px;background:none;border:none;color:var(--azul);font-size:20px;cursor:pointer;flex-shrink:0;line-height:1}
.tab-add:hover{color:var(--azul);}

.abas { display: flex; gap: 6px; padding: 12px 22px 0; }
.aba-btn {
  padding: 8px 18px;
  border: 1px solid var(--borda);
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  background: var(--fundo);
  cursor: pointer;
  font-size: 14px;
  color: var(--texto);
}
.aba-btn.ativa { background: var(--bg); font-weight: 600; color: var(--azul); }

.pilares {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 8px 22px;
  background: var(--bg);
  border-bottom: 1px solid var(--borda);
  font-size: 12.5px;
  color: var(--cinza);
}
.pilares-rotulo { font-weight: 600; }
#pilar-tabs { display: flex; flex-wrap: wrap; gap: 5px; }
.pilar-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border: 1px solid var(--borda);
  border-radius: 12px;
  background: var(--bg);
  color: var(--texto);
  cursor: pointer;
  font-size: 12.5px;
}
.pilar-tab.ativa {
  background: var(--azul);
  border-color: var(--azul);
  color: #fff;
  font-weight: 600;
}
.pilar-x {
  font-weight: 700;
  opacity: 0.55;
  padding: 0 2px;
}
.pilar-x:hover { opacity: 1; color: var(--nok); }
.pilar-tab.ativa .pilar-x:hover { color: #ffb4b4; }
#pilar-add {
  padding: 4px 12px;
  border: 1px dashed var(--azul);
  border-radius: 12px;
  background: var(--azul-claro);
  color: var(--azul);
  cursor: pointer;
  font-size: 12.5px;
}
#pilar-add:hover { background: var(--azul); color: #fff; }
.dica-inline { font-size: 11px; color: #999; }

main { padding: 16px 22px 4px; }
.aba { display: flex; gap: 18px; align-items: flex-start; }
.aba.oculta { display: none; }

/* ---------- formulário ---------- */
.painel { flex: 0 0 400px; max-width: 400px; }
fieldset {
  border: 1px solid var(--borda);
  border-radius: 6px;
  background: var(--bg);
  margin: 0 0 12px;
  padding: 8px 12px 12px;
}
legend { font-size: 12.5px; font-weight: 600; color: var(--azul); padding: 0 4px; }
.grade { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 10px; }
/* rótulo em bloco: o texto e a unidade (kN, kN·cm, sub-índices) fluem na MESMA
   linha; o campo (input/select), sendo block + width:100%, cai sozinho abaixo.
   (Antes o label era flex-column e quebrava cada trecho inline numa linha.) */
.grade label { display: block; font-size: 11.5px; color: var(--cinza); line-height: 1.35; }
.grade label input, .grade label select { white-space: normal; }
.radios { display: flex; gap: 16px; }
.radios label { display: flex; flex-direction: row; align-items: center; gap: 5px; font-size: 13px; color: var(--texto); }
.grade input, .grade select {
  margin-top: 2px;
  padding: 5px 7px;
  border: 1px solid var(--borda);
  border-radius: 4px;
  font-size: 13.5px;
  width: 100%;
}
.dica { margin: 8px 0 0; font-size: 11px; color: var(--cinza); }
.btn-mini {
  padding: 3px 10px;
  border: 1px solid var(--azul);
  border-radius: 10px;
  background: var(--azul-claro);
  color: var(--azul);
  cursor: pointer;
  font-size: 11.5px;
  margin-right: 6px;
}
.btn-mini:hover { background: var(--azul); color: #fff; }
.grade-3col { grid-template-columns: 1fr 1fr 1fr; }
.sel-perfil-cat { font-size: 12.5px; }
.so-lrfd { margin-top: 8px; display: none; grid-template-columns: 1fr 1fr; }
form.lrfd .so-lrfd { display: grid; }

/* ---------- memória de cálculo ---------- */
.memoria {
  flex: 1 1 auto;
  background: var(--bg);
  border: 1px solid var(--borda);
  border-radius: 6px;
  padding: 20px 26px 26px;
  min-width: 0;
}
.memo-cab { border-bottom: 2px solid var(--azul); padding-bottom: 8px; margin-bottom: 14px; }
.memo-cab h2 { margin: 0 0 2px; font-size: 17px; color: var(--azul); }
.memo-cab .memo-meta { font-size: 12px; color: var(--cinza); }

.memo-entrada { width: 100%; border-collapse: collapse; font-size: 12.5px; margin: 6px 0 14px; }
.memo-entrada td { border: 1px solid var(--borda); padding: 3px 8px; }
.memo-entrada td:nth-child(odd) { background: var(--azul-claro); width: 26%; color: var(--texto); }

/* resumo dos dados de entrada (topo da memória) */
.resumo-tab { border-collapse: collapse; margin: 4px 0 12px; font-size: 12.5px; width: 100%; max-width: 620px; }
.resumo-tab th, .resumo-tab td { border: 1px solid var(--borda, #d0d5dd); padding: 4px 9px; text-align: left; vertical-align: top; }
.resumo-tab .rt-grp { background: var(--fundo, #f5f7fa); color: var(--azul, #1d4e89); font-weight: 700; width: 90px; }
.resumo-tab .rt-cmp { color: var(--cinza, #667085); width: 150px; }
.rt-id { font-size: 12px; color: var(--cinza, #667085); margin: 0 0 6px; }
.resumo-fig { display: flex; gap: 14px; flex-wrap: wrap; margin: 4px 0 10px; }
.resumo-fig .fig { flex: 0 1 360px; }
.resumo-fig .fig svg, .resumo-fig .fig img { width: 100%; height: auto; border: 1px solid var(--borda, #d0d5dd); border-radius: 6px; background: #fff; }
.resumo-fig .fig-cap { font-size: 11.5px; color: var(--cinza, #667085); text-align: center; margin-top: 3px; }

.passo { margin: 0 0 13px; }
.passo h3 {
  margin: 0 0 4px;
  font-size: 13.5px;
  color: var(--azul);
}
.formula {
  font-family: "Cambria Math", Cambria, Georgia, serif;
  font-size: 14.5px;
  padding: 1.5px 0 1.5px 16px;
  line-height: 1.55;
}
.obs { font-size: 12px; color: var(--cinza); padding-left: 16px; }

.badge {
  display: inline-block;
  padding: 1px 9px;
  border-radius: 10px;
  font-family: "Segoe UI", system-ui, sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  vertical-align: 1px;
  margin-left: 6px;
}
.badge.ok { background: #e2f3e6; color: var(--ok); border: 1px solid var(--ok); }
.badge.nok { background: #fde8e8; color: var(--nok); border: 1px solid var(--nok); }

.resultado {
  margin: 18px 0 10px;
  border: 2px solid var(--azul);
  border-radius: 6px;
  background: var(--azul-claro);
  padding: 12px 16px;
}
.resultado h3 { margin: 0 0 6px; font-size: 14px; color: var(--azul); }
.resultado .spec { font-size: 19px; font-weight: 700; color: var(--azul); }
.resultado .spec small { font-size: 13px; font-weight: 400; color: var(--cinza); }

.avisos { margin: 10px 0; }
.avisos div {
  background: #fff7e0;
  border: 1px solid #e0b400;
  border-radius: 4px;
  color: #7a6200;
  font-size: 12.5px;
  padding: 5px 10px;
  margin-bottom: 4px;
}
[data-tema="escuro"] .avisos div {
  background: #2a2200;
  border-color: #7a6200;
  color: #e0c040;
}

.croqui { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 24px; align-items: flex-start; }
.croqui figure { margin: 0; }
.croqui figcaption { font-size: 11px; color: var(--cinza); text-align: center; margin-top: 2px; }

.croqui-inline { margin-top: 8px; text-align: center; }
.croqui-inline figure { margin: 0; display: inline-block; }
.croqui-inline figcaption { font-size: 11px; color: var(--cinza); margin-top: 2px; }

label.check { flex-direction: row; align-items: center; gap: 6px; }
label.check input { width: auto; }

.hipoteses {
  margin-top: 16px;
  border-top: 1px solid var(--borda);
  padding-top: 8px;
  font-size: 11px;
  color: var(--cinza);
  line-height: 1.5;
}

.acoes { padding: 14px 22px; }
.acoes button {
  padding: 9px 22px;
  font-size: 14.5px;
  border: none;
  border-radius: 6px;
  background: var(--azul);
  color: #fff;
  cursor: pointer;
  margin-right: 8px;
}
.acoes button:hover { filter: brightness(1.15); }

.rodape {
  padding: 10px 22px 22px;
  font-size: 11.5px;
  color: #888;
  max-width: 980px;
}

@media (max-width: 900px) {
  .aba { flex-direction: column; }
  .painel { max-width: none; flex: 1 1 auto; width: 100%; }
}

/* memória não pode ultrapassar a largura do celular */
@media (max-width: 600px) {
  .memoria { padding: 14px 12px 16px; max-width: 100%; overflow-wrap: anywhere; }
  .memoria table { width: 100%; max-width: 100%; table-layout: fixed; font-size: 11px; }
  .memoria th, .memoria td { word-break: break-word; overflow-wrap: anywhere; padding: 3px 5px; }
  .resumo-tab .rt-grp, .resumo-tab .rt-cmp,
  .memo-entrada td:nth-child(odd) { width: auto; }
  .passo, .memo-cab, .memo-cab h2 { max-width: 100%; overflow-wrap: anywhere; }
  .memoria svg, .memoria figure, .memoria img { max-width: 100%; height: auto; display: block; }
}

/* ---------- impressão ---------- */
@media print {
  @page { margin: 12mm 14mm; size: A4; }
  :root, [data-tema="escuro"] {
    --azul-claro: #eaf1f9; --cinza: #555; --borda: #d7dce3; --fundo: #fff;
    --bg: #fff; --texto: #222; --topo-bg: #1d4e89; --input-bg: #fff; --input-border: #d7dce3;
    --ok: #1a7f37; --nok: #c62828;
  }
  body { background: #fff; color: #222; font-size: 12px; }
  .no-print, .acoes, .rodape, .topo, .projeto, .hipoteses, .obs-projeto-area, .tema-btn, .tabs-bar { display: none !important; }
  main { padding: 0; }
  .aba.oculta { display: none !important; }
  .memoria { border: none; padding: 0; }
  .resultado { break-inside: avoid; }
  .passo { break-inside: avoid; }
  .croqui { break-inside: avoid; }
}
