/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/
@font-face {
  font-family: 'Playfair Display';
  src: url('/fonts/playfair_display/PlayfairDisplay-Bold.woff2') format('woff2'),
      url('/fonts/playfair_display/PlayfairDisplay-Bold.woff') format('woff');
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display';
  src: url('fonts/playfair_display/PlayfairDisplay-Medium.woff2') format('woff2'),
      url('fonts/playfair_display/PlayfairDisplay-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display';
  src: url('fonts/playfair_display/PlayfairDisplay-Italic.woff2') format('woff2'),
      url('fonts/playfair_display/PlayfairDisplay-Italic.woff') format('woff');
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display';
  src: url('fonts/playfair_display/PlayfairDisplay-Regular.woff2') format('woff2'),
      url('fonts/playfair_display/PlayfairDisplay-Regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Playfair Display';
  src: url('fonts/playfair_display/PlayfairDisplay-SemiBold.woff2') format('woff2'),
      url('fonts/playfair_display/PlayfairDisplay-SemiBold.woff') format('woff');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}


:root {
  --background: 40 25% 93%;
  --foreground: 0 0% 10%;
  --primary: 0 0% 12%;
  --border: 40 15% 80%;
  --card: 30 15% 96%;
  --muted: 40 15% 88%;
  --muted-foreground: 0 0% 35%;
  --primary-foreground: 40 25% 95%;
  --accent-foreground: 0 0% 5%;
  --accent: 42 75% 50%;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --gold: 42 75% 50%;
  --gold-light: 42 65% 65%;
  --espresso: 20 50% 8%;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --radius: .5rem;
  --tw-gradient-from-position: ;
  --shadow-glow: 0 0 60px hsl(0 0% 10% / .08);
  --shadow-deep: 0 25px 50px -12px hsl(0 0% 0% / .15);
  --coffee-dark: 25 45% 12%;
  --coffee-medium: 25 35% 25%;
  --coffee-light: 30 25% 40%;
  --cream: 35 40% 94%;
  --gradient-gold: linear-gradient(
    135deg,
    hsl(43, 72%, 49%),
    hsl(35, 70%, 42%)
  );
  --gradient-card: linear-gradient(
    145deg,
    hsl(40, 20%, 97%),
    hsl(40, 20%, 94%)
  );
  --gradient-dark: linear-gradient(180deg, hsl(40, 25%, 93%), hsl(40, 20%, 88%));
  --gradient-hero: linear-gradient(135deg, hsl(40, 25%, 93%) 0%, hsl(40, 20%, 90%) 50%, hsl(38, 20%, 91%) 100%);
}
.contact-sect #gform_wrapper_1[data-form-index="0"].gform-theme,
.contact-sect [data-parent-form="1_0"] {
  --gf-color-primary: hsl(var(--primary));
  --gf-color-primary-rgb: 32, 76, 229;
  --gf-color-primary-contrast: #fff;
  --gf-color-primary-contrast-rgb: 255, 255, 255;
  --gf-color-primary-darker: rgb(25, 53, 87);
  --gf-color-primary-lighter: rgba(25, 53, 87, 0.7);
  --gf-color-secondary: #fff;
  --gf-color-secondary-rgb: 255, 255, 255;
  --gf-color-secondary-contrast: #193557;
  --gf-color-secondary-contrast-rgb: 17, 35, 55;
  --gf-color-secondary-darker: #f5f5f5;
  --gf-color-secondary-lighter: #ffffff;
  --gf-color-out-ctrl-light: rgba(17, 35, 55, 0.1);
  --gf-color-out-ctrl-light-rgb: 17, 35, 55;
  --gf-color-out-ctrl-light-darker: rgba(104, 110, 119, 0.35);
  --gf-color-out-ctrl-light-lighter: #f5f5f5;
  --gf-color-out-ctrl-dark: #585e6a;
  --gf-color-out-ctrl-dark-rgb: 88, 94, 106;
  --gf-color-out-ctrl-dark-darker: #193557;
  --gf-color-out-ctrl-dark-lighter: rgba(17, 35, 55, 0.65);
  --gf-color-in-ctrl: #f9fafb;
  --gf-color-in-ctrl-rgb: 255, 255, 255;
  --gf-color-in-ctrl-contrast: #112337;
  --gf-color-in-ctrl-contrast-rgb: 17, 35, 55;
  --gf-color-in-ctrl-darker: #f5f5f5;
  --gf-color-in-ctrl-lighter: #ffffff;
  --gf-color-in-ctrl-primary: hsl(var(--primary));
  --gf-color-in-ctrl-primary-rgb: 32, 76, 229;
  --gf-color-in-ctrl-primary-contrast: #fff;
  --gf-color-in-ctrl-primary-contrast-rgb: 255, 255, 255;
  --gf-color-in-ctrl-primary-darker: hsl(var(--primary));
  --gf-color-in-ctrl-primary-lighter: rgba(hsl(var(--primary)), 0.7);
  --gf-color-in-ctrl-light: rgba(17, 35, 55, 0.1);
  --gf-color-in-ctrl-light-rgb: 17, 35, 55;
  --gf-color-in-ctrl-light-darker: rgba(104, 110, 119, 0.35);
  --gf-color-in-ctrl-light-lighter: #f5f5f5;
  --gf-color-in-ctrl-dark: #585e6a;
  --gf-color-in-ctrl-dark-rgb: 88, 94, 106;
  --gf-color-in-ctrl-dark-darker: #112337;
  --gf-color-in-ctrl-dark-lighter: rgba(17, 35, 55, 0.65);
  --gf-radius: 8px;
  --gf-font-size-secondary: 14px;
  --gf-font-size-tertiary: 13px;
  --gf-icon-ctrl-number: url("data:image/svg+xml,%3Csvg width='8' height='14' viewBox='0 0 8 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M4 0C4.26522 5.96046e-08 4.51957 0.105357 4.70711 0.292893L7.70711 3.29289C8.09763 3.68342 8.09763 4.31658 7.70711 4.70711C7.31658 5.09763 6.68342 5.09763 6.29289 4.70711L4 2.41421L1.70711 4.70711C1.31658 5.09763 0.683417 5.09763 0.292893 4.70711C-0.0976311 4.31658 -0.097631 3.68342 0.292893 3.29289L3.29289 0.292893C3.48043 0.105357 3.73478 0 4 0ZM0.292893 9.29289C0.683417 8.90237 1.31658 8.90237 1.70711 9.29289L4 11.5858L6.29289 9.29289C6.68342 8.90237 7.31658 8.90237 7.70711 9.29289C8.09763 9.68342 8.09763 10.3166 7.70711 10.7071L4.70711 13.7071C4.31658 14.0976 3.68342 14.0976 3.29289 13.7071L0.292893 10.7071C-0.0976311 10.3166 -0.0976311 9.68342 0.292893 9.29289Z' fill='rgba(17, 35, 55, 0.65)'/%3E%3C/svg%3E");
  --gf-icon-ctrl-select: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M0.292893 0.292893C0.683417 -0.097631 1.31658 -0.097631 1.70711 0.292893L5 3.58579L8.29289 0.292893C8.68342 -0.0976311 9.31658 -0.0976311 9.70711 0.292893C10.0976 0.683417 10.0976 1.31658 9.70711 1.70711L5.70711 5.70711C5.31658 6.09763 4.68342 6.09763 4.29289 5.70711L0.292893 1.70711C-0.0976311 1.31658 -0.0976311 0.683418 0.292893 0.292893Z' fill='rgba(17, 35, 55, 0.65)'/%3E%3C/svg%3E");
  --gf-icon-ctrl-search: url("data:image/svg+xml,%3Csvg version='1.1' xmlns='http://www.w3.org/2000/svg' width='640' height='640'%3E%3Cpath d='M256 128c-70.692 0-128 57.308-128 128 0 70.691 57.308 128 128 128 70.691 0 128-57.309 128-128 0-70.692-57.309-128-128-128zM64 256c0-106.039 85.961-192 192-192s192 85.961 192 192c0 41.466-13.146 79.863-35.498 111.248l154.125 154.125c12.496 12.496 12.496 32.758 0 45.254s-32.758 12.496-45.254 0L367.248 412.502C335.862 434.854 297.467 448 256 448c-106.039 0-192-85.962-192-192z' fill='rgba(17, 35, 55, 0.65)'/%3E%3C/svg%3E");
  --gf-ctrl-border-color: hsl(var(--border));
  --gf-ctrl-label-color-primary: hsl(var(--primary));
  --gf-ctrl-label-color-secondary: hsl(var(--primary));
  --gf-ctrl-btn-border-color-secondary: #42a5d7;
  --gf-ctrl-file-btn-bg-color-hover: #ebebeb;
  --gf-field-pg-steps-number-color: rgba(17, 35, 55, 0.8);
  --gf-ctrl-border-color-focus: hsl(var(--border));
  --gf-ctrl-label-color-req: hsl(var(--primary));
}

body {
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
}

.overflow-hidden {
  overflow: hidden;
}
.relative {
  position: relative;
}
.absolute {
  position: absolute;
}
.sticky {
  position: sticky;
}
.top-28 {
  top: 7rem;
}
.opacity-50 {
  opacity: 0.5;
}
.opacity-90 {
  opacity: 0.9;
}
.opacity-60 {
  opacity: .6;
}
.opacity-0 {
  opacity: 0;
}
.right-3 {
  right: .75rem;
}

.bottom-3 {
  bottom: .75rem;
}
.bg-background-95 {
  background-color: hsl(var(--background) / .95);
}
.bg-muted {
  background-color: hsl(var(--muted));
}
.bg-primary-10 {
  background-color: rgba(25, 53, 87, 0.1);
}
.bg-accent {
  background-color: hsl(var(--accent));
}
.bg-secondary {
  background-color: var(--fs-color-secondary);
}
.bg-gradient-card {
  background: var(--gradient-card);
}
.bg-coffee-dark {
  background-color: hsl(var(--coffee-dark));
}
.hover-bg-coffee-medium:hover {
  background-color: hsl(var(--coffee-medium));
}
.text-primary-30 {
  color: rgba(25, 53, 87, 0.3);
}
.text-cream {
  color: hsl(var(--cream));
}
.dark .text-secondary,
.text-secondary {
  color: var(--fs-color-secondary);
}
.dark .text-primary-foreground-80,
.text-primary-foreground-80 {
  color: rgba(255, 255, 255, 0.8);
}
.dark .text-primary-foreground-60,
.text-primary-foreground-60 {
  color: rgb(255, 255, 255, 0.6);
}
.text-secondary-foreground {
  color: #fff;
}
.border-border-30,
.border-border\/30 {
  border-color: hsl(var(--border) / .3);
}
.border-color {
  color: #dae0e7;
}
.border-y {
  border-top: 1px solid hsl(var(--border) / 0.3);
  border-bottom: 1px solid hsl(var(--border) / 0.3);
}
.italic {
  font-style: italic;
}
.font-bold {
  font-weight: 700;
}
.font-medium {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
}
.font-display {
  font-family:
    Playfair Display,
    Georgia,
    serif;
}
.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}
.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}
.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}
.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}
.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}
.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}
.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.text-center {
  text-align: center;
}
.w-full {
  width: 100%;
}
.w-2 {
  width: 0.5rem;
}
.w-4 {
  width: 1rem;
}
.w-5 {
  width: 1.25rem;
}
.w-6 {
  width: 1.5rem;
}
.w-10 {
  width: 2.5rem;
}
.w-11 {
  width: 2.75rem;
}
.w-12 {
  width: 3rem;
}
.w-14 {
  width: 3.5rem;
}
.w-20 {
  width: 5rem;
}
.h-3 {
  height: .75rem;
}
.h-4 {
  height: 1rem;
}
.h-5 {
  height: 1.25rem;
}
.h-6 {
  height: 1.5rem;
}
.h-9 {
  height: 2.25rem;
}
.h-10 {
  height: 2.5rem;
}
.h-11 {
  height: 2.75rem;
}
.h-12 {
  height: 3rem;
}
.h-14 {
  height: 3.5rem;
}
.h-20 {
  height: 5rem;
}
.h-64 {
  height: 16rem;
}
.w-3-5,
.w-3\.5 {
  width: .875rem;
}
.h-3-5,
.h-3\.5 {
  height: .875rem;
}
.h-full {
  height: 100%;
}
.max-w-3xl {
  max-width: 48rem;
}
.max-w-2xl {
  max-width: 42rem;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.max-w-200 {
  max-width: 200px;
}
body .row .max-w-4xl,
.max-w-4xl {
  max-width: 56rem;
}
.tracking-wide {
  letter-spacing: 0.025em;
}
.tracking-wide-minus {
  letter-spacing: -0.025em;
}
.p-3 {
  padding: 0.75rem;
}
.p-5 {
  padding: 1.25rem;
}
.p-6 {
  padding: 1.5rem;
}
.p-8 {
  padding: 2rem;
}
.pt-2 {
  padding-top: .5rem;
}
.pt-4 {
  padding-top: 1rem;
}
.pt-6 {
  padding-top: 1.5rem;
}
.pb-4 {
  padding-bottom: 1rem;
}
.px-8 {
  padding-left: 2rem;
  padding-right: 2rem;
}
.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}
.px-2-5,
.px-2\.5 {
  padding-left: .625rem;
  padding-right: .625rem;
}
.px-3 {
  padding-left: .75rem;
  padding-right: .75rem;
}
.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}
.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.py-20 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
.ml-1 {
  margin-left: .25rem;
}
.mt-05 {
  margin-top: 0.125rem;
}
.mt-1 {
  margin-top: 0.25rem;
}
.mt-2 {
  margin-top: 0.5rem;
}
.mt-3 {
  margin-top: 0.75rem;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-6 {
  margin-top: 1.5rem;
}
.mt-8 {
  margin-top: 2rem;
}
.mb-1 {
  margin-bottom: 0.25rem;
}
.mb-2 {
  margin-bottom: 0.5rem;
}
.mb-3 {
  margin-bottom: 0.75rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-6 {
  margin-bottom: 1.5rem;
}
.mb-8 {
  margin-bottom: 2rem;
}
.mb-10 {
  margin-bottom: 2.5rem;
}
.mb-12 {
  margin-bottom: 3rem;
}
.mb-16 {
  margin-bottom: 4rem;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.line-clamp-1 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.grid {
  display: grid;
}
.gap-05 {
  gap: 0.125rem;
}
.gap-1 {
  gap: 0.25rem;
}
.gap-1-5,
.gap-1\.5 {
  gap: .375rem;
}
.gap-2 {
  gap: 0.5rem;
}
.gap-3 {
  gap: 0.75rem;
}
.gap-4 {
  gap: 1rem;
}
.gap-6 {
  gap: 1.5rem;
}
.gap-8 {
  gap: 2rem;
}
.bg-card {
  background-color: #fff;
}
.hover-bg-card:hover {
  background-color: hsl(var(--card));
}
.shrink-0 {
  flex-shrink: 0;
}
.shadow-card {
  box-shadow: rgba(25, 53, 87, 0.1) 0px 4px 20px -4px;
}
.shadow-card-hover {
  box-shadow: rgba(25, 53, 87, 0.1) 0px 4px 20px -4px;
}
.shadow-card-hover:hover {
  box-shadow: 0 12px 32px -8px rgba(25, 53, 87, 0.18);
}
.shadow-elevated {
  box-shadow: 0 10px 40px -10px hsl(25 45% 12% / .2);
}
.shadow-deep {
  box-shadow: var(--shadow-deep);
}
.hover-underline:hover{
  text-decoration: underline;
}
.hover-shadow-glow:hover {
  box-shadow: var(--shadow-glow);
}
.hover-border-primary-50:hover,
.hover\:border-primary\/50:hover {
  border-color: hsl(var(--primary) / .5);
}
.hover-scale-1-02:hover,
.hover\:scale-\[1\.02\]:hover {
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.rounded {
  border-radius: 0.25rem;
}
.rounded-sm {
  border-radius: calc(var(--radius) - 4px);
}
.rounded-md {
  border-radius: calc(var(--radius) - 2px);
}
.rounded-full {
  border-radius: 9999px;
}
.rounded-lg {
  border-radius: 0.625rem;
}
.rounded-xl {
  border-radius: 0.75rem;
}
.rounded-2xl {
  border-radius: 1rem;
}
.h-44 {
  height: 11rem;
}

/* common css  */
/* Layout */
.block {
  display: block;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex {
  display: flex;
}
.flex-col {
  flex-direction: column;
}
.inline-flex {
  display: inline-flex;
}
.items-center {
  align-items: center;
}

/*  */
.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}
.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.pt-8 {
  padding-top: 2rem;
}
.pt-24 {
  padding-top: 6rem !important;
}
.mt-12 {
  margin-top: 3rem;
}
.p-4 {
  padding: 1rem;
}
.bg-muted-50,
.bg-muted\/50 {
  background-color: hsl(var(--muted) / 0.5);
}
.bg-muted-30,
.bg-muted\/30 {
  background-color: hsl(var(--muted) / .3);
}
.border {
  border: 1px solid hsl(var(--border));
  
}
.border-border-50,
.border-border\/50 {
  border-color: hsl(var(--border) / 0.5);
}


.mb-0 {
  margin-bottom: 0;
}

/* Sizing */
.w-px {
  width: 1px;
}

.h-12 {
  height: 3rem;
}
.h-56 {
  height: 14rem;
}
.max-w-xl {
  max-width: 36rem;
}
.max-w-xl {
  max-width: 36rem;
}
/* Borders & Radius */
.border-t {
  border-top: 1px solid hsl(var(--border) / 0.3);
}

/* Typography – Size */
.text-5xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.leading-tight {
  line-height: 1.25;
}
.cursor-pointer {
  cursor: pointer;
}
.uppercase {
  text-transform: uppercase;
}
.tracking-brochure {
  letter-spacing: 0.25em;
}
/* Colors & Backgrounds */
.text-primary {
  color: hsl(var(--primary));
}
.hover-text-primary {
  color: hsl(var(--primary));
}
.text-primary-foreground {
  color: hsl(var(--primary-foreground));
}
.text-foreground {
  color: hsl(var(--foreground));
}
.text-muted-foreground {
  color: hsl(var(--muted-foreground));
}
.bg-primary {
  background-color: hsl(var(--primary));
}
.text-gradient-gold {
  background-image: var(--gradient-gold);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
}
/* Animations & Transitions */
.animate-fade-up {
  animation: fadeUp 0.8s ease-out forwards;
}
.animate-bounce {
  animation: bounce 1s infinite;
}
.animate-pulse {
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
.animate-float {
  animation: float 6s ease-in-out infinite;
}
.delay-100 {
  transition-delay: 0.1s;
}
.delay-200 {
  transition-delay: 0.2s;
}
.delay-300 {
  transition-delay: 0.3s;
}
.invert {
  filter: invert(1);
}
.inset-0 {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.bottom-8 {
  bottom: 2rem;
}
.left-3 {
  left: .75rem;
}
.top-3 {
  top: .75rem;
}
.position-center {
  left: 50%;
  transform: translateX(-50%);
}
.tracking-widest {
  letter-spacing: 0.1em;
}

.bg-gradient-to-b {
  background-image: linear-gradient(
    to bottom,
    hsl(var(--primary)),
    transparent
  );
}
.opacity-15 {
  opacity: 0.15;
}
.object-cover {
  -o-object-fit: cover;
  object-fit: cover;
}
.z-index-0 {
  z-index: -1;
}
.z-10 {
  z-index: 10;
}
.bg-gradient-to-r {
  background-image: linear-gradient(to right, var(--tw-gradient-stops));
}
.from-background {
  --tw-gradient-from: hsl(var(--background));
  --tw-gradient-to: hsl(var(--background) / 0);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}
.via-background-90 {
  --tw-gradient-to: hsl(var(--background) / 0);
  --tw-gradient-stops:
    var(--tw-gradient-from), hsl(var(--background) / 0.9), var(--tw-gradient-to);
}
.to-background-70 {
  --tw-gradient-to: hsl(var(--background) / 0.7);
}
.transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s;
}
.duration-700 {
  transition-duration: .7s;
}
.duration-300 {
  transition-duration: .3s;
}
.justify-end {
  justify-content: flex-end;
}
.justify-between {
  justify-content: space-between;
}
.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .15s;
}
.group:hover .group-hover-scale-110 {
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.group:hover .group-hover-text-primary,
.group:hover .group-hover\:text-primary {
  color: hsl(var(--primary));
}
.group:hover .group-hover-gap-2,
.group:hover .group-hover\:gap-2 {
  gap: .5rem;
}
.group-btn:hover .group-hover-btn-translate-x-1, 
.group:hover .group-hover-translate-x-1,
.group\/btn:hover .group-hover\/btn\:translate-x-1, 
.group:hover .group-hover\:translate-x-1 {
  --tw-translate-x: .25rem;
  transform: translateX(var(--tw-translate-x));
}
.group:hover .group-hover-opacity-100 {
  opacity: 1;
}
.col-pb-0 > .col {
  padding-bottom: 0;
}
.col-p-0 > .col {
  padding: 0;
}
#main,
#wrapper {
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
}

/* header  */
.header-wrapper .header-bottom,
.absolute-footer {
  display: none;
}

.header-wrapper .header-nav-main.nav-left {
  justify-content: center;
}

.header-main .nav > li > a {
  color: hsl(var(--foreground) / 0.7);
  padding: 0;
  font-weight: 500;
}

.header-main .nav > li.menu-item > a.nav-top-link {
  position: relative;
  transition: all 0.2s linear;
}

.header-main .nav > li.menu-item > a.nav-top-link:after {
  transition-duration: 0.3s;
  content: "";
  animation-duration: 0.3s;
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  background-color: hsl(var(--primary));
  transform: scaleX(0) scaleY(1);
  width: 100%;
  height: 0.125rem;
  bottom: 0;
  left: 0;
  position: absolute;
  transform-origin: right;
}
.header-main .nav > li.menu-item > a.nav-top-link:hover {
  color: hsl(var(--primary));
}

.header-main .nav > li.menu-item > a.nav-top-link:hover:after {
  --tw-scale-x: 1;
  transform: scaleX(1) scaleY(1);
  transform-origin: left;
}

.header-inner .flex-right .nav > li {
  font-size: 0.875rem;
  line-height: 1.25rem;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.3s;
  color: #1a1a1ab3;
  font-weight: 500;
  white-space: nowrap;
  align-items: center;
  width: 2.5rem;
  justify-content: center;
  gap: 0.5rem;
  height: 2.5rem;
  display: inline-flex;
  margin: 0;
}
.header-inner .flex-right .nav > li i {
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.7;
}
.header-inner .flex-right .nav > li:hover i {
  opacity: 1;
}
.header-inner .flex-right .nav > li i::before {
  content: unset;
}
.header-inner .flex-right .nav > li i.icon-search {
  background-image: url(images/search.svg);
}
.header-inner .flex-right .nav > li i.icon-user {
  background-image: url(images/user.svg);
}
.header-inner .flex-right .nav > li i.icon-shopping-cart {
  background-image: url(images/cart.svg);
}
.header-inner .flex-right .nav > li i.icon-menu {
  background-image: url(images/nav.svg);
}
.header-inner .flex-right .nav .nav-dropdown {
  top: 100%;
}
.header-cart-link i{
  opacity: 1;
}
.header-cart-link [data-icon-label]:after {
  background-color: hsl(var(--coffee-dark));
  border-radius: 99px;
  box-shadow: none;
  color: #fff;
  content: attr(data-icon-label);
  font-family: DM Sans, system-ui, sans-serif !important;
  font-size: .75rem;
  font-style: normal;
  font-weight: bolder;
  height: 1.25rem;
  letter-spacing: -.5px;
  line-height: 1.25rem;
  min-width: 1.25rem;
  opacity: 1;
  padding-left: 2px;
  padding-right: 2px;
  position: absolute;
  right: -10px;
  text-align: center;
  top: -10px;
  transition: transform .2s;
  z-index: 1;
}
.header-inner .flex-right .nav > li .icon-menu {
  width: 24px;
  height: 24px;
  background-size: 24px 24px;
  opacity: 1;
}

.main-menu-overlay {
  display: none;
}
body:has(.main-menu-overlay) .header-inner .flex-right .nav > li.nav-icon {
  display: none;
}
.header-inner .flex-right .nav > li.html_topbar_left {
  display: none;
}
body:has(.main-menu-overlay) .header-inner .flex-right .nav > li.html_topbar_left {
  display: flex;
}
.mfp-wrap:has(#main-menu) {
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  --tw-backdrop-blur: blur(16px);
  backdrop-filter: var(--tw-backdrop-blur);
  transform: unset;
  height: 100vh !important;
  width: 100vw !important;
  position: fixed !important;
  z-index: 9999 !important;
  padding-top: 70px !important;
}

/* Mobile menu full screen overlay */
@media only screen and (max-width: 849px) {
  .mfp-wrap:has(#main-menu) {
    height: 100dvh !important;
  }

  .mfp-wrap:has(#main-menu) .mfp-content {
    height: calc(100% - 70px) !important;
    overflow: visible !important;
  }

  .mfp-wrap:has(#main-menu) .sidebar-menu {
    height: 100% !important;
    overflow: visible !important;
  }

  .off-canvas {
    height: 100% !important;
    overflow: visible !important;
  }

  .nav-sidebar {
    overflow: visible !important;
  }
}

.mfp-wrap:has(#main-menu) .mfp-close {
  display: none;
}

.mfp-wrap:has(#main-menu) .mfp-container {
  position: relative !important;
  pointer-events: auto !important;
}
.mfp-wrap:has(#main-menu) .mfp-container::before {
  content: unset;
}

.mfp-wrap:has(#main-menu) .mfp-content,
.mfp-container .sidebar-menu {
  padding: 0;
  pointer-events: auto !important;
}

.off-canvas,
.nav-sidebar,
.nav-sidebar a {
  pointer-events: auto !important;
}
.nav-sidebar {
  padding: 1.5rem 1rem;
  gap: 1rem;
  flex-direction: column;
  display: flex;
}
.off-canvas-center .nav-vertical > li > a,
.off-canvas-center .nav-vertical > li > ul > li a {
  justify-content: left;
}
.off-canvas .nav-vertical > li > a {
  padding: 0.5rem 0 !important;
  transition-property:
    color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.15s;
  color: hsl(var(--foreground) / 0.8);
  font-weight: 500;
  font-size: 1rem;
  line-height: 24px;
  font-family:
    DM Sans,
    system-ui,
    sans-serif;
}
.off-canvas .nav-vertical > li {
  transition: unset;
}
.nav-sidebar.nav-vertical>li.menu-item:hover {
  background-color: unset;
}
.header-button-1 .button {
  color: hsl(var(--primary-foreground));
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding-left: 2rem;
  padding-right: 2rem;
  background-color: hsl(var(--primary));
  border-radius: calc(var(--radius) - 2px);
  white-space: nowrap;
  gap: 0.5rem;
  justify-content: center;
  align-items: center;
  height: 2.75rem;
  display: inline-flex;
  margin-top: 1rem;
  width: 100%;
  margin: 0;
}

.header-wrapper.stuck {
  box-shadow: unset;
  border: 1px solid;
  --tw-backdrop-blur: blur(12px);
  backdrop-filter: var(--tw-backdrop-blur);
  background-color: hsl(var(--background) / 0.95);
  border-color: hsl(var(--border) / 0.5);
}

/* footer  */
.ux-footer {
  background-color: hsl(var(--muted) / 0.5);
  border: 1px solid;
  border-color: hsl(var(--border) / 0.5);
  font-size: 14px;
  color: hsl(var(--muted-foreground));
  font-weight: 400;
}

.ux-footer .ux-logo-link {
  padding: 0 !important;
  margin-bottom: 1.5rem;
}

.follow-icons {
  gap: 1rem;
  display: flex;
  margin-top: 1.5rem;
}
.follow-icons .icon {
  margin: 0;
  color: hsl(var(--muted-foreground));
  background-color: hsl(var(--muted));
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  border: unset;
  font-size: 14px;
}

.follow-icons .button i {
  top: 0 !important;
}

.social-icons .button.icon:hover {
  background-color: hsl(var(--primary)) !important;
  color: #fff !important;
}

.ux-footer-head {
  color: hsl(var(--foreground));
  font-weight: 600;
  margin-bottom: 1.5rem;
}

.ux-footer-head h3 {
  font-size: 1rem;
  margin-bottom: 0;
}

.ux-footer-col svg {
  width: 20px;
  height: 20px;
  color: hsl(var(--primary));
  margin-top: 3px;
}

.ux-footer-bottom-row p {
  margin-bottom: 0;
}
.ux-footer-bottom-row {
  padding-top: 2rem;
  margin-top: 1.5rem;
  border-top: 1px solid;
  border-color: hsl(var(--border) / 0.5);
  padding-left: 1rem;
  padding-right: 1rem;
}

.coffee-leaves-pattern {
  background-image: url('images/coffee-leaves.png');
}
.hero-sect {
  margin-top: -80px;
}
.hero-sect .section-content {
  min-height: 100vh;
  padding-top: 150px;
}

/* Custom Components */

.text-8xl {
  font-size: 3rem;
  line-height: 1;
}

.text-6xl {
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.ux-btn {
  animation-duration: 0.3s;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  color: hsl(var(--primary));
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.75rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  border-radius: 9999px;
  white-space: nowrap;
  gap: 0.5rem;
  justify-content: center;
  align-items: center;
  height: 3.5rem;
  display: inline-flex;
  cursor: pointer;
  font-size: 18px;
  font-weight: 700;
}
.ux-btn.is-outline {
  background-color: transparent;
  border-color: hsl(var(--primary));
  border-width: 2px;
  color: hsl(var(--primary));
}
.ux-btn.is-outline:hover {
  background-color: hsl(var(--primary));
  border-color: hsl(var(--primary));
  color: #fff;
}
.ux-btn:not(.is-outline):hover {
  filter: brightness(1.1);
  box-shadow:
    0 10px 15px -3px rgb(0 0 0 / 0.1),
    0 4px 6px -4px rgb(0 0 0 / 0.1);
  transform: scale(1.03);
  color: hsl(var(--primary));
}
.ux-btn .icon-angle-right {
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
  background-position: center;
  background-image: url("images/arrow-right.svg");
  background-repeat: no-repeat;
}
.ux-btn .icon-angle-right::before {
  content: unset;
}

.grid-icon {
  background-color: hsl(var(--primary) / 0.1);
  border-radius: 0.5rem;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  transition: all 0.2s linear;
}
.grid-icon svg {
  width: 1.5rem;
  height: 1.5rem;
  color: hsl(var(--primary));
}
.large-icon-box .grid-icon{
  width: 3.5rem;
  height: 3.5rem;
}
.large-icon-box .grid-icon svg{
  width: 28px;
  height: 28px;
}
.ux-grid-col > .col-inner {
  padding: 1.5rem;
  background: var(--gradient-card);
  border: 1px solid hsl(var(--border) / 0.5);
  border-radius: 0.75rem;
  transition: all 0.2s linear;
  height: 100%;
}
.ux-grid-col > .col-inner:hover {
  border-color: hsl(var(--primary) / 0.5);
}
.ux-grid-col > .col-inner:hover .grid-icon {
  background-color: hsl(var(--primary) / 0.2);
}
.large-icon-box .ux-grid-col > .col-inner{
  padding: 2rem;
}
.large-icon-box .ux-grid-col > .col-inner:before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: hsl(var(--primary) / .05);
  opacity: 0;
  transition: all 0.2s linear;
}
.large-icon-box .ux-grid-col > .col-inner:hover:before{
  opacity: 1;
}
.large-icon-box .ux-grid-col > .col-inner:hover{
  box-shadow: var(--shadow-glow);
}
.ux-grid-col p {
  margin-bottom: 0;
}
.why-choose-sect .section-content:before{
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  height: 800px;
  width: 800px;
  background-color: hsl(var(--primary) / .05);
  border-radius: 9999px;
  filter: blur(64px);
  transform: translate(-50%, -50%);
}

.pattern-overlay {
  background-image:
    radial-gradient(
      circle at 20% 80%,
      hsl(0 0% 10% / 0.03) 0%,
      transparent 50%
    ),
    radial-gradient(circle at 80% 20%, hsl(0 0% 10% / 0.03) 0%, transparent 50%);
}

.sect-row {
  align-items: center;
}
.sect-row .img-inner img {
  max-width: 448px;
}

.sub-title,
.sub-title p {
  letter-spacing: 0.25em;
  color: hsl(var(--primary));
  text-transform: uppercase;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
  display: block;
  margin-bottom: 1rem;
}

.ux-para {
  line-height: 1.625;
  color: hsl(var(--muted-foreground));
  font-size: 1.125rem;
  margin-bottom: 2rem;
}

.left-icon-box {
  background: #fff;
  border: 1px solid #dae0e7;
  box-shadow: rgba(25, 53, 87, 0.1) 0px 4px 20px -4px;
  padding: 1.25rem;
  width: 100%;
  border-radius: 0.75rem;
}
.left-icon-box .icon {
  background: #d0e6f1;
  border-radius: 0.625rem;
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.left-icon-box .icon-inner {
  display: flex;
  align-items: center;
  justify-content: center;
}
.left-icon-box .icon svg {
  padding-top: 0;
  width: 24px;
  height: 24px;
}
.left-icon-box .icon svg,
.left-icon-box .icon svg path {
  fill: none;
}

html:has(.main-menu-overlay) {
  overflow: hidden;
}
.off-canvas-center .nav-sidebar.nav-vertical > li > a {
  font-family: "DM Sans", sans-serif !important;
}
.ux-form_wrapper .gform_heading {
  display: none;
}
.ux-form {
  max-width: 672px !important;
  margin: 0 auto !important;
  --gf-form-gap-y: 1rem;
}

.ux-form input[type="text"],
.ux-form input[type="email"]{
  font-size: 1rem !important;
  line-height: 1.5rem !important;
  padding-top: 0.75rem !important;
  padding-bottom: 0.75rem !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  background-color: hsl(var(--muted) / 0.5) !important;
  border-color: hsl(var(--border) / 0.5) !important;
  border: 1px solid !important;
  border-radius: var(--radius) !important;
  border-color: hsl(var(--border) / 0.5) !important;
  width: 100% !important;
  height: 3rem !important;
  display: flex !important;
  box-shadow: unset !important;
}
.ux-form input[type="text"]:focus,
.ux-form input[type="email"]:focus {
  box-shadow:0 0 0 0px #fff, 0 0 0 calc(3px + 0px) hsl(0 0% 12% / 0.5), 0 0 #0000 !important;
}
.ux-form input[type="text"]::placeholder,
.ux-form input[type="email"]::placeholder{
  opacity: 0.6;
}
.contact-submit-btn button,
.ux-form input[type="submit"] {
    animation-duration: 0.3s !important;
    transition-property: all !important;
    transition-timing-function: 
cubic-bezier(0.4, 0, 0.2, 1) !important;
    color: #000000 !important;
    font-weight: 500 !important;
    font-size: 1.125rem !important;
    line-height: 1.75rem !important;
    padding-left: 2.5rem !important;
    padding-right: 2.5rem !important;
    border-radius: 9999px !important;
    white-space: nowrap !important;
    gap: 0.5rem !important;
    justify-content: center ! IMPORTANT;
    align-items: center !important;
    height: 3.5rem ! IMPORTANT;
    display: inline-flex !important
;
    cursor: pointer !important;
    font-size: 1.125rem !important;
    font-weight: 600 !important;
    background-color: #d7a423 !important;
}
.contact-submit-btn svg{
  width: 16px;
  height: 16px;
}
.gform_wrapper.gform-theme--foundation .contact-submit-btn{
  grid-column: 1 / -1;
  text-align: center;
}
.gform_wrapper .gform-body{
  position: relative;
}
.gform_wrapper .gfield.gfield--type-submit .gform-button{
  position: absolute;
  left: 50%;
  bottom: 1rem;
  z-index: 10;
  transform: translateX(-50%);
  width: 205px !important;
  opacity: 0 !important;
}
.gform_wrapper .gform_footer {
  margin: 0 !important;
}
.contact-sect .gform-theme--framework .gform_validation_errors{
  display: none;
}
.ux-form .gform_footer{
    justify-content: center;
}
.contact-submit-btn button:hover,
.ux-form input[type="submit"]:hover {
    filter: brightness(1.1);
    box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    transform: scale(1.03);
    color: hsl(var(--primary));
}
.sec-border-top:before,
.shop-section:before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(31, 31, 31, 0.2), rgba(0, 0, 0, 0));
}
.sec-border-top:after,
.shop-section:after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  background-image:linear-gradient(to right, rgba(0, 0, 0, 0), rgba(31, 31, 31, 0.2), rgba(0, 0, 0, 0));
}
.coffee-beans-bg {
  background-image: url('images/coffee-beans-pattern.gif');
  background-size: cover;
  background-position: center;
  background-repeat: repeat;
}
.shop-filters-right-inner .dropdown-toggle{
  font-weight: 400;
  padding-right: 40px;
  width: 100%;
}
.shop-filters-right-inner .dropdown-toggle::after{
  content: '';
  background: url('images/check-icon.svg') no-repeat center center;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
  opacity: 0.4;
}
.shop-filters-right-inner .dropdown-toggle span{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
.shop-filters-right-inner .dropdown{
  position: relative;
  width: 200px;
}
.shop-filters-right-inner .dropdown-menu{
  display: none;
  background: #fff;
  border: 1px solid #dae0e7;
  border-radius: 0.3rem;
  padding:0.25rem;
  box-shadow: rgba(25, 53, 87, 0.1) 0px 4px 20px -4px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  z-index: 1000;
  list-style: none;
}
.shop-filters-right-inner .dropdown-menu li{
  font-size: .875rem;
  line-height: 1.25rem;
  margin: 0;
  padding: 0.4rem 2rem;
  border-radius: 0.3rem;
  position: relative;
  cursor: pointer;
}
.shop-filters-right-inner .dropdown-menu li svg{
  position: absolute;
  top: 8px;
  left: 8px;
  width: 18px;
  height: 18px;
  display: none;
}
.shop-filters-right-inner .dropdown-menu li.active svg{
  display: block;
}
.shop-filters-right-inner .dropdown-menu li:hover{
  background-color: hsl(var(--accent));
}
.shop-filters-right-inner .dropdown.open-dropdown .dropdown-menu{
  display: block;
}
.category-card .bg-gradient-to-t{
  background-image: linear-gradient(to top, rgb(242, 239, 233), rgba(242, 239, 233, 0.7), rgba(242, 239, 233, 0.3));
}
.shop-products .row .row-small:not(.row-collapse){
  margin-left: -12px;
  margin-right: -12px;
}
.shop-products .row-small>.col{
  padding: 0 11.8px 23.6px;
}
.products .product-small .box-image img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition-duration: .7s;
  transition-property: transform;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}
.products .product-small.group:hover .box-image img{
  --tw-scale-x: 1.1;
  --tw-scale-y: 1.1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.products .product-small .box-image .bg-gradient-to-t{
  background-image:linear-gradient(to top, rgb(242, 239, 233), rgba(242, 239, 233, 0.2), rgba(0, 0, 0, 0));
}
.box-image .addtocart-btn-wrapper a{
  display: inline-flex;
  color: #fff;
}
.product-small .add-to-cart-button .button{
  min-height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  white-space: nowrap;
  border-radius: calc(var(--radius) - 2px);
  border: 2px solid hsl(var(--primary));
  background-color: transparent;
  color: hsl(var(--primary));
  padding-left: .75rem;
  padding-right: .75rem;
  font-size: .875rem;
  line-height: 1.25rem;
  font-weight: 500;
  transition-property: all;
  transition-timing-function: cubic-bezier(.4, 0, .2, 1);
  transition-duration: .3s;
}
.product-small .add-to-cart-button .button:hover{
  background-color: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  border-color: hsl(var(--primary));
}
.product-small .tag-novita{
  color: hsl(var(--accent-foreground));
  background-color: hsl(var(--accent));
}
.product-small .tag-bestseller{
  color: hsl(var(--primary-foreground));
  background-color: hsl(var(--primary));
}
.product-small .tag-esclusivo{
  color: hsl(var(--foreground));
  background-color: hsl(var(--muted));
}
.product-small .col-inner{
  height: 100%;
}
.product-small .product-small{
  height: 100%;
}
.product-small .image-none{
  height: 100%;
  width: 100%;
}
.product-small .image-none a{
  height: 100%;
  width: 100%;
}
.product-small .box-image .addtocart-btn-wrapper span{
  display: none;
}
.product-small .product-box-details .addtocart-btn-wrapper{
  display: none;
}
.contact-privacy a{
  color: hsl(var(--primary));
}
.contact-privacy a:hover{
  color:hsl(var(--primary));
  text-decoration: underline;
}

.footer-link-col a{
  color:hsl(var(--muted-foreground));
}
.footer-link-col a:hover{
  color: hsl(var(--primary));
}

.product-gallery-slider img {
  max-width: 636px;
  max-height: 636px;
  object-fit: cover;
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.5s;
}

.product-gallery .flickity-button {
  display: none;
}

.product-gallery-slider img:hover {
  transform: scale(1.05);
}

.woocommerce-product-gallery__image > a {
  display: block;
  overflow: hidden;
  border-radius: 1rem;
  width: fit-content;
}

.woocommerce-product-gallery__image > a:hover img {
  transform: scale(1.05);
}
.product-thumbnails a {
  border-radius: 0.375rem;
  height: 100%;
  align-items: center;
  justify-content: center;
  opacity: 0.7;
}
.product-thumbnails a:hover,
.product-thumbnails .is-nav-selected a{
    opacity: 1;
}
.product-thumbnails .is-nav-selected a{
    box-shadow: 0 0 0 2px hsl(30 10% 98%), 0 0 0 calc(2px + 2px) hsl(25 45% 12%), 0 0 #0000;
}
.product-thumbnails img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0;
  transform: unset !important;
  opacity: 1;
}

.product-thumbnails .flickity-slider > .col {
    width: 100px;
    height: 100px;
    padding: 10px !important;
}

.product-gallery {
  position: relative;
}

.product-gallery #product-tags {
  position: absolute;
  z-index: 3;
}
.product-gallery #product-tags > ul {
  list-style: none;
  margin: 0;
  padding: 1rem;
}
.product-gallery #product-tags > ul > li {
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  background-color: #2c1c11;
  color: #f6f1ea;
  border-radius: 9999px;
  margin: 0;
}
.product-gallery #product-tags > ul > li.tag-novita {
  color: hsl(var(--accent-foreground));
  background-color: hsl(var(--accent));
}
.product-gallery #product-tags > ul > li.tag-bestseller {
  color: hsl(var(--primary-foreground));
  background-color: hsl(var(--primary));
}
.product-gallery #product-tags > ul > li.tag-esclusivo {
  color: hsl(var(--foreground));
  background-color: hsl(var(--muted));
}
.mb-half {
  margin-bottom: 0.5rem;
}
.product-info{
  padding-top: 0;
}
.product-info-box {
  padding: 2rem;
  background-color: hsl(30 10% 98% / 0.95);
  border-radius: 1rem;
  box-shadow: 0 10px 40px -10px hsl(25 45% 12% / 0.2);
  backdrop-filter: blur(12px);
}

