/* #region Reset basico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

button,
button:hover,
button:active,
button:focus {
    cursor: pointer;
    text-shadow: none;
    box-shadow: none;
    border: none;
    background: none;
}
/* #endregion Reset basico */

/* === VARIABLES CSS === */
:root {
  /* === Primary Color Palette === */
--color-primary: #D4AF37; /* Dorado más saturado y vibrante */
--color-primary-light: color-mix(in srgb, var(--color-primary) 70%, white);
--color-primary-dark: color-mix(in srgb, var(--color-primary) 70%, black);
--color-on-primary: #FFFFFF;
  --color-on-primary-80:     rgba(255, 255, 255, 0.8);
  --color-primary-dark: color-mix(in srgb, var(--color-primary) 70%, black);
  --color-secondary:      #1E1E1E; /* Secondary brand color (dark gray) */
  --color-secondary-light: color-mix(in srgb, var(--color-secondary) 30%, white);
  --color-secondary-dark: color-mix(in srgb, var(--color-secondary) 70%, black);
  --color-on-secondary:   #F7F6F2; /* Text/icon color on secondary */
  --color-tertiary:       #7A8B6F; /* Tertiary brand color (muted green) */
  --color-on-tertiary:    #FFFFFF; /* Text/icon color on tertiary */

  /* === Neutral Palette === */
  --neutral-100:          #F7F6F2; /* Lightest neutral (backgrounds) */
  --neutral-300:          #D8D6CF; /* Light neutral (subtle backgrounds) */
  --neutral-500:          #A8A79F; /* Mid neutral (borders, dividers) */
  --neutral-700:          #5E5D58; /* Dark neutral (text, accents) */
  --neutral-900:          #2B2A27; /* Darkest neutral (backgrounds, text) */

  /* === Semantic Colors === */
  --color-success:        #489647; /* Success state (e.g., buttons, alerts) */
  --color-success-dark:   #3f7e3e; 
  --color-error:          #D9534F; /* Error state (e.g., validation) */
  --color-warning:        #f8c702; /* Warning state (e.g., alerts) */
  --color-warning-dark:   #e0b506;
  --color-info:           #5bc0de; /* Info state (e.g., tooltips) */

  /* === Role-Based Colors === */
  --background-color:     var(--neutral-100); /* Default background */
  --background-color-transparent: var(--color-on-primary-80); /* Transparent white background */
  --text-color:           var(--neutral-900); /* Primary text */
  --text-color-light:     var(--neutral-100); /* Light text for dark backgrounds */
  --title-color:          var(--neutral-900); /* Titles and headings */
  --accent-color:         var(--color-primary); /* Highlights, buttons, links */
  --background-color-alt: #E3DBCC; /* Beige cálido, con tinte meloso */
  --background-color-alt-lighter: #F4EFE6; /* Marfil con matiz dorado */
  --background-color-alt-transparent: color-mix(in srgb, #E3DBCC 85%, transparent);

  /* === WFGraphics Colors (for footer or specific components) === */
  --wf-bg:                #151C25; /* Footer background */
  --wf-border:            #799C9B; /* Footer border */
  --wf-strip:             #4C6160; /* Footer animation strip */
  --wf-text:              #B2CFCD; /* Footer text */

  /* === Typography === */
  --font-family-primary:   "Montserrat", sans-serif;
  --font-family-secondary: "Playfair Display", serif;
  --font-weight-light:     300;
  --font-weight-normal:    400;
  --font-weight-semibold:  600;
  --font-weight-bold:      700;
  --font-size-base:        16px;
  --font-size-sm:          0.875rem; /* 14px */
  --font-size-md:          1rem;     /* 16px h6 */
  --font-size-lg:          1.25rem;  /* 20px h5 */
  --font-size-h4:          1.125rem;  /* 18px */
  --font-size-h3:          1.5rem;   /* 24px */
  --font-size-h2:          1.75rem;  /* 28px */
  --font-size-h1:          2rem;     /* 32px */
  --font-title:            var(--font-weight-bold) var(--font-size-h1) / 1.2 var(--font-family-primary);
  --font-subtitle:         var(--font-weight-semibold) var(--font-size-h2) / 1.3 var(--font-family-primary);
  --font-text-normal:      var(--font-weight-normal) var(--font-size-md) / 1.5 var(--font-family-primary);

  /* === Spacing === */
  --spacing-xx-small:      0.25rem; /* 4px */
  --spacing-small:         0.5rem;  /* 8px */
  --spacing-medium:        1rem;    /* 16px */
  --spacing-large:         1.5rem;  /* 24px */
  --spacing-x-large:       2rem;    /* 32px */

  /* === Border Radius === */
  --border-radius-small:   4px;
  --border-radius-medium:  8px;
  --border-radius-large:   12px;

  /* === Shadows === */
  --shadow-xs:             0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-sm:             0 2px 4px rgba(0, 0, 0, 0.1);
  --shadow-md:             0 4px 8px rgba(0, 0, 0, 0.15);
  --shadow-lg: 0 10px 20px rgba(0, 0, 0, 0.15);
  --shadow-xl: 0 20px 40px rgba(0, 0, 0, 0.2);

  /* === Transitions === */
  --transition-duration-default: 0.3s;
  --transition-duration-fast:    0.2s;
  --transition-duration-slow:    0.6s;

  --transition-easing-smooth:    ease-in-out;

  /* === Gradients === */
  --gradient-sky-light:    linear-gradient(to top, var(--color-primary), var(--neutral-100) 80%);
  --gradient-sky-horizontal: linear-gradient(to right, var(--neutral-100), var(--color-primary));
  --gradient-honey-soft:   linear-gradient(to bottom right, var(--color-primary), var(--neutral-100));
  --gradient-tertiary:     linear-gradient(to top, var(--color-tertiary), var(--neutral-100));
  --gradient-secondary:    linear-gradient(to bottom, var(--color-secondary), var(--neutral-900));
}

/* === Gradient Classes === */
.gradient--sky-light {
  background: var(--gradient-sky-light); /* Linear gradient: --color-primary to --neutral-100 */
}
.gradient--sky-horizontal {
  background: var(--gradient-sky-horizontal); /* Linear gradient: --neutral-100 to --color-primary */
}
.gradient--honey-soft {
  background: var(--gradient-honey-soft); /* Linear gradient: --color-primary to --neutral-100 */
}
.gradient--tertiary {
  background: var(--gradient-tertiary); /* Linear gradient: --color-tertiary to --neutral-100 */
}
.gradient--secondary {
  background: var(--gradient-secondary); /* Linear gradient: --color-secondary to --neutral-900 */
}

/* === Headings === */
h1 {
  font: var(--font-title);
  color: var(--title-color);
}

h2 {
  color: var(--color-text);
  font: var(--font-subtitle);
  margin-bottom: var(--spacing-medium);
}

h3 {
  font: var(--font-weight-normal) var(--font-size-h3) / 1.3 var(--font-family-primary);
  color: var(--neutral-700); /* --neutral-900 */
  margin: var(--spacing-medium) 0;
}

h4 {
  font: var(--font-weight-medium) var(--font-size-h4) / 1.3 var(--font-family-primary); /* Use --font-size-lg instead of removed --font-size-h4 */
  color: var(--neutral-900);
  margin: var(--spacing-small) 0;
}

h5 {
  font: var(--font-weight-medium) var(--font-size-h5) / 1.3 var(--font-family-primary); /* Use --font-size-md instead of removed --font-size-h5 */
  color: var(--title-color); /* --neutral-900 */
  margin: var(--spacing-small) 0;
}

h6 {
  font: var(--font-weight-medium) var(--font-size-sm) / 1.3 var(--font-family-primary);
  color: var(--title-color);
}

/* === Paragraphs === */
p {
  margin: var(--spacing-medium) 0;
  font-family: var(--font-family-primary);
  font-weight: var(--font-weight-normal);
  color: var(--text-color); 
}

/* === Links and Lists === */
a, ul, ol, li {
  list-style: none !important;
  text-decoration: none;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-md);
}
i {
  font-size: var(--font-size-md2);
  transition: font-size 0.3s ease-in, transform 0.3s ease-in-out;
}
i:hover {
  font-size: var(--font-size-lg);
  transform: scale(1.05);
}

