@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap");

/* SuperCesta — Catálogo do Vendedor (mobile-first) */
:root {
  --bg: #f4f1ec;
  --surface: #ffffff;
  --text: #1a1a1a;
  --muted: #5c5c5c;
  --primary: #092e7a;
  --primary-contrast: #fff;
  --diff-up: #c45c00;
  --diff-down: #092e7a;
  --border: #e0dbd4;
  --shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  --radius: 12px;
  --radius-sm: 8px;
  --header-comp: 120px;
  --font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  /* Layout tipo app: celular full-bleed; ≥680px painel centralizado */
  --app-shell-max: 680px;
  --app-pad-x: 1rem;
  --app-frame-outer: #d9d3c9;
}

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

html {
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.45;
  color: var(--text);
  background: var(--bg);
  min-height: 100dvh;
  padding: env(safe-area-inset-top, 0) env(safe-area-inset-right, 0) env(safe-area-inset-bottom, 0)
    env(safe-area-inset-left, 0);
}

#app {
  position: relative;
  min-height: 100dvh;
  margin: 0 auto;
  width: 100%;
}

.view {
  display: none;
  min-height: 100dvh;
}

.view--active {
  display: block;
}

/* Seleção: barra superior fixa, lista rola (app) */
#view-selecao.view--active {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}

#view-selecao .app-header {
  flex-shrink: 0;
}

#view-selecao .cestas-grid {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.view[hidden] {
  display: none !important;
}

.app-header {
  position: relative;
  padding: max(1rem, env(safe-area-inset-top, 0px)) var(--app-pad-x) 1rem;
  text-align: center;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.app-header__sair {
  position: absolute;
  top: max(0.65rem, env(safe-area-inset-top, 0px));
  right: var(--app-pad-x);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  padding: 0.35rem 0.5rem;
  border-radius: var(--radius-sm, 6px);
}

.app-header__sair:hover {
  color: var(--primary);
  background: var(--surface-2, rgba(0, 0, 0, 0.04));
}

.app-header--compact {
  text-align: center;
  padding-bottom: 0.65rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
}

.app-header--compact .btn--back {
  align-self: flex-start;
  margin: 0 0 0 calc(-1 * var(--app-pad-x) + 0.25rem);
}

.app-title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.app-subtitle {
  margin: 0.4rem 0 0;
  color: var(--muted);
  font-size: 0.875rem;
  font-weight: 500;
  max-width: 22rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.35;
}

/* Seleção — cards (catálogo), 2 colunas */
.cestas-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem 0.65rem;
  /* Não esticar linhas/cards para preencher a área do scroll — altura = conteúdo */
  align-items: start;
  align-content: start;
  padding: 1rem var(--app-pad-x) calc(1.75rem + env(safe-area-inset-bottom, 0px));
  max-width: 100%;
  margin: 0 auto;
  width: 100%;
}

@media (min-width: 680px) {
  .cestas-grid {
    gap: 1rem 0.85rem;
  }
}

.cesta-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  overflow: hidden;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
  width: 100%;
  background: var(--surface);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 16px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 1px 2px rgba(0, 0, 0, 0.04),
    0 8px 24px rgba(0, 0, 0, 0.06);
  transition:
    transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}

.cesta-card:hover,
.cesta-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(0, 0, 0, 0.1);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.85) inset,
    0 2px 4px rgba(0, 0, 0, 0.05),
    0 14px 36px rgba(0, 0, 0, 0.1);
  outline: none;
}

.cesta-card:focus-visible {
  box-shadow:
    0 0 0 2px var(--surface),
    0 0 0 4px var(--primary),
    0 14px 36px rgba(0, 0, 0, 0.08);
}

.cesta-card:active {
  transform: translateY(0);
  transition-duration: 0.1s;
}

