/* Seções personalizadas ocultas até serem ativadas no editor de Formato */
.sec-row.oculta { display: none !important; }

:root {
  --bg:       #eef2ef;
  --panel:    #ffffff;
  --row-alt:  #f7faf8;
  --border:   #d6e3da;
  --border2:  #c4d6ca;
  --ink:      #172418;
  --ink2:     #3d5c46;
  --ink3:     #7a9882;
  --primary:  #1b4d36;
  --primary-h:#123625;
  --accent:   #2a7a52;
  --accent-l: #e6f4ed;
  --pill-bg:  #f0f7f3;
  --danger:   #c04040;
  --shadow:   0 1px 4px rgba(0,0,0,.07);
  --shadow-m: 0 4px 20px rgba(0,0,0,.11);
  --r:        6px;
  --t:        .15s ease;
  --header-h: 58px;
  --chrome-h: var(--header-h);
}

/* Header actions: a barra de ações fica sempre visível na barra de título,
   tanto no modo horizontal quanto no modo caixa lateral. No modo horizontal
   ela duplica os botões da sidebar; no modo lateral a sidebar some. */
.header-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-left: 12px;
}

/* Rodapé lateral: visível só no modo caixa lateral (fica dentro do main-col).
   O <footer> normal (fora do main-col) é ocultado no modo lateral. */
.footer-lateral { display: none; }
body.lateral-on .footer-lateral { display: block; }
body.lateral-on .wrap > footer:not(.footer-lateral) { display: none; }

/* Barra de ações de laudo: oculta no horizontal (botões ficam na sidebar);
   no modo caixa lateral a sidebar some, então aparece fixa no rodapé da coluna
   de seções. */
.lateral-laudo-bar { display: none; }
body.lateral-on .lateral-laudo-bar {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  position: sticky;
  bottom: 0;
  z-index: 50;
  padding: 10px 12px;
  margin-top: 6px;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.lateral-laudo-bar .btn-primary,
.lateral-laudo-bar .btn-muted,
.lateral-laudo-bar .btn-ghost { border-radius: 6px; }
.btn-header {
  background: #fff;
  color: var(--primary);
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
}
.btn-header[disabled] { opacity: .5; cursor: not-allowed; }

/* Icon-only header history buttons */
.btn-header.btn-hist { padding: 6px; width: 40px; display: inline-flex; align-items: center; justify-content: center; }
.btn-header.btn-hist svg { display: block; }

/* Botão Salvar (somente ícone) */
.btn-icon { display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.btn-header.btn-icon { padding: 6px 4px; width: 34px; font-size: 1.05rem; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html:has(body.lateral-on),
html.lateral-on { scroll-behavior: auto; }

body:not(.lateral-on) {
  overflow: visible;
  height: auto;
  min-height: 100vh;
  padding-left: 135px;
}

body {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--ink);
  background: var(--bg);
}

/* -- HEADER -- */
.app-header {
  background: var(--primary);
  height: 58px;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky; top: 0; z-index: 200;
  box-shadow: 0 2px 10px rgba(0,0,0,.22);
}
.app-header h1 {
  font-size: 23px;
  font-weight: 700;
  letter-spacing: .03em;
  color: #fff;
}

/* -- SIDEBAR -- */
.sidebar {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 135px;
  background: var(--panel);
  border-right: 1px solid var(--border);
  box-shadow: 2px 0 10px rgba(0,0,0,.04);
  display: flex; flex-direction: column;
  padding: 14px 10px 18px;
  gap: 4px;
  z-index: 90;
  overflow-y: auto;
}
body.lateral-on .sidebar { display: none; }
body.lateral-on { padding-left: 0; }

.sidebar .sb-brand {
  font-family: 'DM Mono', monospace; font-size: 11px;
  color: var(--ink3); padding: 0 8px 8px; letter-spacing: .08em;
  text-transform: uppercase; border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.sidebar button {
  width: 100%; justify-content: flex-start;
  padding: 8px 10px; font-size: 13px;
}
.sidebar .sb-divider { height: 1px; background: var(--border); margin: 8px 4px; }
.sidebar .sb-section-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--ink3); padding: 6px 10px 2px; font-weight: 600;
}
.sidebar button[disabled] { opacity: .45; cursor: not-allowed; }

/* Floating submenu "Opcoes" */
.sb-submenu {
  position: fixed; left: 143px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
  min-width: 240px;
  z-index: 500;
  padding: 6px;
  /* Estado fechado — animável (display não transiciona, por isso usamos
     opacity/visibility/transform). transform-origin no canto onde o menu
     "nasce" (topo-esquerda, junto ao botão da sidebar). */
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px) scale(.97);
  transform-origin: top left;
  pointer-events: none;
  transition: opacity .15s ease,
              transform .22s cubic-bezier(.16, 1, .3, 1),
              visibility 0s linear .22s;
}
.sb-submenu.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  transition: opacity .15s ease,
              transform .26s cubic-bezier(.16, 1, .3, 1),
              visibility 0s;
}
/* Stagger sutil dos itens ao abrir — dá sensação de "cascata" rápida. */
@keyframes sbItemIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sb-submenu.show > button,
.sb-submenu.show > .sb-folder-toggle {
  animation: sbItemIn .24s cubic-bezier(.16, 1, .3, 1) both;
}
.sb-submenu.show > *:nth-child(1) { animation-delay: .02s; }
.sb-submenu.show > *:nth-child(2) { animation-delay: .04s; }
.sb-submenu.show > *:nth-child(3) { animation-delay: .06s; }
.sb-submenu.show > *:nth-child(4) { animation-delay: .08s; }
.sb-submenu.show > *:nth-child(5) { animation-delay: .10s; }
.sb-submenu.show > *:nth-child(6) { animation-delay: .12s; }
.sb-submenu.show > *:nth-child(7) { animation-delay: .13s; }
.sb-submenu.show > *:nth-child(8) { animation-delay: .14s; }
.sb-submenu.show > *:nth-child(n+9) { animation-delay: .15s; }
@media (prefers-reduced-motion: reduce) {
  .sb-submenu { transition: opacity .12s ease, visibility 0s linear .12s; transform: none; }
  .sb-submenu.show { transform: none; transition: opacity .12s ease, visibility 0s; }
  .sb-submenu.show > button,
  .sb-submenu.show > .sb-folder-toggle { animation: none; }
}
.sb-submenu button {
  width: 100%; justify-content: flex-start;
  padding: 8px 12px; font-size: 13px;
  background: transparent; color: var(--ink2);
  border: none; text-align: left; border-radius: 5px;
  display: flex; align-items: center;
}
.sb-submenu button:hover { background: var(--accent-l); color: var(--primary); }
.sb-submenu .sb-toggle-state {
  margin-left: auto; font-size: 10.5px;
  padding: 2px 7px; border-radius: 9px;
  background: var(--border); color: var(--ink3);
  font-weight: 600; text-transform: uppercase; letter-spacing: .04em;
}
.sb-submenu .sb-toggle-state.on { background: var(--accent); color: #fff; }
.sb-submenu-section {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink3);
  padding: 6px 12px 3px;
  margin-top: 2px;
}
.sb-submenu .sb-slot-btn {
  padding-left: 20px;
  font-size: 12.5px;
}
/* Estados ".slot-state" e ".slot-data" compartilham layout/cores */
.sb-submenu .sb-slot-btn .slot-state,
.sb-submenu .sb-slot-btn .slot-data {
  margin-left: auto;
  font-size: 10px;
  color: var(--ink3);
  font-weight: 500;
}
.sb-submenu .sb-slot-btn .slot-data { font-variant-numeric: tabular-nums; }
.sb-submenu .sb-slot-btn .slot-state.ativo,
.sb-submenu .sb-slot-btn .slot-data.ativo {
  color: var(--accent);
  font-weight: 600;
}
.sb-submenu .sb-folder-toggle .sb-folder-arrow {
  margin-left: auto;
  font-size: 11px;
  color: var(--ink3);
}
.sb-submenu .sb-folder-toggle.open {
  background: var(--accent-l);
  color: var(--primary);
}
.sb-submenu .sb-folder-toggle.open .sb-folder-arrow { color: var(--primary); }
.sb-submenu-lateral { min-width: 220px; }

