/* rango — identidade visual
   paleta: verde panela + terracota + creme  */

:root {
  --verde: #2F855A;
  --verde-escuro: #22543D;
  --verde-hover: #276749;
  --verde-claro: #C6F6D5;
  --verde-fundo: #EAF6EE;
  --terracota: #E76F51;
  --ambar: #F4A261;
  --creme: #F7F2E8;
  --papel: #FFFDF8;
  --tinta: #2B2620;
  --cinza: #8B8579;
  --linha: #EBE3D2;
}

body {
  font-family: 'Nunito', 'Segoe UI', sans-serif;
  background-color: var(--creme);
  color: var(--tinta);
}

a { color: var(--verde); text-decoration: none; }
a:hover { color: var(--verde-hover); }

.material-symbols-rounded {
  font-size: 20px;
  vertical-align: -4px;
  font-variation-settings: 'opsz' 20;
}

/* ---------- navegação ---------- */

.barra {
  background: rgba(255, 253, 248, .94);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--linha);
  padding-top: .4rem;
  padding-bottom: .4rem;
}

.barra .nav-link {
  color: var(--tinta);
  font-weight: 600;
  border-radius: 999px;
  padding: .45rem .95rem;
  margin: 0 .1rem;
}

.barra .nav-link:hover { background: var(--verde-fundo); color: var(--verde-escuro); }

.barra .nav-link.active {
  background: var(--verde);
  color: #fff;
}

.barra .dropdown-menu {
  border: 1px solid var(--linha);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(43, 38, 32, .10);
  overflow: hidden;
}

.barra .dropdown-item { font-weight: 600; padding: .5rem 1.1rem; }
.barra .dropdown-item:hover { background: var(--verde-fundo); color: var(--verde-escuro); }

/* ---------- estrutura ---------- */

.conteudo {
  max-width: 1200px;
  padding-top: 1.75rem;
  padding-bottom: 5rem;
  min-height: calc(100vh - 130px);
}

.rodape { padding: 1.2rem 0 2rem; color: var(--cinza); }

.titulo {
  font-size: 1.45rem;
  font-weight: 800;
  margin: 0;
}

.titulo .material-symbols-rounded { color: var(--verde); font-size: 26px; vertical-align: -5px; }

.contagem {
  font-size: .85rem;
  font-weight: 700;
  color: var(--verde-escuro);
  background: var(--verde-claro);
  border-radius: 999px;
  padding: .15rem .6rem;
  vertical-align: 3px;
}

.cabecalho-pagina {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: 1.1rem;
}