.product-info .tipo-radio {
  display: flex;
  gap: 10px;
}

.product-info .tipo-radio label {
  position: relative;
  cursor: pointer;
}

.product-info .tipo-radio input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.product-info .tipo-radio span {
  display: inline-block;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: var(--radius);
  background-color: hsl(var(--muted));
  color: hsl(var(--muted-foreground));
  font-weight: 500;
  transition: all 0.2s ease;
  font-size: 1rem;
}

.product-info .tipo-radio input:checked + span {
  background-color: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
}
.text-gold {
  color: hsl(var(--gold));
}
.italic {
  font-style: italic;
}
.product-info .price-wrapper{
  display: none;
}
.product-info .variations{
  display: none;
}
.product-intensity-value 

.product_title {
  font-size: 1.875rem;
  line-height: 2.25rem;
  margin-bottom: .5rem;
}
.single-product #main{
  background-image: url('images/coffee-beans-pattern-1360.png');
  background-size: cover;
  background-position: center center;
  background-attachment: fixed;
}
.product-page-title{
  border-bottom: 1px solid hsl(var(--border));
  border-top: 1px solid hsl(var(--border) / .4);
}
.product-page-title .page-title-inner{
  min-height: 52px;
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.breadcrumbs{
  font-size: .875rem;
  line-height: 1.25rem;
}
.breadcrumbs a.current,
.breadcrumbs a{
  color: hsl(var(--muted-foreground));
}
 .breadcrumbs a:hover{
  color: hsl(var(--foreground));
}
.breadcrumbs .divider, .breadcrumbs .separator{
  color: hsl(var(--muted-foreground));
  opacity: 1;
}
.shop-container{
  padding: 2rem 0;
}
.product-images .woocommerce-product-gallery__image > a{
  aspect-ratio: 1 / 1;
  position: relative;
  box-shadow: 0 10px 40px -10px hsl(25 45% 12% / .2);
  overflow: hidden;
  border-radius: 1rem;
}
.product-images .woocommerce-product-gallery__image > a img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.5s;
  max-width: unset;
  max-height: unset;
}
.contact-img .img-inner{
  width: 100%;
  height: 100%;
}
.contact-img .img-inner img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.product-info .woocommerce-product-rating{
  display: none;
}
.product-info  .woocommerce-variation{
  display: none !important;
}
.product-info .single_add_to_cart_button:not(.simple-product-button),
.product-info .ux-quantity.buttons_added{
  display: none !important;
}
.product-info .variant-short-description{
  margin-bottom: 1.5rem;
}
.variation-extra-fields .product-intensity{
  margin-bottom: 1.5rem;
}
.product-info .price-preview{
  margin-bottom: 1.5rem;
}
.product-summary .woocommerce-Price-currencySymbol,
.price-text span.amount{
  font-size: 2.25rem;
  line-height: 2.5rem;
  font-weight: 700;
  vertical-align: unset;
}
.product-info .price-text .price{
  font-size: 2.25rem;
  margin: 0;
  line-height: 1;
}
.shadow-soft {
  box-shadow: 0 4px 20px -4px hsl(25 45% 12% / .15);
}
.hover-shadow-soft:hover {
  box-shadow: 0 4px 20px -4px hsl(25 45% 12% / .15);
}
.product-summary .woocommerce-variation-add-to-cart .woocommerce-Price-currencySymbol,
 .woocommerce-variation-add-to-cart span.amount{
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 700;
  vertical-align: unset;
  color: hsl(var(--cream));
 }
 .confezione-radio-button {
  background-color: #fff;
  color: hsl(var(--coffee-dark));
  border: 2px solid hsl(var(--coffee-dark));
 }
 .confezione-radio-button:hover{
  background-color: hsl(var(--coffee-dark));
  color: hsl(var(--cream));
 }