/* Modo visitante: desabilita controles destrutivos/admin (inclui .btn-edit-opt) */
.modo-visitante .sidebar button.btn-save,
.modo-visitante .sidebar button[onclick*="showPopup"],
.modo-visitante .sidebar button[onclick*="deleteCheckedCheckboxes"],
.modo-visitante .sb-submenu button,
.modo-visitante .sb-submenu-item,
.modo-visitante .sb-folder-toggle,
.modo-visitante .sb-slot-btn,
.modo-visitante [onclick*="retornarAoInicial"],
.modo-visitante [onclick*="toggleAutoSave"],
.modo-visitante [onclick*="abrirPopupAdmin"],
body.modo-visitante .btn-edit-opt {
  opacity: 0.4 !important;
  pointer-events: none !important;
  cursor: default !important;
  filter: grayscale(0.6) !important;
}

/* ON state for lateral button */
body.lateral-on #btn-caixa-lateral {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

body.lateral-on .output-bar { display: none; }

/* Bottom output bar visible only in lateral mode */
.output-bottom-bar { display: none; }
body.lateral-on .output-bottom-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--row-alt);
  border-top: 1px solid var(--border);
}

/* Modo lateral — desktop (grid 2 colunas, chrome fixo) */
@media (min-width: 1281px) {
  body.lateral-on {
    overflow: hidden;
    height: 100vh;
    padding-left: 0;
  }

  body.lateral-on .app-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 200;
  }

  body.lateral-on .wrap {
    margin-top: var(--chrome-h);
    height: calc(100vh - var(--chrome-h));
    max-width: none;
    padding: 14px 20px 0;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(380px, 1fr);
    grid-template-rows: minmax(0, 1fr);
    column-gap: 16px;
    align-items: stretch;
  }

  body.lateral-on .wrap > .main-col {
    grid-column: 1;
    grid-row: 1;
    display: block;
    min-height: 0;
    height: 100%;
    max-height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  body.lateral-on .footer-lateral {
    background: var(--bg);
    border-top: 1px solid var(--border);
    width: 100%;
  }

  body.lateral-on .wrap > .output-wrap {
    grid-column: 2;
    grid-row: 1;
    align-self: start;     /* não estica até a altura toda da coluna */
    position: relative;
    top: auto;
    margin-top: 0;
    min-height: 0;
    max-height: 100%;      /* cresce com o texto, mas limita à altura da coluna */
    height: auto;          /* inicia na altura do conteúdo (≈10 linhas) */
    display: flex;
    flex-direction: column;
    overflow: hidden;
    overflow: clip;
  }

  body.lateral-on .wrap > .output-wrap .output-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
  }

  body.lateral-on .text-toolbar,
  body.lateral-on .output-bottom-bar {
    flex-shrink: 0;
  }

  /* Caixa de texto inicia com ~10 linhas (10 × 1.3em) + padding inferior e
     cresce com o conteúdo até a altura da coluna. */
  body.lateral-on .wrap > .output-wrap #output { min-height: calc(13em + 16px); }
}