.cabecalho-pagina .acoes { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.busca input { width: 190px; }

.filtro-select {
  width: auto;
  max-width: 170px;
  border-radius: 999px;
  font-weight: 600;
  color: var(--verde-escuro);
}

.painel {
  background: var(--papel);
  border: 1px solid var(--linha);
  border-radius: 18px;
  padding: 1.1rem 1.35rem;
  box-shadow: 0 6px 24px rgba(43, 38, 32, .05);
}

.painel-form { max-width: 720px; margin-top: 1rem; }
.painel-form .titulo { margin-bottom: 1.4rem; }

/* ---------- botões e formulários ---------- */

.btn { border-radius: 999px; font-weight: 700; }

.btn-primary {
  --bs-btn-bg: var(--verde);
  --bs-btn-border-color: var(--verde);
  --bs-btn-hover-bg: var(--verde-hover);
  --bs-btn-hover-border-color: var(--verde-hover);
  --bs-btn-active-bg: var(--verde-escuro);
  --bs-btn-active-border-color: var(--verde-escuro);
  --bs-btn-disabled-bg: var(--verde);
  --bs-btn-disabled-border-color: var(--verde);
}

.btn-outline-primary {
  --bs-btn-color: var(--verde);
  --bs-btn-border-color: var(--verde);
  --bs-btn-hover-bg: var(--verde);
  --bs-btn-hover-border-color: var(--verde);
  --bs-btn-active-bg: var(--verde-escuro);
  --bs-btn-active-border-color: var(--verde-escuro);
}

.btn-apagar {
  color: #b8574a;
  border: none;
  background: transparent;
  padding: .2rem .45rem;
}
.btn-apagar:hover { color: #fff; background: var(--terracota); }

/* botão só de ícone, sem borda */
.btn-icone {
  color: var(--verde);
  border: none;
  background: transparent;
  padding: .2rem .45rem;
}
.btn-icone:hover { color: var(--verde-escuro); background: var(--verde-fundo); }

/* lampadinha de sugerir refeição */
.btn-sugerir {
  border: none;
  background: transparent;
  color: var(--terracota);
  padding: 0 .15rem;
  line-height: 1;
  vertical-align: middle;
}
.btn-sugerir:hover { color: var(--verde-escuro); transform: rotate(-15deg); }
.btn-sugerir .material-symbols-rounded { font-size: 19px; }

.form-control, .form-select {
  border-radius: 12px;
  border-color: var(--linha);
  padding: .5rem .85rem;
}
.form-control:focus, .form-select:focus {
  border-color: var(--verde);
  box-shadow: 0 0 0 .2rem rgba(47, 133, 90, .15);
}

.form-label { font-weight: 700; font-size: .9rem; color: var(--verde-escuro); }

.form-check-input:checked { background-color: var(--verde); border-color: var(--verde); }

.pagination {
  --bs-pagination-color: var(--verde);
  --bs-pagination-hover-color: var(--verde-escuro);
  --bs-pagination-hover-bg: var(--verde-fundo);
  --bs-pagination-focus-color: var(--verde-escuro);
  --bs-pagination-focus-bg: var(--verde-fundo);
  --bs-pagination-focus-box-shadow: 0 0 0 .2rem rgba(47, 133, 90, .15);
  --bs-pagination-active-bg: var(--verde);
  --bs-pagination-active-border-color: var(--verde);
  --bs-pagination-border-color: var(--linha);
}

/* ---------- tabelas ---------- */

.painel .table { margin-bottom: 0; }
.painel .table > :not(caption) > * > * { background: transparent; }

.table thead th {
  font-size: .78rem;
  text-transform: lowercase;
  letter-spacing: .06em;
  color: var(--cinza);
  border-bottom: 2px solid var(--linha);
  font-weight: 800;
}

.table td { border-color: var(--linha); }
.table-hover > tbody > tr:hover > * { background: var(--verde-fundo); }

th a { color: var(--cinza); }
th a.asc::after { content: ' ↓'; color: var(--verde); }
th a.desc::after { content: ' ↑'; color: var(--verde); }

/* larguras fixas para as tabelas ficarem iguais em todas as telas (desktop) */
.col-acao { width: 64px; text-align: center; }
@media (min-width: 768px) {
  .painel .table { table-layout: fixed; }
  .painel .table th, .painel .table td { overflow-wrap: anywhere; }
  .col-curta { width: 120px; }
  .col-media { width: 160px; }
}

/* ---------- selos e chips ---------- */

.selo-hoje { background: var(--terracota); }
.selo-amanha { background: var(--ambar); color: var(--tinta); }
.selo-hoje, .selo-amanha {
  font-size: .66rem;
  padding: 2px 6px;
  vertical-align: 1px;
}

.folha { color: var(--verde); }

.chip-prato {
  display: inline-block;
  background: var(--verde-fundo);
  border: 1px solid #d5e9dc;
  color: var(--verde-escuro);
  border-radius: 999px;
  padding: .15rem .7rem;
  margin: .12rem .18rem .12rem 0;
  font-size: .86rem;
  font-weight: 600;
}
.chip-prato:hover { background: var(--verde-claro); color: var(--verde-escuro); }
.chip-prato.veg { border-color: var(--verde); }

/* ---------- tom select ---------- */

.ts-control { border-radius: 12px !important; border-color: var(--linha) !important; padding: .45rem .6rem; }
.ts-wrapper.multi .ts-control > .item {
  background: var(--verde-claro);
  color: var(--verde-escuro);
  border-radius: 999px;
  font-weight: 600;
  padding: .1rem .6rem;
}
.opcao-prato { display: flex; flex-direction: column; }
.opcao-prato small { color: var(--cinza); }

/* ---------- quantidades dos ingredientes ---------- */

.lista-quantidades {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .4rem .9rem;
  margin-top: .55rem;
}

.linha-quantidade { display: flex; align-items: center; gap: .5rem; }

.linha-quantidade span {
  flex: 1;
  min-width: 0;
  font-weight: 600;
  font-size: .85rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.linha-quantidade input { max-width: 150px; }

/* ---------- página do prato ---------- */

.painel-prato { max-width: 860px; margin: 0 auto; padding: 0; overflow: hidden; }

.foto-capa {
  height: 340px;
  background-size: cover;
  background-position: center;
  border-radius: 18px 18px 0 0; /* só os cantos de cima */
}

.foto-capa.sem-foto {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--verde-fundo), var(--creme));
}
.foto-capa.sem-foto .material-symbols-rounded { font-size: 72px; color: var(--verde); opacity: .45; }

.corpo-prato { padding: 1.4rem 1.8rem 1.8rem; }

.ficha-prato {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem 1.2rem;
  color: var(--cinza);
  font-weight: 600;
  margin: .6rem 0 0;
}
.ficha-prato .material-symbols-rounded { color: var(--verde); font-size: 18px; }

.secao-prato {
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--terracota);
  margin: 1.5rem 0 .5rem;
}