.confezione-radio-button.active{
    background-color: hsl(var(--coffee-dark));
    color: hsl(var(--cream));
}
.confezione-radio-button.active:hover{
  --tw-scale-x: 1.02;
  --tw-scale-y: 1.02;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.product-summary .woocommerce-variation-add-to-cart .confezione-radio-button .woocommerce-Price-currencySymbol,
.woocommerce-variation-add-to-cart .confezione-radio-button span.amount{
  color: hsl(var(--coffee-dark));
}
.product-summary .woocommerce-variation-add-to-cart .confezione-radio-button.active .woocommerce-Price-currencySymbol,
.woocommerce-variation-add-to-cart .confezione-radio-button.active span.amount{
  color: hsl(var(--cream));
}
.product-summary .woocommerce-variation-add-to-cart .confezione-radio-button:hover .woocommerce-Price-currencySymbol,
.woocommerce-variation-add-to-cart .confezione-radio-button:hover span.amount{
  color: hsl(var(--cream));
}
.product-info  .confezione-radio-button .price{
  margin: 0;
  line-height: 1;
}
.product-summary .variations_button.woocommerce-variation-add-to-cart{
  padding: 0;
  margin-bottom: 1.5rem;
}
.product-usp p{
  margin: 0;
}
.product-info form.cart{
  margin: 0;
}
.product-page-sections .panel .woocommerce-product-attributes{
  display: none;
}
.product-features{
  margin-bottom: 1.5rem;
}
.product-features ul{
  margin: 0;
  padding: 0;
  list-style: none;
}
.product-features ul li{
  margin: 0;
  padding: 0;
}
.product-features ul h3{
  margin: 0;
  font-size: 1rem;
}
.product-features ul p{
  margin: 0;
}
.product-section-description,
.related-products-box,
.up-sells-box,
.panel #reviews,
.additional-information-after,
#custom-variation-description-target {
  padding: 1.5rem;
  background-color: hsl(30 10% 98% / 0.95);
  border-radius: 1rem;
  margin-top: 2rem;
  box-shadow: 0 10px 40px -10px hsl(25 45% 12% / 0.2);
}
#custom-variation-description-target .ux-para{
  margin-bottom: 0;
}
#custom-variation-description-target  .space-y-4 p{
  margin-bottom: 0;
}
#custom-variation-description-target:empty {
  display: none;
}
.panel .woocommerce-Reviews{
  margin-top: 2rem !important;
}