/* Modo lateral — tablet/mobile (layout em bloco, scroll da página) */
@media (max-width: 1280px) {
  body.lateral-on {
    overflow: visible;
    height: auto;
    padding-left: 0;
  }

  body.lateral-on .app-header {
    position: sticky;
    top: 0;
  }

  body.lateral-on .wrap {
    display: block;
    max-width: 1500px;
    margin: 0 auto;
    margin-top: 0;
    height: auto;
    overflow: visible;
    padding: 14px 20px 0;
  }

  body.lateral-on .wrap > .main-col {
    max-height: none;
    overflow-y: visible;
  }

  body.lateral-on .wrap > .output-wrap {
    position: static;
    max-height: none;
    height: auto;
    margin-top: 12px;
  }
}

/* ───────────────────────────────────────────────
   TELAS MÉDIAS / NOTEBOOKS PEQUENOS  (≤ 1100px)
   Reduz header, sidebar, labels, padding e fontes
   para aproveitar melhor o espaço vertical/horizontal.
   ─────────────────────────────────────────────── */
@media (max-width: 1100px) {

  :root {
    --header-h: 46px;
  }

  /* HEADER - mais compacto */
  .app-header {
    height: 46px;
    padding: 0 12px;
  }
  .app-header h1 {
    font-size: 17px;
  }

  /* SIDEBAR - mais estreita */
  .sidebar {
    width: 105px;
    padding: 10px 6px 14px;
    gap: 2px;
  }
  .sidebar button {
    padding: 6px 6px;
    font-size: 11.5px;
  }
  .sidebar .sb-brand {
    font-size: 10px;
    padding: 0 6px 6px;
  }
  .sidebar .sb-section-label {
    font-size: 9px;
    padding: 4px 6px 1px;
  }

  /* BODY - ajusta padding para sidebar menor */
  body:not(.lateral-on) {
    padding-left: 105px;
  }

  /* WRAP - padding lateral reduzido */
  .wrap {
    padding: 10px 10px 0;
  }

  /* SEÇÃO - labels mais compactos */
  .sec-label {
    width: 90px;
    padding: 8px 8px 8px 12px;
    font-size: 10px;
  }
  .sec-content {
    padding: 8px 10px;
  }

  /* CONTROLES - selects e spans mais enxutos */
  .ctrl-row {
    padding: 4px 6px;
    gap: 3px;
  }
  .ctrl-row span,
  select {
    font-size: 12px;
  }
  select {
    padding: 2px 4px;
  }

  /* ITEMS/PILLS - menores */
  .item {
    padding: 3px 8px 3px 6px;
  }
  .item label {
    font-size: 12.5px;
  }
  .item input[type=checkbox] {
    width: 12px;
    height: 12px;
  }

  /* BOTÕES GLOBAIS - menores */
  button {
    font-size: 12px;
    padding: 5px 10px;
  }
  .btn-save {
    padding: 5px 12px;
  }
  .btn-primary {
    padding: 5px 14px;
  }
  .btn-add {
    padding: 2px 8px;
    font-size: 11.5px;
  }

  /* OUTPUT - barras mais enxutas */
  .output-bar {
    padding: 10px 10px 6px;
    gap: 4px;
  }
  .text-toolbar {
    padding: 5px 10px;
  }
  #output {
    padding: 0 12px 12px;
    min-height: 150px;
  }

  /* SUBMENU flutuante - reposiciona para sidebar menor */
  .sb-submenu {
    left: 113px;
  }

  /* AP - pedido de anatomopatológico */
  .ap-bar {
    padding: 8px 10px;
  }
  #ap-output {
    padding: 10px 12px;
  }

  /* HEADER RIGHT - mantém legível */
  .header-right {
    gap: 6px;
  }
  #user-status button {
    font-size: 11.5px;
    padding: 4px 10px;
  }

  /* SUBROW da conclusão composta */
  .sec-subrow {
    gap: 3px;
  }
  .subrow-label {
    font-size: 9.5px;
    padding: 1px 6px;
  }

  /* FOOTER */
  footer {
    padding: 8px 10px;
  }
}

/* Header logout button on dark background */
#user-status button {
  color: rgba(255,255,255,.92) !important;
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.3) !important;
}
#user-status button:hover {
  background: rgba(255,255,255,.22) !important;
  color: #fff !important;
}
.tsep { width: 1px; height: 20px; background: var(--border2); margin: 0 3px; }

