:root {
  --vino-burgundy: #691929;
  --vino-cream: #F2E7DE;
  --vino-gold: #C7A97B;
  --vino-dark: #2B1B1B;
  --vino-gray: #EDECEC;
}

.card {
  border-radius: 16px !important;
}

.btn-vinyolo {
  background-color: #691929;
  color: #F2E7DE;
  border: none;
  transition: background-color 0.2s ease, transform 0.1s ease;
}
.btn-vinyolo:hover {
  background-color: #8C2A3A;
  color: #fff;
  transform: translateY(-1px);
}
.btn-vinyolo:active {
  transform: translateY(0);
  background-color: #591520;
}
/* --- Outline Variant --- */
.btn-vinyolo-outline {
  background-color: transparent;
  border: 2px solid #691929;
  color: #691929;
  font-weight: 500;
  transition: all 0.2s ease-in-out;
}

.btn-vinyolo-outline:hover,
.btn-vinyolo-outline:focus {
  background-color: #691929;
  color: #F2E7DE;
  border-color: #691929;
}
.table thead {
  background-color: #691929;
  color: #F2E7DE;
}
.btn {
  border-radius: 8px;
  font-weight: 500;
  padding: 0.55rem 1.2rem;
  transition: all 0.25s ease-in-out;
}
#ai-bubble {
  position: fixed;
  bottom: 25px;
  right: 25px;
  background: #691929;
  color: #f2e7de;
  font-size: 1.8rem;
  padding: 12px 16px;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 4px 10px rgba(0,0,0,0.3);
  transition: all 0.2s ease;
  z-index: 2000;
}
#ai-bubble:hover { transform: scale(1.1); }

#ai-panel {
  position: fixed;
  bottom: 90px;
  right: 25px;
  width: 260px;
  background: #fffdf9;
  border: 2px solid #691929;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.2);
  padding: 15px;
  display: none;
  z-index: 2001;
}
#ai-panel.open { display: block; }

#ai-panel input {
  width: 100%;
  margin-bottom: 8px;
  border: 1px solid #ccc;
  border-radius: 6px;
  padding: 6px;
}
#ai-panel button {
  width: 100%;
  background: #691929;
  color: #f2e7de;
  border: none;
  border-radius: 6px;
  padding: 6px;
}
#ai-panel button:hover {
  background: #8d2a3a;
}

.btn-vino-primary {
  background-color: var(--vino-burgundy);
  color: var(--vino-cream);
  border: none;
}
.btn-vino-primary:hover {
  background-color: #8c2336;
  box-shadow: 0 0 8px rgba(105, 25, 41, 0.3);
}

.btn-vino-outline {
  border: 1.5px solid var(--vino-burgundy);
  color: var(--vino-burgundy);
  background-color: transparent;
}
.btn-vino-outline:hover {
  background-color: var(--vino-burgundy);
  color: var(--vino-cream);
}

.btn-vino-danger {
  background-color: #b33939;
  color: white;
  border: none;
}
.btn-vino-danger:hover {
  background-color: #e15b5b;
}

.btn-vino-muted {
  background-color: var(--vino-gray);
  color: var(--vino-dark);
  border: none;
}
