/*
 Theme Name:   Bootscore Child
 Description:  Bootscore Child Theme
 Author:       Bootscore
 Author URI:   https://bootscore.me
 Template:     bootscore
 Version:      6.0.0
 Requires at least: 5.0
 Tested up to: 6.6
 Requires PHP: 7.4
 License: MIT License
 License URI: https://github.com/bootscore/bootscore-child/blob/main/LICENSE
 Text Domain:  bootscore
*/

@font-face {
  font-family: "Zen Maru Gothic";
  src: url("assets/fonts/ZenMaruGothic-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Zen Maru Gothic";
  src: url("assets/fonts/ZenMaruGothic-Black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --hnmi-primary: #993f32;
  --hnmi-light-primary: #aa5500;
  --hnmi-dark-primary: #6c3f26;
  --hnmi-secondary: #fbc107;
  --hnmi-light-secondary: #ffeebe;
  --hnmi-dark-secondary: #ebb912;
  --hnmi-dark-gray: #3e0902;
  --hnmi-light-gray: #ffffff;
  --hnmi-soft: #fff8ea;
}

::-moz-selection {
  color: var(--hnmi-light-gray);
  background: var(--hnmi-primary);
}

::selection {
  color: var(--hnmi-light-gray);
  background: var(--hnmi-primary);
}

/* accesibilidad */
.skip-link {
  position: absolute;
  top: -1000px;
  left: -1000px;
  height: 1px;
  width: 1px;
  text-align: left;
  overflow: hidden;
}

a.skip-link:focus,
a.skip-link:active {
  top: 0;
  left: 0;
  width: auto;
  height: auto;
  z-index: 99999;
  background-color: var(--hnmi-primary);
  color: var(--hnmi-light-gray);
  padding: 1rem;
  font-weight: 900;
  text-decoration: none;
  outline: 2px solid var(--hnmi-secondary);
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--hnmi-soft);
  color: var(--hnmi-primary);
  font-family: "Zen Maru Gothic", system-ui, sans-serif;
}

img,
video {
  max-width: 100%;
}

a {
  color: var(--hnmi-primary);
  text-decoration: none;
}

a:hover {
  color: var(--hnmi-light-primary);
}

p {
  color: var(--hnmi-primary);
  line-height: 1.65;
}

hr {
  border: 1px solid var(--hnmi-primary);
  opacity: 1;
}

.h1,
.h2,
.h3,
.h4,
button {
  color: var(--hnmi-primary);
}

.h1 {
  font-size: clamp(3rem, 7vw, 5.75rem);
  font-weight: 900;
  line-height: 0.95;
  text-transform: uppercase;
}

.h2 {
  color: var(--hnmi-primary);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 900;
  line-height: 1.05;
}

.h3 {
  font-size: clamp(1.15rem, 2vw, 1.5rem);
  font-weight: 900;
  text-transform: uppercase;
}

.lead {
  color: var(--hnmi-dark-primary);
  font-size: clamp(1.35rem, 3vw, 2rem);
  font-weight: 400;
  line-height: 1.35;
}

.eyebrow {
  color: var(--hnmi-light-primary);
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 900;
  letter-spacing: 0.12rem;
  margin-bottom: 0.75rem;
  text-transform: uppercase;
}

.btn,
.button,
button,
input[type="submit"] {
  border-radius: 0;
  font-weight: 900;
  letter-spacing: 0.05rem;
}

.btn {
  padding: 0.75rem 1.5rem;
}

.btn-primary,
.btn-cta:hover,
.btn-primary-outline {
  background-color: transparent;
  border: 1px solid var(--hnmi-primary);
  border-radius: 10px;
  color: var(--hnmi-primary);
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus-visible,
.btn-primary-outline:hover {
  background-color: var(--hnmi-primary) !important;
  border-color: var(--hnmi-primary) !important;
  color: var(--hnmi-light-gray) !important;
}

.btn-cta,
.single_add_to_cart_button,
.checkout-button,
.wc-block-components-button:not(.is-link) {
  background-color: var(--hnmi-secondary);
  border: 1px solid var(--hnmi-secondary);
  border-radius: 10px;
  color: var(--hnmi-dark-gray);
}

.btn-cta:hover,
.single_add_to_cart_button:hover,
.checkout-button:hover,
.wc-block-components-button:not(.is-link):hover {
  background-color: var(--hnmi-dark-secondary);
  border-color: var(--hnmi-dark-secondary);
  color: var(--hnmi-dark-gray);
}

.btn-white {
  border: 1px solid var(--hnmi-light-gray);
  color: var(--hnmi-light-gray);
}

.tarjeta,
.card {
  border-radius: 0;
}

.navbar,
#masthead {
  background-color: rgba(255, 248, 234, 0.94);
}

#masthead .navbar-brand img,
.custom-logo {
  max-height: 64px;
}

/* ==== header ==== */
#masthead.hnmi-header {
  background-color: transparent;
  padding: 0.75rem 0;
  transition:
    background-color 0.2s ease,
    box-shadow 0.2s ease;
  z-index: 1030;
}