/* -- BUTTONS -- */
button {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  padding: 6px 14px;
  border: none;
  border-radius: var(--r);
  cursor: pointer;
  transition: background var(--t), transform var(--t);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
button:active { transform: scale(.97); }
button:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.btn-save    { background: var(--accent); color: #fff; padding: 6px 18px; box-shadow: 0 2px 6px rgba(42,122,82,.3); }
.btn-save:hover { background: var(--primary); }
.btn-ghost   { background: transparent; color: var(--ink2); border: 1px solid var(--border2); }
.btn-ghost:hover { background: var(--accent-l); border-color: var(--accent); color: var(--primary); }
.btn-hist   { font-size: 1.35rem; line-height: 1; padding: 0.2rem 0.5rem; display: inline-flex; align-items: center; justify-content: center; gap: 4px; }
.btn-hist svg { width: 1.25rem; height: 1.25rem; stroke: #2e7d32; display: block; }
.btn-hist:hover svg { stroke: #1b5e20; }
.btn-hist:disabled svg { stroke: #9e9e9e; }
.btn-hist-label { font-size: 0.85rem; display: inline; }
body.lateral-on .btn-hist-label { display: none; }
body.lateral-on .btn-hist svg { display: block; }
.barrett-spin {
  display: inline-flex;
  flex-direction: column;
  vertical-align: middle;
  margin: 0 4px 0 1px;
}
.barrett-step {
  font-family: inherit;
  font-size: 7px;
  line-height: 1;
  width: 16px;
  height: 11px;
  padding: 0;
  border: 1px solid var(--border2);
  background: var(--panel, #f4f7f5);
  color: var(--ink3);
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-red     { background: transparent; color: var(--danger); border: 1px solid #f0d4d4; }
.btn-red:hover { background: var(--danger); color: #fff; }
.btn-add     { background: var(--accent); color: #fff; padding: 3px 11px; font-size: 12.5px; border-radius: 4px; }
.btn-add:hover { background: var(--primary); }
.btn-primary { background: var(--primary); color: #fff; padding: 7px 20px; }
.btn-primary:hover { background: var(--primary-h); }
.btn-primary[onclick="copiarConteudo()"] { padding: 7px 12px; }
.btn-muted   { background: var(--pill-bg); color: var(--ink2); border: 1px solid var(--border); }
.btn-muted:hover { background: var(--border); }
.btn-muted[onclick="gerarPedidoAP()"] { padding: 7px 12px; }

/* -- LAYOUT -- */
.wrap {
  max-width: 1500px;
  margin: 0 auto;
  padding: 14px 20px 0;
}
.main-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* -- MOBILE / TABLET -- */
@media (max-width: 900px) {
  body { padding-left: 0; }
  .sidebar { display: none; }
  .wrap { padding: 10px 10px 0; }
  button { font-size: 12.5px; padding: 6px 10px; }
  .sec-row { flex-direction: column; }
  .sec-label { width: 100%; border-right: none; border-bottom: 1px solid var(--border2); padding: 8px 12px; }
  .sec-content { padding: 8px 10px; }
  .ctrl-row { padding: 6px; flex-direction: column; align-items: stretch; }
  .item label { font-size: 13px; }
  .output-wrap { margin-top: 10px; }
  #output { padding: 12px; font-size: 11pt; }
  .app-header { padding: 0 12px; }
  /* No mobile horizontal a barra de ações não cabe na barra de título;
     mantém-se escondida (no modo lateral ela continua aparecendo). */
  body:not(.lateral-on) .header-actions { display: none; }
  select { max-width: 100%; }
  body.lateral-on .wrap { display: block; }
  body.lateral-on .wrap > .output-wrap { position: static; max-height: none; }
  .output-bar { display: flex; }
  /* Toque: alvos maiores e barras que quebram linha em vez de estourar */
  button { min-height: 40px; }
  .output-bar, .output-bottom-bar, .text-toolbar { flex-wrap: wrap; }
  /* Evita zoom automático do iOS ao focar campos (fonte < 16px) */
  input[type="text"], input[type="search"], input[type="number"],
  textarea, select { font-size: 16px; max-width: 100%; }
  /* Popups não estouram a viewport estreita */
  .popup { width: 95vw; max-width: 95vw; }
}

/* -- SECTION TABLE -- */
.sections-table {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: var(--shadow);
  overflow: hidden;
}

.sec-row {
  display: flex;
  align-items: flex-start;
  border-bottom: 1px solid var(--border);
  transition: background var(--t);
}
.sec-row:last-child { border-bottom: none; }
.sec-row:nth-child(even) { background: var(--row-alt); }

.sec-label {
  flex-shrink: 0;
  width: 128px;
  padding: 10px 12px 10px 16px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--ink3);
  user-select: none;
  cursor: pointer;
  transition: color .15s ease;
}
.sec-label:hover { color: var(--primary); }
.sec-row:not(.collapsed) > .sec-label { color: var(--primary); }

.sec-content {
  flex: 1;
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  transition: opacity 0s;
}

/* Efeitos visuais desligados (toggle em Opções) — modo "plano": todas as
   seções abertas ao mesmo tempo, sem transições e sem cursor
   de clique (volta ao visual original anterior ao acordeão). */
body.sem-efeitos .sec-content,
body.sem-efeitos .sec-label { transition: none !important; }
body.sem-efeitos .sec-label { cursor: default; }
body.sem-efeitos .sec-row > .sec-label { color: var(--ink3); }

/* Retorno ao ativo: instantâneo (transition 0s no estado base).
   Saída para inativo: devagar (transition 1s definida no estado collapsed — o browser
   usa a transição do estado DESTINO). */
.sec-content > :not(.sortable-zone) { transition: opacity 0s; }

/* Estado colapsado: conteúdo visível mas com opacidade reduzida.
   Sem alteração de tamanho — sem layout shift. */
.sec-row.collapsed > .sec-content > :not(.sortable-zone) {
  opacity: 0.5;
  transition: opacity 1s cubic-bezier(.22,.61,.36,1) .1s;
}
.sec-row.collapsed > .sec-content .item:not(:has(input:checked)) {
  opacity: 0.5;
  transition: background var(--t), border-color var(--t), box-shadow var(--t), opacity 1s cubic-bezier(.22,.61,.36,1) .1s;
}

/* -- SORTABLE ZONE (drag via Pointer Events — sem jQuery UI) -- */
.sortable-zone {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 4px;
  min-height: 8px;
}
[data-ph="1"] { pointer-events: none; }

/* Lesões, Divertículos e Canal Anal têm ctrl-row + zona vazia por padrão.
   Sem override: gap(5) + min-height(8) + padding-bottom(10) = 23px abaixo
   do ctrl-row vs apenas 10px acima. Zeramos min-height e reduzimos o
   padding-bottom para igualar o espaçamento visual. */
#sortable-alteracao,
#sortable-diverticulo,
#sortable-canalanal { min-height: 0; }

#alteracao,
#diverticulo,
#canalanal { padding-bottom: 6px; }

/* -- PILLS / ITEMS -- */
.item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--pill-bg);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 5px 12px 5px 8px;
  cursor: grab;
  transition: background var(--t), border-color var(--t), box-shadow var(--t), opacity 0s;
  user-select: none;
  width: fit-content;
  max-width: 100%;
}
.item:hover  { background: #fff; border-color: var(--accent); box-shadow: 0 1px 6px rgba(42,122,82,.15); }
.item:active { cursor: grabbing; }
.item:has(input:checked) { background: var(--primary); border-color: var(--primary-h); }
.item:has(input:checked) label { color: #fff; }
.item input[type=checkbox] {
  width: 14px; height: 14px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}
.item:has(input:checked) input[type=checkbox] { accent-color: #fff; }
.item label {
  font-size: 13.5px;
  line-height: 1.4;
  color: var(--ink);
  cursor: pointer;
}
.item.item-dinamico { width: 100%; border-radius: 6px; }

/* -- DYNAMIC CONTROLS -- */
.ctrl-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  padding: 6px 10px;
  background: var(--row-alt);
  border: 1px solid var(--border);
  border-radius: var(--r);
}
.ctrl-row span {
  font-size: 13px;
  color: var(--ink3);
  font-weight: 500;
}

.sec-subrow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
}
.subrow-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ink3);
  background: var(--border);
  padding: 2px 8px;
  border-radius: 3px;
}

/* -- SELECTS -- */
select {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  padding: 3px 6px;
  border: 1px solid var(--border2);
  border-radius: 4px;
  background: var(--panel);
  color: var(--ink);
  cursor: pointer;
  transition: border-color var(--t), box-shadow var(--t);
}

/* ───────────────────────────────────────────────
   Base compartilhada para inputs de texto / textareas
   (.edit-group, .popup, .opt-editor-row, #auth-box)
   Sizing/padding específicos vêm nas regras abaixo.
   ─────────────────────────────────────────────── */
.edit-group input[type=text],
.edit-group textarea,
.popup textarea,
.popup input[type=text],
.opt-editor-row input,
.opt-editor-row textarea,
#auth-box input[type=email],
#auth-box input[type=password],
#auth-box input[type=text] {
  font-family: 'DM Sans', sans-serif;
  border: 1px solid var(--border2);
  background: var(--row-alt);
  color: var(--ink);
  transition: border-color var(--t), box-shadow var(--t);
}

/* Focus unificado para selects, inputs e textareas */
select:focus,
.edit-group input:focus,
.edit-group textarea:focus,
.popup input:focus,
.popup textarea:focus,
.opt-editor-row input:focus,
.opt-editor-row textarea:focus,
#auth-box input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(42, 122, 82, .2);
}

/* -- POPUPS -- */
.backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(5,20,12,.4);
  z-index: 9997;
  backdrop-filter: blur(3px);
}
.backdrop.show { display: block; }

.popup {
  display: none;
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(96vw, 860px);
  max-height: 88vh;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 26px 20px;
  z-index: 9998;
  box-shadow: var(--shadow-m);
  overflow-y: auto;
}
.popup h3 {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
#checkbox-list { max-height: 52vh; overflow-y: auto; padding-right: 4px; }
.edit-group { padding: 10px 0; border-bottom: 1px solid var(--border); }
.edit-group strong {
  display: block; margin-bottom: 4px;
  font-size: 11px; text-transform: uppercase;
  letter-spacing: .07em; color: var(--ink3);
}

/* Sizing/padding específico de cada input/textarea (base compartilhada acima) */
.edit-group input[type=text] { font-size: 14px;   padding: 5px 9px; border-radius: 5px; width: 320px; }
.edit-group textarea         { font-size: 13.5px; padding: 6px 9px; border-radius: 5px; width: 100%; height: 60px; margin-top: 4px; resize: vertical; }
.popup textarea              { font-size: 13.5px; padding: 6px 9px; border-radius: 5px; width: 100%; height: 120px; resize: vertical; }
.popup input[type=text]      { font-size: 14px;   padding: 6px 9px; border-radius: 5px; width: 100%; }
.popup label                 { display: block; font-size: 13px; font-weight: 500; color: var(--ink2); margin: 10px 0 4px; }
.popup select                { font-size: 13.5px; padding: 5px 8px; margin-bottom: 2px; }
.popup-footer                { display: flex; gap: 7px; margin-top: 14px; flex-wrap: wrap; }

/* Edit button beside selects (hidden by default) */
.btn-edit-opt {
  display: none;
  background: transparent; color: var(--ink3);
  border: 1px solid var(--border2); border-radius: 4px;
  padding: 1px 6px; font-size: 12px; line-height: 1.3;
  margin-left: 2px; cursor: pointer;
  transition: background var(--t), color var(--t), border-color var(--t);
}
.btn-edit-opt:hover { background: var(--accent-l); color: var(--primary); border-color: var(--accent); }
body.mostrar-edit-opts .btn-edit-opt { display: inline-block; }

@keyframes edit-opt-wiggle {
  0%, 100% { transform: rotate(0deg); }
  15% { transform: rotate(-14deg) scale(1.15); }
  30% { transform: rotate(12deg)  scale(1.15); }
  45% { transform: rotate(-9deg)  scale(1.1); }
  60% { transform: rotate(7deg)   scale(1.05); }
  75% { transform: rotate(-4deg); }
}
body.edit-opts-wiggling .btn-edit-opt {
  animation: edit-opt-wiggle .7s ease both;
  color: var(--primary);
  border-color: var(--accent);
  background: var(--accent-l);
}

/* Dropdown option editor — layout modernizado (cards), análogo ao Laudo EDA */
#popup-edit-options {
  width: min(96vw, 940px);
  padding-bottom: 0;
  overflow: hidden;
}
#popup-edit-options-body {
  max-height: 56vh;
  overflow-y: auto;
  padding: 2px 4px 2px 0;
}
.opt-editor-legenda {
  font-size: 12px;
  line-height: 1.45;
  color: var(--ink3);
  background: var(--row-alt);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 11px;
  margin: -2px 0 12px;
}
.opt-editor-legenda code {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--primary);
  background: var(--accent-l);
  border-radius: 4px;
  padding: 1px 4px;
}
#popup-edit-options .popup-footer {
  margin: 14px -26px 0;
  padding: 12px 26px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.92), var(--panel));
  border-top: 1px solid var(--border);
}
.opt-editor-row {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 9px;
  margin-bottom: 8px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: 0 1px 3px rgba(0,0,0,.035);
}
.opt-editor-row input,
.opt-editor-row textarea {
  font-size: 13px;
  padding: 6px 8px;
  border-radius: 5px;
  line-height: 1.35;
}
.opt-editor-row textarea { box-sizing: border-box; resize: none; overflow-x: hidden; }
.opt-editor-row .opt-label-in { flex: 0 0 140px; }
.opt-editor-row .opt-valor-in { flex: 1 1 auto; min-width: 0; }
.opt-editor-row .opt-extra-in { flex: 0 0 220px; }
.opt-editor-row .opt-btn {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  justify-content: center;
  padding: 0;
  font-size: 13px;
  border: 1px solid var(--border2); background: var(--panel);
  border-radius: 4px; cursor: pointer; color: var(--ink2);
}
.opt-editor-row .opt-btn:hover { background: var(--accent-l); border-color: var(--accent); color: var(--primary); }
.opt-editor-row .opt-btn-rm:hover { background: var(--danger); color: #fff; border-color: var(--danger); }

/* ----------------------------------------------------------
   EDITOR DE ESTRUTURA (esqueleto das frases dos construtores)
   ---------------------------------------------------------- */
.estrutura-token-chip {
  display: inline-block; padding: 1px 6px; margin: 0 1px; border-radius: 999px;
  font-size: 12px; font-weight: 600; white-space: nowrap; vertical-align: baseline;
  background: var(--accent-l); color: var(--primary);
  border: 1px solid var(--accent); user-select: none; cursor: default;
}
.estrutura-campo {
  padding: 9px; margin-bottom: 9px; border: 1px solid var(--border);
  border-radius: 8px; background: var(--panel);
}
.estrutura-campo-rotulo { font-size: 12px; font-weight: 600; color: var(--ink2); margin-bottom: 5px; }
.estrutura-campo-editor {
  min-height: 30px; box-sizing: border-box; padding: 6px 8px;
  font-size: 13px; line-height: 1.5; border-radius: 5px;
  border: 1px solid var(--border2); background: var(--panel); color: var(--ink);
  white-space: pre-wrap; word-break: break-word;
}
.estrutura-campo-editor:focus { border-color: var(--accent); outline: none; }
.estrutura-paleta {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
  margin-top: 7px; padding-top: 7px; border-top: 1px dashed var(--border);
}
.estrutura-paleta-rotulo { font-size: 12px; color: var(--ink3); margin-right: 2px; }
.estrutura-token-add {
  font-size: 12px; padding: 4px 9px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--accent); background: var(--panel); color: var(--primary);
}
.estrutura-token-add:hover { background: var(--accent-l); }

