:root {
  --color-black: #111111;
  --color-burgundy: #7a1f2b;
  --color-olive: #5a6b3d;
  --color-cream: #f6f1e7;
  --color-text: #333333;
  --color-text-light: #f6f1e7;
}

body {
  font-family: 'Source Sans 3', sans-serif;
  background-color: var(--color-black);
  color: var(--color-text-light);
  margin: 0;
  padding: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  color: var(--color-cream);
}

@media (max-width: 768px) {
  h1.display-1 { font-size: 3rem; }
  h2.display-3 { font-size: 2.5rem; }
  h2.display-4 { font-size: 2rem; }
}

/* Parallax Style */
.parallax {
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 600px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Fix for mobile parallax issues */
@media (max-width: 1024px) {
  .parallax {
    background-attachment: scroll; /* Fallback for mobile */
    min-height: 400px;
  }
}

.parallax::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 1;
}

.parallax-content {
  position: relative;
  z-index: 2;
  padding: 20px;
}

/* Sections */
.section {
  padding: 100px 0;
  background-color: var(--color-black);
}

@media (max-width: 768px) {
  .section {
    padding: 60px 0;
  }
}

.section-cream {
  background-color: var(--color-cream);
  color: var(--color-text);
}

.section-cream h2, .section-cream h3 {
  color: var(--color-black);
}

/* Parallax Backgrounds */
.bg-hero {
  background-image: url('https://images.unsplash.com/photo-1510850431481-7568554b2f1c?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80');
}

.bg-separator {
  background-image: url('https://images.unsplash.com/photo-1506377247377-2a5b3b417ebb?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80');
}

.bg-products {
  background-image: url('https://images.unsplash.com/photo-1474722883778-792e7990302f?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80');
}

.bg-damajuana {
  background-image: url('https://images.unsplash.com/photo-1534113414509-0eec2bfb493f?ixlib=rb-4.0.3&auto=format&fit=crop&w=1920&q=80');
}

/* Specific elements */
.navbar {
  background-color: rgba(17, 17, 17, 0.95) !important;
  border-bottom: 1px solid var(--color-burgundy);
  transition: all 0.3s;
}

@media (max-width: 991px) {
  .navbar-collapse {
    background-color: var(--color-black);
    padding: 20px;
    border-top: 1px solid var(--color-burgundy);
    margin-top: 10px;
  }
}

.navbar-brand {
  font-family: 'Playfair Display', serif;
  font-size: 1.8rem;
  color: var(--color-burgundy) !important;
  font-weight: bold;
}

.nav-link {
  color: var(--color-cream) !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0 10px;
}

.nav-link:hover {
  color: var(--color-burgundy) !important;
}

.btn-burgundy {
  background-color: var(--color-burgundy);
  color: var(--color-cream);
  border: none;
  padding: 12px 30px;
  border-radius: 2px;
  text-transform: uppercase;
  font-weight: bold;
  letter-spacing: 1px;
  transition: 0.3s;
}

.btn-burgundy:hover {
  background-color: var(--color-olive);
  color: var(--color-cream);
}

.btn-outline-burgundy {
  background-color: transparent;
  color: var(--color-burgundy);
  border: 2px solid var(--color-burgundy);
  padding: 10px 25px;
  text-transform: uppercase;
  font-weight: bold;
}

.btn-outline-burgundy:hover {
  background-color: var(--color-burgundy);
  color: var(--color-cream);
}

/* Cards */
.card-wine {
  background-color: #1a1a1a;
  border: 1px solid #333;
  color: var(--color-cream);
  transition: transform 0.3s;
  height: 100%;
}

.card-wine:hover {
  transform: translateY(-10px);
  border-color: var(--color-burgundy);
}

@media (max-width: 576px) {
  .card-wine:hover {
    transform: none; /* Desactivar efecto hover en móviles pequeños para evitar saltos */
  }
}

.card-wine .card-title {
  color: var(--color-burgundy);
}

/* Footer */
footer {
  background-color: #0a0a0a;
  padding: 50px 0 20px;
  border-top: 3px solid var(--color-burgundy);
}

.footer-logo {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  color: var(--color-burgundy);
}

.social-links a {
  color: var(--color-cream);
  font-size: 1.5rem;
  margin-right: 15px;
  transition: 0.3s;
}

.social-links a:hover {
  color: var(--color-olive);
}

/* Form Placeholders - Versión ultra-compatible para móviles */
input.form-control::-webkit-input-placeholder,
textarea.form-control::-webkit-input-placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
  -webkit-text-fill-color: #ffffff !important;
}

input.form-control:-moz-placeholder,
textarea.form-control:-moz-placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
}

input.form-control::-moz-placeholder,
textarea.form-control::-moz-placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
}

input.form-control:-ms-input-placeholder,
textarea.form-control:-ms-input-placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
}

input.form-control::placeholder,
textarea.form-control::placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
}

/* Forzar que el campo no tenga estilos internos de iOS que oculten el texto */
.form-control {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-clip: padding-box;
}

/* Ajuste específico para los inputs oscuros */
.form-control.bg-dark {
  background-color: #222222 !important;
  color: #ffffff !important;
  border: 1px solid #444444 !important;
}