.cesta-card__nome {
  margin: 0;
  padding: 0.65rem 0.6rem 0.5rem;
  font-size: clamp(0.8125rem, calc(0.35rem + 2.8vw), 1rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
  text-align: left;
  color: var(--text);
}

@media (min-width: 680px) {
  .cesta-card__nome {
    padding: 0.85rem 0.85rem 0.6rem;
    font-size: 1.0625rem;
  }
}

.cesta-card__media {
  display: block;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
  background: #ebe6df;
}

.cesta-card__thumb-frame {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #e5e0d8;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

@media (min-width: 680px) {
  .cesta-card__thumb-frame {
    aspect-ratio: 16 / 10;
  }
}

.cesta-card__thumb-frame--empty {
  background: repeating-linear-gradient(
    -12deg,
    #e8e3dc,
    #e8e3dc 8px,
    #e2ddd5 8px,
    #e2ddd5 16px
  );
  opacity: 1;
  min-height: 0;
}

.cesta-card__thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.001);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.cesta-card:hover .cesta-card__thumb,
.cesta-card:focus-visible .cesta-card__thumb {
  transform: scale(1.03);
}

.cesta-card__footer {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem;
  padding: 0.55rem 0.55rem 0.65rem;
  margin-top: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  background: linear-gradient(180deg, #faf9f7 0%, var(--surface) 100%);
}

@media (min-width: 680px) {
  .cesta-card__footer {
    gap: 1rem;
    padding: 0.8rem 1.15rem 1rem;
  }
}

.cesta-card__itens {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
  flex-shrink: 1;
  min-width: 0;
  line-height: 1.25;
}

@media (min-width: 680px) {
  .cesta-card__itens {
    font-size: 0.6875rem;
    letter-spacing: 0.08em;
  }
}

.cesta-card__preco {
  margin: 0;
  font-size: clamp(0.8125rem, calc(0.45rem + 2.5vw), 1.1875rem);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--primary);
  letter-spacing: -0.03em;
  text-align: right;
  white-space: nowrap;
  line-height: 1.2;
}

@media (prefers-reduced-motion: reduce) {
  .cesta-card,
  .cesta-card__thumb {
    transition: none;
  }

  .cesta-card:hover,
  .cesta-card:focus-visible {
    transform: none;
  }

  .cesta-card:hover .cesta-card__thumb,
  .cesta-card:focus-visible .cesta-card__thumb {
    transform: none;
  }
}

/* Composição — header fixo */
.composicao-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
  background: var(--surface);
  padding: 0.5rem var(--app-pad-x) 0.85rem;
  padding-top: max(0.5rem, env(safe-area-inset-top, 0px));
  border-bottom: 1px solid var(--border);
  box-shadow: 0 6px 20px rgba(9, 46, 122, 0.06);
}

.composicao-header__toolbar {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
  width: 100%;
}

.composicao-header__toolbar .btn--back {
  flex-shrink: 0;
  margin: 0;
}

.composicao-header__brand {
  text-align: center;
  width: 100%;
  max-width: 28rem;
  margin: 0 auto;
}

.composicao-header__eyebrow {
  margin: 0;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

.composicao-header__titulo {
  margin: 0.2rem 0 0.15rem;
  font-size: clamp(1.05rem, 2.8vw, 1.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--text);
}

.composicao-header__meta {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--muted);
  font-weight: 500;
}

.composicao-resumo-caps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
  width: 100%;
  max-width: 26rem;
  margin: 0 auto;
}

/*
 * FAB adicionar produto: círculo com “+” só.
 * Sempre position: fixed ao viewport — rolagem no body, no #app ou só no .composicao-body
 * não pode levar o botão (absolute no #app subia quando a página rolava).
 */
.composicao-fab {
  position: fixed;
  right: max(0.85rem, calc(env(safe-area-inset-right, 0px) + 0.35rem));
  bottom: max(0.85rem, calc(env(safe-area-inset-bottom, 0px) + 0.5rem));
  z-index: 90;
  width: 3.35rem;
  height: 3.35rem;
  min-width: 3.35rem;
  min-height: 3.35rem;
  padding: 0;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  gap: 0;
  border: none;
  cursor: pointer;
  font: inherit;
  box-shadow:
    0 2px 12px rgba(9, 46, 122, 0.28),
    0 1px 3px rgba(0, 0, 0, 0.08);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease;
  display: inline-flex;
}

.composicao-fab .btn__ico,
.composicao-fab .lucide {
  width: 1.55rem;
  height: 1.55rem;
}

.composicao-fab[hidden] {
  display: none !important;
}

.composicao-fab:hover {
  transform: translateY(-2px);
  box-shadow:
    0 6px 20px rgba(9, 46, 122, 0.32),
    0 2px 6px rgba(0, 0, 0, 0.08);
}

.composicao-fab:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px rgba(9, 46, 122, 0.35),
    0 2px 12px rgba(9, 46, 122, 0.28);
}

/* Desktop: encostar o FAB no canto direito do painel (≈680px), não no canto do monitor */
@media (min-width: 680px) {
  .composicao-fab {
    right: calc(
      (100vw - min(var(--app-shell-max), calc(100vw - 2.5rem))) / 2 + max(0.85rem, env(safe-area-inset-right, 0px))
    );
  }
}

.composicao-resumo-caps__cell {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.45rem;
  text-align: center;
  min-width: 0;
}