@media (max-width: 900px) {
  #popup-edit-options { width: min(96vw, 860px); }
  .opt-editor-row {
    flex-direction: column;
    gap: 7px;
  }
  .opt-editor-row .opt-label-in,
  .opt-editor-row .opt-valor-in,
  .opt-editor-row .opt-extra-in {
    flex: 0 0 auto;
    width: 100%;
  }
}

/* -- OUTPUT -- */
.output-wrap {
  margin-top: 12px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: var(--shadow);
  overflow: hidden;
  transform: translateZ(0);
}
.output-wrap.caixa-layout-animando {
  position: relative;
  z-index: 140;
  will-change: transform, opacity;
  backface-visibility: hidden;
  box-shadow: 0 18px 42px rgba(23,36,24,.18);
  pointer-events: none;
}
.main-col-layout-animando {
  will-change: transform, opacity;
}
body.caixa-transicao-lateral .main-col-layout-animando {
  animation: mainColEncaixaLateral .46s cubic-bezier(.16, 1, .3, 1) both;
}
body.caixa-transicao-horizontal .main-col-layout-animando {
  animation: mainColEncaixaHorizontal .46s cubic-bezier(.16, 1, .3, 1) both;
}
@keyframes mainColEncaixaLateral {
  from { opacity: .88; transform: translateX(-10px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes mainColEncaixaHorizontal {
  from { opacity: .9; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.output-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  padding: 8px 14px;
  background: var(--row-alt);
  border-bottom: 1px solid var(--border);
}
.text-toolbar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  background: var(--panel);
  border-bottom: 1px solid var(--border2);
}
.text-toolbar select {
  font-size: 12px;
  padding: 2px 4px;
  border: 1px solid var(--border);
  border-radius: 3px;
}
.text-toolbar button {
  font-size: 12px;
  padding: 2px 6px;
  border: 1px solid var(--border);
  background: var(--panel);
  border-radius: 3px;
  cursor: pointer;
}
.text-toolbar button:hover { background: var(--row-alt); }

/* Botões de alinhamento na text-toolbar (output) */
.text-toolbar .align-btn { padding: 2px 6px; line-height: 0; }
.text-toolbar .align-btn svg {
  display: block;
  opacity: .65;
  transition: opacity .12s;
}
.text-toolbar .align-btn:hover svg { opacity: 1; }

#output {
  font-family: Arial, sans-serif;
  font-size: 12pt;
  line-height: 1.3;
  padding: 16px 20px;
  min-height: 220px;
  outline: none;
  white-space: pre-wrap;
  color: var(--ink);
}
#output:focus { background: #fdfffe; }

@media (prefers-reduced-motion: reduce) {
  .output-wrap.caixa-layout-animando,
  .main-col-layout-animando {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}
/* Modo lateral mantém o topo justo (a text-toolbar fica imediatamente acima). */
body.lateral-on #output { padding: 0 16px 16px; }

/* Pedido de AP — caixa abaixo do laudo, oculta até gerar */
#ap-wrap[hidden] { display: none; }
#ap-wrap { border-top: 2px solid var(--border); background: var(--panel); }
.ap-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: var(--row-alt);
  border-top: 1px solid var(--border);
}
.ap-bar strong { flex: 1 1 auto; font-size: 13px; color: var(--primary); }
#ap-output {
  font-family: Arial, sans-serif;
  font-size: 12pt;
  line-height: 1.4;
  padding: 12px 16px 16px;
  min-height: 90px;
  max-height: 40vh;
  overflow-y: auto;
  outline: none;
  white-space: pre-wrap;
  color: var(--ink);
}
#ap-output:focus { background: #fdfffe; }

/* -- TOAST -- */
#toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(70px);
  background: var(--primary);
  color: #c8eedd;
  padding: 8px 22px;
  border-radius: 20px;
  font-size: 13px; font-weight: 500;
  box-shadow: 0 4px 18px rgba(0,0,0,.22);
  z-index: 99999;
  opacity: 0; pointer-events: none;
  transition: transform .2s ease, opacity .2s ease;
  white-space: nowrap;
}
#toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }

footer {
  position: relative;
  text-align: center;
  padding: 10px 20px;
  font-size: 11px;
  color: var(--ink3);
  font-family: 'DM Mono', monospace;
  letter-spacing: .04em;
  background: var(--bg);
  border-top: 1px solid var(--border);
  z-index: 1;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }

/* -- USER STATUS (header) -- */
.header-right    { display: flex; align-items: center; gap: 10px; }
#save-indicator  { font-family: 'DM Mono', monospace; font-size: 11px; color: rgba(255,255,255,.45); transition: opacity .3s; }
#user-status     { display: flex; align-items: center; gap: 7px; }
.user-email {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: rgba(255,255,255,.88);
  background: rgba(255,255,255,.1);
  padding: 3px 10px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.18);
}
.btn-xs          { font-size: 11.5px !important; padding: 3px 9px !important; }
.btn-autosave-on { box-shadow: 0 0 0 2px rgba(255,255,255,.25) !important; }

/* -- AUTH OVERLAY -- */
#auth-overlay {
  display: none; position: fixed; inset: 0;
  background: var(--bg); z-index: 99999;
  align-items: center; justify-content: center;
}
#auth-overlay.show { display: flex; }
#auth-box {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 32px 36px;
  width: min(92vw, 380px); box-shadow: var(--shadow-m); text-align: center;
}
.auth-logo { font-size: 34px; margin-bottom: 6px; }
#auth-box h2 { font-size: 16px; font-weight: 600; color: var(--primary); margin-bottom: 20px; }
.auth-tabs { display: flex; border-bottom: 2px solid var(--border); margin-bottom: 18px; }
.auth-tab {
  flex: 1; background: transparent; border: none;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
  padding: 7px; font-family: 'DM Sans', sans-serif; font-size: 13.5px;
  font-weight: 500; color: var(--ink3); cursor: pointer;
  transition: color var(--t), border-color var(--t);
}
.auth-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
#auth-box input[type=email],
#auth-box input[type=password],
#auth-box input[type=text] {
  display: block; width: 100%;
  font-size: 14px; padding: 9px 12px;
  border-radius: 6px;
  margin-bottom: 10px;
}
.btn-full { width: 100%; justify-content: center; padding: 9px !important; margin-top: 2px; }
.btn-link {
  background: none; border: none; color: var(--ink3);
  font-size: 12.5px; cursor: pointer; margin-top: 10px;
  padding: 0; font-family: 'DM Sans', sans-serif;
  text-decoration: underline; text-underline-offset: 2px;
}
.btn-link:hover { color: var(--accent); }
#auth-erro { color: var(--danger); font-size: 13px; margin-top: 10px; min-height: 18px; text-align: left; }

