/* ============================================================
   FalaproDono — Design System
   Clean, minimalista, estilo Google. Pouquíssima coisa na tela.
   ============================================================ */

:root {
  /* Cores */
  --azul:        #1a73e8;
  --azul-escuro: #1557b0;
  --verde:       #1e8e3e;
  --vermelho:    #d93025;
  --amarelo:     #f9ab00;
  --laranja:     #e8710a;

  --texto:       #202124;
  --texto-suave: #5f6368;
  --borda:       #dadce0;
  --fundo:       #ffffff;
  --fundo-suave: #f8f9fa;

  --sombra:      0 1px 3px rgba(60,64,67,.15), 0 4px 8px rgba(60,64,67,.08);
  --sombra-hover:0 1px 3px rgba(60,64,67,.25), 0 6px 14px rgba(60,64,67,.12);

  --raio:        12px;
  --raio-g:      24px;
}

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

html, body { height: 100%; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  color: var(--texto);
  background: var(--fundo);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

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

/* ---------- Topo / header minimalista ---------- */
.topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 28px;
  font-size: 14px;
}
.topo a { color: var(--texto-suave); margin-left: 22px; }
.topo a:hover { color: var(--texto); text-decoration: none; }

/* ---------- Logo / marca ---------- */
.marca {
  font-family: -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-weight: 800;
  letter-spacing: -.5px;
  display: inline-flex;
  align-items: baseline;
}
.marca .fale  { color: #1c2430; }
.marca .pro   { color: #1c2430; }
.marca .dono  { color: #0a7d4f; }

/* ---------- Layout central tipo Google ---------- */
.centro {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px;
}
.logo-grande {
  font-size: clamp(44px, 7vw, 64px);
  font-weight: 800;
  letter-spacing: -2px;
  margin-bottom: 2px;
}
.tagline {
  font-weight: 700;
  font-size: clamp(14px, 2.3vw, 18px);
  letter-spacing: -.2px;
  background: linear-gradient(90deg, #46607a 0%, #2f7a55 55%, #138a3c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  margin-bottom: 20px;
}

/* ---------- Caixa de busca / CTA central ---------- */
.caixa-acao {
  width: 100%;
  max-width: 540px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* ---------- Barra de busca de empresa (estilo Google) ---------- */
.busca-wrap { position: relative; width: 100%; text-align: left; }
.busca-input {
  width: 100%;
  border: 1px solid #ededee;
  border-radius: 999px;
  padding: 19px 28px;
  font-size: 16px;
  font-family: inherit;
  color: var(--texto);
  background: #fff;
  box-shadow: 0 4px 16px rgba(60,64,67,.13);
  transition: box-shadow .15s;
}
.busca-input::placeholder { color: #9aa0a6; }
.busca-input:focus {
  outline: none;
  border-color: #e0e0e1;
  box-shadow: 0 6px 22px rgba(60,64,67,.20);
}
.busca-result {
  position: absolute;
  left: 0; right: 0;
  top: calc(100% + 8px);
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  box-shadow: var(--sombra-hover);
  overflow: hidden;
  z-index: 20;
}
.busca-item {
  padding: 13px 18px;
  cursor: pointer;
  font-size: 15px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.busca-item:hover { background: var(--fundo-suave); }
.busca-vazio { padding: 16px 18px; color: var(--texto-suave); font-size: 14px; }
.busca-vazio a { font-weight: 600; }

/* ---------- Botões ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: var(--raio);
  padding: 14px 22px;
  font-size: 15px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: box-shadow .15s, background .15s, transform .05s;
  background: var(--fundo-suave);
  color: var(--texto);
}
.btn:hover { box-shadow: var(--sombra); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-primario { background: var(--azul); color: #fff; }
.btn-primario:hover { background: var(--azul-escuro); }
.btn-verde { background: var(--verde); color: #fff; }
.btn-verde:hover { background: #176c30; }
.btn-contorno { background: #fff; border-color: var(--borda); color: var(--texto-suave); }
.btn-dono { background: #fff; border: 2px solid #0a7d4f; color: #0a7d4f; }
.btn-dono:hover { background: #e6f5ee; box-shadow: none; }
.btn-bloco { width: 100%; }
.btn-grande { padding: 16px 24px; font-size: 16px; }

/* ---------- Cartão genérico ---------- */
.cartao {
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 24px;
}

/* ---------- Página de conteúdo (formulário/painel) ---------- */
.pagina {
  max-width: 620px;
  margin: 0 auto;
  padding: 24px 20px 80px;
}
.pagina-larga { max-width: 980px; }

.titulo-pagina {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -.5px;
  margin-bottom: 6px;
}
.subtitulo-pagina {
  color: var(--texto-suave);
  margin-bottom: 28px;
}

/* ---------- Formulário ---------- */
.campo { margin-bottom: 20px; }
.campo label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 8px;
}
.campo input,
.campo textarea,
.campo select {
  width: 100%;
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 13px 14px;
  font-size: 15px;
  font-family: inherit;
  color: var(--texto);
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
}
.campo input:focus,
.campo textarea:focus,
.campo select:focus {
  outline: none;
  border-color: var(--azul);
  box-shadow: 0 0 0 3px rgba(26,115,232,.15);
}
.campo textarea { min-height: 130px; resize: vertical; }
.dica { font-size: 13px; color: var(--texto-suave); margin-top: 6px; }

/* ---------- Seletor de tipo (reclamação/sugestão/crítica/elogio) ---------- */
.tipos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.tipo {
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 16px 8px;
  text-align: center;
  cursor: pointer;
  background: #fff;
  transition: border-color .15s, box-shadow .15s, background .15s;
  user-select: none;
}
.tipo:hover { box-shadow: var(--sombra); }
.tipo .emoji { font-size: 26px; display: block; margin-bottom: 6px; }
.tipo .rotulo { font-size: 13px; font-weight: 600; }
.tipo.ativo { border-color: var(--azul); background: #e8f0fe; }
.tipo.ativo.reclamacao { border-color: var(--vermelho); background: #fce8e6; }
.tipo.ativo.sugestao   { border-color: var(--azul);     background: #e8f0fe; }
.tipo.ativo.critica    { border-color: var(--laranja);  background: #fef0e0; }
.tipo.ativo.elogio     { border-color: var(--verde);    background: #e6f4ea; }

/* ---------- Estrelas de nota ---------- */
.estrelas { display: flex; gap: 6px; font-size: 34px; }
.estrelas .estrela { cursor: pointer; color: var(--borda); transition: color .1s, transform .1s; }
.estrelas .estrela:hover { transform: scale(1.1); }
.estrelas .estrela.ativa { color: var(--amarelo); }

/* ---------- Mensagem de sucesso ---------- */
.sucesso {
  text-align: center;
  padding: 40px 20px;
}
.sucesso .icone {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--verde);
  color: #fff;
  font-size: 38px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
}

/* ---------- Painel: estatísticas ---------- */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 28px;
}
.stat {
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 18px;
  text-align: center;
}
.stat .num { font-size: 30px; font-weight: 700; }
.stat .rot { font-size: 13px; color: var(--texto-suave); margin-top: 2px; }
.stat.vermelho .num { color: var(--vermelho); }
.stat.azul .num { color: var(--azul); }
.stat.laranja .num { color: var(--laranja); }
.stat.verde .num { color: var(--verde); }

/* ---------- Painel: filtros ---------- */
.filtros { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.filtro {
  border: 1px solid var(--borda);
  background: #fff;
  border-radius: 999px;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  color: var(--texto-suave);
}
.filtro.ativo { background: var(--texto); color: #fff; border-color: var(--texto); }

/* ---------- Painel: item de feedback ---------- */
.feedback-item {
  background: #fff;
  border: 1px solid var(--borda);
  border-left: 4px solid var(--borda);
  border-radius: var(--raio);
  padding: 18px 20px;
  margin-bottom: 12px;
}
.feedback-item.reclamacao { border-left-color: var(--vermelho); }
.feedback-item.sugestao   { border-left-color: var(--azul); }
.feedback-item.critica    { border-left-color: var(--laranja); }
.feedback-item.elogio     { border-left-color: var(--verde); }

.feedback-topo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.feedback-tag {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 3px 10px;
  border-radius: 999px;
}
.feedback-tag.reclamacao { background: #fce8e6; color: var(--vermelho); }
.feedback-tag.sugestao   { background: #e8f0fe; color: var(--azul); }
.feedback-tag.critica    { background: #fef0e0; color: var(--laranja); }
.feedback-tag.elogio     { background: #e6f4ea; color: var(--verde); }
.feedback-data { font-size: 12px; color: var(--texto-suave); }
.feedback-nota { color: var(--amarelo); font-size: 14px; margin-bottom: 6px; }
.feedback-msg { font-size: 15px; color: var(--texto); white-space: pre-wrap; }
.feedback-contato { font-size: 13px; color: var(--texto-suave); margin-top: 10px; }

/* ---------- Caixa de QR Code ---------- */
.qr-box { text-align: center; }
.qr-box img { border: 1px solid var(--borda); border-radius: var(--raio); padding: 12px; background:#fff; }

/* ---------- Placa imprimível (minimalista — versão oficial) ---------- */
.placa {
  width: 340px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--borda);
  border-radius: 22px;
  padding: 34px 28px;
  text-align: center;
  box-shadow: 0 12px 34px rgba(60,64,67,.14);
}
.placa-pergunta {
  font-family: -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 25px;
  font-weight: 800;
  letter-spacing: -.5px;
  line-height: 1.15;
  color: #1c2430;
}
.placa-marca {
  font-size: 36px;
  letter-spacing: -1.2px;
  margin-top: 8px;
}
.placa-tipos {
  font-size: 13px;
  font-weight: 600;
  color: #5b6678;
  margin-top: 6px;
}
.placa-qr {
  width: fit-content;
  margin: 24px auto 0;
  padding: 14px;
  border: 1px solid var(--borda);
  border-radius: 14px;
}
.placa-qr img { display: block; margin: 0 auto; }
.placa-aponte {
  font-size: 12.5px;
  color: var(--texto-suave);
  margin-top: 14px;
}
/* Gancho de crescimento orgânico: atrai outros donos que veem a plaquinha */
.placa-dono {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px dashed var(--borda);
  font-size: 11px;
  color: var(--texto-suave);
}
.placa-dono strong { color: #0a7d4f; }

/* ---------- Utilidades ---------- */
.vazio { text-align: center; color: var(--texto-suave); padding: 50px 20px; }
.linha { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.entre { justify-content: space-between; }
.mt { margin-top: 24px; }
.mb { margin-bottom: 24px; }
.rodape { text-align: center; color: var(--texto-suave); font-size: 13px; padding: 24px; }
.aviso {
  background: var(--fundo-suave);
  border: 1px solid var(--borda);
  border-radius: var(--raio);
  padding: 14px 16px;
  font-size: 14px;
  color: var(--texto-suave);
  margin-bottom: 24px;
}

/* ---------- Responsivo ---------- */
@media (max-width: 560px) {
  .tipos { grid-template-columns: repeat(2, 1fr); }
  .stats { grid-template-columns: repeat(2, 1fr); }
}

@media print {
  .topo, .rodape, .btn, .no-print { display: none !important; }
  .placa { border-width: 3px; }
}