.texto-receita { line-height: 1.75; white-space: normal; }

@media (max-width: 576px) {
  .foto-capa { height: 210px; }
  .corpo-prato { padding: 1rem 1.1rem 1.3rem; }
}

/* ---------- pratos: visão em cards ---------- */

.grade-pratos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1rem;
}

.cartao-prato {
  display: flex;
  flex-direction: column;
  background: var(--papel);
  border: 1px solid var(--linha);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 6px 24px rgba(43, 38, 32, .05);
  color: var(--tinta);
  transition: transform .12s ease, box-shadow .12s ease;
}

.cartao-prato:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(43, 38, 32, .12);
  color: var(--tinta);
}

.cartao-prato-foto {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
}

.cartao-prato-foto.sem-foto {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--verde-fundo), var(--creme));
}

.cartao-prato-foto.sem-foto .material-symbols-rounded {
  font-size: 44px;
  color: var(--verde);
  opacity: .5;
}

.cartao-prato-corpo { padding: .7rem .9rem .8rem; display: flex; flex-direction: column; gap: .15rem; }
.cartao-prato-nome { font-weight: 800; line-height: 1.25; }
.cartao-prato-nome .video-link { font-size: 18px; }
.cartao-prato-sobre { color: var(--cinza); }
.cartao-prato-meta { color: var(--cinza); margin-top: .25rem; }

/* ---------- fotos e vídeos das receitas ---------- */

.foto-mini {
  width: 42px;
  height: 42px;
  object-fit: cover;
  border-radius: 10px;
  margin-right: .45rem;
  vertical-align: middle;
  border: 1px solid var(--linha);
}

.foto-receita {
  max-width: 100%;
  max-height: 220px;
  border-radius: 14px;
  border: 1px solid var(--linha);
}

.video-receita {
  max-width: 420px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--linha);
}

.video-link { color: var(--terracota); }
.video-link:hover { color: var(--verde-escuro); }

/* ---------- cardápio: dias ---------- */

.dia-data { white-space: normal; }
.dia-data b { font-size: 1.02rem; white-space: nowrap; }
.dia-data small { white-space: nowrap; }
/* selo hoje/amanhã sempre na linha de baixo da data
   (block + fit-content: display table engoliria o padding) */
.dia-data .badge {
  display: block;
  width: fit-content;
  margin-top: .25rem;
}

.semana-cab { border-bottom: 2px solid var(--linha); padding-bottom: .5rem; margin-bottom: .5rem; }

.titulo-semana {
  font-weight: 800;
  font-size: 1.02rem;
  color: var(--verde-escuro);
}
.titulo-semana .material-symbols-rounded { color: var(--verde); }
.titulo-semana:hover { color: var(--verde); }

