@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&display=swap');

:root {
  --color-earth: #8B4513;
  /* SaddleBrown - Primária */
  --color-earth-dark: #5D2E0C;
  --color-gold: #D4AF37;
  /* Dourado - Destaques */
  --color-cream: #F5F5DC;
  /* Bege/Creme - Fundo */
  --color-cream-dark: #E5E5C0;
  --color-wine: #800000;
  /* Vinho - Apenas detalhes */
  --color-white: #ffffff;
  --color-text: #2c1a0a;
  /* Marrom muito escuro para texto */
}

body {
  background-color: var(--color-cream);
  color: var(--color-text);
  font-family: 'Plus Jakarta Sans', sans-serif;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Navbar overrides */
#mainNav {
  background-color: var(--color-earth);
  border-bottom: 2px solid var(--color-gold);
}

#mainNav .navbar-brand,
#mainNav .nav-link {
  color: var(--color-white) !important;
  font-weight: 700;
}

#mainNav .nav-link:hover {
  color: var(--color-gold) !important;
}

/* Navbar Toggle for Mobile */
.navbar-toggler {
  color: var(--color-white) !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgb%28255, 255, 255%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Header/Masthead */
header.masthead {
  position: relative;
  background-color: var(--color-earth);
}

header.masthead .site-heading h1,
header.masthead .site-heading h2,
header.masthead .post-heading h1 {
  color: var(--color-gold);
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
  text-align: center;
  line-height: 1.2;
}

header.masthead .site-heading h1 {
  font-size: 3.5rem;
}

header.masthead .site-heading h2 {
  font-size: 2.5rem;
}

header.masthead .subheading {
  color: var(--color-cream);
}

header.masthead .meta {
  color: var(--color-gold);
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5);
  font-size: 1.25rem;
  font-weight: 300;
  margin-bottom: 0px;
  display: block;
}

header.masthead .meta a {
  color: var(--color-white) !important;
  text-decoration: underline;
}

/* Posts */
.post-preview>a {
  color: var(--color-text);
}

.post-preview>a:hover {
  color: var(--color-earth);
}

.post-title {
  color: var(--color-earth);
}

.post-meta {
  color: #5D2E0C;
  font-style: italic;
}

.post-meta>a {
  color: var(--color-earth);
  font-weight: 700;
  text-decoration: none;
}

.post-meta>a:hover {
  color: var(--color-gold);
  text-decoration: underline;
}

/* Buttons */
.btn-primary {
  background-color: var(--color-earth);
  border-color: var(--color-earth);
}

.btn-primary:hover {
  background-color: var(--color-earth-dark);
  border-color: var(--color-earth-dark);
}

.btn-outline-dark {
  color: var(--color-earth);
  border-color: var(--color-earth);
}

.btn-outline-dark:hover {
  background-color: var(--color-earth);
  color: var(--color-white);
}

/* Footer */
footer {
  background-color: var(--color-earth-dark);
  color: var(--color-cream);
  padding: 3rem 0;
  margin-top: auto;
}

footer .fa-circle {
  color: var(--color-gold);
}

footer .fa-inverse {
  color: var(--color-earth-dark);
}

footer .text-muted {
  color: #F0EDD8 !important;
}

footer a {
  color: #F0EDD8;
  text-decoration: underline;
}

footer a:hover {
  color: var(--color-gold);
}

/* General improvements */
img {
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.form-control:focus {
  border-color: var(--color-gold);
  box-shadow: 0 0 0 0.25rem rgba(212, 175, 55, 0.25);
}

/* Details in Wine */
.border-top {
  border-top: 2px solid var(--color-wine) !important;
}

/* Search bar */
#searchInputBlog {
  border: 2px solid var(--color-earth);
  border-radius: 25px;
  padding: 10px 20px;
}

/* Shopping Cart Harmony */
.cart-icon {
  color: var(--color-gold) !important;
}

.cart-badge {
  background-color: var(--color-gold) !important;
  color: var(--color-earth-dark) !important;
}

/* Modal Styling */
.modal-content {
  background-color: var(--color-cream);
  border: 2px solid var(--color-earth-dark);
}

.modal-header {
  background-color: var(--color-earth-dark);
  color: var(--color-gold);
  border-bottom: 2px solid var(--color-gold);
}

.modal-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
}

.modal-header .btn-close {
  filter: invert(1) sepia(1) saturate(5) hue-rotate(10deg);
}

#carrinho-lista .list-group-item {
  background-color: transparent;
  border-color: rgba(93, 46, 12, 0.2);
}

.total-geral {
  color: var(--color-earth-dark);
  font-weight: 800;
}

.modal-footer {
  background-color: var(--color-cream);
  border-top: 1px solid var(--color-gold);
}

/* Add to Cart - In Cart State */
.btn-in-cart {
  background-color: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  color: var(--color-earth-dark) !important;
  transition: all 0.3s ease;
}

.btn-in-cart:hover {
  background-color: var(--color-earth-dark) !important;
  border-color: var(--color-earth-dark) !important;
  color: var(--color-gold) !important;
}

/* Welcome Modal Styling */
.modal-boas-vindas {
  background-color: rgba(0, 0, 0, 0.75);
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  backdrop-filter: blur(5px);
}

.modal-content-boas-vindas {
  background-color: var(--color-cream);
  margin: 5% auto;
  padding: 0;
  width: 90%;
  max-width: 500px;
  text-align: center;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
  border: 3px solid var(--color-earth-dark);
  position: relative;
  overflow: hidden;
}

.modal-content-boas-vindas h2 {
  color: var(--color-earth-dark);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  margin-top: 20px;
}

.modal-content-boas-vindas p {
  padding: 0 20px 20px;
  color: var(--color-text);
}

.close-btn-boas-vindas {
  position: absolute;
  right: 15px;
  top: 10px;
  color: var(--color-white);
  font-size: 32px;
  font-weight: bold;
  cursor: pointer;
  z-index: 10;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}

.close-btn-boas-vindas:hover {
  color: var(--color-gold);
}

/* Contact Form Feedback */
.php-email-form .loading {
  background: var(--color-white);
  padding: 15px;
  border-radius: 8px;
  color: var(--color-earth);
  font-weight: 600;
}

.php-email-form .error-message {
  background: #f8d7da;
  color: #721c24;
  padding: 15px;
  border-radius: 8px;
  border: 1px solid #f5c6cb;
  margin-bottom: 15px;
}

.php-email-form .sent-message {
  background: #d4edda;
  color: #155724;
  padding: 15px;
  border-radius: 8px;
  border: 1px solid #c3e6cb;
  margin-bottom: 15px;
  font-weight: 600;
}

.d-block {
  display: block !important;
}

.d-none {
  display: none !important;
}