.composicao-resumo-caps__cell--destaque {
  background: var(--surface);
  border-color: var(--primary);
  border-width: 1px;
  box-shadow: 0 0 0 1px rgba(9, 46, 122, 0.12);
}

.composicao-resumo-caps__label {
  display: block;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  margin-bottom: 0.2rem;
  line-height: 1.2;
}

.composicao-resumo-caps__value {
  display: block;
  font-size: 0.8125rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  line-height: 1.2;
  word-break: break-word;
}

.composicao-resumo-caps__value--lg {
  font-size: 0.9375rem;
  color: var(--primary);
}

#comp-diff-wrap .composicao-resumo-caps__value {
  color: var(--muted);
}

.composicao-header__diff--up .composicao-resumo-caps__value {
  color: var(--diff-up);
}

.composicao-header__diff--down .composicao-resumo-caps__value {
  color: var(--diff-down);
}

.composicao-header__parcela {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--muted);
  text-align: center;
  font-weight: 500;
}

.composicao-body {
  padding: 1rem var(--app-pad-x) 2rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  margin: 0;
  box-sizing: border-box;
  /* Espaço para não ficar por baixo do FAB (canto) + botão Finalizar */
  padding-bottom: calc(6.5rem + env(safe-area-inset-bottom, 0));
}

/* View composição: lista usa toda a largura do painel (#app / viewport) */
#view-composicao {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

#lista-por-categoria {
  width: 100%;
  min-width: 0;
}

/* Lista por categoria */
.cat-block {
  width: 100%;
  min-width: 0;
  margin-bottom: 1.5rem;
}

.cat-block__title {
  margin: 0 0 0.65rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}

.produto-linha {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.65rem;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background: var(--surface);
  border-radius: var(--radius-sm);
  padding: 0.85rem 0.9rem;
  margin-bottom: 0.5rem;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
  border: 1px solid var(--border);
}

.produto-linha__thumb-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  align-self: start;
  flex-shrink: 0;
}

.produto-linha__col {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Miniatura em listas de produto (composição, variações, substituição) */
.lista-prod-thumb {
  flex-shrink: 0;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--bg);
  border: 1px solid var(--border);
  box-sizing: border-box;
}

/* Com imagem cadastrada: área fixa branca; a foto fica contida (sem crop) */
.lista-prod-thumb:not(.lista-prod-thumb--empty) {
  background: #fff;
}

/* Composição: caixa padrão fixa (não estica com a altura do card) */
.produto-linha__thumb-col .lista-prod-thumb--linha {
  flex: 0 0 90px;
  width: 90px;
  height: 90px;
  min-width: s90px;
  min-height: 90px;
}

.lista-prod-thumb--var {
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
}

.lista-prod-thumb--subst {
  width: 52px;
  height: 52px;
  min-width: 52px;
  min-height: 52px;
}

.lista-prod-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.lista-prod-thumb--empty {
  background: repeating-linear-gradient(
    -12deg,
    #ebe6df,
    #ebe6df 6px,
    #e3ded6 6px,
    #e3ded6 12px
  );
  border-style: dashed;
}

.produto-linha__main {
  flex: 1;
  min-width: 0;
}

.produto-linha__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.5rem;
}

.produto-linha__nome {
  margin: 0;
  font-weight: 600;
  font-size: 1rem;
}

.produto-linha__acoes {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}

.produto-linha__detalhe {
  margin: 0.35rem 0 0;
  font-size: 1rem;
  color: var(--muted);
}

.produto-linha__subtotal {
  margin: 0.4rem 0 0;
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--primary);
}

.variacoes-panel {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 0.65rem;
  padding: 0.75rem;
  background: var(--bg);
  border-radius: var(--radius-sm);
  border: 1px dashed var(--border);
}

.variacoes-panel__title {
  margin: 0 0 0.5rem;
  font-size: 0.85rem;
  font-weight: 600;
}

.variacoes-panel__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.variacoes-panel__item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  text-align: left;
  padding: 0.5rem 0.6rem;
  margin-bottom: 0.35rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  font: inherit;
  cursor: pointer;
}

.variacoes-panel__item-text {
  flex: 1;
  min-width: 0;
  font-size: 0.88rem;
  line-height: 1.35;
}

.variacoes-panel__item:hover,
.variacoes-panel__item:focus-visible {
  border-color: var(--primary);
  outline: none;
}

.variacoes-panel__item--atual {
  border-color: var(--primary);
  background: rgba(13, 92, 59, 0.06);
}

.variacoes-panel__close {
  margin-top: 0.5rem;
}