/* ── Barra de formatação fixa do popup ── */
#popup-format-toolbar {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 6px 10px;
  margin-bottom: 10px;
  background: var(--row-alt, #f5f5f5);
  border: 1px solid var(--border2, #ddd);
  border-radius: 6px;
  position: sticky;
  top: 0;
  z-index: 1;
}
#popup-format-toolbar .fmt-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 28px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 4px;
  background: transparent;
  color: var(--ink, #333);
  font-size: 14px;
  cursor: pointer;
  transition: background .12s, border-color .12s;
  user-select: none;
}
#popup-format-toolbar .fmt-btn:hover  { background: var(--accent-l, #e6f4ed); border-color: var(--accent, #2a7a52); }
#popup-format-toolbar .fmt-btn:active { background: var(--accent, #2a7a52); color: #fff; }
#popup-format-toolbar .fmt-btn-bold      { font-weight: 700; font-size: 15px; }
#popup-format-toolbar .fmt-btn-italic    { font-style: italic; font-size: 15px; }
#popup-format-toolbar .fmt-btn-underline { text-decoration: underline; }

/* Botões de alinhamento: ícones SVG sutis */
#popup-format-toolbar .fmt-btn-align { width: 34px; }
#popup-format-toolbar .fmt-btn-align svg {
  display: block;
  margin: 0 auto;
  opacity: .7;
  transition: opacity .12s;
}
#popup-format-toolbar .fmt-btn-align:hover svg { opacity: 1; }