/* === Common Icon Styles === */
.a-icon.a-icon-small-add,
.a-icon.a-icon-small-add-disabled,
.a-icon.a-icon-small-remove,
.a-icon.a-icon-small-remove-disabled,
.a-icon.a-icon-small-trash,
.a-icon.a-icon-small-trash-disabled {
  background-image: url(https://m.media-amazon.com/images/S/sash/3FFjjnZ6FBQZUp2.png);
  background-size: 512px 512px;
  background-repeat: no-repeat;
  display: inline-block;
  height: 16px;
  width: 16px;
}

.a-icon-small-trash {
  background-position: -310px -145px;
}

/* Estilos adicionales para nuevas secciones */
body {
    font-family: var(--font-family-secondary);
    background-color: var(--color-white);
    color: var(--text-color);
    line-height: 1.6;
    padding-top: 70px;
}

.container-bg {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-large);
  text-align: center;
  position: relative;
  background: url('../assets/images/bg/bg-paisaje-001.webp') center/cover no-repeat;
  background-attachment: fixed;
  overflow: hidden;
  isolation: isolate;
}

.container-bg-b {
  padding: var(--spacing-large);
  position: relative;
  background: url('../assets/images/bg/bg-paisaje-001.webp') center/cover no-repeat;
  background-attachment: fixed;
  overflow: hidden;
  isolation: isolate;
}
.container {
  background: var(--background-color-transparent);
  padding: var(--spacing-large);
  margin-top: 0;
  margin-bottom: var(--spacing-large);
  display: block;
  box-sizing: border-box;
  text-align: center;
  border-radius: var(--border-radius-small);
  width: 85%;
  margin-left: auto;  /* Añade esto */
  margin-right: auto; /* Añade esto */
}