#masthead.hnmi-header .hnmi-navbar {
  background-color: transparent;
  padding: 0;
}

#masthead .hnmi-header-container {
  align-items: center;
  background-color: rgba(255, 248, 234, 0.94);
  border: 1px solid rgba(153, 63, 50, 0.18);
  border-radius: 1.25rem;
  box-shadow: 0 1rem 2rem rgba(62, 9, 2, 0.08);
  gap: 1rem;
  min-height: 5.25rem;
  padding: 0.55rem 0.85rem;
}

#masthead .hnmi-navbar-brand {
  align-items: center;
  background-color: var(--hnmi-light-secondary);
  border-radius: 1rem;
  display: inline-flex;
  flex: 0 0 auto;
  min-height: 4rem;
  padding: 0.6rem 1rem;
}

#masthead .hnmi-navbar-brand img {
  display: block;
  max-height: 1.5rem;
  width: auto;
}

#masthead #bootscore-navbar {
  align-items: center;
  gap: 0.35rem;
}

#masthead #bootscore-navbar .nav-link {
  border-radius: 999px;
  color: var(--hnmi-primary);
  font-size: 0.95rem;
  font-weight: 900;
  letter-spacing: 0.05rem;
  padding: 0.65rem 1rem;
  text-transform: uppercase;
}

#masthead #bootscore-navbar .nav-link:hover,
#masthead #bootscore-navbar .nav-link:focus-visible,
#masthead #bootscore-navbar .current-menu-item>.nav-link,
#masthead #bootscore-navbar .current-menu-ancestor>.nav-link {
  background-color: var(--hnmi-primary);
  color: var(--hnmi-light-gray);
}

#masthead .dropdown-menu {
  background-color: var(--hnmi-soft);
  border: 1px solid rgba(153, 63, 50, 0.18);
  border-radius: 1rem;
  box-shadow: 0 1rem 2rem rgba(62, 9, 2, 0.1);
  padding: 0.5rem;
}

#masthead .dropdown-item {
  border-radius: 0.75rem;
  color: var(--hnmi-primary);
  font-weight: 900;
}

#masthead .dropdown-item:hover,
#masthead .dropdown-item:focus {
  background-color: var(--hnmi-light-secondary);
  color: var(--hnmi-dark-primary);
}

#masthead .hnmi-header-actions {
  gap: 0.35rem;
}

#masthead .hnmi-header-actions .btn,
#masthead .hnmi-header-actions button,
#masthead .hnmi-header-actions a {
  align-items: center;
  background-color: var(--hnmi-light-secondary);
  border: 1px solid rgba(153, 63, 50, 0.25);
  border-radius: 999px;
  color: var(--hnmi-primary);
  display: inline-flex;
  height: 2.85rem;
  justify-content: center;
  min-width: 2.85rem;
  padding: 0.65rem 0.85rem;
}

#masthead .hnmi-header-actions .cart-toggler {
  background-color: var(--hnmi-secondary);
  border-color: var(--hnmi-secondary);
  color: var(--hnmi-dark-gray);
}

#masthead .hnmi-header-actions .btn:hover,
#masthead .hnmi-header-actions button:hover,
#masthead .hnmi-header-actions a:hover {
  background-color: var(--hnmi-primary);
  border-color: var(--hnmi-primary);
  color: var(--hnmi-light-gray);
}

#masthead .cart-content {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-size: 0.75rem;
  font-weight: 900;
  justify-content: center;
  line-height: 1;
  margin-left: 0.4rem;
  min-height: 1.25rem;
  min-width: 1.25rem;
  padding: 0.2rem;
}

#masthead .hnmi-header-actions a:hover .cart-content span {
  color: var(--hnmi-light-gray);
}

#masthead .hnmi-offcanvas-nav {
  background-color: var(--hnmi-soft);
  color: var(--hnmi-primary);
}

#masthead .offcanvas-title {
  color: var(--hnmi-primary);
  font-weight: 900;
  text-transform: uppercase;
}

/* ==== inicio ==== */
.home {
  overflow-x: clip;
}

.home section {
  position: relative;
}

.home .hero {
  clip-path: ellipse(150% 100% at 50% 0%);
  min-height: 760px;
  padding-bottom: 6rem;
  padding-top: 10rem;
  position: relative;
  z-index: 2;
}

.home .hero .container {
  position: relative;
  z-index: 1;
}

.home .hero-logo {
  max-height: 160px;
  width: min(260px, 70vw);
}

.home .hero .lead {
  margin-bottom: 1rem;
}

.home .hero .flecha {
  color: var(--hnmi-primary);
}

.home .hero .video {
  inset: 0;
  mix-blend-mode: screen;
  opacity: 0.5;
  position: absolute;
  z-index: -1;
}