.woocommerce-Reviews-title {
  letter-spacing: -0.025em;
  font-size: 1.875rem;
  line-height: 2.25rem;
  font-size: 1.5rem;
  line-height: 2rem;
  margin-bottom: 0.5rem;
  color: hsl(var(--foreground));
  text-align: center;
}

.commentlist {
  margin-top: 2rem;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 1.5rem;
  display: grid;
  margin-bottom: 0;
}
.woocommerce-Reviews {
    margin: 0 !important;
}
.woocommerce-Reviews #comments{
    padding: 0;
}
.commentlist .comment,
.commentlist .review {
  animation-duration: 0.3s;
  transition-duration: 0.3s;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  padding: 1.5rem;
  background-color: hsl(30 15% 96% / 0.5);
  border-radius: 0.75rem;
  border: 1px solid hsla(30 20% 85% /0.5) !important;
  margin: 0;
}
.commentlist .comment > .children,
.commentlist .review > .children{
  display: none;
}
.commentlist .comment:hover,
.commentlist .review:hover {
  border-color: hsl(var(--primary) / 0.3) !important;
}
.commentlist .comment .review-item,
.commentlist .review .review-item {
  flex-direction: column;
}
.text-primary-30 {
  color: hsl(var(--primary) / 0.3);
}
.w-8 {
  width: 2rem;
}