.container__wide {
  background: var(--background-color-transparent);
  padding: var(--spacing-large);
  margin-top: 0;
  display: block;
  box-sizing: border-box;
  text-align: center;
  border-radius: var(--border-radius-small);
}
/* Tarjetas Sercicios */

.container__contenido {
  padding: var(--spacing-medium);
  position: relative;
  margin: 0;
}

.container__card-wide {
    padding: var(--spacing-medium);

  border-radius: var(--border-radius-medium);
}

.container__card-wide img {
  width: 100%;
  height: 200px;
  object-fit: cover; /* Mantiene proporciones y cubre el área */
  display: block; /* Elimina espacio inferior por defecto de las imágenes */
}

.catalogo-texto,
.catalogo-texto-x2 {
  display: grid;
  gap: var(--spacing-large);
  box-sizing: border-box;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.catalogo-servicios__item {
  position: relative;
  background: var(--background-color);
  border: 1px solid var(--neutral-300);
  border-radius: var(--border-radius-large);
  box-shadow: var(--shadow-sm);
  padding: var(--spacing-medium);
  transition: transform var(--transition-duration-slow) var(--transition-easing-smooth),
              box-shadow var(--transition-duration-slow) var(--transition-easing-smooth),
              padding-top var(--transition-duration-slow) var(--transition-easing-smooth);
  text-align: left;
  overflow: hidden;
  min-height: 150px;
}

.catalogo-servicios__item::before {
  content: '';
  display: block;
  width: 100%;
  height: 200px; /* Adjust based on image aspect ratio if needed */
  background-size: cover;
  background-position: center;
  border-radius: var(--border-radius-large) var(--border-radius-large) 0 0;
  opacity: 0; /* Initially hidden */
  transition: opacity var(--transition-duration-slow) var(--transition-easing-smooth);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0; /* Behind content */
}

/* Unique images for each card */
.catalogo-servicios__item.instalacion::before {
  background-image: url('../assets/images/other/apiario.jpg');
}

.catalogo-servicios__item.capacitacion::before {
  background-image: url('../assets/images/other/capacitacion.jpg');
}

.catalogo-servicios__item.investigacion::before {
  background-image: url('../assets/images/other/investigacion.jpg');
}

.catalogo-servicios__item.mantenimiento::before {
  background-image: url('../assets/images/other/mantenimiento.jpg');
}

.catalogo-servicios__item:hover::before,
.catalogo-servicios__item:active::before {
  opacity: 1; /* Fade in on hover/tap */
}

.catalogo-servicios__item:hover,
.catalogo-servicios__item:active {
  padding-top: calc(var(--spacing-medium) + 200px); /* Expand card for image */
  transform: translateY(-4px) scale(1.02);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary);
}

.catalogo-texto__item {
  position: relative;
  background: var(--background-color-alt-lighter);
  border: 1px solid var(--neutral-300);
  border-radius: var(--border-radius-large);
  box-shadow: var(--shadow-sm);
  padding: var(--spacing-medium);
  transition: transform var(--transition-duration-default) var(--transition-easing-smooth),
              box-shadow var(--transition-duration-default) var(--transition-easing-smooth);
  text-align: left;
  overflow: hidden;
  min-height: 150px;
}

.catalogo-texto__item:hover,
.catalogo-texto__item:active {
  transform: scale(1.02);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary);
}


.catalogo-servicios__item h2,
.catalogo-servicios__item p {
  position: relative;
  z-index: 1; /* Above image */
}

.catalogo-servicios__item h2,
.catalogo-texto__item h2 {
  text-align: center;
  margin-bottom: var(--spacing-small);
  margin-top: var(--spacing-small);
}

.catalogo-texto__item p {
  font-family: var(--font-family-primary);
  color: var(--text-color);
  line-height: 1.6;

}

.catalogo-texto__item ul {
  list-style: none;
}

@media (min-width: 1024px) {
  .container {
    width: 90%;
  }
  .catalogo-texto {
    grid-template-columns: repeat(3, 1fr);
  }
  .catalogo-texto-x2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .container {
    width: 100%;
  }
}

