:root {
  --av-bg: #f6f3ee;
  --av-surface: #ffffff;
  --av-ink: #251f1c;
  --av-muted: #746b64;
  --av-line: #e6ddd3;
  --av-primary: #7f1d2d;
  --av-primary-dark: #5f1220;
  --av-accent: #b9803f;
  --av-success: #28724f;
  --av-shadow: 0 18px 50px rgba(50, 32, 23, 0.12);
}

body.appvinho-page {
  background: var(--av-bg) !important;
  color: var(--av-ink);
}

body.appvinho-page .site-footer,
body.appvinho-page footer,
body.appvinho-page .wp-block-template-part,
body.appvinho-page .entry-title {
  display: none !important;
}

body.appvinho-page .site,
body.appvinho-page .site-content,
body.appvinho-page .content-area,
body.appvinho-page main,
body.appvinho-page article,
body.appvinho-page .entry-content {
  background: transparent !important;
}

body.appvinho-page .entry-content {
  margin: 0 !important;
  max-width: none !important;
  padding: 0 !important;
}

.av-app-shell {
  width: min(1120px, calc(100% - 32px));
  margin: 32px auto;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.av-app-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: 28px;
  border: 1px solid rgba(127, 29, 45, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(127, 29, 45, 0.95), rgba(75, 24, 32, 0.98)),
    var(--av-primary);
  box-shadow: var(--av-shadow);
  color: #fff;
}

.av-eyebrow {
  margin: 0 0 8px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.av-app-header h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.65rem, 3vw, 2.4rem);
  font-weight: 760;
  line-height: 1.08;
  letter-spacing: 0;
}

.av-subtitle {
  max-width: 680px;
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 1rem;
  line-height: 1.5;
}

.av-user-pill {
  flex: 0 0 auto;
  max-width: 240px;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  font-size: 0.86rem;
  font-weight: 650;
  text-align: center;
}

.av-app-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 14px 0;
}

.av-app-nav a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--av-line);
  border-radius: 8px;
  background: var(--av-surface);
  color: var(--av-ink);
  font-size: 0.94rem;
  font-weight: 700;
  text-decoration: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, color 160ms ease;
}

.av-app-nav a:hover,
.av-app-nav a:focus,
.av-app-nav a.is-active {
  border-color: rgba(127, 29, 45, 0.4);
  box-shadow: 0 8px 22px rgba(127, 29, 45, 0.09);
  color: var(--av-primary);
}

.av-app-content {
  min-height: 420px;
  padding: 26px;
  border: 1px solid var(--av-line);
  border-radius: 8px;
  background: var(--av-surface);
  box-shadow: 0 10px 30px rgba(50, 32, 23, 0.07);
}

.av-app-content .container,
.av-app-content .container-fluid {
  width: 100%;
  max-width: 100%;
  padding: 0;
  margin: 0;
}

.av-app-content h3,
.av-app-content h4,
.av-app-content h5 {
  margin: 0 0 16px;
  color: var(--av-ink);
  font-family: inherit;
  font-weight: 760;
  line-height: 1.2;
  letter-spacing: 0;
}

.av-app-content p,
.av-app-content li,
.av-app-content label,
.av-app-content .text-muted {
  font-size: 1rem;
  line-height: 1.55;
}

.av-app-content form,
.av-formulario,
.av-form-login,
.av-form-cadastro {
  max-width: 640px !important;
  margin: 0 auto !important;
}

.av-app-content .form-control,
.av-app-content input[type="text"],
.av-app-content input[type="tel"],
.av-app-content input[type="password"],
.av-app-content input[type="email"],
.av-app-content input[type="file"],
.av-app-content select,
.av-app-content textarea {
  min-height: 46px;
  border: 1px solid #d8cec3;
  border-radius: 8px;
  color: var(--av-ink);
  box-shadow: none;
}

.av-app-content textarea {
  min-height: 112px;
}

.av-app-content .form-control:focus,
.av-app-content input:focus,
.av-app-content select:focus,
.av-app-content textarea:focus {
  border-color: var(--av-primary);
  box-shadow: 0 0 0 3px rgba(127, 29, 45, 0.13);
  outline: none;
}

.av-app-content .btn {
  min-height: 44px;
  border-radius: 8px;
  padding: 10px 16px;
  font-weight: 750;
}

.av-app-content .btn-primary,
.av-app-content .btn-success {
  border-color: var(--av-primary);
  background: var(--av-primary);
  color: #fff;
}

.av-app-content .btn-primary:hover,
.av-app-content .btn-success:hover {
  border-color: var(--av-primary-dark);
  background: var(--av-primary-dark);
}

.av-app-content .btn-outline-primary,
.av-app-content .btn-outline-secondary,
.av-app-content .btn-outline-success,
.av-app-content .btn-outline-dark {
  border-color: #cbbdb0;
  color: var(--av-primary);
  background: #fff;
}

.av-app-content .btn-outline-primary:hover,
.av-app-content .btn-outline-secondary:hover,
.av-app-content .btn-outline-success:hover,
.av-app-content .btn-outline-dark:hover {
  border-color: var(--av-primary);
  background: rgba(127, 29, 45, 0.07);
  color: var(--av-primary-dark);
}

.av-app-content .card {
  overflow: hidden;
  border: 1px solid var(--av-line);
  border-radius: 8px;
  box-shadow: none !important;
}

.av-app-content .alert {
  border-radius: 8px;
  border-width: 1px;
}

.av-app-content img {
  max-width: 100%;
  height: auto;
}

#previewImagem,
#resultadoVinho,
#resultado-vinhos {
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

#btnProcurar {
  width: min(100%, 360px);
  min-height: 54px;
  font-size: 1.05rem;
}

#chat-mensagens {
  min-height: 360px;
  border: 1px solid var(--av-line) !important;
  border-radius: 8px !important;
}

#form-mensagem {
  max-width: 760px !important;
}

@media (max-width: 720px) {
  .av-app-shell {
    width: min(100% - 20px, 1120px);
    margin: 12px auto 24px;
  }

  .av-app-header {
    flex-direction: column;
    padding: 22px;
  }

  .av-user-pill {
    max-width: 100%;
  }

  .av-app-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .av-app-content {
    padding: 18px;
  }
}