.h-8 {
  height: 2rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.star-rating {
  margin-bottom: 0.75rem !important;
  margin-top: 0 !important;
}
.star-rating span:before {
  color: var(--primary) !important;
}
.star-rating:before,
.woocommerce-page .star-rating:before {
  color: var(--primary) !important;
}
.space-y-4>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}
.commentlist .comment .comment-text,
.commentlist .review .comment-text {
  padding: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
}
.commentlist .comment .comment-text .description,
.commentlist .review .comment-text .description {
  order: -1;
  color: hsl(var(--foreground) / 0.9);
  line-height: 1.625;
  font-style: italic;
  margin-bottom: 1.5rem;
}
.commentlist .comment .comment-text .description p,
.commentlist .review .comment-text .description p {
  margin: 0;
}
.commentlist .comment .comment-text .meta,
.commentlist .review .comment-text .meta {
  justify-content: space-between;
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.commentlist .comment .comment-text .meta .woocommerce-review__dash,
.commentlist .review .comment-text .meta .woocommerce-review__dash {
  display: none !important;
}
.woocommerce-review__author {
  color: hsl(var(--foreground));
  font-weight: 600;
  font-size: 1rem;
}
.woocommerce-review__published-date {
  font-size: 0.75rem;
  line-height: 1rem;
  color: hsl(var(--muted-foreground));
}
#review_form_wrapper{
    display: none;
    padding: 0;
}
.customize-support #review_form_wrapper{
  display: block;
}
#review_form_wrapper .review-form-inner{
  border: 0;
  padding: 0;
  margin-top: 40px;
}
#review_form_wrapper .form-submit .submit{
  color: hsl(var(--primary));
  background-color: var(--fs-color-primary);
  border-radius: 99px;
  text-transform: unset;
  padding: 0.3rem 2rem;
}
#review_form_wrapper .comment-form-comment #comment{
  border-radius: var(--radius) !important;
  border-color: hsl(var(--border) / 0.5) !important;
}
.page-title:not(.featured-title)+main .product-main,
.product-main {
  padding: 0;
}
.backdrop-blur-md{
  backdrop-filter:blur(12px);
}
.related-products-box .product-small .box-image,
.up-sells-box .product-small .box-image{
  height: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: none;
  margin-bottom: 1rem;
  width: 100%;
}
.related-products-box .product-small.group .box-image img{
  width: 100%;
    height: 100%;
    object-fit: cover;
    transition-duration: .7s;
    transition-property: transform;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
}
.related-products-box.products .product-small.group:hover .box-image img,
.up-sells-box.products .product-small.group:hover .box-image img{
  transform: scale(1);
}
.related-products-box .product-small .box-image .addtocart-btn-wrapper,
.up-sells-box .product-small .box-image .addtocart-btn-wrapper{
  display: none;
}
.related-products-box .product-small .box-image .image-none,
.up-sells-box .product-small .box-image .image-none{
  height: 4rem;
  width: 4rem;
  border-radius: var(--radius);
  overflow: hidden;
}
.related-products-box .product-small .box-image .image-none a,
.up-sells-box .product-small .box-image .image-none a{
  width: 100%;
  height: 100%;
}
.related-products-box .prouct-card-tags,
.up-sells-box .prouct-card-tags{
  position: unset !important;
}
.related-products-box .product-small .tag-label-text,
.up-sells-box .product-small .tag-label-text{
  background-color: hsl(var(--primary) / .1);
  padding: 0.25rem 0.5rem;
  color: hsl(var(--primary));
  font-weight: 500;
  font-size: .75rem;
  line-height: 1rem;
  letter-spacing: 0;
  
}
.related-products-box .product-box-details .addtocart-btn-wrapper,
.up-sells-box .product-box-details .addtocart-btn-wrapper{
  display: block;
  margin-left: auto;
}
.related-products-box .product-box-details > .add-to-cart-button,
.up-sells-box .product-box-details > .add-to-cart-button{
  display: none;
}
.related-products-box .price-from-text,
.up-sells-box .price-from-text{
  display: none;
}
.related-products-box .product-small.box,
.up-sells-box .product-small.box{
  background-color: hsl(var(--card) / .5);
  backdrop-filter:blur(4px);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
}
.related-products-box .product-box-cat-wrapper,
.up-sells-box .product-box-cat-wrapper{
  display: none;
}
.related-products-box .intensity-wrapper,
.up-sells-box .intensity-wrapper{
  display: none;
}
.related-products-box .box-text-products,
.up-sells-box .box-text-products{
  padding: 0;
  display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}