@media (max-width: 576px) {
  .container-bg {
    background-attachment: scroll;
    top: -15px;
    padding: var(--spacing-large) 0 0 0;

  }
  .container {
    width: 100%;
  }
}
/* #endregion Estilos Comunes */

/* #region nav */
.nav {
    width: 100%;
    height: 70px;
    background-color: var(--neutral-900);
    display: flex;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    box-shadow: var(--shadow-xs);
}

.nav__logo {
    display: flex;
    gap: 10px;
}

.nav__logo-text {
    height: 55px;
    margin-top: 5px;
}

.nav__logo-symbol {
    margin-top: 5px;
    height: 60px;
    margin-left: -5px;
    position: relative;
    display: inline-block;
    transition: transform 0.8s ease-in-out;
}

.nav__logo-container {
    position: relative;
    display: inline-block;
    text-decoration: none;
    min-width: 210px;
}

.nav__logo-container::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0);
    border-radius: 4px;
    pointer-events: none;
}

.nav__logo-container img {
    pointer-events: none;
    user-select: none;
    -webkit-user-drag: none;
}

.nav__right {
    display: flex;
    align-items: center;
    margin-right: 10px;
    margin-left: auto;
}

.nav__hamburger {
    display: none;
    background: none;
    border: none;
    color: var(--color-white); /* Changed to use variable */
    font-size: var(--font-size-xl);
    font-family: var(--font-family-secondary);
    cursor: pointer;
}

.nav__menu {
    list-style: none;
    display: flex;
    margin: 0;
}

.nav__menu a {
    color: var(--color-on-primary); 
    background-color: var(--neutral-900);
    padding: var(--spacing-small);
    text-decoration: none;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-family-primary);
    font-size: var(--font-size-md); /* Replaced --font-size-h5 */
    font-weight: var(--font-weight-light);
    line-height: 1.3;
    transition: all .3s ease-in-out;
}

.nav__menu a:hover {
    color: var(--background-color);
    background-color: var(--neutral-700);
}

.desktop-only {
    margin-left: var(--spacing-small);
    display: none;
}

.hamburger-icon {
    font-size: var(--font-size-h1);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-family-secondary);
    color: var(--neutral-300);
}

.hamburger-icon:hover {
    color: var(--neutral-500); /* Adjusted to a dark background color */
}

.nav__cart-btn {
    padding: 0;
    margin-left: 50px;
    display: inline-flex;
    align-items: center;
}

.nav__cart-icon {
    width: 45px;
    height: 45px;
    position: absolute;
    right: 15px;
    animation: parpadeo 1.5s infinite;
}

@keyframes parpadeo {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.6;
    }
}

.nav__cart-icon:hover {
    transform: scale(1.4);
    border: var(--warning-color) 1px solid; /* Adjusted to new variable */
    border-radius: 3px;
    padding: 5px;
}

.cart-count {
    position: absolute;
    top: 12px;
    right: 10px;
    background-color: var(--warning-color); /* Adjusted to new variable */
    color: var(--color-on-primary);
    border-radius: 50%;
    width: 25px;
    height: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-family-primary);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
}

.cart-count:hover {
    color: var(--color-warning);
}

.cart-count--animate {
    animation: pulse 0.6s ease-in-out;
}

@keyframes pulse {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.4);
        background-color: var(--primary-color-dark);
        color: var(--warning-color); /* Adjusted to new variable */
        border: var(--warning-color) 3px solid; /* Adjusted to new variable */
    }
    100% {
        transform: scale(1);
    }
}
/* #endregion nav */

/* Hero Section */
.hero {
    height: calc(70vh - 130px);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--text-color);
    position: relative;
    z-index: 2;
}s

.hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url('../assets/images/bg/bg-local-001-.png') no-repeat center/cover;
    opacity: 0.25;
}
.hero::after {
    content: '';
    position: absolute;
    top: 10%;
    left: -15%; /* Centra horizontalmente */
    transform: translateX(0); /* Ajuste fino para centrado */
    width: 400px; /* Ancho fijo */
    height: 800px;
    /* background: url('../assets/images/Apicultor.webp') no-repeat top center/cover; */
    overflow: hidden; /* Oculta el excedente */
}

.hero__content {
    position: relative;
    z-index: 1;
    max-width: 800px;
    padding: var(--spacing-large);
      background: var(--background-color-transparent);

}

.hero h1 {
    font-family: var(--font-family-tertiary);
    font-size: var(--font-size-2xl);
    margin-bottom: var(--spacing-medium);
}

.hero p {
    max-width: 800px;
    margin: 0 auto var(--spacing-large);
    font-size: var(--font-size-md2);
    line-height: 1.6;
    color: var(--text-color);
}