.variacoes-panel--modal {
  margin-top: 0;
  max-height: min(52vh, 380px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  border-style: solid;
}

/* Log */
.log-box {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 0.75rem 0.9rem;
  margin-bottom: 1.25rem;
}

.log-box__title {
  margin: 0 0 0.5rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted);
}

.log-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.88rem;
}

.log-list li {
  padding: 0.25rem 0;
  border-bottom: 1px solid var(--border);
}

.log-list li:last-child {
  border-bottom: none;
}

.log-empty {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
}

/* Botões */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 1rem;
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  border: 2px solid transparent;
  text-decoration: none;
}

.btn--block {
  width: 100%;
}

.btn--primary {
  background: var(--primary);
  color: var(--primary-contrast);
}

.btn--primary:hover,
.btn--primary:focus-visible {
  filter: brightness(1.08);
  outline: none;
}

.btn--secondary {
  background: var(--surface);
  color: var(--text);
  border-color: var(--border);
}

.btn--ghost {
  background: transparent;
  color: var(--primary);
  padding: 0.35rem 0.5rem;
  margin: -0.35rem -0.5rem;
}

.btn--small {
  font-size: 0.8rem;
  padding: 0.35rem 0.65rem;
}

.btn--icon {
  padding: 0.4rem;
  min-width: 2.25rem;
  min-height: 2.25rem;
}

.btn--icon.btn--small {
  padding: 0.3rem;
  min-width: 2rem;
  min-height: 2rem;
}

.btn--icon-text {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
}

.btn__ico {
  display: block;
  flex-shrink: 0;
}

.btn__ico,
.btn .lucide {
  width: 1.25rem;
  height: 1.25rem;
}

.btn--small .btn__ico,
.btn--small .lucide {
  width: 1.1rem;
  height: 1.1rem;
}

.btn--icon .btn__ico,
.btn--icon .lucide {
  width: 1.2rem;
  height: 1.2rem;
}

.btn--whatsapp {
  background: #092e7a;
  color: #fff;
}

.btn--whatsapp:hover,
.btn--whatsapp:focus-visible {
  filter: brightness(1.05);
  outline: none;
}

.composicao-actions {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 1.5rem;
}

/* Resumo */
.resumo-body {
  padding: 0 var(--app-pad-x) calc(1.75rem + env(safe-area-inset-bottom, 0px));
  max-width: 100%;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.resumo-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.resumo-card p {
  margin: 0.35rem 0;
  font-size: 0.95rem;
}

.resumo-alteracoes__title {
  font-size: 1rem;
  margin: 1rem 0 0.5rem;
}

.field {
  display: block;
  margin-bottom: 1rem;
}

.field__label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.field__input {
  width: 100%;
  padding: 0.65rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font: inherit;
}

.resumo-cliente-bloco {
  margin-bottom: 1rem;
}

.resumo-cliente-combo {
  position: relative;
  width: 100%;
}

.resumo-cliente-combo__input {
  width: 100%;
}

.resumo-cliente-combo__list {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  z-index: 60;
  margin: 0;
  padding: 0.35rem 0;
  list-style: none;
  max-height: min(14rem, 45dvh);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow);
}

.resumo-cliente-combo__list[hidden] {
  display: none !important;
}

.resumo-cliente-combo__option {
  margin: 0;
  padding: 0.55rem 0.75rem;
  cursor: pointer;
  font-size: 0.9rem;
  line-height: 1.35;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  font: inherit;
  color: var(--text);
  display: block;
}

.resumo-cliente-combo__option:hover,
.resumo-cliente-combo__option:focus-visible {
  background: rgba(9, 46, 122, 0.08);
  outline: none;
}

.resumo-cliente-combo__option--empty {
  cursor: default;
  color: var(--muted);
  font-size: 0.85rem;
}

.resumo-cliente-combo__option--empty:hover,
.resumo-cliente-combo__option--empty:focus-visible {
  background: transparent;
}

.resumo-cliente-combo__nome {
  display: block;
  font-weight: 600;
}

.resumo-cliente-combo__tel {
  display: block;
  font-size: 0.82rem;
  color: var(--muted);
  margin-top: 0.1rem;
}

.resumo-cliente-combo__msg {
  margin: 0;
  padding: 0.65rem 0.75rem;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.4;
}

.resumo-cliente-meta {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  color: var(--text-muted, #5a6b62);
}

.resumo-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

/* Bloco de valores após alterações */
.resumo-body > .resumo-card {
  margin-top: 1rem;
}

.resumo-alteracoes {
  min-width: 0;
}

/* Modal */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(0, 0, 0, 0.45);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 1rem;
  padding-bottom: max(1rem, env(safe-area-inset-bottom));
}

@media (min-width: 480px) {
  .modal-overlay {
    align-items: center;
  }
}