/* ---------- lista de compras ---------- */

.secao-mercado {
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--terracota);
  margin: 1.3rem 0 .4rem;
}
.secao-mercado:first-child { margin-top: 0; }

.item-compra {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .3rem .6rem;
  padding: .32rem .2rem;
  border-bottom: 1px dashed var(--linha);
}

.mini-prato {
  display: inline-flex;
  align-items: baseline;
  gap: .3rem;
  background: var(--verde-fundo);
  border: 1px solid #d5e9dc;
  color: var(--verde-escuro);
  border-radius: 999px;
  padding: .05rem .55rem;
  font-size: .68rem;
  font-weight: 600;
  max-width: 160px;
  overflow: hidden;
  vertical-align: middle;
}
.mini-prato:hover { background: var(--verde-claro); color: var(--verde-escuro); }
.mini-prato .dias { flex-shrink: 0; }
.mini-prato .dias::after { content: ' –'; color: var(--cinza); font-weight: 400; }
.mini-prato .dia {
  color: #b7ae9d; /* tom claro no dia comum */
  font-weight: 800;
  text-transform: lowercase;
}
.mini-prato .dia-hoje { color: #d62828; }   /* vermelho: é hoje! */
.mini-prato .dia-amanha { color: #b8860b; } /* amarelo escuro: amanhã */
.mini-prato .nome {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.item-compra .item-nome { display: inline-flex; align-items: baseline; gap: .6rem; }
.item-compra input { transform: scale(1.15); }
.item-compra.riscado label { text-decoration: line-through; color: var(--cinza); }
.item-compra small { color: var(--cinza); }
.item-compra label { cursor: pointer; font-weight: 600; }

/* ---------- login ---------- */

.pagina-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(60rem 30rem at 110% -10%, rgba(47, 133, 90, .16), transparent 60%),
    radial-gradient(50rem 26rem at -20% 110%, rgba(231, 111, 81, .14), transparent 60%),
    var(--creme);
  padding: 1rem;
}

.cartao-login {
  background: var(--papel);
  border: 1px solid var(--linha);
  border-radius: 22px;
  box-shadow: 0 20px 60px rgba(43, 38, 32, .12);
  padding: 2.4rem 2.2rem 2rem;
  width: 100%;
  max-width: 380px;
  text-align: center;
}

.cartao-login img { margin-bottom: 1.6rem; }
.cartao-login .frase { color: var(--cinza); margin-bottom: 1.4rem; }

/* ---------- cardápio público ---------- */

.publico-topo { text-align: center; padding: 2.2rem 0 1rem; }

.grade-dias {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.cartao-dia {
  background: var(--papel);
  border: 1px solid var(--linha);
  border-radius: 18px;
  padding: 1rem 1.2rem;
  box-shadow: 0 6px 24px rgba(43, 38, 32, .05);
}

.cartao-dia.hoje { border: 2px solid var(--verde); }

.cartao-dia h3 { font-size: 1.05rem; font-weight: 800; margin-bottom: .2rem; }
.cartao-dia h3 small { color: var(--cinza); font-weight: 600; }

.refeicao-nome {
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--terracota);
  margin: .7rem 0 .1rem;
}

.cartao-dia ul { list-style: none; padding: 0; margin: 0; }
.cartao-dia li { padding: .12rem 0; font-weight: 600; }

/* ---------- impressão ---------- */

.pagina-imprimir { max-width: 900px; margin: 2rem auto; padding: 0 1.5rem; font-family: 'Nunito', sans-serif; }
.pagina-imprimir h2 { font-weight: 800; }

@media print {
  .barra, .rodape, .acoes, .nao-imprime, .btn { display: none !important; }
  body { background: #fff; }
  .painel { border: none; box-shadow: none; padding: 0; }
  .conteudo { padding-top: 0; }
}

/* ---------- responsivo ---------- */

@media (max-width: 768px) {
  .busca input { width: 130px; }
  .some-mobile { display: none; }
  .painel { overflow-x: auto; }
}