/* .btn .btn--primary .btn--primary:hover Ver en Form */

/* Productos */
.losproductos {
    padding: var(--spacing-large);
    text-align: center;
    background: var(--color-white);
}

/* Scroll Indicator */
.scroll-indicator {
    position: fixed;
    bottom: calc(34vh);
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    animation: float 1.4s cubic-bezier(0.4, 0, 0.2, 1) infinite;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

@keyframes float {
    0%, 100% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(-10px);
    }
}

.scroll-indicator.hidden {
    opacity: 0;
    visibility: hidden;
}

.scroll-arrow {
    display: flex;
    justify-content: center;
    align-items: center;
    width: var(--spacing-x-large);
    height: var(--spacing-x-large);
}

.scroll-arrow, .scroll-top {
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: var(--shadow-md);
    transition: all 0.5s ease-out;
    text-decoration: none;
    color: var(--text-color); /* Changed to use variable */
}

.scroll-arrow:hover {
    rotate: 180deg;
}

.fa-arrow-down {
    font-size: 1rem;
}

.fa-arrow-down:hover {
    font-size: 1rem;
}

.fa-arrow-up {
    font-size: 0.8rem;
}

.fa-arrow-up:hover {
    font-size: 0.8rem;
}

html {
    scroll-behavior: smooth;
}

.products__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-large);
    margin-top: var(--spacing-medium);
    align-items: stretch;
}

.product__card {
    flex: 0 0 325px;
    background: var(--background-color);
    border-radius: var(--border-radius-medium);
    box-shadow: var(--shadow-md);
    display: flex;
    flex-direction: column;
    padding: var(--spacing-medium);
    margin-top: var(--spacing-medium);

}
.product__card ul {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    margin-bottom: var(--spacing-medium);
}
.product__card li {
    text-align: left;
    padding-left: var(--spacing-x-large);
}

.product__card li span {
    display: inline-block;
    width: var(--spacing-medium);
}

.product__card:hover {
    box-shadow: var(--shadow-md);
    transform: scale(1.05);
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

.product__card img {
    width: 100%;
    object-fit: cover;
    flex-shrink: 0;
}

.product__card h3, .product__card p {
    padding: 0;
    margin: var(--spacing-small);
    flex-grow: 0;
}

/* HTML: <img class="hexagon" src="" alt=""> */
.mission-container {
  display: flex;
  align-items: center; /* Vertically centers the image and title */
  padding-left: 0;
  padding-right: var(--spacing-small);
  margin-bottom: var(--spacing-small); /* Space between header and paragraph */
  justify-content: center;
  height: 50px;
}
.hexagon-shadow-container {
    /* Apply the shadow to this new container */
    filter: drop-shadow(var(--shadow-sm));
}
.hexagon-wrapper {
  width: 50px !important;
  height: 55px !important;
  background: red;
  background-size: cover;
  background-position: center;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}
.hexagon-wrapper:hover {
    transform: scale(1.1);
    transition: transform 0.3s ease-in-out;
}

.hexagon-wrapper--mission {
  background-image: url('../assets/images/other/mission.jpg');
}

.hexagon-wrapper--vision {
  background-image: url('../assets/images/other/vision.jpg');
}

.hexagon-wrapper--values {
  background-image: url('../assets/images/other/values.jpg');
}

/* Capacitaciones */
.trainings {
    height: calc(70vh - 130px);
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--text-color);
    position: relative;
    padding: var(--spacing-medium);
    z-index: 3;
      background: var(--background-color-transparent);

}
.trainings:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url('../assets/images/bg/bg-capacitacion-001.png') no-repeat center/cover;
    opacity: 0.25;
    z-index: -1;
}

.trainings h2, .trainings h4, .training__info p, .training__info .btn {
    margin: 0;
}

.trainings h2 {
    font-size: var(--font-size-h2);
}

.trainings h4 {
    margin: var(--spacing-small) 0;
    font-size: var(--font-size-h4);
}

.trainings__content, .training__info {
    display: flex;
    flex-flow: column;
    gap: var(--spacing-large);
    align-items: center;
}

.trainings__content {
    max-width: 600px;
}

.training__info {
    gap: var(--spacing-medium);
}

/* #region Form */
/* Estilos para la sección de contacto */

.contact__container {
  display: flex;
  gap: var(--spacing-large);
}

.contact__info {
  flex: 1;
  padding: var(--spacing-medium);
  margin-top: var(--spacing-x-large);
  text-align: center;
  text-decoration: none;
  color: var(--text-color);
}

.contact__info h2 {
  font: var(--font-subtitle); /* Montserrat, semibold, 1.75rem */
  color: var(--title-color); /* 10% neutral-900 */
  margin-bottom: var(--spacing-medium);
}