.related-products-box .title-wrapper,
.up-sells-box .title-wrapper {
  margin-bottom: .5rem;
}
.related-products-box .product-description,
.up-sells-box .product-description{
  margin-bottom: 1rem;
}
.related-products-box .product-box-details,
.up-sells-box .product-box-details{
  border: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
}
.related-products-box .product-box-details .add-to-cart-btn,
.up-sells-box .product-box-details .add-to-cart-btn{
  gap: .5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hover-text-accent-foreground:hover {
  color: hsl(var(--accent-foreground));
}
.hover-bg-accent:hover {
  background-color: hsl(var(--accent));
}
.hover-shadow-lg:hover{
  box-shadow:rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.1) 0px 4px 6px -4px;
}
.related-products-box > .row,
.up-sells-box > .row{
  margin-bottom: -20px !important;
}
.related-products-box .product-card-overlay,
.up-sells-box .product-card-overlay{
  display: none;
}








@media (min-width: 549px) {
  .sm-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0px, 1fr));
  }
  .sm-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sm-flex-row,
  .sm\:flex-row {
      flex-direction: row;
  }
  .sm-items-center,
  .sm\:items-center {
    align-items: center;
  }
  .sm-w-\[200px\],
  .sm-w-200 {
    width: 200px;
  }
  .related-products-box .product-small.col,
  .up-sells-box .product-small.col{
    flex-basis: 50%;
    max-width: 50%;
  }


}
@media (min-width: 768px) {
  .md-text-3xl,
  .md\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .md-text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
  .md-text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }
  .md-text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .md-text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
  .md-text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  .text-8xl {
    font-size: 4.5rem;
    line-height: 1;
  }
  .text-6xl {
    font-size: 3rem;
    line-height: 1;
  }
  .sub-desc {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
  .text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  .commentlist {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .related-products-box .product-small.col,
  .up-sells-box .product-small.col{
    flex-basis: 33.33%;
    max-width: 33.33%;
  }
}

@media screen and (min-width: 850px) {
  .product .product-gallery.large-6{
    flex-basis: 100%;
    max-width: 100%;
  }
  .product .product-info.large-6{
    flex-basis: 100%;
    max-width: 100%;
  }
}
@media (min-width: 1024px) {
  .lg-p-10 {
    padding: 2.5rem;
  }
  .lg-text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
  .lg-text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }
  .lg-text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .lg-text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
  .lg-text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  .lg-py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .lg-py-32 {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
  .lg-text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
  .lg-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .lg-col-span-2 {
    grid-column: span 2 / span 2;
  }
  .lg-col-span-1 {
    grid-column: span 1 / span 1;
  }
  .lg-p-8 {
    padding: 2rem;
  }
  .lg-gap-6 {
    gap: 1.5rem;
  }
  .lg-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .text-8xl {
    font-size: 6rem;
    line-height: 1;
  }

  .text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
  .product_title {
    font-size: 3rem;
    line-height: 1;
    
  }
  .shop-container{
    padding: 3rem 0;
  }
  .product-gallery{
    padding-right: 2rem;
    padding-bottom: 1rem;
  }
  .product-info{
    padding-left: 2rem;
    padding-bottom: 1rem;
  }
  .product-section-description,
  .related-products-box,
  .up-sells-box,
  .panel #reviews,
  .additional-information-after, #custom-variation-description-target {
    padding: 2.5rem;
  }
  
  .woocommerce-Reviews-title {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .commentlist {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .product .product-gallery.large-6{
    flex-basis: 50%;
    max-width: 50%;
  }
  .product .product-info.large-6{
    flex-basis: 50%;
    max-width: 50%;
  }
  .related-products-box .product-small.col,
  .up-sells-box .product-small.col{
    flex-basis: 25%;
    max-width: 25%;
  }
  .related-products-box,
  .up-sells-box{
    margin-bottom: 3rem;
  }

}
@media (min-width: 1280px) {
  .xl-grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .xl-grid-cols-5 {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .shop-products .large-columns-3>.col {
    flex-basis: 25%;
    max-width: 25%;
  }
}
@media only screen and (max-width: 1024px) {
  .product-images .woocommerce-product-gallery__image > a{
    width: 100%;
  }
  .product-gallery{
    margin-bottom: 2rem;
  }
  .product-gallery .flickity-viewport{
    margin-left: 5px;
    margin-right: 5px;
    width: calc(100% - 10px) !important;
  }
  .product-info-box{
    padding: 1.5rem;
  }
  .product-info{
    padding-bottom: 1rem;
  }

}
@media only screen and (max-width: 849px) {
  .page-title-inner .medium-text-center{
    text-align: left !important;
  }
  .page-title-inner.medium-flex-wrap .flex-col{
    padding: 0;
  }
}
@media only screen and (max-width: 768px) {

  .sub-desc {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}
@media only screen and (max-width: 550px) {
  /*************** ADD MOBILE ONLY CSS HERE  ***************/

  .ux-footer-bottom-row p {
    margin-bottom: 0.5rem !important;
  }
  .ux-footer-bottom-row p:last-child {
    margin: 0;
  }

  .ux-footer-bottom-row p {
    text-align: center !important;
  }
  .ux-btn {
    width: 100%;
  }
  .hero-sect .section-content {
    padding-top: 120px;
  }
  .shop-filters-right{
    width: 100%;
  }
  .shop-filters-right-inner .dropdown{
    width: 100%;
  }
  .ux-form .gform_footer .gform_button{
    width: 100%;
  }
  .contact-submit-btn button,
  .ux-form input[type="submit"]{
    width: 100% !important;
  }
  .gform_wrapper .gfield.gfield--type-submit .gform-button{
    width: 100% !important;
  }



}

@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes bounce {
  0%,
  to {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}
@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}

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




