.fmt-separator {
  display: inline-block;
  width: 1px;
  height: 20px;
  margin: 0 4px;
  background: var(--border2, #ddd);
}

/* ---- Editor de Formato (popup-formato) — Tier A ---- */
.btn-formato { font-weight: 600; }
#popup-formato {
  width: min(96vw, 600px);
  /* NÃO define display aqui (herdaria de .popup{display:none}). O grid é
     aplicado por abrirEditorFormato() — top auto / scroll 1fr / bottom auto. */
  grid-template-rows: auto 1fr auto;
  padding: 0; overflow: hidden;
}
#popup-formato h3 { margin: 0 0 10px; padding: 0; border-bottom: none; }
#popup-formato .fmt-toolbar-top {
  padding: 18px 22px 12px;
  border-bottom: 1px solid var(--border2);
  background: var(--panel);
}
#popup-formato .fmt-scroll {
  min-height: 0;
  overflow-y: auto;
  padding: 14px 22px 4px;
}
#popup-formato .fmt-toolbar-bottom {
  display: flex; gap: 8px; justify-content: flex-end;
  padding: 12px 22px 16px;
  border-top: 1px solid var(--border2);
  background: var(--panel);
}
#popup-formato .fmt-legenda { font-size: 13px; color: var(--ink3); margin-bottom: 14px; line-height: 1.45; }
#popup-formato .fmt-perfil-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
#popup-formato .fmt-perfil-row label { margin: 0; flex: 0 0 auto; font-weight: 600; }
#popup-formato .fmt-perfil-row select { flex: 1; }
#popup-formato .fmt-actions { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
/* Botões da barra de ações (Novo/Duplicar/Renomear) — base neutra. */
#popup-formato .fmt-actions .btn {
  background: var(--row-alt, #f1f4f2); color: var(--ink2);
  border: 1px solid var(--border2); border-radius: var(--r, 6px);
  padding: 6px 12px; font-size: 13px; cursor: pointer;
}
#popup-formato .fmt-actions .btn:hover { background: var(--accent-l); border-color: var(--accent); color: var(--primary); }
#popup-formato .fmt-aviso {
  background: var(--accent-l); color: var(--primary);
  border: 1px solid var(--border2); border-radius: 6px;
  padding: 8px 12px; font-size: 12.5px; margin-bottom: 12px;
}
#popup-formato .fmt-grupo {
  border: 1px solid var(--border2); border-radius: 8px;
  padding: 4px 14px 10px; margin-bottom: 12px;
}
#popup-formato .fmt-grupo legend {
  font-size: 11px; text-transform: uppercase; letter-spacing: .07em;
  color: var(--ink3); font-weight: 600; padding: 0 6px;
}
#popup-formato .fmt-row { display: flex; align-items: center; gap: 10px; margin: 7px 0; }
#popup-formato .fmt-row > label:first-child { margin: 0; flex: 0 0 200px; font-weight: 500; color: var(--ink2); }
#popup-formato .fmt-row label { display: inline-flex; align-items: center; gap: 6px; margin: 0; }
#popup-formato .fmt-row input[type=text],
#popup-formato .fmt-row input[type=number],
#popup-formato .fmt-row select { flex: 1; margin: 0; }
#popup-formato .fmt-row input[type=number] { max-width: 90px; flex: 0 0 auto; }
#popup-formato .fmt-row input:disabled,
#popup-formato .fmt-row select:disabled { background: var(--row-alt, #f1f4f2); opacity: .6; cursor: not-allowed; }
#popup-formato .fmt-livre-ajuda { font-size: 12px; color: var(--ink3); margin: 2px 0 8px; line-height: 1.4; }
#popup-formato .fmt-livre-row { border: 1px dashed var(--border2); border-radius: 6px; padding: 6px 10px 8px; margin-bottom: 8px; }
#popup-formato .fmt-livre-texto { width: 100%; font-size: 13.5px; padding: 6px 9px; border-radius: 5px; resize: vertical; margin: 4px 0; }
#popup-formato .fmt-livre-del { flex: 0 0 auto; padding: 2px 8px; }
#popup-formato textarea:disabled { background: var(--row-alt, #f1f4f2); opacity: .6; cursor: not-allowed; }
#popup-formato .fmt-subgrupo { margin: 10px 0 6px; padding: 8px 10px 4px; background: var(--row-alt, #f7faf8); border-left: 3px solid var(--accent); border-radius: 4px; }
#popup-formato .fmt-sublegenda { font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--accent); margin: 0 0 6px; }