.contact__list {
  list-style-type: none !important;
  padding: 0;
  color: var(--text-color);
  text-decoration:  !important;
}

.contact__list li {
  margin-bottom: var(--spacing-medium);
  font-family: var(--font-family-secondary);
  position: relative;
  padding-left: var(--spacing-large);
}
.contact__list i {
    color: var(--text-color); /* Primary brand color */
}
.contact__list a {
    text-decoration: none;
    color: inherit; /* Opcional: quita el color azul */
  }

.contact__separator {
  width: 1px;
  border: 1px solid var(--neutral-100);
  margin: var(--spacing-large) var(--spacing-large);
}

.contact__form {
  flex: 1;
  padding: var(--spacing-medium);
}

.form__group {
  margin: var(--spacing-medium) 0;
}

.form__group label {
  display: block;
  margin-bottom: var(--spacing-small);
  color: var(--text-color); /* neutral-700 */
  font-family: var(--font-family-primary); /* Montserrat */
  font-weight: var(--font-weight-semibold); /* 600 */
  font-size: var(--font-size-md);
}

.form__group input,
.form__group textarea {
  width: 100%;
  padding: var(--spacing-medium);
  background: var(--color-on-primary);
    border: 1px solid var(--neutral-300);
  border-radius: var(--border-radius-small); /* 4px */
  font-family: var(--font-family-primary); /* Montserrat */
  font-size: var(--font-size-md); /* 1rem */
  transition: all var(--transition-duration-default) var(--transition-easing-smooth);
}

    background: var(--background-color-alt-lighter);
    border: 1px solid var(--neutral-300);
    border-radius: var(--border-radius-large);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-medium);
    transition: transform var(--transition-duration-default) var(--transition-easing-smooth), box-shadow var(--transition-duration-default) var(--transition-easing-smooth);
    text-align: left;
    overflow: hidden;
    min-height: 150px;

.form__group input:focus,
.form__group textarea:focus {
  outline: none;
  border-color: var(--color-info); /* #5BC0DE */
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-warning) 20%, transparent); /* Warning with transparency */
}

.form__group textarea {
  resize: vertical;
  min-height: 120px;
}

.form__group .error-message {
  color: var(--color-error); /* #D9534F */
  font-size: var(--font-size-sm); /* 0.875rem */
  margin-top: var(--spacing-xx-small);
  display: none; /* Hidden by default, shown via JS */
}

.btn {
  background: radial-gradient(ellipse farthest-corner at right bottom, #FFD700 0%, #DAA520 30%, #e9aa0b 40%, transparent 80%),
            radial-gradient(ellipse farthest-corner at left top, #f1cd3d 0%, #f0e18c 25%, #FFD700 62.5%, #DAA520 100%);
  display: inline-block;
  padding: var(--spacing-medium) var(--spacing-large);
  font-family: var(--font-family-primary); /* Montserrat */
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold); /* 600 */
  border-radius: var(--border-radius-medium); /* 4px */
  transition: all var(--transition-duration-default) var(--transition-easing-smooth);
  text-align: center;
  width: auto;
  margin-top: var(--spacing-small);
  margin-bottom: var(--spacing-small);
  cursor: pointer;
  text-decoration: none;
  color: var(--text-color);
  border: none;
  box-shadow: var(--shadow-sm);
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: var(--text-color-light);
  box-shadow: var(--shadow-md);
  font-size: var(--font-size-md2);
}

.btn:focus,
.btn:active {
  outline: 3px solid var(--color-info); /* #5BC0DE */
  outline-offset: 2px;

}
.btn--secondary {
  background: var(--color-secondary);
  box-shadow: none;
  border-radius: 0; /* 4px */
  margin-top: var(--spacing-medium);
  margin-bottom: calc(var(--spacing-xx-small) * -1);
  color: var(--color-on-secondary);
}

/* Responsive */
@media (max-width: 768px) {
  .contact__container {
    flex-direction: column;
  }

  .contact__separator {
    width: 100%;
    height: 1px;
    margin: var(--spacing-medium) 0;
  }
}
/* #endregion Form */

/* Botón Volver Arriba */
.scroll-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    visibility: hidden;
    width: var(--spacing-large);
    height: var(--spacing-large);
    z-index: 1000;
}
.scroll-top:hover {
    background: rgba(255, 255, 255, 1);
    scale: 1.2;
}

.scroll-top.active {
    opacity: 1;
    visibility: visible;
}