.modal-overlay[hidden] {
  display: none;
}

.modal {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 1.25rem;
  width: 100%;
  max-width: 400px;
  max-height: 85dvh;
  overflow-y: auto;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
}

.modal--wide {
  max-width: min(520px, 100%);
}

.modal__title {
  margin: 0 0 0.75rem;
  font-size: 1.1rem;
}

.modal__body {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  color: var(--text);
}

.modal__body .field:last-child {
  margin-bottom: 0;
}

.modal-form__hint {
  margin: 0 0 0.75rem;
  font-size: 0.875rem;
  color: var(--text-muted, #5a6b62);
}

.modal-form__erro {
  margin: 0.5rem 0 0;
  font-size: 0.875rem;
  color: #b42318;
}

.resumo-novo-cliente {
  margin-top: 0.5rem;
}

.modal__actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.modal__actions .btn {
  width: 100%;
}

.subst-filtros {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
}

.subst-filtros button {
  font-size: 0.8rem;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  cursor: pointer;
}

.subst-filtros button.is-active {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}

.subst-lista {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 45dvh;
  overflow-y: auto;
}

.subst-lista > li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.subst-item {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  width: 100%;
  text-align: left;
  padding: 0.65rem 0.75rem;
  margin-bottom: 0.4rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  font: inherit;
  cursor: pointer;
}

.subst-item__body {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.subst-item:hover,
.subst-item:focus-visible {
  border-color: var(--primary);
  outline: none;
}

.subst-item__nome {
  font-weight: 600;
  display: block;
}

.subst-item__meta {
  font-size: 0.82rem;
  color: var(--muted);
  display: block;
  margin-top: 0.2rem;
}

.subst-item__diff {
  font-size: 0.82rem;
  margin-top: 0.25rem;
  font-weight: 600;
}

.subst-item__diff--up {
  color: var(--diff-up);
}

.subst-item__diff--down {
  color: var(--diff-down);
}

.subst-item__diff--zero {
  color: var(--muted);
}

/* Celular (largura menor que 680px): tela cheia com safe area */
@media (max-width: 679.98px) {
  #view-selecao .app-header {
    padding-top: max(0.85rem, env(safe-area-inset-top, 0px));
  }
}

/* Desktop / tablet largo: painel central tipo app (máx. 680px) */
@media (min-width: 680px) {
  :root {
    --app-pad-x: 1.25rem;
  }

  body {
    background: var(--app-frame-outer);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: max(0.75rem, env(safe-area-inset-top, 0px)) max(1rem, env(safe-area-inset-right, 0px))
      max(0.75rem, env(safe-area-inset-bottom, 0px)) max(1rem, env(safe-area-inset-left, 0px));
  }

  #app {
    flex: 1 1 auto;
    width: 100%;
    max-width: var(--app-shell-max);
    min-height: calc(100dvh - 1.5rem - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    min-height: calc(100vh - 1.5rem - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
    border-radius: 20px;
    border: 1px solid rgba(0, 0, 0, 0.07);
    box-shadow:
      0 1px 2px rgba(0, 0, 0, 0.04),
      0 12px 40px rgba(0, 0, 0, 0.1),
      0 32px 64px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    background: var(--bg);
    display: flex;
    flex-direction: column;
  }

  .view {
    flex: 1 1 auto;
    display: none;
    flex-direction: column;
    min-height: 0;
    min-width: 0;
    width: 100%;
    align-self: stretch;
  }

  .view--active {
    display: flex;
  }

  .view[hidden].view--active {
    display: none !important;
  }

  #view-selecao.view--active {
    flex: 1 1 auto;
    min-height: 0;
  }

  #view-composicao.view--active {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
  }

  #view-composicao .composicao-header {
    flex-shrink: 0;
  }

  #view-composicao .composicao-body {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    width: 100%;
    align-self: stretch;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: calc(5.5rem + env(safe-area-inset-bottom, 0px));
  }

  #view-resumo.view--active {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    width: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  #view-resumo .resumo-body {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
  }

  .app-header {
    padding-top: 1.1rem;
    background: var(--surface);
  }

  .app-title {
    font-size: 1.45rem;
  }

  .composicao-resumo-caps {
    max-width: min(26rem, 100%);
    gap: 0.55rem;
  }

  .composicao-resumo-caps__cell {
    padding: 0.55rem 0.5rem;
  }

  .composicao-resumo-caps__value {
    font-size: 0.875rem;
  }

  .composicao-resumo-caps__value--lg {
    font-size: 1.05rem;
  }

  .modal-overlay {
    padding: 1.5rem;
  }
}