.home .hero .video>* {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.home .hero::after {
  background-color: #ffdf73;
  content: "";
  inset: 0;
  mix-blend-mode: screen;
  position: absolute;
  z-index: -1;
}

.flecha {
  animation: hnmi-bounce 1.6s ease-in-out infinite;
  display: inline-flex;
  height: 60px;
  justify-content: center;
  width: 40px;
}

.flecha a {
  color: inherit;
}

.home .bienvenida {
  background-color: var(--hnmi-soft);
  padding-bottom: 7rem;
  padding-top: 7rem;
}

.home .bienvenida-img {
  border-radius: 1.25rem;
  overflow: hidden;
}

.home .bienvenida-img img {
  aspect-ratio: 4 / 5;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.home .disfruta {
  background-color: var(--hnmi-dark-gray);
  margin-top: -4rem;
  padding-bottom: 6rem;
  padding-top: 8rem;
  position: relative;
}

.home .disfruta::before {
  background-image: url("assets/img/inicio-cerezo.png");
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 220px auto;
  content: "";
  inset: 2rem auto auto 1rem;
  opacity: 0.8;
  position: absolute;
  width: 260px;
  height: 260px;
}

.home .disfruta .h2 {
  color: var(--hnmi-secondary);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
}

.home .disfruta .h3 {
  color: var(--hnmi-light-secondary);
  transition: all 0.3s;
}

.home .disfruta p {
  color: var(--hnmi-light-secondary);
}

.home .disfruta .col-cerezo {
  margin-bottom: 4rem;
}

.home .disfruta .restaurantes {
  -ms-overflow-style: none;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.home .disfruta .restaurantes::-webkit-scrollbar {
  display: none;
}

.home .disfruta .slide-item {
  flex: 0 0 80%;
  scroll-snap-align: start;
}

.home .disfruta figure {
  background-color: var(--hnmi-dark-gray);
  border-radius: 1.25rem;
  height: 100%;
  overflow: hidden;
  position: relative;
}

.home .disfruta figure::before {
  background: linear-gradient(180deg,
      rgba(0, 0, 0, 0.45) 0%,
      rgba(62, 9, 2, 0.25) 52%,
      rgba(62, 9, 2, 0.95) 100%);
  border-radius: 1.25rem;
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  transition: all 0.3s;
}

.home .disfruta figure img {
  aspect-ratio: 1;
  border-radius: 1.25rem;
  height: 100%;
  -webkit-mask-image: linear-gradient(180deg,
      #000 0%,
      #000 55%,
      rgba(0, 0, 0, 0.75) 72%,
      transparent 100%);
  mask-image: linear-gradient(180deg,
      #000 0%,
      #000 55%,
      rgba(0, 0, 0, 0.75) 72%,
      transparent 100%);
  object-fit: cover;
  width: 100%;
}

.home .disfruta .arrow {
  display: flex;
  flex-direction: column;
  inset: 0;
  justify-content: end;
  padding: 2rem;
  position: absolute;
  z-index: 1;
}

.home .disfruta .arrow .cards-text p {
  color: #fff;
  height: 0;
  opacity: 0;
  transition: all 0.3s;
}

.home .disfruta .arrow:hover .cards-text p {
  height: 100%;
  opacity: 1;
}

.home .disfruta .arrow:hover .cards-text .h3 {
  color: var(--hnmi-light-secondary);
  transform: translateY(-25%);
}

.home .disfruta .arrow-img {
  position: relative;
}

.home .disfruta .arrow-img .cola-flecha,
.home .disfruta .arrow-img .punta-1,
.home .disfruta .arrow-img .punta-2 {
  background-color: var(--hnmi-secondary);
  position: absolute;
}

.home .disfruta .arrow-img .cola-flecha {
  height: 4px;
  transition: width 0.2s;
  width: 60%;
}

.home .disfruta .arrow:hover .arrow-img .cola-flecha {
  width: 100%;
}

.home .disfruta .arrow-img .punta-1,
.home .disfruta .arrow-img .punta-2 {
  border-radius: 1rem;
  height: 4px;
  right: -1px;
  transform-origin: right center;
  width: 1.5rem;
}

.home .disfruta .arrow-img .punta-1 {
  rotate: 45deg;
  top: 1px;
}

.home .disfruta .arrow-img .punta-2 {
  bottom: 1px;
  rotate: -45deg;
}

.home .pedido {
  background-color: var(--hnmi-light-secondary);
  padding: 7rem 0;
}

.home .pedido-pasos {
  display: grid;
  gap: 1.5rem;
}

.home .pedido-pasos article {
  align-items: flex-start;
  border-bottom: 1px solid rgba(153, 63, 50, 0.35);
  display: flex;
  gap: 1.25rem;
  padding-bottom: 1.5rem;
}

.home .pedido-pasos span {
  color: var(--hnmi-light-primary);
  flex: 0 0 auto;
  font-size: 1.25rem;
  font-weight: 900;
}

.home .pedido-pasos p {
  margin-bottom: 0;
}

.home .pedido-img {
  border-radius: 1.25rem;
  overflow: hidden;
}

.home .pedido-img img {
  aspect-ratio: 5 / 4;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.home .productos {
  background-color: var(--hnmi-soft);
  padding: 7rem 0;
  border-bottom: 1px solid rgba(153, 63, 50, 0.12);
}

.home .contacto {
  padding-bottom: 7rem;
  padding-top: 7rem;
  position: relative;
}

.home .contacto::before {
  background-color: silver;
  background-image:
    radial-gradient(circle at 100% 150%,
      silver 24%,
      white 24%,
      white 28%,
      silver 28%,
      silver 36%,
      white 36%,
      white 40%,
      transparent 40%,
      transparent),
    radial-gradient(circle at 0 150%,
      silver 24%,
      white 24%,
      white 28%,
      silver 28%,
      silver 36%,
      white 36%,
      white 40%,
      transparent 40%,
      transparent),
    radial-gradient(circle at 50% 100%,
      white 10%,
      silver 10%,
      silver 23%,
      white 23%,
      white 30%,
      silver 30%,
      silver 43%,
      white 43%,
      white 50%,
      silver 50%,
      silver 63%,
      white 63%,
      white 71%,
      transparent 71%,
      transparent);
  background-size: 150px 75px;
  content: "";
  inset: 0;
  opacity: 0.1;
  position: absolute;
  z-index: -1;
}

.home .contacto a {
  color: var(--hnmi-dark-gray);
  font-size: 1.5rem;
}

.home .contacto form,
.home .contacto #nf-form-1-cont {
  background-color: var(--hnmi-light-secondary);
  padding: 1rem;
}

.home .contacto label {
  color: var(--hnmi-primary);
}

.home .contacto input:not([type="submit"]),
.home .contacto textarea,
.home .contacto select {
  background-color: #fff;
  border: 1px solid var(--hnmi-dark-secondary);
  border-radius: 0;
}

.home .contacto input[type="submit"] {
  background-color: var(--hnmi-primary);
  border: 1px solid var(--hnmi-primary);
  color: var(--hnmi-light-gray);
  padding: 0.75rem 2rem;
  text-transform: uppercase;
}

.home .contacto input[type="submit"]:hover {
  background-color: var(--hnmi-dark-primary);
}

/* ==== WooCommerce ==== */
.hnmi-woocommerce {
  background:
    linear-gradient(180deg,
      rgba(255, 238, 190, 0.7) 0,
      rgba(255, 248, 234, 0) 22rem),
    var(--hnmi-soft);
  padding-bottom: 6rem;
  padding-top: 7rem;
}

.hnmi-woocommerce #main {
  overflow: hidden;
}

.hnmi-woocommerce .container {
  position: relative;
}

.hnmi-woocommerce .container::before {
  background-image: url("assets/img/inicio-cerezo.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 15rem;
  opacity: 0.16;
  pointer-events: none;
  position: absolute;
  right: 1rem;
  top: 0;
  width: 15rem;
}

.hnmi-shop-panel {
  position: relative;
  z-index: 1;
}

.hnmi-woocommerce.tienda .woocommerce-products-header {
  border-bottom: 1px solid rgba(153, 63, 50, 0.25);
  margin-bottom: 2.5rem;
  max-width: 58rem;
  padding-bottom: 1.5rem;
}

.hnmi-woocommerce.tienda .woocommerce-products-header::before,
.hnmi-woocommerce.producto div.product::before {
  color: var(--hnmi-light-primary);
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 900;
  letter-spacing: 0.12rem;
  margin-bottom: 0.75rem;
  text-transform: uppercase;
}

.hnmi-woocommerce.tienda .woocommerce-products-header::before {
  content: "Carta Hanami";
}

.hnmi-woocommerce .woocommerce-result-count {
  color: var(--hnmi-dark-primary);
  font-weight: 900;
}

.hnmi-woocommerce .woocommerce-ordering select {
  background-color: var(--hnmi-light-gray);
  min-height: 3rem;
  padding: 0.65rem 2.5rem 0.65rem 1rem;
}

.hnmi-woocommerce ul.products,
.hnmi-woocommerce .products {
  row-gap: 2rem;
}

@media (max-width: 576px) {

  .hnmi-woocommerce ul.products,
  .hnmi-woocommerce .products {
    row-gap: 0rem;
  }

}

.hnmi-woocommerce .product.card,
.hnmi-woocommerce ul.products li.product {
  box-shadow: 0 1rem 2rem rgba(62, 9, 2, 0.08);
  transition:
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.hnmi-woocommerce .product.card:hover,
.hnmi-woocommerce ul.products li.product:hover {
  box-shadow: 0 1.35rem 2.5rem rgba(62, 9, 2, 0.14);
  transform: translateY(-0.25rem);
}

.hnmi-woocommerce.producto div.product {
  position: relative;
}

.hnmi-woocommerce.producto div.product div.images,
.hnmi-woocommerce.producto div.product div.summary {
  margin-bottom: 3rem;
}

.hnmi-woocommerce.producto div.product div.images img {
  background-color: var(--hnmi-light-secondary);
  border-radius: 1.25rem;
}

.hnmi-woocommerce.producto div.product .summary {
  background-color: var(--hnmi-soft);
  border: 1px solid rgba(153, 63, 50, 0.2);
  padding: 1.5rem;
}

.hnmi-woocommerce.producto div.product p.price,
.hnmi-woocommerce.producto div.product span.price {
  color: var(--hnmi-primary);
  font-size: clamp(1.6rem, 3vw, 2.5rem);
  justify-content: flex-start;
  margin-bottom: 1.5rem;
}

.hnmi-woocommerce.producto .woocommerce-product-details__short-description {
  border-bottom: 1px solid rgba(153, 63, 50, 0.25);
  border-top: 1px solid rgba(153, 63, 50, 0.25);
  margin-bottom: 1.5rem;
  padding: 1.25rem 0;
}

.hnmi-woocommerce.producto .product_meta {
  color: var(--hnmi-dark-primary);
  display: grid;
  gap: 0.5rem;
  margin-top: 1.5rem;
}

.hnmi-woocommerce.producto .woocommerce-tabs,
.hnmi-woocommerce.producto .related.products,
.hnmi-woocommerce.producto .upsells.products {
  clear: both;
}

.hnmi-woocommerce.producto .woocommerce-tabs {
  background-color: var(--hnmi-soft);
  margin-bottom: 4rem;
  padding: 1.5rem;
}

.hnmi-woocommerce.producto .related.products>h2,
.hnmi-woocommerce.producto .upsells.products>h2 {
  color: var(--hnmi-primary);
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  font-weight: 900;
  margin-bottom: 1.5rem;
  text-transform: uppercase;
}

.woocommerce .page-title,
.woocommerce-products-header__title,
.woocommerce div.product .product_title,
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title {
  color: var(--hnmi-primary);
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 900;
  letter-spacing: 0.18rem;
  margin-bottom: 2rem;
  text-transform: uppercase;
}

.woocommerce-result-count,
.woocommerce .woocommerce-ordering,
.woocommerce-notices-wrapper {
  margin-bottom: 2rem;
}

.woocommerce .wc-breadcrumb,
.woocommerce-breadcrumb,
.woocommerce .breadcrumb {
  background-color: transparent !important;
  color: var(--hnmi-primary);
}

.woocommerce .wc-breadcrumb a,
.woocommerce-breadcrumb a,
.woocommerce .breadcrumb a {
  color: var(--hnmi-dark-primary);
}

.wc-breadcrumb .breadcrumb-item:first-child a::before {
  background-color: var(--hnmi-primary);
}

.woocommerce .woocommerce-ordering select,
.woocommerce select,
.woocommerce input.input-text,
.woocommerce textarea {
  border: 1px solid var(--hnmi-secondary);
  border-radius: 0;
  color: var(--hnmi-dark-primary);
}

.woocommerce .products {
  align-items: stretch;
}

.woocommerce div.product.card,
.woocommerce ul.products li.product,
.woocommerce .product.card {
  background-color: var(--hnmi-light-secondary);
  border: 0;
  border-radius: 0.625rem;
  overflow: hidden;
}

@media (max-width: 576px) {

  .woocommerce div.product.card,
  .woocommerce ul.products li.product,
  .woocommerce .product.card {
    flex-direction: row;
  }

  .woocommerce div.product.card>a,
  .woocommerce ul.products li.product>a,
  .woocommerce .product.card>a {
    max-width: 33%;

  }

  .woocommerce div.product.card a img,
  .woocommerce ul.products li.product a img,
  .woocommerce .product.card a img {
    height: 100%;
  }


}




.woocommerce div.product.card>div,
.woocommerce .product.card>div {
  justify-content: space-between;
  padding: 0.9rem;
}

.woocommerce .product.card img,
.woocommerce ul.products li.product a img {
  aspect-ratio: 6 / 5;
  border-radius: 0;
  object-fit: cover;
  width: 100%;
}

.woocommerce .card .woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--hnmi-primary);
  font-size: 1.35rem;
  font-weight: 400;
  margin-bottom: 1rem;
  text-align: start;
  text-transform: uppercase;
}

.woocommerce div.product span.price,
.woocommerce .card .price,
.woocommerce ul.products li.product .price {
  color: var(--hnmi-primary);
  display: flex;
  font-weight: 900;
  gap: 0.75rem;
  justify-content: space-between;
}

.woocommerce div.product span.price del,
.woocommerce .card .price del,
.woocommerce ul.products li.product .price del {
  color: var(--hnmi-dark-primary);
  font-weight: 400;
  opacity: 1 !important;
}

.woocommerce div.product span.price ins,
.woocommerce .card .price ins,
.woocommerce ul.products li.product .price ins {
  color: var(--hnmi-primary);
  font-weight: 900;
  text-decoration: none;
}

.woocommerce span.onsale {
  background-color: var(--hnmi-primary) !important;
  border-radius: 0;
  color: var(--hnmi-light-gray);
  font-size: 1rem;
  font-weight: 400;
  left: auto !important;
  min-height: auto;
  min-width: auto;
  padding: 0.5rem 0.75rem;
  right: 0;
  text-transform: uppercase;
  top: 1.5rem;
  width: fit-content !important;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.product .card-body a.button {
  background-color: transparent;
  border: 1px solid var(--hnmi-primary);
  border-radius: 0;
  color: var(--hnmi-primary);
  font-size: 1rem;
  font-weight: 900;
  padding: 0.75rem 1rem;
  text-transform: uppercase;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.product .card-body a.button:hover {
  background-color: var(--hnmi-primary);
  color: var(--hnmi-light-secondary);
}

.woocommerce div.product form.cart .single_add_to_cart_button.button.alt {
  align-items: center;
  background-color: var(--hnmi-secondary) !important;
  border: 1px solid var(--hnmi-secondary) !important;
  border-radius: 10px;
  color: var(--hnmi-dark-gray) !important;
  display: inline-flex;
  flex: 1 1 14rem;
  font-size: 1rem;
  font-weight: 900;
  gap: 0.6rem;
  justify-content: center;
  letter-spacing: 0.05rem;
  line-height: 1.2;
  overflow: hidden;
  position: relative;
  text-transform: uppercase;
}

.woocommerce div.product form.cart .single_add_to_cart_button.button.alt:hover,
.woocommerce div.product form.cart .single_add_to_cart_button.button.alt:focus-visible {
  background-color: var(--hnmi-dark-secondary) !important;
  border-color: var(--hnmi-dark-secondary) !important;
  color: var(--hnmi-dark-gray) !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button.button.alt.loading,
.woocommerce div.product form.cart .single_add_to_cart_button.button.alt.disabled,
.woocommerce div.product form.cart .single_add_to_cart_button.button.alt:disabled {
  opacity: 1;
}

.woocommerce div.product form.cart .single_add_to_cart_button.button.alt.loading {
  cursor: wait;
}

.woocommerce div.product form.cart .single_add_to_cart_button.button.alt::after {
  display: none !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button .btn-loader {
  align-items: center;
  background-color: inherit;
  border-radius: inherit;
  color: inherit;
  display: none;
  inset: 0;
  justify-content: center;
  position: absolute;
  z-index: 1;
}

.woocommerce div.product form.cart .single_add_to_cart_button.loading .btn-loader {
  display: flex;
}

.woocommerce div.product form.cart .single_add_to_cart_button .spinner-border {
  height: 1.1rem;
  width: 1.1rem;
}

.woocommerce div.product form.cart {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.woocommerce form .quantity,
form .quantity {
  border: 1px solid var(--hnmi-dark-secondary);
  margin-right: 0 !important;
}

.woocommerce form .quantity input,
.woocommerce form .quantity button,
form .quantity input,
form .quantity button {
  background-color: var(--hnmi-light-secondary) !important;
  border: 0 !important;
  border-radius: 0;
  color: var(--hnmi-primary) !important;
}

.woocommerce div.product div.images img {
  aspect-ratio: 1;
  object-fit: cover;
}

.woocommerce div.product .summary {
  color: var(--hnmi-primary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border-radius: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  background-color: var(--hnmi-light-secondary);
  border-color: var(--hnmi-primary);
}

.woocommerce #secondary .widget,
.woocommerce .widget_price_filter,
.woocommerce .wc-block-product-categories,
#woocommerce_price_filter-2,
#yith-woocommerce-ajax-navigation-filters-2 {
  background-color: transparent;
  border: 0 !important;
}

.woocommerce #secondary .widget-title,
.widget-title.h5,
.filter-title {
  background-color: transparent !important;
  border: 0;
  color: var(--hnmi-primary) !important;
  font-weight: 900;
}

.woocommerce #secondary button,
.price_slider_amount button {
  border: 1px solid var(--hnmi-primary) !important;
  border-radius: 0 !important;
  color: var(--hnmi-primary) !important;
}

.woocommerce #secondary button:hover,
.price_slider_amount button:hover {
  background-color: var(--hnmi-light-secondary) !important;
}

.ui-slider-range {
  background-color: var(--hnmi-primary) !important;
}

.ui-slider-handle {
  background-color: var(--hnmi-light-primary) !important;
}

.woocommerce a.term-label {
  position: relative;
}

.woocommerce a.term-label::after {
  content: "";
  inset: 0 0 0 -1.5rem;
  position: absolute;
  z-index: 1;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
p.no-comments {
  background-color: var(--hnmi-light-secondary);
  border-top-color: var(--hnmi-primary);
  color: var(--hnmi-primary);
}

.woocommerce-message a,
.woocommerce-info a,
.woocommerce-error a {
  color: var(--hnmi-dark-primary);
  font-weight: 900;
}

.woocommerce table.shop_table,
.woocommerce-cart-form,
.cart_totals,
.woocommerce-checkout-review-order,
.woocommerce form.checkout,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-navigation {
  background-color: rgba(255, 238, 190, 0.55);
  border: 0;
  border-radius: 0;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
  border-color: rgba(153, 63, 50, 0.25);
  color: var(--hnmi-primary);
}

.woocommerce table.shop_table thead {
  background-color: var(--hnmi-primary);
}

.woocommerce table.shop_table thead th {
  color: var(--hnmi-light-gray);
}

.woocommerce-cart .cart-collaterals .cart_totals h2,
.woocommerce-checkout h3,
.woocommerce-account h2,
.woocommerce-account h3 {
  color: var(--hnmi-primary);
  font-weight: 900;
  text-transform: uppercase;
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce-checkout #payment #place_order {
  background-color: var(--hnmi-primary);
  border-color: var(--hnmi-primary);
  border-radius: 10px;
  color: var(--hnmi-light-gray);
}

.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-checkout #payment #place_order:hover {
  background-color: var(--hnmi-dark-primary);
}

.woocommerce-checkout #payment {
  background-color: var(--hnmi-light-secondary);
  border-radius: 0;
}

.woocommerce-checkout #payment div.payment_box {
  background-color: #fff;
  color: var(--hnmi-dark-primary);
}

.woocommerce .offcanvas-header {
  color: var(--hnmi-primary);
  font-weight: 900;
  text-transform: uppercase;
}

.woocommerce #masthead .offcanvas.show,
.woocommerce #masthead .offcanvas.showing {
  background-color: var(--hnmi-soft);
}

.woocommerce .woocommerce-mini-cart-item {
  background-color: transparent !important;
}

.woocommerce .item-name a,
.woocommerce-mini-cart__total strong {
  color: var(--hnmi-primary);
  font-weight: 600;
}

.woocommerce .cart-footer {
  background-color: transparent !important;
}

.wc-block-components-radio-control__option {
  background-color: var(--hnmi-light-gray);
  margin-bottom: 1rem !important;
  padding-right: 1.5rem !important;
}

.wc-block-components-radio-control__option-checked {
  background-color: var(--hnmi-light-secondary);
}

.wc-block-components-radio-control .wc-block-components-radio-control__input:checked::before {
  background-color: var(--hnmi-primary) !important;
}

.wc-block-components-sidebar-layout {
  flex-direction: column-reverse;
}

.wc-block-components-sidebar-layout .wc-block-components-main,
.wc-block-components-sidebar {
  width: 100% !important;
}

.wc-block-components-order-summary__button-text,
.wc-block-components-product-name {
  color: var(--hnmi-primary);
  font-weight: 900;
}

.wc-block-components-totals-wrapper {
  border-top: 1px solid var(--hnmi-primary) !important;
}

.wc-block-components-radio-control__label-group>span {
  color: var(--hnmi-dark-primary);
}

.wc-block-components-sidebar.wc-block-checkout__sidebar.wp-block-woocommerce-checkout-totals-block.is-sticky {
  position: static !important;
}

/* ==== footer ==== */
.hnmi-footer {
  background-color: var(--hnmi-light-gray) !important;
  border-top: 1px solid rgba(153, 63, 50, 0.12);
  padding: 3rem 0;
}

.hnmi-footer-logo {
  display: inline-flex;
}

.hnmi-footer-logo img {
  display: block;
  max-width: 13rem;
  width: 100%;
}

.hnmi-footer-legal {
  text-align: left;
}

.hnmi-footer-legal ul {
  justify-items: start;
}

.hnmi-footer h2 {
  color: var(--hnmi-primary);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.25;
  margin-bottom: 1.1rem;
}

.hnmi-footer ul {
  display: grid;
  gap: 0.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.hnmi-footer li,
.hnmi-footer a {
  color: var(--hnmi-dark-primary);
  font-size: 0.92rem;
  line-height: 1.55;
}

.hnmi-footer a:hover {
  color: var(--hnmi-light-primary);
}

/* ==== 404 ==== */
.error404-page {
  background:
    radial-gradient(circle at 15% 20%,
      rgba(251, 193, 7, 0.22) 0 8rem,
      transparent 8.1rem),
    linear-gradient(180deg,
      rgba(255, 238, 190, 0.72) 0,
      rgba(255, 248, 234, 0) 24rem),
    var(--hnmi-soft);
  overflow: hidden;
}

.error404-hero {
  min-height: calc(100vh - 8rem);
  padding: 3rem 0 3rem;
  position: relative;
}

.error404-hero::before,
.error404-hero::after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  pointer-events: none;
  position: absolute;
}

.error404-hero::before {
  background-image: url("assets/img/inicio-cerezo.png");
  height: 14rem;
  left: 1.5rem;
  opacity: 0.18;
  top: 8rem;
  width: 14rem;
}

.error404-hero::after {
  background-image: url("assets/img/sakura-cerezo-2.png");
  bottom: 3rem;
  height: 16rem;
  opacity: 0.16;
  right: -3rem;
  width: 16rem;
}

.error404-hero .container {
  position: relative;
  z-index: 1;
}

.error404-visual {
  align-items: center;
  display: grid;
  gap: clamp(0.25rem, 2vw, 1.5rem);
  grid-template-columns: minmax(0, 1fr) minmax(10rem, 22rem) minmax(0, 1fr);
  margin: clamp(2.5rem, 6vw, 5rem) auto;
  max-width: 58rem;
}

.error404-number {
  color: var(--hnmi-primary);
  display: block;
  font-size: clamp(6rem, 24vw, 18rem);
  font-weight: 900;
  line-height: 0.8;
  text-align: center;
  text-shadow: 0.16em 0.16em 0 rgba(251, 193, 7, 0.28);
}

.error404-plate {
  animation: hnmi-float-plate 4.5s ease-in-out infinite;
  margin: 0;
  position: relative;
  z-index: 1;
}

.error404-plate::before {
  background-color: rgba(153, 63, 50, 0.12);
  border-radius: 50%;
  bottom: -0.35rem;
  content: "";
  filter: blur(0.25rem);
  height: 1.25rem;
  left: 15%;
  position: absolute;
  right: 15%;
  z-index: -1;
}

.error404-plate img {
  display: block;
  filter: drop-shadow(0 1.5rem 1.7rem rgba(62, 9, 2, 0.18));
  transform: rotate(-4deg);
  width: 100%;
}

.error404-steam {
  animation: hnmi-steam 3s ease-in-out infinite;
  background-color: rgba(153, 63, 50, 0.28);
  border-radius: 999px;
  height: 4rem;
  position: absolute;
  top: -2.25rem;
  width: 0.18rem;
  z-index: 2;
}

.error404-steam::before,
.error404-steam::after {
  background-color: inherit;
  border-radius: inherit;
  content: "";
  height: 1.7rem;
  position: absolute;
  width: inherit;
}

.error404-steam::before {
  left: -0.65rem;
  top: 0.3rem;
  transform: rotate(28deg);
}

.error404-steam::after {
  right: -0.65rem;
  top: 1.6rem;
  transform: rotate(-28deg);
}

.error404-steam.steam-1 {
  animation-delay: 0s;
  left: 30%;
}

.error404-steam.steam-2 {
  animation-delay: 0.45s;
  left: 50%;
  top: -2.75rem;
}

.error404-steam.steam-3 {
  animation-delay: 0.9s;
  left: 70%;
}

@keyframes hnmi-bounce {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(0.75rem);
  }
}

@keyframes hnmi-float-plate {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-0.75rem);
  }
}

@keyframes hnmi-steam {
  0% {
    opacity: 0;
    transform: translateY(0) scaleY(0.75);
  }

  35% {
    opacity: 0.8;
  }

  100% {
    opacity: 0;
    transform: translateY(-2.5rem) scaleY(1.15);
  }
}

@media (min-width: 768px) {
  .hnmi-footer-legal {
    text-align: right;
  }

  .hnmi-footer-legal ul {
    justify-items: end;
  }

  .home .disfruta .slide-item {
    flex: 0 0 45%;
  }
}

@media (min-width: 992px) {
  .home .disfruta .col-cerezo {
    z-index: 1;
  }

  .home .disfruta figure img {
    aspect-ratio: 3 / 4;
  }
}

@media (max-width: 991.98px) {
  #masthead.hnmi-header {
    padding: 0.5rem 0;
  }

  #masthead .hnmi-header-container {
    border-radius: 1rem;
    min-height: 4.5rem;
  }

  #masthead .hnmi-navbar-brand {
    min-height: 2.4rem;
    padding: 0.5rem 0.75rem;
  }

  #masthead .hnmi-navbar-brand img {
    max-height: 1rem;
  }

  #masthead .hnmi-offcanvas-nav .offcanvas-body {
    padding: 1rem;
  }

  #masthead #bootscore-navbar {
    align-items: stretch;
    gap: 0.5rem;
  }

  #masthead #bootscore-navbar .nav-link {
    background-color: var(--hnmi-light-secondary);
    border-radius: 1rem;
    padding: 0.85rem 1rem;
  }

  .home .hero {
    min-height: 680px;
    padding-top: 8rem;
  }

  .home .bienvenida,
  .home .pedido,
  .home .productos,
  .home .contacto {
    padding-bottom: 5rem;
    padding-top: 5rem;
  }

  .error404-hero {
    padding: 8rem 0 5rem;
  }

  .error404-hero::before {
    height: 10rem;
    top: 7rem;
    width: 10rem;
  }

  .error404-visual {
    grid-template-columns: minmax(0, 1fr) minmax(8.5rem, 16rem) minmax(0, 1fr);
  }
}

@media (max-width: 575.98px) {
  .home .hero {
    min-height: 620px;
    padding-top: 7rem;
  }

  .home .hero-logo {
    max-height: 120px;
  }

  .home .disfruta .arrow {
    padding: 1.25rem;
  }

  .woocommerce .page-title,
  .woocommerce-products-header__title,
  .woocommerce div.product .product_title {
    letter-spacing: 0.05rem;
  }

  .error404-hero {
    padding-bottom: 4rem;
  }

  .error404-visual {
    gap: 0;
    grid-template-columns: 0.85fr 1.3fr 0.85fr;
    margin: 2.5rem auto;
  }

  .error404-number {
    font-size: clamp(4.5rem, 30vw, 7rem);
    text-shadow: 0.11em 0.11em 0 rgba(251, 193, 7, 0.28);
  }

  .error404-steam {
    height: 3rem;
    top: -1.75rem;
  }
}