/* Accesibilidad */
:focus {
    outline: 2px solid var(--info-color);
    outline-offset: 2px;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* #region Carrito */
/* === Carrito lateral === */
.contenedor-carrito {
    position: fixed;
    top: 0;
    right: -450px;
    width: 450px;
    height: 100vh;
    background-color: var(--background-color);
    box-shadow: var(--shadow-lg);
    transition: right var(--transition-duration-default) var(--transition-easing-smooth);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    /* Cambia esto: */
    justify-content: flex-start; /* Alinea todo al inicio */
    gap: 0; /* Elimina espacios entre hijos */
    overflow-y: auto;
    border-left: 1px solid var(--neutral-300);
    border-radius: var(--border-radius-small) 0 0 var(--border-radius-small);
    padding: 0; /* Asegura que no hay padding */
}

.cart--active {
    right: 0;
}

/* Botón cerrar */
.contenedor-carrito__close-btn {
    position: absolute;
    top: var(--spacing-small);
    right: var(--spacing-small);
    font: var(--font-weight-semibold) var(--font-size-md) var(--font-family-primary);
    color: var(--color-white);
    background-color: var(--color-primary);
    border: none;
    padding: 6px 12px;
    border-radius: var(--border-radius-small);
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.contenedor-carrito__close-btn:hover {
    background-color: var(--color-primary-dark);
    transform: scale(1.05);
}

/* Header del carrito */
.overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    z-index: 999;
}

.overlay--active {
    display: block;
}
.contenedor-carrito__header {
    background: var(--color-primary-dark);
    padding-top: var(--spacing-medium);
    text-align: center;
    border-bottom: 1px solid var(--neutral-200);
}

.contenedor-carrito__title {
    font: var(--font-weight-semibold) var(--font-size-h2) var(--font-family-primary);
    margin: 0 0 var(--spacing-medium) 0;
    color: var(--text-color-light);
}

.cotizacion__fecha, .mensaje-instruccion {
  padding: var(--spacing-medium);
  line-height: 1.4;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-style: italic;
  text-align: center;
  background-color: var(--background-color-alt);
  color: var(--text-color); /* Neutral-700 */
}

.carrito {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px; /* Espacio entre texto e icono */
  margin-top: 0;
}

.carrito__icon {
  font-size: var(--font-size-lg);
  color: var(--text-color);
  animation: float var(--anim-duration, 2s) var(--anim-easing, ease-in-out) infinite;
  display: inline-block;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(var(--float-distance, 6px)); }
}

.carrito__icon:hover {
  font-size: var(--font-size-lg);
  transform: scale(1);
  color: var(--text-color); !important;
}

/* Lista de productos */
.carrito__intro {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  text-align: center;
  padding-top: var(--spacing-large);
  padding-bottom: var(--spacing-small);
  width: 100%;
  margin-top: 0%;
  margin-bottom: 0%;
}

.carrito__lista {
    list-style: none;
    margin: var(--spacing-medium);
    padding: 0;
}

.carrito__lista li {
    /* Mantenemos el resto de tus estilos flexbox */
    display: flex;
    justify-content: end; /* Esto empuja el contenedor a la derecha */
    align-items: center;
    color: var(--text-color);
    border-bottom: 1px solid var(--neutral-200);
    padding: var(--spacing-small);
    padding-left: 0;
    font: var(--font-weight-normal) var(--font-size-sm) var(--font-family-primary);
    gap: 3%;
    text-align: right;
}
.carrito__lista li:hover {
    background: var(--neutral-300);
}

.carrito__cantidad {
    background: var(--neutral-300);
    color: var(--text-color);
    padding: var(--spacing-small) var(--spacing-small);
    border-radius: var(--border-radius-small);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-normal);
    text-align: center;
}

.carrito__precio {
  flex: 0 0 20%;
  font: var(--font-weight-semibold) var(--font-size-md) var(--font-family-secondary);
  color: var(--text-color);
  text-align: right;
}

.eliminar {
    background: var(--neutral-500);
    border: none;
    border-radius: var(--border-radius-small);
    cursor: pointer;
    transition: transform 0.2s ease;
    display: flex; /* Ensure button content is centered */
    align-items: center;
    justify-content: center;
    padding: var(--spacing-small);
}

.eliminar:hover {
    transform: scale(1.4);
    background: var(--neutral-700);
}
.eliminar:hover img {
    filter: brightness(0) invert(1);
}
/* Animación de latido (Opcional, si quieres algo más elaborado) */
.eliminar:hover {
  animation: latido 1s infinite alternate ease-in-out; /* Aplica la animación */
}

@keyframes latido {
  0% {
    transform: scale(1.4); /* Tamaño inicial del latido */
  }
  50% {
    transform: scale(1.5); /* Tamaño máximo del latido */
  }
  100% {
    transform: scale(1.4); /* Vuelve al tamaño inicial del latido */
  }
}

/* Totales */
.carrito__total-vigencia {
  background: var(--background-color-alt);
  border: 1px solid var(--neutral-200);
  border-radius: var(--border-radius-small);
  text-align: center;
  margin: var(--spacing-small);
  color: var(--text-color);
  width: 100%;
  line-height: 1.25;
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-style: italic;
  color: var(--primary-color-dark);
}

.carrito__total {
    font: var(--font-weight-bold) var(--font-size-h3) var(--font-family-primary);
    color: var(--title-color);
    margin: var(--spacing-small) 0;
}

/* Botón vaciar */
.carrito__vaciar {
    width: 80%;
    margin: var(--spacing-small) auto;
    padding: var(--spacing-small);
    background: var(--color-warning);
    color: var(--color-white);
    border: none;
    border-radius: var(--border-radius-small);
    cursor: pointer;
    font: var(--font-weight-medium) var(--font-size-md) var(--font-family-secondary);
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.carrito__vaciar:hover {
    background: var(--color-warning-dark);
    transform: translateY(-2px);
}

.cart__form {
    padding: var(--spacing-small);
    margin: 0 5px;
}

/* General container for all label + input/textarea (name, phone, email, textarea) */
.cart__form-field-container {
  display: grid;
  grid-template-columns: 120px 1fr; /* Label: 120px, Input/Textarea: remaining width */
  gap: 1rem; /* Space between label and input/textarea */
  width: 100%; /* Full width of parent */
  box-sizing: border-box; /* Prevent overflow */
  margin-bottom: 1rem; /* Optional: Space between form fields */
  align-items: center;
}

/* Specific styles for inputs (name, phone, email) */
.cart__form-input {
  width: 100%; /* Full width of grid cell */
  height: 35px; /* Consistent height for inputs */
  box-sizing: border-box; /* Prevent overflow */
  padding-top: var(--spacing-medium); /* Optional: Improve input appearance */
  border: 1px solid var(--neutral-500);
}

/* Specific styles for textarea */
.cart__form-textarea {
  width: 100%; /* Full width of grid cell */
  min-height: 75px; /* Minimum height */
  resize: vertical; /* Vertical resizing only */
  box-sizing: border-box; /* Prevent overflow */
  padding: 0.5rem; /* Optional: Consistent padding */
  border: 1px solid var(--neutral-500);
}

/* Styles for labels */
.cart__form-label {
  font-family: var(--font-family-primary);
  font-size: var(--font-size-base)
  font-weight: var(--font-weight-semibold);
  align-self: start; /* Align to top of grid cell */
}
.center-item{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  background: var(--color-success);
  color: var(--text-color-light);
}
.center-item:hover {
  background-color: var(--color-success-dark);
}
/* === Responsivo === */
@media (max-width: 576px) {
  
    .contenedor-carrito {
        width: 100%;
        right: -100%;
        border-radius: 0;
    }

    .cart--active {
        right: 0;
    }
}

/* #region Media Queries */
@media (min-width: 1024px) {
    .desktop-only {
        display: inline !important;
    }
}
@media (max-width: 768px) {
    .nav__menu {
        width: 50%;
        background-color: var(--dark-primary-color);
        position: absolute;
        top: 55px;
        right: 0;
        flex-direction: column;
        text-align: center;
        opacity: 0;
        transform: translateY(-60px);
        transition: opacity 0.3s ease, transform 0.3s ease;
        visibility: hidden;
        z-index: 1000;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
    }
    .nav__menu.active {
        display: flex;
        opacity: 1;
        transform: translateY(0);
        visibility: visible;
    }
    .nav__hamburger {
        display: block;
        margin-right: var(--spacing-medium);
    }
    .trainings__content {
        flex-direction: column;
    }
    .trainings__content img {
        width: 100%;
    }
    .categorias {
        flex-direction: column;
        align-items: center;
    }
}

@media (max-width: 576px) {
    :root {
        --font-size-h6: 1rem;
        --font-size-h5: 1.125rem;
        --font-size-h4: 1.25rem;
        --font-size-h3: 1.375rem;
        --font-size-h2: 1.5rem;
        --font-size-h1: 1.75rem;
    }
    .nav__menu {
        width: 100%;
        transform: translateY(-60px);
        transition: opacity 0.3s ease, transform 0.3s ease;
        visibility: hidden;
        z-index: 1000;
        background: var(--neutral-900);
    }
    .nav__menu a {
        height: 55px;
        font-size: var(--font-size-md);
        font-weight: var(--font-weight-medium);
    }
    .cart-count {
        top: 8px;
        right: 10px;
        width: 22px;
        height: 22px;
    }
    .hero::before {
        top: -15px;
    }
    .cart--active {
        right: 0;
    }
}
/* #endregion Media Queries */