*,
:after,
:before {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/
*,
:after,
:before {
    box-sizing: border-box;
    border: 0 solid #e5e7eb
}

:after,
:before {
    --tw-content: ""
}

:host,
html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    font-family: Inter, sans-serif;
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent
}

body {
    margin: 0;
    line-height: inherit
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
pre,
samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    font-size: 100%;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
    margin: 0;
    padding: 0
}

button,
select {
    text-transform: none
}

button,
input:where([type=button]),
input:where([type=reset]),
input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0
}

fieldset {
    margin: 0
}

fieldset,
legend {
    padding: 0
}

menu,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    opacity: 1;
    color: #9ca3af
}

input::placeholder,
textarea::placeholder {
    opacity: 1;
    color: #9ca3af
}

[role=button],
button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle
}

img,
video {
    max-width: 100%;
    height: auto
}

[hidden]:where(:not([hidden=until-found])) {
    display: none
}

html {
    scroll-behavior: smooth
}

.container {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 1rem;
    padding-left: 1rem
}

@media (min-width:640px) {
    .container {
        max-width: 640px
    }
}

@media (min-width:768px) {
    .container {
        max-width: 768px
    }
}

@media (min-width:1024px) {
    .container {
        max-width: 1024px
    }
}

@media (min-width:1280px) {
    .container {
        max-width: 1280px
    }
}

@media (min-width:1400px) {
    .container {
        max-width: 1400px
    }
}

#masthead .site-branding img,
body.woocommerce #masthead .site-branding img,
body.woocommerce-page #masthead .site-branding img {
    height: 45px !important;
    max-height: 45px !important
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0
}

.pointer-events-none {
    pointer-events: none
}

.visible {
    visibility: visible
}

.invisible {
    visibility: hidden
}

.fixed {
    position: fixed
}

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.sticky {
    position: sticky
}

.inset-0 {
    inset: 0
}

.inset-x-0 {
    left: 0;
    right: 0
}

.inset-y-0 {
    top: 0;
    bottom: 0
}

.-right-16 {
    right: -4rem
}

.-top-16 {
    top: -4rem
}

.-top-4 {
    top: -1rem
}

.bottom-4 {
    bottom: 1rem
}

.left-0 {
    left: 0
}

.left-1\/2 {
    left: 50%
}

.left-4 {
    left: 1rem
}

.right-0 {
    right: 0
}

.right-4 {
    right: 1rem
}

.top-0 {
    top: 0
}

.top-4 {
    top: 1rem
}

.top-8 {
    top: 2rem
}

.top-\[14px\] {
    top: 14px
}

.top-full {
    top: 100%
}

.z-0 {
    z-index: 0
}

.z-10 {
    z-index: 10
}

.z-50 {
    z-index: 50
}

.order-1 {
    order: 1
}

.order-2 {
    order: 2
}

.order-3 {
    order: 3
}

.col-span-1 {
    grid-column: span 1/span 1
}

.col-span-full {
    grid-column: 1/-1
}

.m-0 {
    margin: 0
}

.mx-auto {
    margin-left: auto;
    margin-right: auto
}

.my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem
}

.-mt-0 {
    margin-top: 0
}

.mb-0 {
    margin-bottom: 0
}

.mb-0\.5 {
    margin-bottom: .125rem
}

.mb-1 {
    margin-bottom: .25rem
}

.mb-1\.5 {
    margin-bottom: .375rem
}

.mb-10 {
    margin-bottom: 2.5rem
}

.mb-12 {
    margin-bottom: 3rem
}

.mb-16 {
    margin-bottom: 4rem
}

.mb-2 {
    margin-bottom: .5rem
}

.mb-20 {
    margin-bottom: 5rem
}

.mb-3 {
    margin-bottom: .75rem
}

.mb-32 {
    margin-bottom: 8rem
}

.mb-4 {
    margin-bottom: 1rem
}

.mb-5 {
    margin-bottom: 1.25rem
}

.mb-6 {
    margin-bottom: 1.5rem
}

.mb-8 {
    margin-bottom: 2rem
}

.ml-1 {
    margin-left: .25rem
}

.ml-4 {
    margin-left: 1rem
}

.ml-auto {
    margin-left: auto
}

.mt-0 {
    margin-top: 0
}

.mt-0\.5 {
    margin-top: .125rem
}

.mt-1 {
    margin-top: .25rem
}

.mt-10 {
    margin-top: 2.5rem
}

.mt-12 {
    margin-top: 3rem
}

.mt-16 {
    margin-top: 4rem
}

.mt-2 {
    margin-top: .5rem
}

.mt-3 {
    margin-top: .75rem
}

.mt-4 {
    margin-top: 1rem
}

.mt-5 {
    margin-top: 1.25rem
}

.mt-6 {
    margin-top: 1.5rem
}

.mt-8 {
    margin-top: 2rem
}

.mt-auto {
    margin-top: auto
}

.line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2
}

.block {
    display: block
}

.inline-block {
    display: inline-block
}

.inline {
    display: inline
}

.flex {
    display: flex
}

.inline-flex {
    display: inline-flex
}

.table {
    display: table
}

.grid {
    display: grid
}

.hidden {
    display: none
}

.aspect-video {
    aspect-ratio: 16/9
}

.h-0\.5 {
    height: .125rem
}

.h-10 {
    height: 2.5rem
}

.h-11 {
    height: 2.75rem
}

.h-12 {
    height: 3rem
}

.h-14 {
    height: 3.5rem
}

.h-16 {
    height: 4rem
}

.h-2 {
    height: .5rem
}

.h-20 {
    height: 5rem
}

.h-3 {
    height: .75rem
}

.h-3\.5 {
    height: .875rem
}

.h-32 {
    height: 8rem
}

.h-4 {
    height: 1rem
}

.h-48 {
    height: 12rem
}

.h-5 {
    height: 1.25rem
}

.h-6 {
    height: 1.5rem
}

.h-7 {
    height: 1.75rem
}

.h-8 {
    height: 2rem
}

.h-9 {
    height: 2.25rem
}

.h-\[45px\] {
    height: 45px
}

.h-\[72px\] {
    height: 72px
}

.h-auto {
    height: auto
}

.h-fit {
    height: -moz-fit-content;
    height: fit-content
}

.h-full {
    height: 100%
}

.min-h-\[80vh\] {
    min-height: 80vh
}

.min-h-screen {
    min-height: 100vh
}

.w-1 {
    width: .25rem
}

.w-10 {
    width: 2.5rem
}

.w-11 {
    width: 2.75rem
}

.w-12 {
    width: 3rem
}

.w-14 {
    width: 3.5rem
}

.w-16 {
    width: 4rem
}

.w-2 {
    width: .5rem
}

.w-20 {
    width: 5rem
}

.w-3\.5 {
    width: .875rem
}

.w-32 {
    width: 8rem
}

.w-4 {
    width: 1rem
}

.w-48 {
    width: 12rem
}

.w-5 {
    width: 1.25rem
}

.w-56 {
    width: 14rem
}

.w-6 {
    width: 1.5rem
}

.w-7 {
    width: 1.75rem
}

.w-8 {
    width: 2rem
}

.w-9 {
    width: 2.25rem
}

.w-\[72px\] {
    width: 72px
}

.w-auto {
    width: auto
}

.w-fit {
    width: -moz-fit-content;
    width: fit-content
}

.w-full {
    width: 100%
}

.min-w-0 {
    min-width: 0
}

.max-w-2xl {
    max-width: 42rem
}

.max-w-3xl {
    max-width: 48rem
}

.max-w-4xl {
    max-width: 56rem
}

.max-w-6xl {
    max-width: 72rem
}

.max-w-7xl {
    max-width: 80rem
}

.max-w-\[440px\] {
    max-width: 440px
}

.max-w-\[480px\] {
    max-width: 480px
}

.max-w-lg {
    max-width: 32rem
}

.max-w-md {
    max-width: 28rem
}

.max-w-none {
    max-width: none
}

.max-w-xl {
    max-width: 36rem
}

.flex-1 {
    flex: 1 1 0%
}

.flex-shrink {
    flex-shrink: 1
}

.flex-shrink-0,
.shrink-0 {
    flex-shrink: 0
}

.flex-grow {
    flex-grow: 1
}

.-translate-x-1\/2 {
    --tw-translate-x: -50%
}

.-translate-x-1\/2,
.-translate-y-1\/2 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.-translate-y-1\/2 {
    --tw-translate-y: -50%
}

.translate-y-0 {
    --tw-translate-y: 0px
}

.translate-y-0,
.translate-y-2 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.translate-y-2 {
    --tw-translate-y: 0.5rem
}

.rotate-1 {
    --tw-rotate: 1deg
}

.rotate-1,
.scale-100 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.scale-100 {
    --tw-scale-x: 1;
    --tw-scale-y: 1
}

.scale-105 {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05
}

.scale-105,
.transform {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@keyframes pulse {
    50% {
        opacity: .5
    }
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite
}

.cursor-not-allowed {
    cursor: not-allowed
}

.cursor-pointer {
    cursor: pointer
}

.list-disc {
    list-style-type: disc
}

.list-none {
    list-style-type: none
}

.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
    flex-direction: column
}

.flex-wrap {
    flex-wrap: wrap
}

.items-start {
    align-items: flex-start
}

.items-end {
    align-items: flex-end
}

.items-center {
    align-items: center
}

.items-baseline {
    align-items: baseline
}

.items-stretch {
    align-items: stretch
}

.justify-center {
    justify-content: center
}

.justify-between {
    justify-content: space-between
}

.gap-1 {
    gap: .25rem
}

.gap-1\.5 {
    gap: .375rem
}

.gap-12 {
    gap: 3rem
}

.gap-16 {
    gap: 4rem
}

.gap-2 {
    gap: .5rem
}

.gap-2\.5 {
    gap: .625rem
}

.gap-3 {
    gap: .75rem
}

.gap-4 {
    gap: 1rem
}

.gap-6 {
    gap: 1.5rem
}

.gap-8 {
    gap: 2rem
}

.space-y-1>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.25rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.25rem*var(--tw-space-y-reverse))
}

.space-y-2>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.5rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.5rem*var(--tw-space-y-reverse))
}

.space-y-2\.5>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.625rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.625rem*var(--tw-space-y-reverse))
}

.space-y-3>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.75rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.75rem*var(--tw-space-y-reverse))
}

.space-y-4>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem*var(--tw-space-y-reverse))
}

.space-y-6>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.5rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.5rem*var(--tw-space-y-reverse))
}

.space-y-8>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(2rem*(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(2rem*var(--tw-space-y-reverse))
}

.divide-y>:not([hidden])~:not([hidden]) {
    --tw-divide-y-reverse: 0;
    border-top-width: calc(1px*(1 - var(--tw-divide-y-reverse)));
    border-bottom-width: calc(1px*var(--tw-divide-y-reverse))
}

.divide-slate-100>:not([hidden])~:not([hidden]) {
    --tw-divide-opacity: 1;
    border-color: rgb(241 245 249/var(--tw-divide-opacity, 1))
}

.divide-slate-50>:not([hidden])~:not([hidden]) {
    --tw-divide-opacity: 1;
    border-color: rgb(248 250 252/var(--tw-divide-opacity, 1))
}

.self-start {
    align-self: flex-start
}

.overflow-hidden {
    overflow: hidden
}

.overflow-x-auto {
    overflow-x: auto
}

.scroll-smooth {
    scroll-behavior: smooth
}

.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap
}

.break-all {
    word-break: break-all
}

.rounded {
    border-radius: .25rem
}

.rounded-2xl {
    border-radius: 1rem
}

.rounded-3xl {
    border-radius: 1.5rem
}

.rounded-\[2\.5rem\] {
    border-radius: 2.5rem
}

.rounded-\[24px\] {
    border-radius: 24px
}

.rounded-\[2rem\] {
    border-radius: 2rem
}

.rounded-\[40px\] {
    border-radius: 40px
}

.rounded-full {
    border-radius: 9999px
}

.rounded-lg {
    border-radius: .5rem
}

.rounded-xl {
    border-radius: .75rem
}

.rounded-b-\[2rem\] {
    border-bottom-right-radius: 2rem;
    border-bottom-left-radius: 2rem
}

.rounded-b-lg {
    border-bottom-right-radius: .5rem
}

.rounded-b-lg,
.rounded-l-lg {
    border-bottom-left-radius: .5rem
}

.rounded-l-lg {
    border-top-left-radius: .5rem
}

.rounded-r-lg {
    border-top-right-radius: .5rem;
    border-bottom-right-radius: .5rem
}

.rounded-t-2xl {
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem
}

.rounded-tl-xl {
    border-top-left-radius: .75rem
}

.rounded-tr-xl {
    border-top-right-radius: .75rem
}

.border {
    border-width: 1px
}

.border-0 {
    border-width: 0
}

.border-2 {
    border-width: 2px
}

.border-4 {
    border-width: 4px
}

.border-\[3px\] {
    border-width: 3px
}

.border-b {
    border-bottom-width: 1px
}

.border-l-4 {
    border-left-width: 4px
}

.border-t {
    border-top-width: 1px
}

.border-dashed {
    border-style: dashed
}

.border-\[\#fee2e2\] {
    --tw-border-opacity: 1;
    border-color: rgb(254 226 226/var(--tw-border-opacity, 1))
}

.border-amber-200 {
    --tw-border-opacity: 1;
    border-color: rgb(253 230 138/var(--tw-border-opacity, 1))
}

.border-blue-500 {
    --tw-border-opacity: 1;
    border-color: rgb(59 130 246/var(--tw-border-opacity, 1))
}

.border-green-100 {
    --tw-border-opacity: 1;
    border-color: rgb(220 252 231/var(--tw-border-opacity, 1))
}

.border-green-200 {
    --tw-border-opacity: 1;
    border-color: rgb(187 247 208/var(--tw-border-opacity, 1))
}

.border-primary-100 {
    --tw-border-opacity: 1;
    border-color: rgb(219 234 254/var(--tw-border-opacity, 1))
}

.border-primary-200 {
    --tw-border-opacity: 1;
    border-color: rgb(191 219 254/var(--tw-border-opacity, 1))
}

.border-primary-500 {
    --tw-border-opacity: 1;
    border-color: rgb(59 130 246/var(--tw-border-opacity, 1))
}

.border-primary-600 {
    --tw-border-opacity: 1;
    border-color: rgb(37 99 235/var(--tw-border-opacity, 1))
}

.border-primary-800\/50 {
    border-color: rgba(30, 64, 175, .5)
}

.border-red-100 {
    --tw-border-opacity: 1;
    border-color: rgb(254 226 226/var(--tw-border-opacity, 1))
}

.border-red-200 {
    --tw-border-opacity: 1;
    border-color: rgb(254 202 202/var(--tw-border-opacity, 1))
}

.border-secondary-100 {
    --tw-border-opacity: 1;
    border-color: rgb(209 250 229/var(--tw-border-opacity, 1))
}

.border-slate-100 {
    --tw-border-opacity: 1;
    border-color: rgb(241 245 249/var(--tw-border-opacity, 1))
}

.border-slate-200 {
    --tw-border-opacity: 1;
    border-color: rgb(226 232 240/var(--tw-border-opacity, 1))
}

.border-slate-200\/50 {
    border-color: rgba(226, 232, 240, .5)
}

.border-slate-200\/60 {
    border-color: rgba(226, 232, 240, .6)
}

.border-slate-300 {
    --tw-border-opacity: 1;
    border-color: rgb(203 213 225/var(--tw-border-opacity, 1))
}

.border-slate-50 {
    --tw-border-opacity: 1;
    border-color: rgb(248 250 252/var(--tw-border-opacity, 1))
}

.border-slate-800 {
    --tw-border-opacity: 1;
    border-color: rgb(30 41 59/var(--tw-border-opacity, 1))
}

.border-transparent {
    border-color: transparent
}

.border-white {
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255/var(--tw-border-opacity, 1))
}

.border-white\/20 {
    border-color: hsla(0, 0%, 100%, .2)
}

.border-white\/5 {
    border-color: hsla(0, 0%, 100%, .05)
}

.bg-\[\#eff6ff\] {
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255/var(--tw-bg-opacity, 1))
}

.bg-\[\#fef2f2\] {
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242/var(--tw-bg-opacity, 1))
}

.bg-amber-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 243 199/var(--tw-bg-opacity, 1))
}

.bg-amber-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(255 251 235/var(--tw-bg-opacity, 1))
}

.bg-black\/50 {
    background-color: rgba(0, 0, 0, .5)
}

.bg-blue-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254/var(--tw-bg-opacity, 1))
}

.bg-blue-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255/var(--tw-bg-opacity, 1))
}

.bg-emerald-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(209 250 229/var(--tw-bg-opacity, 1))
}

.bg-emerald-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(236 253 245/var(--tw-bg-opacity, 1))
}

.bg-gray-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(243 244 246/var(--tw-bg-opacity, 1))
}

.bg-green-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(220 252 231/var(--tw-bg-opacity, 1))
}

.bg-green-100\/50 {
    background-color: rgba(220, 252, 231, .5)
}

.bg-green-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(240 253 244/var(--tw-bg-opacity, 1))
}

.bg-green-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94/var(--tw-bg-opacity, 1))
}

.bg-orange-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(255 237 213/var(--tw-bg-opacity, 1))
}

.bg-primary-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254/var(--tw-bg-opacity, 1))
}

.bg-primary-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255/var(--tw-bg-opacity, 1))
}

.bg-primary-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(59 130 246/var(--tw-bg-opacity, 1))
}

.bg-primary-500\/10 {
    background-color: rgba(59, 130, 246, .1)
}

.bg-primary-500\/30 {
    background-color: rgba(59, 130, 246, .3)
}

.bg-primary-600 {
    --tw-bg-opacity: 1;
    background-color: rgb(37 99 235/var(--tw-bg-opacity, 1))
}

.bg-purple-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(243 232 255/var(--tw-bg-opacity, 1))
}

.bg-purple-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(250 245 255/var(--tw-bg-opacity, 1))
}

.bg-red-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226/var(--tw-bg-opacity, 1))
}

.bg-red-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242/var(--tw-bg-opacity, 1))
}

.bg-red-600 {
    --tw-bg-opacity: 1;
    background-color: rgb(220 38 38/var(--tw-bg-opacity, 1))
}

.bg-secondary-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(236 253 245/var(--tw-bg-opacity, 1))
}

.bg-secondary-600 {
    --tw-bg-opacity: 1;
    background-color: rgb(5 150 105/var(--tw-bg-opacity, 1))
}

.bg-slate-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(241 245 249/var(--tw-bg-opacity, 1))
}

.bg-slate-100\/50 {
    background-color: rgba(241, 245, 249, .5)
}

.bg-slate-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(248 250 252/var(--tw-bg-opacity, 1))
}

.bg-slate-50\/10 {
    background-color: rgba(248, 250, 252, .1)
}

.bg-slate-50\/30 {
    background-color: rgba(248, 250, 252, .3)
}

.bg-slate-50\/50 {
    background-color: rgba(248, 250, 252, .5)
}

.bg-slate-900 {
    --tw-bg-opacity: 1;
    background-color: rgb(15 23 42/var(--tw-bg-opacity, 1))
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255/var(--tw-bg-opacity, 1))
}

.bg-white\/10 {
    background-color: hsla(0, 0%, 100%, .1)
}

.bg-white\/20 {
    background-color: hsla(0, 0%, 100%, .2)
}

.bg-white\/50 {
    background-color: hsla(0, 0%, 100%, .5)
}

.bg-white\/90 {
    background-color: hsla(0, 0%, 100%, .9)
}

.bg-yellow-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 249 195/var(--tw-bg-opacity, 1))
}

.bg-yellow-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 252 232/var(--tw-bg-opacity, 1))
}

.bg-gradient-to-b {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops))
}

.bg-gradient-to-br {
    background-image: linear-gradient(to bottom right, var(--tw-gradient-stops))
}

.bg-gradient-to-r {
    background-image: linear-gradient(to right, var(--tw-gradient-stops))
}

.from-primary-400 {
    --tw-gradient-from: #60a5fa var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(96, 165, 250, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary-500 {
    --tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(59, 130, 246, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary-600 {
    --tw-gradient-from: #2563eb var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(37, 99, 235, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-primary-900 {
    --tw-gradient-from: #1e3a8a var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(30, 58, 138, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-slate-50 {
    --tw-gradient-from: #f8fafc var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(248, 250, 252, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.from-white {
    --tw-gradient-from: #fff var(--tw-gradient-from-position);
    --tw-gradient-to: hsla(0, 0%, 100%, 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.to-primary-800 {
    --tw-gradient-to: #1e40af var(--tw-gradient-to-position)
}

.to-secondary-500 {
    --tw-gradient-to: #10b981 var(--tw-gradient-to-position)
}

.to-secondary-600 {
    --tw-gradient-to: #059669 var(--tw-gradient-to-position)
}

.to-secondary-900 {
    --tw-gradient-to: #064e3b var(--tw-gradient-to-position)
}

.to-slate-50 {
    --tw-gradient-to: #f8fafc var(--tw-gradient-to-position)
}

.to-white {
    --tw-gradient-to: #fff var(--tw-gradient-to-position)
}

.bg-clip-text {
    -webkit-background-clip: text;
    background-clip: text
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover
}

.p-0 {
    padding: 0
}

.p-1\.5 {
    padding: .375rem
}

.p-10 {
    padding: 2.5rem
}

.p-4 {
    padding: 1rem
}

.p-5 {
    padding: 1.25rem
}

.p-6 {
    padding: 1.5rem
}

.p-8 {
    padding: 2rem
}

.px-1 {
    padding-left: .25rem;
    padding-right: .25rem
}

.px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem
}

.px-2 {
    padding-left: .5rem;
    padding-right: .5rem
}

.px-2\.5 {
    padding-left: .625rem;
    padding-right: .625rem
}

.px-3 {
    padding-left: .75rem;
    padding-right: .75rem
}

.px-3\.5 {
    padding-left: .875rem;
    padding-right: .875rem
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem
}

.px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem
}

.px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem
}

.py-0\.5 {
    padding-top: .125rem;
    padding-bottom: .125rem
}

.py-1 {
    padding-top: .25rem;
    padding-bottom: .25rem
}

.py-1\.5 {
    padding-top: .375rem;
    padding-bottom: .375rem
}

.py-10 {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem
}

.py-12 {
    padding-top: 3rem;
    padding-bottom: 3rem
}

.py-16 {
    padding-top: 4rem;
    padding-bottom: 4rem
}

.py-2 {
    padding-top: .5rem;
    padding-bottom: .5rem
}

.py-2\.5 {
    padding-top: .625rem;
    padding-bottom: .625rem
}

.py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem
}

.py-24 {
    padding-top: 6rem;
    padding-bottom: 6rem
}

.py-3 {
    padding-top: .75rem;
    padding-bottom: .75rem
}

.py-3\.5 {
    padding-top: .875rem;
    padding-bottom: .875rem
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem
}

.py-5 {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem
}

.py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem
}

.pb-0 {
    padding-bottom: 0
}

.pb-32 {
    padding-bottom: 8rem
}

.pb-6 {
    padding-bottom: 1.5rem
}

.pb-8 {
    padding-bottom: 2rem
}

.pl-11 {
    padding-left: 2.75rem
}

.pl-4 {
    padding-left: 1rem
}

.pr-4 {
    padding-right: 1rem
}

.pt-1 {
    padding-top: .25rem
}

.pt-10 {
    padding-top: 2.5rem
}

.pt-12 {
    padding-top: 3rem
}

.pt-20 {
    padding-top: 5rem
}

.pt-3 {
    padding-top: .75rem
}

.pt-4 {
    padding-top: 1rem
}

.pt-6 {
    padding-top: 1.5rem
}

.pt-8 {
    padding-top: 2rem
}

.text-left {
    text-align: left
}

.text-center {
    text-align: center
}

.text-right {
    text-align: right
}

.font-display {
    font-family: Lexend, sans-serif
}

.font-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace
}

.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-5xl {
    font-size: 3rem;
    line-height: 1
}

.text-9xl {
    font-size: 8rem;
    line-height: 1
}

.text-\[10px\] {
    font-size: 10px
}

.text-\[11px\] {
    font-size: 11px
}

.text-\[15px\] {
    font-size: 15px
}

.text-base {
    font-size: 1rem;
    line-height: 1.5rem
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem
}

.text-sm {
    font-size: .875rem;
    line-height: 1.25rem
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem
}

.text-xs {
    font-size: .75rem;
    line-height: 1rem
}

.font-black {
    font-weight: 900
}

.font-bold {
    font-weight: 700
}

.font-extrabold {
    font-weight: 800
}

.font-medium {
    font-weight: 500
}

.font-normal {
    font-weight: 400
}

.font-semibold {
    font-weight: 600
}

.uppercase {
    text-transform: uppercase
}

.italic {
    font-style: italic
}

.not-italic {
    font-style: normal
}

.leading-\[1\.1\] {
    line-height: 1.1
}

.leading-none {
    line-height: 1
}

.leading-relaxed {
    line-height: 1.625
}

.leading-snug {
    line-height: 1.375
}

.leading-tight {
    line-height: 1.25
}

.tracking-\[0\.2em\] {
    letter-spacing: .2em
}

.tracking-tight {
    letter-spacing: -.025em
}

.tracking-tighter {
    letter-spacing: -.05em
}

.tracking-wide {
    letter-spacing: .025em
}

.tracking-wider {
    letter-spacing: .05em
}

.tracking-widest {
    letter-spacing: .1em
}

.text-\[\#2563eb\] {
    --tw-text-opacity: 1;
    color: rgb(37 99 235/var(--tw-text-opacity, 1))
}

.text-\[\#334155\] {
    --tw-text-opacity: 1;
    color: rgb(51 65 85/var(--tw-text-opacity, 1))
}

.text-\[\#475569\] {
    --tw-text-opacity: 1;
    color: rgb(71 85 105/var(--tw-text-opacity, 1))
}

.text-\[\#ef4444\] {
    --tw-text-opacity: 1;
    color: rgb(239 68 68/var(--tw-text-opacity, 1))
}

.text-accent-500 {
    --tw-text-opacity: 1;
    color: rgb(16 185 129/var(--tw-text-opacity, 1))
}

.text-amber-500 {
    --tw-text-opacity: 1;
    color: rgb(245 158 11/var(--tw-text-opacity, 1))
}

.text-amber-600 {
    --tw-text-opacity: 1;
    color: rgb(217 119 6/var(--tw-text-opacity, 1))
}

.text-amber-700 {
    --tw-text-opacity: 1;
    color: rgb(180 83 9/var(--tw-text-opacity, 1))
}

.text-blue-600 {
    --tw-text-opacity: 1;
    color: rgb(37 99 235/var(--tw-text-opacity, 1))
}

.text-blue-700 {
    --tw-text-opacity: 1;
    color: rgb(29 78 216/var(--tw-text-opacity, 1))
}

.text-blue-800 {
    --tw-text-opacity: 1;
    color: rgb(30 64 175/var(--tw-text-opacity, 1))
}

.text-emerald-600 {
    --tw-text-opacity: 1;
    color: rgb(5 150 105/var(--tw-text-opacity, 1))
}

.text-gray-600 {
    --tw-text-opacity: 1;
    color: rgb(75 85 99/var(--tw-text-opacity, 1))
}

.text-gray-800 {
    --tw-text-opacity: 1;
    color: rgb(31 41 55/var(--tw-text-opacity, 1))
}

.text-green-500 {
    --tw-text-opacity: 1;
    color: rgb(34 197 94/var(--tw-text-opacity, 1))
}

.text-green-600 {
    --tw-text-opacity: 1;
    color: rgb(22 163 74/var(--tw-text-opacity, 1))
}

.text-green-700 {
    --tw-text-opacity: 1;
    color: rgb(21 128 61/var(--tw-text-opacity, 1))
}

.text-green-800 {
    --tw-text-opacity: 1;
    color: rgb(22 101 52/var(--tw-text-opacity, 1))
}

.text-orange-600 {
    --tw-text-opacity: 1;
    color: rgb(234 88 12/var(--tw-text-opacity, 1))
}

.text-primary-100 {
    --tw-text-opacity: 1;
    color: rgb(219 234 254/var(--tw-text-opacity, 1))
}

.text-primary-200 {
    --tw-text-opacity: 1;
    color: rgb(191 219 254/var(--tw-text-opacity, 1))
}

.text-primary-300 {
    --tw-text-opacity: 1;
    color: rgb(147 197 253/var(--tw-text-opacity, 1))
}

.text-primary-400 {
    --tw-text-opacity: 1;
    color: rgb(96 165 250/var(--tw-text-opacity, 1))
}

.text-primary-500 {
    --tw-text-opacity: 1;
    color: rgb(59 130 246/var(--tw-text-opacity, 1))
}

.text-primary-600 {
    --tw-text-opacity: 1;
    color: rgb(37 99 235/var(--tw-text-opacity, 1))
}

.text-primary-700 {
    --tw-text-opacity: 1;
    color: rgb(29 78 216/var(--tw-text-opacity, 1))
}

.text-primary-900 {
    --tw-text-opacity: 1;
    color: rgb(30 58 138/var(--tw-text-opacity, 1))
}

.text-purple-600 {
    --tw-text-opacity: 1;
    color: rgb(147 51 234/var(--tw-text-opacity, 1))
}

.text-red-500 {
    --tw-text-opacity: 1;
    color: rgb(239 68 68/var(--tw-text-opacity, 1))
}

.text-red-600 {
    --tw-text-opacity: 1;
    color: rgb(220 38 38/var(--tw-text-opacity, 1))
}

.text-red-700 {
    --tw-text-opacity: 1;
    color: rgb(185 28 28/var(--tw-text-opacity, 1))
}

.text-red-800 {
    --tw-text-opacity: 1;
    color: rgb(153 27 27/var(--tw-text-opacity, 1))
}

.text-secondary-600 {
    --tw-text-opacity: 1;
    color: rgb(5 150 105/var(--tw-text-opacity, 1))
}

.text-slate-100 {
    --tw-text-opacity: 1;
    color: rgb(241 245 249/var(--tw-text-opacity, 1))
}

.text-slate-200 {
    --tw-text-opacity: 1;
    color: rgb(226 232 240/var(--tw-text-opacity, 1))
}

.text-slate-300 {
    --tw-text-opacity: 1;
    color: rgb(203 213 225/var(--tw-text-opacity, 1))
}

.text-slate-400 {
    --tw-text-opacity: 1;
    color: rgb(148 163 184/var(--tw-text-opacity, 1))
}

.text-slate-500 {
    --tw-text-opacity: 1;
    color: rgb(100 116 139/var(--tw-text-opacity, 1))
}

.text-slate-600 {
    --tw-text-opacity: 1;
    color: rgb(71 85 105/var(--tw-text-opacity, 1))
}

.text-slate-700 {
    --tw-text-opacity: 1;
    color: rgb(51 65 85/var(--tw-text-opacity, 1))
}

.text-slate-800 {
    --tw-text-opacity: 1;
    color: rgb(30 41 59/var(--tw-text-opacity, 1))
}

.text-slate-900 {
    --tw-text-opacity: 1;
    color: rgb(15 23 42/var(--tw-text-opacity, 1))
}

.text-transparent {
    color: transparent
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity, 1))
}

.text-white\/80 {
    color: hsla(0, 0%, 100%, .8)
}

.text-yellow-800 {
    --tw-text-opacity: 1;
    color: rgb(133 77 14/var(--tw-text-opacity, 1))
}

.underline {
    text-decoration-line: underline
}

.line-through {
    text-decoration-line: line-through
}

.no-underline {
    text-decoration-line: none
}

.antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.opacity-0 {
    opacity: 0
}

.opacity-100 {
    opacity: 1
}

.opacity-20 {
    opacity: .2
}

.opacity-40 {
    opacity: .4
}

.opacity-50 {
    opacity: .5
}

.opacity-80 {
    opacity: .8
}

.opacity-\[0\.03\] {
    opacity: .03
}

.shadow {
    --tw-shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color)
}

.shadow,
.shadow-2xl {
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-2xl {
    --tw-shadow: 0 25px 50px -12px rgba(0, 0, 0, .25);
    --tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color)
}

.shadow-inner {
    --tw-shadow: inset 0 2px 4px 0 rgba(0, 0, 0, .05);
    --tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color)
}

.shadow-inner,
.shadow-lg {
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-lg {
    --tw-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color)
}

.shadow-md {
    --tw-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color)
}

.shadow-md,
.shadow-sm {
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-sm {
    --tw-shadow: 0 1px 2px 0 rgba(0, 0, 0, .05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color)
}

.shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.shadow-primary-200 {
    --tw-shadow-color: #bfdbfe;
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-primary-400 {
    --tw-shadow-color: #60a5fa;
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-primary-500\/25 {
    --tw-shadow-color: rgba(59, 130, 246, .25);
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-primary-500\/30 {
    --tw-shadow-color: rgba(59, 130, 246, .3);
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-primary-900\/25 {
    --tw-shadow-color: rgba(30, 58, 138, .25);
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-secondary-500\/25 {
    --tw-shadow-color: rgba(16, 185, 129, .25);
    --tw-shadow: var(--tw-shadow-colored)
}

.shadow-slate-200\/20 {
    --tw-shadow-color: rgba(226, 232, 240, .2);
    --tw-shadow: var(--tw-shadow-colored)
}

.ring-2 {
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)
}

.ring-2,
.ring-4 {
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)
}

.ring-4 {
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)
}

.ring-primary-100 {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(219 234 254/var(--tw-ring-opacity, 1))
}

.ring-primary-500 {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(59 130 246/var(--tw-ring-opacity, 1))
}

.ring-white {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(255 255 255/var(--tw-ring-opacity, 1))
}

.blur-3xl {
    --tw-blur: blur(64px)
}

.blur-3xl,
.drop-shadow-md {
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)
}

.drop-shadow-md {
    --tw-drop-shadow: drop-shadow(0 4px 3px rgba(0, 0, 0, .07)) drop-shadow(0 2px 2px rgba(0, 0, 0, .06))
}

.backdrop-blur {
    --tw-backdrop-blur: blur(8px)
}

.backdrop-blur,
.backdrop-blur-md {
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.backdrop-blur-md {
    --tw-backdrop-blur: blur(12px)
}

.backdrop-blur-sm {
    --tw-backdrop-blur: blur(4px);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.transition {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s
}

.transition-all {
    transition-property: all;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s
}

.transition-colors {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s
}

.transition-opacity {
    transition-property: opacity;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s
}

.transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    transition-duration: .15s
}

.transition-transform {
    transition-property: transform;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

.duration-150,
.transition-transform {
    transition-duration: .15s
}

.duration-200 {
    transition-duration: .2s
}

.duration-300 {
    transition-duration: .3s
}

.duration-500 {
    transition-duration: .5s
}

.prose-evp {
    color: #1e293b;
    font-size: 1.0625rem;
    line-height: 1.8;
    max-width: 72ch
}

.prose-evp p {
    margin-top: 0;
    margin-bottom: 1.5em
}

.prose-evp h1,
.prose-evp h2,
.prose-evp h3,
.prose-evp h4 {
    font-family: Lexend, Inter, sans-serif;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.3;
    margin-top: 2.5em;
    margin-bottom: .75em;
    scroll-margin-top: 96px
}

.prose-evp h2 {
    font-size: 1.625rem;
    padding-bottom: .5em;
    border-bottom: 2px solid #e2e8f0
}

.prose-evp h2:before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 1.2em;
    background: #2563eb;
    border-radius: 2px;
    margin-right: .6em;
    vertical-align: middle;
    position: relative;
    top: -1px
}

.prose-evp h3 {
    font-size: 1.25rem;
    color: #1e293b
}

.prose-evp h4 {
    font-size: 1.05rem;
    color: #334155
}

.prose-evp a {
    color: #2563eb;
    text-decoration: underline;
    text-decoration-color: #bfdbfe;
    text-underline-offset: 3px;
    transition: color .15s, text-decoration-color .15s;
    font-weight: 500
}

.prose-evp a:hover {
    color: #1d4ed8;
    text-decoration-color: #2563eb
}

.prose-evp ol,
.prose-evp ul {
    margin-bottom: 1.5em;
    padding-left: 1.5em
}

.prose-evp ul {
    list-style: none;
    padding-left: 0
}

.prose-evp ul li {
    position: relative;
    padding-left: 1.5em;
    margin-bottom: .5em
}

.prose-evp ul li:before {
    content: "";
    position: absolute;
    left: 0;
    top: .65em;
    width: 6px;
    height: 6px;
    background: #2563eb;
    border-radius: 50%
}

.prose-evp ol {
    list-style: decimal
}

.prose-evp ol li {
    padding-left: .25em
}

.prose-evp li p,
.prose-evp ol li {
    margin-bottom: .5em
}

.prose-evp blockquote {
    border-left: 4px solid #2563eb;
    background: #eff6ff;
    padding: 1rem 1.5rem;
    margin: 2em 0;
    border-radius: 0 12px 12px 0;
    font-style: italic;
    color: #1e40af;
    font-size: 1.05em;
    line-height: 1.7
}

.prose-evp blockquote p:last-child {
    margin-bottom: 0
}

.prose-evp blockquote cite {
    display: block;
    margin-top: .75em;
    font-size: .875rem;
    font-style: normal;
    font-weight: 600;
    color: #3b82f6
}

.prose-evp code {
    font-size: .875em;
    background: #f1f5f9;
    color: #be123c;
    padding: .125em .4em;
    border-radius: 5px;
    border: 1px solid #e2e8f0
}

.prose-evp code,
.prose-evp pre {
    font-family: JetBrains Mono, Fira Code, ui-monospace, monospace
}

.prose-evp pre {
    background: #0f172a;
    color: #e2e8f0;
    font-size: .875rem;
    line-height: 1.7;
    padding: 1.5rem;
    border-radius: 12px;
    overflow-x: auto;
    margin: 2em 0;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1)
}

.prose-evp pre code {
    background: none;
    color: inherit;
    padding: 0;
    border: none;
    font-size: inherit
}

.prose-evp hr {
    border: none;
    border-top: 2px solid #e2e8f0;
    margin: 2.5em 0
}

.prose-evp img {
    border-radius: 12px;
    max-width: 100%;
    height: auto;
    margin: 2em auto;
    display: block;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05)
}

.prose-evp table {
    width: 100%;
    border-collapse: collapse;
    margin: 2em 0;
    font-size: .9rem;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06)
}

.prose-evp thead {
    background: #2563eb;
    color: #fff
}

.prose-evp thead th {
    padding: .75rem 1rem;
    text-align: left;
    font-weight: 600;
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .05em
}

.prose-evp tbody tr {
    border-bottom: 1px solid #f1f5f9;
    transition: background .1s
}

.prose-evp tbody tr:hover {
    background: #f8fafc
}

.prose-evp tbody td {
    padding: .75rem 1rem;
    color: #334155;
    vertical-align: top
}

.prose-evp .callout-info,
.prose-evp .wp-block-info {
    background: #eff6ff !important;
    border-left: 4px solid #2563eb !important;
    border-radius: 0 10px 10px 0 !important;
    padding: 1rem 1.25rem !important;
    margin: 1.5em 0 !important;
    font-size: .95em !important;
    color: #1e40af !important
}

.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden
}

.woocommerce-breadcrumb {
    font-size: .875rem;
    color: #64748b;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: .25rem
}

.woocommerce-breadcrumb a {
    color: inherit
}

.woocommerce-breadcrumb a:hover {
    color: #2563eb
}

.woocommerce div.product {
    display: block
}

.woocommerce div.product div.images {
    border-radius: .75rem;
    overflow: hidden
}

.woocommerce div.product div.images img {
    border-radius: .75rem;
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover
}

.woocommerce div.product div.images .flex-control-thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: 1rem;
    list-style: none;
    padding: 0
}

.woocommerce div.product div.images .flex-control-thumbs li {
    flex: 0 0 calc(20% - 0.4rem);
    cursor: pointer
}

.woocommerce div.product div.images .flex-control-thumbs li img {
    border-radius: .5rem;
    border: 2px solid transparent;
    transition: border-color .2s, opacity .2s;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    opacity: .7
}

.woocommerce div.product div.images .flex-control-thumbs li img:hover,
.woocommerce div.product div.images .flex-control-thumbs li.flex-active img {
    opacity: 1;
    border-color: #2563eb
}

.woocommerce div.product div.summary {
    display: flex;
    flex-direction: column;
    gap: 1.25rem
}

.woocommerce div.product .product_title {
    font-size: 1.875rem;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.3;
    margin: 0
}

.woocommerce div.product .woocommerce-product-rating {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .5rem
}

.woocommerce .star-rating {
    color: #facc15
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-size: 1.875rem;
    font-weight: 700;
    color: #2563eb
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    font-size: 1.25rem;
    color: #94a3b8;
    font-weight: 400;
    margin-right: .5rem
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    text-decoration: none
}

.woocommerce div.product .woocommerce-product-details__short-description {
    color: #475569;
    line-height: 1.7
}

.woocommerce div.product form.cart {
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce div.product form.cart .single_add_to_cart_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 2rem;
    background-color: #2563eb;
    color: #fff;
    font-weight: 700;
    border-radius: .75rem;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    transition: background-color .2s;
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, .3);
    text-decoration: none
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background-color: #1d4ed8
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: .25rem;
    border-bottom: 1px solid #e2e8f0;
    margin-bottom: 2rem;
    list-style: none;
    padding: 0;
    margin-top: 0
}

.woocommerce div.product .woocommerce-tabs ul.tabs:before {
    display: none
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: transparent;
    border: none;
    border-radius: 0;
    margin: 0;
    padding: 0
}

.woocommerce div.product .woocommerce-tabs ul.tabs li:after,
.woocommerce div.product .woocommerce-tabs ul.tabs li:before {
    display: none
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    display: inline-block;
    padding: .75rem 1.25rem;
    font-size: .875rem;
    font-weight: 500;
    color: #475569;
    border-bottom: 2px solid transparent;
    transition: color .2s, border-color .2s;
    text-decoration: none
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: #2563eb;
    border-color: #2563eb
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: #2563eb;
    border-color: #2563eb;
    background: transparent
}

.woocommerce div.product .woocommerce-tabs .panel {
    color: #334155;
    line-height: 1.75;
    max-width: none
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 1rem;
    color: #0f172a
}

.woocommerce div.product .product_meta {
    font-size: .875rem;
    color: #64748b;
    padding-top: 1rem;
    border-top: 1px solid #f1f5f9;
    display: flex;
    flex-direction: column;
    gap: .25rem
}

.woocommerce div.product .product_meta a {
    color: #2563eb
}

.woocommerce div.product .product_meta a:hover {
    text-decoration: underline
}

.woocommerce .related>h2,
.woocommerce .upsells>h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1.5rem
}

.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 1.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
    clear: both
}

@media (min-width:640px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media (min-width:1024px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr)
    }
}

.woocommerce ul.products li.product {
    background: #fff;
    border-radius: .75rem;
    overflow: hidden;
    border: 1px solid #f1f5f9;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
    transition: box-shadow .2s
}

.woocommerce ul.products li.product:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, .1)
}

.woocommerce ul.products li.product a img {
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 1rem;
    font-weight: 600;
    color: #1e293b;
    padding: .75rem 1rem .25rem
}

.woocommerce ul.products li.product .price {
    padding: 0 1rem .75rem;
    color: #2563eb;
    font-weight: 700
}

.woocommerce ul.products li.product .button {
    display: block;
    margin: 0 1rem 1rem;
    padding: .5rem;
    text-align: center;
    background-color: #2563eb;
    color: #fff;
    border-radius: .5rem;
    font-size: .875rem;
    font-weight: 500;
    transition: background-color .2s;
    text-decoration: none
}

.woocommerce ul.products li.product .button:hover {
    background-color: #1d4ed8
}

.woocommerce table.shop_table {
    width: 100%;
    font-size: .875rem;
    border-collapse: collapse
}

.woocommerce table.shop_table thead th {
    text-align: left;
    font-weight: 600;
    color: #334155;
    padding: .75rem 1rem;
    border-bottom: 1px solid #e2e8f0;
    background: #f8fafc
}

.woocommerce table.shop_table td {
    padding: 1rem;
    border-bottom: 1px solid #f1f5f9;
    color: #334155
}

.woocommerce .cart-collaterals .cart_totals {
    background: #f8fafc;
    border-radius: .75rem;
    padding: 1.5rem;
    border: 1px solid #f1f5f9
}

.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
    border-radius: .75rem;
    padding: 1rem;
    margin-bottom: 1.5rem;
    border: 1px solid;
    font-size: .875rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: .75rem
}

.woocommerce-message {
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #166534
}

.woocommerce-info {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: #1e3a8a
}

.woocommerce-error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b
}

.woocommerce-info a.button,
.woocommerce-message a.button {
    margin-left: auto;
    padding: .375rem 1rem;
    border-radius: .5rem;
    font-weight: 600;
    font-size: .875rem
}

.woocommerce-MyAccount-navigation ul {
    list-style: none;
    padding: 0;
    margin: 0
}

.woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: .75rem 1rem;
    font-size: .875rem;
    font-weight: 500;
    color: #475569;
    border-radius: .5rem;
    transition: background .15s, color .15s;
    text-decoration: none
}

.woocommerce-MyAccount-navigation ul li a:hover {
    background: #f8fafc;
    color: #2563eb
}

.woocommerce-MyAccount-navigation ul li.is-active a {
    background: #eff6ff;
    color: #2563eb;
    font-weight: 600
}

.woocommerce-orders-table,
.woocommerce-table--order-details {
    width: 100%;
    font-size: .875rem;
    border-collapse: collapse
}

.woocommerce-orders-table th,
.woocommerce-table--order-details th {
    text-align: left;
    font-weight: 600;
    color: #334155;
    padding: .75rem 1rem;
    border-bottom: 1px solid #e2e8f0;
    background: #f8fafc
}

.woocommerce-orders-table td,
.woocommerce-table--order-details td {
    padding: .75rem 1rem;
    border-bottom: 1px solid #f1f5f9;
    color: #475569
}

.woocommerce-orders-table .button {
    display: inline-flex;
    padding: .375rem .75rem;
    background-color: #2563eb;
    color: #fff;
    border-radius: .5rem;
    font-size: .75rem;
    font-weight: 500;
    text-decoration: none;
    transition: background-color .2s
}

.woocommerce-orders-table .button:hover {
    background-color: #1d4ed8
}

.woocommerce form .form-row {
    margin-bottom: 1rem
}

.woocommerce form .form-row label {
    display: block;
    font-size: .875rem;
    font-weight: 500;
    color: #334155;
    margin-bottom: .25rem
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
    width: 100%;
    padding: .625rem 1rem;
    border: 1px solid #cbd5e1;
    border-radius: .5rem;
    background: #fff;
    color: #0f172a;
    font-size: .875rem;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, .15)
}

.evp-purchase-actions .tm-extra-product-options input[type=text],
.evp-purchase-actions .tm-extra-product-options select,
.evp-purchase-actions .tm-extra-product-options textarea {
    width: 100% !important;
    border-radius: .75rem !important;
    border-width: 1px !important;
    --tw-border-opacity: 1 !important;
    border-color: rgb(226 232 240/var(--tw-border-opacity, 1)) !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(248 250 252/var(--tw-bg-opacity, 1)) !important;
    padding: .75rem 1rem !important;
    --tw-text-opacity: 1 !important;
    color: rgb(15 23 42/var(--tw-text-opacity, 1)) !important
}

.evp-purchase-actions .tm-extra-product-options input[type=text]::-moz-placeholder,
.evp-purchase-actions .tm-extra-product-options select::-moz-placeholder,
.evp-purchase-actions .tm-extra-product-options textarea::-moz-placeholder {
    --tw-placeholder-opacity: 1 !important;
    color: rgb(148 163 184/var(--tw-placeholder-opacity, 1)) !important
}

.evp-purchase-actions .tm-extra-product-options input[type=text]::placeholder,
.evp-purchase-actions .tm-extra-product-options select::placeholder,
.evp-purchase-actions .tm-extra-product-options textarea::placeholder {
    --tw-placeholder-opacity: 1 !important;
    color: rgb(148 163 184/var(--tw-placeholder-opacity, 1)) !important
}

.evp-purchase-actions .tm-extra-product-options input[type=text],
.evp-purchase-actions .tm-extra-product-options select,
.evp-purchase-actions .tm-extra-product-options textarea {
    outline: 2px solid transparent !important;
    outline-offset: 2px !important;
    transition-property: all !important;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1) !important;
    transition-duration: .15s !important
}

.nextgen-checkout .evp-purchase-actions .tm-extra-product-options input[type=text].lg\:w-3\/5,
.nextgen-checkout .evp-purchase-actions .tm-extra-product-options select.lg\:w-3\/5,
.nextgen-checkout .evp-purchase-actions .tm-extra-product-options textarea.lg\:w-3\/5 {
    padding: 2rem 3rem !important
}

.evp-purchase-actions .tm-extra-product-options input[type=text]:focus,
.evp-purchase-actions .tm-extra-product-options select:focus,
.evp-purchase-actions .tm-extra-product-options textarea:focus {
    --tw-border-opacity: 1 !important;
    border-color: rgb(59 130 246/var(--tw-border-opacity, 1)) !important;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) !important;
    --tw-ring-color: rgba(59, 130, 246, .2) !important
}

@media (prefers-color-scheme:dark) {

    .evp-purchase-actions .tm-extra-product-options input[type=text],
    .evp-purchase-actions .tm-extra-product-options select,
    .evp-purchase-actions .tm-extra-product-options textarea {
        --tw-border-opacity: 1 !important;
        border-color: rgb(51 65 85/var(--tw-border-opacity, 1)) !important;
        background-color: rgba(15, 23, 42, .5) !important;
        --tw-text-opacity: 1 !important;
        color: rgb(255 255 255/var(--tw-text-opacity, 1)) !important
    }
}

.evp-purchase-actions .tm-extra-product-options-field {
    margin-bottom: 1rem !important;
    border-style: none !important
}

.evp-purchase-actions .tm-epo-element-label {
    margin-bottom: .5rem !important;
    display: block !important;
    font-size: .875rem !important;
    line-height: 1.25rem !important;
    font-weight: 700 !important;
    --tw-text-opacity: 1 !important;
    color: rgb(51 65 85/var(--tw-text-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .evp-purchase-actions .tm-epo-element-label {
        --tw-text-opacity: 1 !important;
        color: rgb(203 213 225/var(--tw-text-opacity, 1)) !important
    }
}

.evp-purchase-actions .tm-epo-element-label {
    font-family: Lexend, sans-serif
}

.evp-purchase-actions .tm-epo-required {
    margin-left: .25rem !important;
    --tw-text-opacity: 1 !important;
    color: rgb(239 68 68/var(--tw-text-opacity, 1)) !important
}

.evp-purchase-actions .tm-element-description {
    margin-top: .25rem !important;
    margin-bottom: .75rem !important;
    font-size: .75rem !important;
    line-height: 1rem !important;
    font-style: italic !important;
    line-height: 1.625 !important;
    --tw-text-opacity: 1 !important;
    color: rgb(100 116 139/var(--tw-text-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .evp-purchase-actions .tm-element-description {
        --tw-text-opacity: 1 !important;
        color: rgb(148 163 184/var(--tw-text-opacity, 1)) !important
    }
}

.evp-purchase-actions .hr_divider {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
    --tw-border-opacity: 1 !important;
    border-color: rgb(241 245 249/var(--tw-border-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .evp-purchase-actions .hr_divider {
        --tw-border-opacity: 1 !important;
        border-color: rgb(51 65 85/var(--tw-border-opacity, 1)) !important
    }
}

.evp-purchase-actions .cpf-type-header h3 {
    margin-top: 1rem !important;
    margin-bottom: .5rem !important;
    font-size: 1rem !important;
    line-height: 1.5rem !important;
    font-weight: 900 !important;
    --tw-text-opacity: 1 !important;
    color: rgb(15 23 42/var(--tw-text-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .evp-purchase-actions .cpf-type-header h3 {
        --tw-text-opacity: 1 !important;
        color: rgb(255 255 255/var(--tw-text-opacity, 1)) !important
    }
}

.evp-purchase-actions .cpf-type-header h3 {
    letter-spacing: -.01em
}

.evp-purchase-actions .tmcp-ul-wrap {
    list-style-type: none !important
}

.evp-purchase-actions .tmcp-field-wrap,
.evp-purchase-actions .tmcp-ul-wrap {
    margin: 0 !important;
    padding: 0 !important
}

.woocommerce #payment {
    background: #f8fafc;
    border-radius: .75rem;
    padding: 1.5rem;
    margin-top: 1.5rem
}

.woocommerce #payment ul.payment_methods {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin-bottom: 1.5rem
}

.evp-account-wrap {
    background: #f8fafc;
    min-height: 100vh
}

.evp-account-header {
    background: linear-gradient(135deg, #0f172a, #1e3a5f 60%, #1e40af);
    padding: 2rem 0
}

.evp-account-header__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem
}

.evp-account-header__avatar {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    background: rgba(99, 102, 241, .25);
    border: 2px solid rgba(165, 180, 252, .5);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0
}

.evp-account-header__label {
    display: block;
    color: #a5b4fc;
    font-size: .6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-bottom: .125rem
}

.evp-account-header__name {
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.2;
    margin: 0
}

.evp-account-body {
    max-width: 1280px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    align-items: flex-start
}

@media (min-width:768px) {
    .evp-account-body {
        flex-direction: row
    }
}

.evp-account-sidebar {
    width: 100%;
    flex-shrink: 0
}

@media (min-width:768px) {
    .evp-account-sidebar {
        width: 230px
    }
}

.evp-account-sidebar__inner {
    background: #fff;
    border-radius: 1rem;
    border: 1px solid #e2e8f0;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
    overflow: hidden;
    position: sticky;
    top: 6rem
}

body.admin-bar .evp-account-sidebar__inner {
    top: 8.5rem
}

.evp-account-main {
    flex: 1;
    min-width: 0
}

.evp-account-panel {
    background: #fff;
    border-radius: 1rem;
    border: 1px solid #e2e8f0;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .06);
    padding: 1.75rem
}

@media (min-width:1024px) {
    .evp-account-panel {
        padding: 2.25rem
    }
}

.evp-account-panel h2,
.evp-account-panel h3 {
    font-family: Lexend, Inter, sans-serif;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 1.25rem
}

.evp-account-panel h2 {
    font-size: 1.25rem
}

.evp-account-panel h3 {
    font-size: 1.0625rem
}

.woocommerce-Message,
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
    list-style: none !important;
    padding: 1.125rem 1.5rem 1.125rem 3.75rem !important;
    border-radius: .75rem !important;
    font-size: .875rem !important;
    margin-bottom: 2rem !important;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1.25rem;
    position: relative !important;
    outline: none !important;
    border-width: 1px !important;
    border-style: solid !important
}

.woocommerce-Message:before,
.woocommerce-error:before,
.woocommerce-info:before,
.woocommerce-message:before {
    position: absolute !important;
    left: 1.25rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 1.25rem !important;
    line-height: 1 !important;
    display: inline-block !important;
    margin: 0 !important
}

.woocommerce-Message--info,
.woocommerce-info {
    background-color: #eff6ff !important;
    color: #1e40af !important;
    border-color: #bfdbfe !important
}

.woocommerce-Message--success,
.woocommerce-message {
    background-color: #f0fdf4 !important;
    color: #166534 !important;
    border-color: #bbf7d0 !important
}

.woocommerce-error {
    background-color: #fef2f2 !important;
    color: #991b1b !important;
    border-color: #fecaca !important
}

.evp-account-panel .woocommerce-error li {
    margin: 0
}

.evp-account-panel .woocommerce-form-row label,
.evp-account-panel p.form-row label {
    display: block;
    font-size: .8125rem;
    font-weight: 600;
    color: #475569;
    margin-bottom: .375rem
}

.evp-account-panel .woocommerce-form-row input,
.evp-account-panel .woocommerce-form-row select,
.evp-account-panel .woocommerce-form-row textarea,
.evp-account-panel p.form-row input,
.evp-account-panel p.form-row select,
.evp-account-panel p.form-row textarea {
    width: 100%;
    padding: .625rem .875rem;
    font-size: .875rem;
    border: 1px solid #e2e8f0;
    border-radius: .625rem;
    background: #fff;
    color: #0f172a;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box
}

.evp-account-panel .woocommerce-form-row input:focus,
.evp-account-panel .woocommerce-form-row select:focus,
.evp-account-panel p.form-row input:focus,
.evp-account-panel p.form-row select:focus {
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, .15)
}

.evp-account-panel .button,
.evp-account-panel .woocommerce-Button,
.evp-account-panel button[type=submit],
.evp-account-panel input[type=submit] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .5rem 1.25rem !important;
    font-size: .8125rem !important;
    font-weight: 700 !important;
    border-radius: .625rem !important;
    cursor: pointer;
    transition: all .15s;
    border: none;
    line-height: normal;
    white-space: nowrap
}

.evp-account-panel .button-compact {
    padding: .3125rem .75rem !important;
    font-size: .75rem !important;
    border-radius: .5rem !important
}

.evp-account-panel .button,
.evp-account-panel .woocommerce-Button,
.evp-account-panel button[type=submit],
.evp-account-panel input[type=submit] {
    background: #2563eb !important;
    color: #fff !important;
    box-shadow: 0 2px 8px rgba(37, 99, 235, .15)
}

.evp-account-panel .button:hover,
.evp-account-panel .woocommerce-Button:hover,
.evp-account-panel button[type=submit]:hover,
.evp-account-panel input[type=submit]:hover {
    background: #1d4ed8 !important;
    color: #fff !important;
    transform: translateY(-1px)
}

.evp-account-panel .woocommerce-Address-title h2 {
    font-size: 1.125rem;
    font-weight: 700;
    color: #0f172a;
    margin: 0
}

.evp-account-panel .woocommerce-Address-title .edit {
    font-size: .8125rem;
    color: #2563eb;
    font-weight: 500;
    text-decoration: none
}

.evp-account-panel address {
    font-style: normal;
    font-size: .875rem;
    color: #475569;
    line-height: 1.75
}

.evp-account-panel .woocommerce-table--order-details {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem
}

.evp-account-panel .woocommerce-table--order-details th {
    padding: .75rem 1rem;
    background: #f1f5f9;
    color: #475569;
    font-weight: 600;
    text-align: left;
    border-bottom: 1px solid #e2e8f0
}

.evp-account-panel .woocommerce-table--order-details td {
    padding: .875rem 1rem;
    border-bottom: 1px solid #f1f5f9;
    color: #334155;
    vertical-align: top
}

.evp-account-panel .woocommerce-table--order-details tfoot td,
.evp-account-panel .woocommerce-table--order-details tfoot th {
    font-weight: 700;
    background: none
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    width: 100% !important
}

.woocommerce-MyAccount-navigation ul li a {
    padding: .5rem !important
}

.woocommerce-MyAccount-navigation .is-active>a {
    background: #eff6ff;
    color: #1d4ed8 !important;
    font-weight: 600
}

.woocommerce,
.woocommerce-area .site-main,
.woocommerce-page .site-main {
    width: 100%
}

.evp-single-product .app_details {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start
}

.evp-tab-label {
    order: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .75rem 1.5rem;
    margin-right: .5rem;
    margin-bottom: .5rem;
    cursor: pointer;
    background: transparent;
    color: #64748b;
    font-weight: 700;
    font-size: .875rem;
    border-radius: .75rem;
    border: 1px solid transparent;
    transition: all .3s cubic-bezier(.4, 0, .2, 1);
    white-space: nowrap
}

.evp-tab-label:hover {
    color: #0f172a;
    background: #f1f5f9
}

.dark .evp-tab-label:hover {
    color: #f8fafc;
    background: #1e293b
}

.evp-tab-input:checked+.evp-tab-label {
    background: #fff;
    color: #2563eb;
    border-color: #e2e8f0;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1)
}

.dark .evp-tab-input:checked+.evp-tab-label {
    background: #1e293b;
    color: #60a5fa;
    border-color: #334155
}

.evp-tab-panel {
    order: 2;
    width: 100%;
    display: none;
    padding: 2.5rem;
    background: #fff;
    border: 1px solid #f1f5f9;
    border-radius: 1.5rem;
    animation: evpTabFadeIn .4s ease-out;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, .1)
}

.dark .evp-tab-panel {
    background: rgba(30, 41, 59, .5);
    border-color: #334155;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1)
}

.evp-tab-input:checked+.evp-tab-label+.evp-tab-panel {
    display: block
}

.evp-support-link {
    text-decoration: none !important
}

@keyframes evpTabFadeIn {
    0% {
        opacity: 0;
        transform: translateY(10px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

@media (max-width:1023px) {
    .evp-tab-label {
        flex: 1 1 auto;
        padding: .5rem 1rem;
        font-size: .75rem
    }

    .evp-tab-panel {
        padding: 1.5rem;
        border-radius: 1rem
    }
}

.evp-purchase-actions .button {
    width: 100%;
    padding: 1.25rem !important;
    font-size: 1.125rem !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: .05em;
    border-radius: 1rem !important;
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, .3)
}

.evp-product-page .site-main {
    background: radial-gradient(circle at top right, rgba(37, 99, 235, .05), transparent), radial-gradient(circle at bottom left, rgba(37, 99, 235, .03), transparent)
}

.evp-single-product .product-gallery .flex-control-nav {
    position: static;
    display: flex;
    gap: .5rem;
    margin-top: 1rem;
    padding: 0;
    list-style: none;
    justify-content: center
}

.evp-single-product .product-gallery .flex-control-nav li img {
    border-radius: .5rem;
    cursor: pointer;
    transition: all .2s;
    opacity: .6;
    border: 2px solid transparent
}

.evp-single-product .product-gallery .flex-control-nav li img.flex-active,
.evp-single-product .product-gallery .flex-control-nav li img:hover {
    opacity: 1;
    border-color: #3b82f6;
    transform: scale(1.05)
}

.evp-single-product .star-rating {
    font-size: .875rem;
    color: #f59e0b
}

.evp-single-product .price {
    font-size: 2.25rem !important;
    font-weight: 900 !important;
    color: #1e293b !important;
    display: flex;
    align-items: center;
    gap: .5rem
}

.evp-single-product .summary.entry-summary {
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
    margin: 0 !important
}

.evp-single-product .product-gallery .wpgs-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important
}

.evp-tab-panel .prose {
    font-size: 1.05rem;
    line-height: 1.8
}

.evp-tab-panel .prose h2 {
    font-size: 1.75rem;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -.025em;
    margin-top: 3rem;
    padding-bottom: .75rem;
    border-bottom: 2px solid #f1f5f9
}

.dark .evp-tab-panel .prose h2 {
    color: #f8fafc;
    border-color: #1e293b
}

.evp-tab-panel .prose ul {
    list-style: none;
    padding-left: 0;
    margin-top: 1.5rem
}

.evp-tab-panel .prose li {
    position: relative;
    padding-left: 2rem;
    margin-bottom: 1rem;
    color: #475569
}

.dark .evp-tab-panel .prose li {
    color: #94a3b8
}

.evp-tab-panel .prose li:before {
    content: "";
    position: absolute;
    left: 0;
    top: .75rem;
    width: .75rem;
    height: 2px;
    background: #2563eb;
    border-radius: 2px
}

.evp-tab-panel .prose img.aligncenter {
    border-radius: 1.5rem;
    margin: 3rem auto;
    box-shadow: 0 20px 50px -12px rgba(0, 0, 0, .1)
}

.reviews-container #comments {
    display: none !important
}

.commentlist {
    display: grid;
    gap: 1.5rem;
    padding: 0;
    list-style: none
}

.commentlist .review {
    background: #fff;
    border: 1px solid #f1f5f9;
    padding: 2rem;
    border-radius: 1.5rem;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, .05);
    transition: all .3s ease
}

.dark .commentlist .review {
    background: rgba(30, 41, 59, .4);
    border-color: #334155;
    box-shadow: none
}

.commentlist .review:hover {
    border-color: #3b82f6;
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .05)
}

.commentlist .comment-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem
}

.commentlist .avatar {
    width: 48px !important;
    height: 48px !important;
    border-radius: 1rem;
    border: 3px solid #f8fafc;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1)
}

.dark .commentlist .avatar {
    border-color: #1e293b
}

.commentlist cite.fn {
    font-style: normal;
    font-weight: 800;
    font-size: 1.125rem;
    color: #0f172a
}

.dark .commentlist cite.fn {
    color: #f1f5f9
}

.commentlist .comment-meta {
    font-size: .813rem;
    color: #94a3b8;
    margin-top: -1.25rem;
    margin-bottom: 1.5rem;
    padding-left: 4.25rem
}

.commentlist p {
    font-size: 1rem;
    line-height: 1.6;
    color: #475569;
    margin: 0
}

.dark .commentlist p {
    color: #94a3b8
}

.commentlist .reply {
    display: none
}

#respond {
    display: none !important
}

.dark .evp-single-product .price {
    color: #f8fafc !important
}

.evp-single-product .price ins {
    text-decoration: none
}

.evp-single-product .price del {
    font-size: 1.25rem;
    opacity: .4;
    margin-right: .5rem
}

.evp-single-product .cart .button {
    width: 100%;
    padding: 1.25rem 2rem !important;
    font-size: 1.125rem !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: .05em;
    border-radius: 1rem !important;
    background: linear-gradient(135deg, #2563eb, #1e40af) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 10px 25px -5px rgba(37, 99, 235, .4) !important;
    transition: all .3s cubic-bezier(.4, 0, .2, 1) !important
}

.evp-single-product .cart .button:hover {
    transform: translateY(-2px) scale(1.01) !important;
    box-shadow: 0 20px 30px -10px rgba(37, 99, 235, .5) !important
}

.evp-single-product .cart .button:active {
    transform: translateY(0) !important
}

.evp-purchase-actions:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 6px;
    background: linear-gradient(90deg, #2563eb, #10b981)
}

.evp-purchase-actions form.cart {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 0 !important
}

.evp-purchase-actions .nta-woo-products-button {
    width: 100% !important;
    margin: 0 !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button {
    width: 100% !important;
    box-sizing: border-box !important;
    padding: .875rem 1.5rem !important;
    border-radius: .75rem !important;
    justify-content: center !important;
    box-shadow: 0 4px 6px -1px rgba(37, 211, 102, .2), 0 2px 4px -1px rgba(37, 211, 102, .1) !important;
    transition: all .3s ease !important;
    background-color: #25d366 !important;
    border: none !important;
    min-height: auto !important
}

.dark .evp-purchase-actions .nta-woo-products-button a.wa__button,
.evp-purchase-actions .nta-woo-products-button a.wa__button:hover {
    background-color: #128c7e !important;
    border-color: transparent !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 15px -3px rgba(37, 211, 102, .3) !important
}

.dark .evp-purchase-actions .nta-woo-products-button a.wa__button:hover {
    background-color: #075e54 !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button .wa__btn_txt {
    text-align: left;
    margin-left: .75rem !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button .wa__cs_info {
    display: none !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button .wa__btn_title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0
}

.dark .evp-purchase-actions .nta-woo-products-button a.wa__button .wa__btn_title {
    color: #fff !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button img,
.evp-purchase-actions .nta-woo-products-button a.wa__button svg {
    filter: brightness(0) invert(1) !important;
    width: 28px !important;
    height: 28px !important
}

.evp-purchase-actions .nta-woo-products-button a.wa__button .wa__btn_icon {
    width: 28px !important;
    height: 28px !important;
    margin: 0 !important;
    padding: 0 !important
}

.evp-single-product .quantity {
    display: none !important
}

.evp-product-video-section iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.evp-single-product .woocommerce-tabs {
    margin-top: 4rem;
    border-top: 1px solid #f1f5f9;
    padding-top: 4rem
}

.dark .evp-single-product .woocommerce-tabs {
    border-color: #1e293b
}

.evp-single-product .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 2rem;
    border-bottom: 2px solid #f1f5f9;
    padding: 0 0 1rem;
    list-style: none;
    margin-bottom: 3rem
}

.dark .evp-single-product .woocommerce-tabs ul.tabs {
    border-color: #1e293b
}

.evp-single-product .woocommerce-tabs ul.tabs li {
    position: relative
}

.evp-single-product .woocommerce-tabs ul.tabs li a {
    font-size: 1rem;
    font-weight: 700;
    color: #64748b;
    text-decoration: none;
    transition: color .2s
}

.evp-single-product .woocommerce-tabs ul.tabs li.active a {
    color: #2563eb
}

.evp-single-product .woocommerce-tabs ul.tabs li.active:after {
    content: "";
    position: absolute;
    bottom: -1.15rem;
    left: 0;
    right: 0;
    height: 2px;
    background: #2563eb
}

.evp-single-product section.related h2 {
    font-size: 2.25rem;
    font-weight: 900;
    margin-bottom: 3rem;
    color: #0f172a;
    letter-spacing: -.025em;
    text-align: center;
    position: relative;
    padding-bottom: 1.5rem
}

.dark .evp-single-product section.related h2 {
    color: #f8fafc
}

.evp-single-product section.related h2:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 4px;
    background: linear-gradient(90deg, #2563eb, #10b981);
    border-radius: 2px
}

.evp-meta-links a {
    color: #2563eb;
    text-decoration: none;
    transition: color .2s ease
}

.evp-meta-links a:hover {
    color: #1e40af;
    text-decoration: underline
}

.dark .evp-meta-links a {
    color: #60a5fa
}

.dark .evp-meta-links a:hover {
    color: #93c5fd
}

.evp-checkout-box:before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(45deg, transparent, hsla(0, 0%, 100%, .05), transparent);
    pointer-events: none
}

.woocommerce ul.products.columns-1,
.woocommerce ul.products.columns-2,
.woocommerce ul.products.columns-3,
.woocommerce ul.products.columns-4,
.woocommerce ul.products.columns-5,
.woocommerce ul.products.columns-6 {
    -moz-column-count: auto !important;
    -moz-columns: auto !important;
    columns: auto !important;
    display: grid !important;
    gap: 2rem !important
}

.woocommerce ul.products.columns-3 {
    grid-template-columns: repeat(1, minmax(0, 1fr)) !important
}

@media (min-width:640px) {

    .woocommerce ul.products.columns-3,
    .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important
    }
}

@media (min-width:1024px) {
    .woocommerce ul.products.columns-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important
    }

    .woocommerce ul.products.columns-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important
    }
}

.woocommerce ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
    float: none !important
}

.nextgen-checkout {
    --checkout-bg: #fff;
    --sidebar-bg: #020617;
    --primary-gradient: linear-gradient(135deg, #6366f1, #a855f7)
}

.nextgen-checkout .woocommerce-billing-fields__field-wrapper,
.nextgen-checkout .woocommerce-shipping-fields__field-wrapper {
    display: grid !important;
    grid-template-columns: repeat(12, 1fr) !important;
    gap: 1.5rem !important;
    background: #f8fafc !important;
    padding: 2rem !important;
    border: 1px solid #f1f5f9 !important;
    border-radius: 2rem !important;
    margin-top: 1.5rem !important
}

.nextgen-checkout #billing_first_name_field {
    order: 1 !important;
    grid-column: span 6 !important
}

.nextgen-checkout #billing_last_name_field {
    order: 2 !important;
    grid-column: span 6 !important
}

.nextgen-checkout #toggle-container-billing_company_field {
    order: 3 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_company_field {
    order: 4 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_address_1_field {
    order: 5 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #toggle-container-billing_address_2_field {
    order: 6 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_address_2_field {
    order: 7 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_country_field {
    order: 8 !important;
    grid-column: span 4 !important
}

.nextgen-checkout #billing_postcode_field {
    order: 9 !important;
    grid-column: span 4 !important
}

.nextgen-checkout #billing_state_field {
    order: 10 !important;
    grid-column: span 4 !important
}

.nextgen-checkout #billing_city_field {
    order: 11 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_phone_field {
    order: 12 !important;
    grid-column: span 12 !important
}

.nextgen-checkout #billing_email_field {
    order: 13 !important;
    grid-column: span 12 !important
}

.nextgen-checkout .toggle-link-container {
    grid-column: span 12 !important
}

@media (max-width:768px) {
    .nextgen-checkout .woocommerce-billing-fields__field-wrapper>* {
        grid-column: span 12 !important
    }
}

.nextgen-checkout .checkout.woocommerce-checkout .form-row {
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    width: 100% !important;
    clear: none !important;
    transition: all .2s ease !important;
    min-height: auto !important;
    position: relative !important
}

.nextgen-checkout .checkout.woocommerce-checkout label {
    color: #64748b !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    margin-bottom: .5rem !important;
    display: block !important;
    line-height: 1.2 !important;
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    user-select: none !important
}

.nextgen-checkout .checkout.woocommerce-checkout label .required {
    color: #cbd5e1 !important;
    text-decoration: none !important
}

.nextgen-checkout .checkout.woocommerce-checkout input.input-text,
.nextgen-checkout .checkout.woocommerce-checkout select,
.nextgen-checkout .checkout.woocommerce-checkout textarea,
.nextgen-checkout .select2-container--default .select2-selection--single {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: .75rem !important;
    padding: .75rem 1rem !important;
    height: auto !important;
    color: #1e293b !important;
    font-weight: 500 !important;
    font-size: 14.5px !important;
    transition: all .2s ease !important;
    outline: none !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, .05) !important;
    overflow: hidden !important;
    margin-top: 0 !important
}

.nextgen-checkout .checkout.woocommerce-checkout input.input-text:focus,
.nextgen-checkout .checkout.woocommerce-checkout select:focus,
.nextgen-checkout .checkout.woocommerce-checkout textarea:focus,
.nextgen-checkout .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 4px rgba(99, 102, 241, .1) !important
}

.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-invalid .select2-selection--single,
.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-invalid input.input-text,
.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-invalid select {
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
    box-shadow: 0 0 0 4px rgba(239, 68, 68, .1) !important
}

.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-invalid label {
    color: #ef4444 !important
}

.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-validated .select2-selection--single,
.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-validated input.input-text,
.nextgen-checkout .checkout.woocommerce-checkout .woocommerce-validated select {
    border-color: #22c55e !important;
    background-color: #f0fdf4 !important
}

.nextgen-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding: 0 !important;
    line-height: normal !important;
    color: inherit !important;
    display: flex !important;
    align-items: center !important
}

.nextgen-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
    top: 0 !important;
    right: 0 !important;
    width: 20px !important
}

.nextgen-checkout .checkout.woocommerce-checkout input.input-text:focus,
.nextgen-checkout .checkout.woocommerce-checkout select:focus {
    background: transparent !important;
    outline: none !important
}

#toggle-address-2 {
    transition: all .2s ease
}

#toggle-address-2:hover {
    color: #4338ca !important
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translateY(20px)
    }

    to {
        opacity: 1;
        transform: translateY(0)
    }
}

.animate-step {
    animation: fadeInUp .5s ease-out forwards
}

.nextgen-checkout #order_review_heading,
.nextgen-checkout #place_order,
.nextgen-checkout .woocommerce-additional-fields,
.nextgen-checkout .woocommerce-checkout-review-order-table {
    display: none !important
}

.nextgen-checkout .payment-selection-container #payment {
    border-style: none !important;
    background-color: transparent !important;
    padding: 0 !important
}

.nextgen-checkout .payment-selection-container ul.payment_methods {
    border-style: none !important;
    padding: 0 !important
}

.nextgen-checkout .payment-selection-container li.wc_payment_method {
    cursor: pointer !important;
    border-radius: 1.5rem !important;
    border-width: 1px !important;
    --tw-border-opacity: 1 !important;
    border-color: rgb(241 245 249/var(--tw-border-opacity, 1)) !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(248 250 252/var(--tw-bg-opacity, 1)) !important;
    padding: 1.5rem !important;
    transition-property: all !important;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1) !important;
    transition-duration: .15s !important
}

.nextgen-checkout .payment-selection-container li.wc_payment_method:has(input:checked) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(191 219 254/var(--tw-border-opacity, 1)) !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255/var(--tw-bg-opacity, 1)) !important;
    --tw-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1) !important;
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) !important;
    --tw-ring-opacity: 1 !important;
    --tw-ring-color: rgb(239 246 255/var(--tw-ring-opacity, 1)) !important
}

.nextgen-checkout .payment-selection-container .payment_box {
    margin-top: 1rem !important;
    border-radius: 1rem !important;
    border-style: none !important;
    background-color: rgba(241, 245, 249, .5) !important;
    padding: 1rem !important;
    font-size: .75rem !important;
    line-height: 1rem !important;
    --tw-text-opacity: 1 !important;
    color: rgb(100 116 139/var(--tw-text-opacity, 1)) !important
}

[data-step-dot] {
    position: relative;
    z-index: 10
}

[data-step-dot=review]:after {
    display: none !important
}

.checkout-notices-compact .woocommerce-info {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    color: #94a3b8 !important;
    display: flex !important;
    align-items: center !important;
    gap: .5rem !important;
    text-transform: uppercase !important;
    letter-spacing: -.01em !important;
    font-size: 11px !important;
    font-weight: 700 !important
}

.checkout-notices-compact .woocommerce-info:before {
    display: none !important
}

.checkout-notices-compact .woocommerce-info a {
    color: #6366f1 !important;
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
    text-decoration-color: #e0e7ff !important
}

.nextgen-checkout .w-full.lg\:w-3\/5 {
    padding: 2rem 3rem !important
}

.nextgen-checkout .woocommerce-error,
.nextgen-checkout .woocommerce-info,
.nextgen-checkout .woocommerce-message {
    display: block !important;
    background: #fef2f2 !important;
    border-left: 4px solid #ef4444 !important;
    color: #991b1b !important;
    padding: .875rem 1.125rem !important;
    border-radius: .75rem !important;
    margin-bottom: 1.25rem !important;
    font-size: .9rem !important;
    list-style: none !important;
    font-weight: 500 !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .05) !important
}

.nextgen-checkout .woocommerce-info {
    background: #eff6ff !important;
    border-left-color: #3b82f6 !important;
    color: #1e40af !important
}

.nextgen-checkout .woocommerce-message {
    background: #f0fdf4 !important;
    border-left-color: #22c55e !important;
    color: #166534 !important
}

.nextgen-checkout .woocommerce-error li,
.nextgen-checkout .woocommerce-info,
.nextgen-checkout .woocommerce-message {
    display: flex !important;
    width: 100% !important;
    align-items: center !important;
    gap: .75rem !important;
    margin: 0 !important;
    padding: 0 !important
}

/* Specific fix for My Account login/register notices to allow vertical wrapping of long error messages */
.account-panel .woocommerce-error li {
    display: block !important;
}

.nextgen-checkout .woocommerce-error:before {
    display: none !important;
    content: none !important
}

.nextgen-checkout .woocommerce-error li:before,
.nextgen-checkout .woocommerce-info:before,
.nextgen-checkout .woocommerce-message:before {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    border-radius: 50% !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    flex-shrink: 0 !important
}

.nextgen-checkout .woocommerce-error li:before {
    content: "!" !important;
    background: #ef4444 !important;
    color: #fff !important
}

.nextgen-checkout .woocommerce-info:before {
    content: "i" !important;
    background: #3b82f6 !important;
    color: #fff !important
}

.nextgen-checkout .woocommerce-message:before {
    content: "✓" !important;
    background: #22c55e !important;
    color: #fff !important
}

.nextgen-checkout .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-form-login-toggle .woocommerce-info {
    display: block !important;
    text-align: center !important;
    padding: .875rem 1.5rem !important
}

.nextgen-checkout .woocommerce-form-login-toggle .woocommerce-info:before,
.woocommerce-form-login-toggle .woocommerce-info:before {
    display: none !important;
    content: none !important
}

.nextgen-checkout .checkout_coupon,
.nextgen-checkout .login,
.nextgen-checkout .register {
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
    margin-bottom: 0 !important;
    box-shadow: none !important
}

.entry-content.prose {
    line-height: 1.8
}

.entry-content.prose h2 {
    font-size: 1.5rem;
    margin-top: 2.5rem;
    margin-bottom: 1.25rem;
    color: #0f172a
}

.entry-content.prose h3 {
    font-size: 1.25rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: #1e293b
}

.entry-content.prose p {
    margin-bottom: 1.5rem
}

.entry-content.prose ol,
.entry-content.prose ul {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem
}

.entry-content.prose li {
    margin-bottom: .5rem
}

.entry-content.prose strong {
    color: #0f172a
}

.product-gallery .woocommerce-product-gallery {
    opacity: 1 !important;
    display: flex;
    flex-direction: column
}

.product-gallery .woocommerce-product-gallery .flex-viewport {
    height: auto !important;
    background: #f8fafc
}

.dark .product-gallery .woocommerce-product-gallery .flex-viewport {
    background: #0f172a
}

.product-gallery .woocommerce-product-gallery__image {
    background: transparent
}

.product-gallery .woocommerce-product-gallery__image img {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
    -o-object-fit: contain;
    object-fit: contain
}

.product-gallery .flex-control-thumbs {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    margin: 0 !important;
    padding: 1rem !important;
    gap: .75rem;
    background: #fff;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.dark .product-gallery .flex-control-thumbs {
    background: #1e293b
}

.product-gallery .flex-control-thumbs::-webkit-scrollbar {
    display: none
}

.product-gallery .flex-control-thumbs li {
    flex: 0 0 calc(33.333% - 0.5rem) !important;
    width: auto !important;
    float: none !important;
    scroll-snap-align: start;
    clear: none !important;
    margin: 0 !important
}

.product-gallery .flex-control-thumbs li img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16/9;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: .5rem;
    border: 2px solid transparent !important;
    transition: all .2s ease;
    opacity: .5;
    cursor: pointer
}

.dark .product-gallery .flex-control-thumbs li img {
    opacity: .4
}

.product-gallery .flex-control-thumbs li img.flex-active,
.product-gallery .flex-control-thumbs li img:hover {
    opacity: 1 !important;
    border-color: #2563eb !important
}

.woocommerce-order-pay #payment ul.payment_methods {
    border-style: none !important;
    padding: 0 !important
}

.woocommerce-order-pay #payment li.wc_payment_method {
    position: relative !important;
    cursor: pointer !important;
    border-radius: 1.5rem !important;
    border-width: 1px !important;
    --tw-border-opacity: 1 !important;
    border-color: rgb(226 232 240/var(--tw-border-opacity, 1)) !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(248 250 252/var(--tw-bg-opacity, 1)) !important;
    padding: 1.5rem !important;
    transition-property: all !important;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1) !important;
    transition-duration: .15s !important
}

@media (prefers-color-scheme:dark) {
    .woocommerce-order-pay #payment li.wc_payment_method {
        --tw-border-opacity: 1 !important;
        border-color: rgb(51 65 85/var(--tw-border-opacity, 1)) !important;
        background-color: rgba(15, 23, 42, .5) !important
    }
}

.woocommerce-order-pay #payment li.wc_payment_method:has(input:checked) {
    --tw-border-opacity: 1 !important;
    border-color: rgb(147 197 253/var(--tw-border-opacity, 1)) !important;
    --tw-bg-opacity: 1 !important;
    background-color: rgb(255 255 255/var(--tw-bg-opacity, 1)) !important;
    --tw-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1) !important;
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color) !important;
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow) !important;
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000) !important;
    --tw-ring-opacity: 1 !important;
    --tw-ring-color: rgb(239 246 255/var(--tw-ring-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .woocommerce-order-pay #payment li.wc_payment_method:has(input:checked) {
        --tw-border-opacity: 1 !important;
        border-color: rgb(59 130 246/var(--tw-border-opacity, 1)) !important;
        --tw-bg-opacity: 1 !important;
        background-color: rgb(30 41 59/var(--tw-bg-opacity, 1)) !important;
        --tw-ring-color: rgba(30, 58, 138, .3) !important
    }
}

.woocommerce-order-pay #payment .payment_box {
    margin-top: 1rem !important;
    border-radius: 1rem !important;
    border-style: none !important;
    background-color: rgba(241, 245, 249, .5) !important;
    padding: 1.25rem !important;
    font-size: .875rem !important;
    line-height: 1.25rem !important;
    line-height: 1.625 !important;
    --tw-text-opacity: 1 !important;
    color: rgb(71 85 105/var(--tw-text-opacity, 1)) !important
}

@media (prefers-color-scheme:dark) {
    .woocommerce-order-pay #payment .payment_box {
        background-color: rgba(15, 23, 42, .8) !important;
        --tw-text-opacity: 1 !important;
        color: rgb(148 163 184/var(--tw-text-opacity, 1)) !important
    }
}

.woocommerce-order-pay #payment li.wc_payment_method>label {
    margin: 0 !important;
    display: flex !important;
    width: 100% !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 !important;
    font-size: 1.125rem !important;
    line-height: 1.75rem !important;
    font-weight: 700 !important;
    --tw-text-opacity: 1 !important;
    color: rgb(30 41 59/var(--tw-text-opacity, 1)) !important
}

.nextgen-checkout .woocommerce-order-pay #payment li.wc_payment_method>label.lg\:w-3\/5 {
    padding: 2rem 3rem !important
}

@media (prefers-color-scheme:dark) {
    .woocommerce-order-pay #payment li.wc_payment_method>label {
        --tw-text-opacity: 1 !important;
        color: rgb(226 232 240/var(--tw-text-opacity, 1)) !important
    }
}

.woocommerce-order-pay #payment li.wc_payment_method>input[type=radio] {
    pointer-events: none !important;
    position: absolute !important;
    opacity: 0 !important
}

.woocommerce-order-pay #payment li.wc_payment_method .payment-provider-logos {
    display: flex !important;
    flex-shrink: 0 !important;
    align-items: center !important;
    gap: .75rem !important
}

.woocommerce-order-pay #payment li.wc_payment_method .payment-provider-logos img {
    height: 1.5rem !important;
    width: auto !important;
    -o-object-fit: contain !important;
    object-fit: contain !important
}

.marker\:text-primary-400 ::marker {
    color: #60a5fa
}

.marker\:text-primary-500 ::marker {
    color: #3b82f6
}

.marker\:text-primary-400::marker {
    color: #60a5fa
}

.marker\:text-primary-500::marker {
    color: #3b82f6
}

.placeholder\:text-slate-400::-moz-placeholder {
    --tw-text-opacity: 1;
    color: rgb(148 163 184/var(--tw-text-opacity, 1))
}

.placeholder\:text-slate-400::placeholder {
    --tw-text-opacity: 1;
    color: rgb(148 163 184/var(--tw-text-opacity, 1))
}

.hover\:-translate-y-0\.5:hover {
    --tw-translate-y: -0.125rem
}

.hover\:-translate-y-0\.5:hover,
.hover\:-translate-y-1:hover {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:-translate-y-1:hover {
    --tw-translate-y: -0.25rem
}

.hover\:-translate-y-2:hover {
    --tw-translate-y: -0.5rem
}

.hover\:-translate-y-2:hover,
.hover\:rotate-0:hover {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:rotate-0:hover {
    --tw-rotate: 0deg
}

.hover\:scale-105:hover {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:border-primary-200:hover {
    --tw-border-opacity: 1;
    border-color: rgb(191 219 254/var(--tw-border-opacity, 1))
}

.hover\:border-primary-400:hover {
    --tw-border-opacity: 1;
    border-color: rgb(96 165 250/var(--tw-border-opacity, 1))
}

.hover\:border-secondary-200:hover {
    --tw-border-opacity: 1;
    border-color: rgb(167 243 208/var(--tw-border-opacity, 1))
}

.hover\:bg-\[\#0A66C2\]:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(10 102 194/var(--tw-bg-opacity, 1))
}

.hover\:bg-\[\#1DA1F2\]:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(29 161 242/var(--tw-bg-opacity, 1))
}

.hover\:bg-\[\#fee2e2\]:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226/var(--tw-bg-opacity, 1))
}

.hover\:bg-primary-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(219 234 254/var(--tw-bg-opacity, 1))
}

.hover\:bg-primary-200:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(191 219 254/var(--tw-bg-opacity, 1))
}

.hover\:bg-primary-50:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(239 246 255/var(--tw-bg-opacity, 1))
}

.hover\:bg-primary-600:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(37 99 235/var(--tw-bg-opacity, 1))
}

.hover\:bg-primary-700:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(29 78 216/var(--tw-bg-opacity, 1))
}

.hover\:bg-red-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226/var(--tw-bg-opacity, 1))
}

.hover\:bg-red-50:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242/var(--tw-bg-opacity, 1))
}

.hover\:bg-red-700:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(185 28 28/var(--tw-bg-opacity, 1))
}

.hover\:bg-secondary-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(209 250 229/var(--tw-bg-opacity, 1))
}

.hover\:bg-secondary-700:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(4 120 87/var(--tw-bg-opacity, 1))
}

.hover\:bg-slate-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(241 245 249/var(--tw-bg-opacity, 1))
}

.hover\:bg-slate-200:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(226 232 240/var(--tw-bg-opacity, 1))
}

.hover\:bg-slate-50:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(248 250 252/var(--tw-bg-opacity, 1))
}

.hover\:bg-slate-800:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(30 41 59/var(--tw-bg-opacity, 1))
}

.hover\:text-\[\#334155\]:hover {
    --tw-text-opacity: 1;
    color: rgb(51 65 85/var(--tw-text-opacity, 1))
}

.hover\:text-primary-300:hover {
    --tw-text-opacity: 1;
    color: rgb(147 197 253/var(--tw-text-opacity, 1))
}

.hover\:text-primary-600:hover {
    --tw-text-opacity: 1;
    color: rgb(37 99 235/var(--tw-text-opacity, 1))
}

.hover\:text-primary-700:hover {
    --tw-text-opacity: 1;
    color: rgb(29 78 216/var(--tw-text-opacity, 1))
}

.hover\:text-red-800:hover {
    --tw-text-opacity: 1;
    color: rgb(153 27 27/var(--tw-text-opacity, 1))
}

.hover\:text-slate-600:hover {
    --tw-text-opacity: 1;
    color: rgb(71 85 105/var(--tw-text-opacity, 1))
}

.hover\:text-slate-700:hover {
    --tw-text-opacity: 1;
    color: rgb(51 65 85/var(--tw-text-opacity, 1))
}

.hover\:text-white:hover {
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity, 1))
}

.hover\:underline:hover {
    text-decoration-line: underline
}

.hover\:shadow-lg:hover {
    --tw-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color)
}

.hover\:shadow-lg:hover,
.hover\:shadow-md:hover {
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.hover\:shadow-md:hover {
    --tw-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color)
}

.hover\:shadow-xl:hover {
    --tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.focus\:border-primary-500:focus {
    --tw-border-opacity: 1;
    border-color: rgb(59 130 246/var(--tw-border-opacity, 1))
}

.focus\:outline-none:focus {
    outline: 2px solid transparent;
    outline-offset: 2px
}

.focus\:ring-2:focus {
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)
}

.focus\:ring-2:focus,
.focus\:ring-4:focus {
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)
}

.focus\:ring-4:focus {
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color)
}

.focus\:ring-primary-500:focus {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(59 130 246/var(--tw-ring-opacity, 1))
}

.focus\:ring-primary-500\/10:focus {
    --tw-ring-color: rgba(59, 130, 246, .1)
}

.focus\:ring-red-500:focus {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(239 68 68/var(--tw-ring-opacity, 1))
}

.focus\:ring-secondary-500:focus {
    --tw-ring-opacity: 1;
    --tw-ring-color: rgb(16 185 129/var(--tw-ring-opacity, 1))
}

.focus\:ring-offset-2:focus {
    --tw-ring-offset-width: 2px
}

.active\:scale-95:active {
    --tw-scale-x: .95;
    --tw-scale-y: .95
}

.active\:scale-95:active,
.group[open] .group-open\:rotate-180 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group[open] .group-open\:rotate-180 {
    --tw-rotate: 180deg
}

.group:focus-within .group-focus-within\:text-primary-500 {
    --tw-text-opacity: 1;
    color: rgb(59 130 246/var(--tw-text-opacity, 1))
}

.group:hover .group-hover\:-translate-x-1 {
    --tw-translate-x: -0.25rem
}

.group:hover .group-hover\:-translate-x-1,
.group:hover .group-hover\:translate-x-1 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group:hover .group-hover\:translate-x-1 {
    --tw-translate-x: 0.25rem
}

.group:hover .group-hover\:rotate-180 {
    --tw-rotate: 180deg
}

.group:hover .group-hover\:rotate-180,
.group:hover .group-hover\:scale-105 {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.group:hover .group-hover\:scale-105 {
    --tw-scale-x: 1.05;
    --tw-scale-y: 1.05
}

.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)) skewX(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-600 {
    --tw-text-opacity: 1;
    color: rgb(37 99 235/var(--tw-text-opacity, 1))
}

.group:hover .group-hover\:opacity-100 {
    opacity: 1
}

@media (min-width:640px) {
    .sm\:inline {
        display: inline
    }

    .sm\:flex {
        display: flex
    }

    .sm\:w-auto {
        width: auto
    }

    .sm\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .sm\:flex-row {
        flex-direction: row
    }

    .sm\:justify-end {
        justify-content: flex-end
    }

    .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem
    }

    .sm\:text-right {
        text-align: right
    }

    .sm\:text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem
    }
}

@media (min-width:768px) {
    .md\:col-span-1 {
        grid-column: span 1/span 1
    }

    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }

    .md\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    .md\:flex-row {
        flex-direction: row
    }

    .md\:items-center {
        align-items: center
    }

    .md\:p-10 {
        padding: 2.5rem
    }

    .md\:p-16 {
        padding: 4rem
    }

    .md\:p-8 {
        padding: 2rem
    }

    .md\:px-12 {
        padding-left: 3rem;
        padding-right: 3rem
    }

    .md\:py-32 {
        padding-top: 8rem;
        padding-bottom: 8rem
    }

    .md\:pt-14 {
        padding-top: 3.5rem
    }

    .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
    }

    .md\:text-6xl {
        font-size: 3.75rem;
        line-height: 1
    }
}

@media (min-width:1024px) {
    .lg\:sticky {
        position: sticky
    }

    .lg\:top-12 {
        top: 3rem
    }

    .lg\:top-24 {
        top: 6rem
    }

    .lg\:order-2 {
        order: 2
    }

    .lg\:order-3 {
        order: 3
    }

    .lg\:col-span-4 {
        grid-column: span 4/span 4
    }

    .lg\:col-span-5 {
        grid-column: span 5/span 5
    }

    .lg\:col-span-6 {
        grid-column: span 6/span 6
    }

    .lg\:col-span-7 {
        grid-column: span 7/span 7
    }

    .lg\:row-span-2 {
        grid-row: span 2/span 2
    }

    .lg\:mx-0 {
        margin-left: 0;
        margin-right: 0
    }

    .lg\:flex {
        display: flex
    }

    .lg\:hidden {
        display: none
    }

    .lg\:w-1\/2 {
        width: 50%
    }

    .lg\:w-80 {
        width: 20rem
    }

    .lg\:scale-105 {
        --tw-scale-x: 1.05;
        --tw-scale-y: 1.05;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
    }

    .lg\:grid-cols-10 {
        grid-template-columns: repeat(10, minmax(0, 1fr))
    }

    .lg\:grid-cols-12 {
        grid-template-columns: repeat(12, minmax(0, 1fr))
    }

    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }

    .lg\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }

    .lg\:flex-row {
        flex-direction: row
    }

    .lg\:justify-start {
        justify-content: flex-start
    }

    .lg\:gap-10 {
        gap: 2.5rem
    }

    .lg\:gap-4 {
        gap: 1rem
    }

    .lg\:px-4 {
        padding-left: 1rem;
        padding-right: 1rem
    }

    .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem
    }

    .lg\:py-16 {
        padding-top: 4rem;
        padding-bottom: 4rem
    }

    .lg\:py-24 {
        padding-top: 6rem;
        padding-bottom: 6rem
    }

    .lg\:text-left {
        text-align: left
    }

    .lg\:text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem
    }

    .lg\:text-5xl {
        font-size: 3rem;
        line-height: 1
    }

    .lg\:text-6xl {
        font-size: 3.75rem;
        line-height: 1
    }

    .lg\:text-7xl {
        font-size: 4.5rem;
        line-height: 1
    }
}

@media (min-width:1280px) {
    .xl\:w-96 {
        width: 24rem
    }
}

@media (prefers-color-scheme:dark) {
    .dark\:divide-slate-700>:not([hidden])~:not([hidden]) {
        --tw-divide-opacity: 1;
        border-color: rgb(51 65 85/var(--tw-divide-opacity, 1))
    }

    .dark\:divide-slate-700\/50>:not([hidden])~:not([hidden]) {
        border-color: rgba(51, 65, 85, .5)
    }

    .dark\:border-amber-700\/50 {
        border-color: rgba(180, 83, 9, .5)
    }

    .dark\:border-green-800 {
        --tw-border-opacity: 1;
        border-color: rgb(22 101 52/var(--tw-border-opacity, 1))
    }

    .dark\:border-green-900\/30 {
        border-color: rgba(20, 83, 45, .3)
    }

    .dark\:border-primary-800 {
        --tw-border-opacity: 1;
        border-color: rgb(30 64 175/var(--tw-border-opacity, 1))
    }

    .dark\:border-red-900\/30 {
        border-color: rgba(127, 29, 29, .3)
    }

    .dark\:border-slate-600 {
        --tw-border-opacity: 1;
        border-color: rgb(71 85 105/var(--tw-border-opacity, 1))
    }

    .dark\:border-slate-700 {
        --tw-border-opacity: 1;
        border-color: rgb(51 65 85/var(--tw-border-opacity, 1))
    }

    .dark\:border-slate-700\/50 {
        border-color: rgba(51, 65, 85, .5)
    }

    .dark\:border-slate-700\/60 {
        border-color: rgba(51, 65, 85, .6)
    }

    .dark\:border-slate-800 {
        --tw-border-opacity: 1;
        border-color: rgb(30 41 59/var(--tw-border-opacity, 1))
    }

    .dark\:bg-amber-900\/20 {
        background-color: rgba(120, 53, 15, .2)
    }

    .dark\:bg-amber-900\/30 {
        background-color: rgba(120, 53, 15, .3)
    }

    .dark\:bg-blue-900\/30 {
        background-color: rgba(30, 58, 138, .3)
    }

    .dark\:bg-emerald-900\/30 {
        background-color: rgba(6, 78, 59, .3)
    }

    .dark\:bg-green-900\/10 {
        background-color: rgba(20, 83, 45, .1)
    }

    .dark\:bg-green-900\/30 {
        background-color: rgba(20, 83, 45, .3)
    }

    .dark\:bg-green-900\/40 {
        background-color: rgba(20, 83, 45, .4)
    }

    .dark\:bg-primary-500\/5 {
        background-color: rgba(59, 130, 246, .05)
    }

    .dark\:bg-primary-600 {
        --tw-bg-opacity: 1;
        background-color: rgb(37 99 235/var(--tw-bg-opacity, 1))
    }

    .dark\:bg-primary-900\/30 {
        background-color: rgba(30, 58, 138, .3)
    }

    .dark\:bg-primary-900\/40 {
        background-color: rgba(30, 58, 138, .4)
    }

    .dark\:bg-primary-900\/50 {
        background-color: rgba(30, 58, 138, .5)
    }

    .dark\:bg-purple-900\/30 {
        background-color: rgba(88, 28, 135, .3)
    }

    .dark\:bg-red-900\/10 {
        background-color: rgba(127, 29, 29, .1)
    }

    .dark\:bg-slate-700 {
        --tw-bg-opacity: 1;
        background-color: rgb(51 65 85/var(--tw-bg-opacity, 1))
    }

    .dark\:bg-slate-700\/20 {
        background-color: rgba(51, 65, 85, .2)
    }

    .dark\:bg-slate-700\/50 {
        background-color: rgba(51, 65, 85, .5)
    }

    .dark\:bg-slate-800 {
        --tw-bg-opacity: 1;
        background-color: rgb(30 41 59/var(--tw-bg-opacity, 1))
    }

    .dark\:bg-slate-800\/20 {
        background-color: rgba(30, 41, 59, .2)
    }

    .dark\:bg-slate-800\/50 {
        background-color: rgba(30, 41, 59, .5)
    }

    .dark\:bg-slate-800\/80 {
        background-color: rgba(30, 41, 59, .8)
    }

    .dark\:bg-slate-900\/50 {
        background-color: rgba(15, 23, 42, .5)
    }

    .dark\:from-slate-800 {
        --tw-gradient-from: #1e293b var(--tw-gradient-from-position);
        --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position);
        --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .dark\:from-slate-800\/80 {
        --tw-gradient-from: rgba(30, 41, 59, .8) var(--tw-gradient-from-position);
        --tw-gradient-to: rgba(30, 41, 59, 0) var(--tw-gradient-to-position);
        --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .dark\:to-slate-800\/90 {
        --tw-gradient-to: rgba(30, 41, 59, .9) var(--tw-gradient-to-position)
    }

    .dark\:to-slate-900\/50 {
        --tw-gradient-to: rgba(15, 23, 42, .5) var(--tw-gradient-to-position)
    }

    .dark\:text-amber-300 {
        --tw-text-opacity: 1;
        color: rgb(252 211 77/var(--tw-text-opacity, 1))
    }

    .dark\:text-amber-400 {
        --tw-text-opacity: 1;
        color: rgb(251 191 36/var(--tw-text-opacity, 1))
    }

    .dark\:text-blue-400 {
        --tw-text-opacity: 1;
        color: rgb(96 165 250/var(--tw-text-opacity, 1))
    }

    .dark\:text-emerald-400 {
        --tw-text-opacity: 1;
        color: rgb(52 211 153/var(--tw-text-opacity, 1))
    }

    .dark\:text-green-300 {
        --tw-text-opacity: 1;
        color: rgb(134 239 172/var(--tw-text-opacity, 1))
    }

    .dark\:text-green-400 {
        --tw-text-opacity: 1;
        color: rgb(74 222 128/var(--tw-text-opacity, 1))
    }

    .dark\:text-primary-300 {
        --tw-text-opacity: 1;
        color: rgb(147 197 253/var(--tw-text-opacity, 1))
    }

    .dark\:text-primary-400 {
        --tw-text-opacity: 1;
        color: rgb(96 165 250/var(--tw-text-opacity, 1))
    }

    .dark\:text-purple-400 {
        --tw-text-opacity: 1;
        color: rgb(192 132 252/var(--tw-text-opacity, 1))
    }

    .dark\:text-red-300 {
        --tw-text-opacity: 1;
        color: rgb(252 165 165/var(--tw-text-opacity, 1))
    }

    .dark\:text-red-400 {
        --tw-text-opacity: 1;
        color: rgb(248 113 113/var(--tw-text-opacity, 1))
    }

    .dark\:text-slate-200 {
        --tw-text-opacity: 1;
        color: rgb(226 232 240/var(--tw-text-opacity, 1))
    }

    .dark\:text-slate-300 {
        --tw-text-opacity: 1;
        color: rgb(203 213 225/var(--tw-text-opacity, 1))
    }

    .dark\:text-slate-400 {
        --tw-text-opacity: 1;
        color: rgb(148 163 184/var(--tw-text-opacity, 1))
    }

    .dark\:text-slate-500 {
        --tw-text-opacity: 1;
        color: rgb(100 116 139/var(--tw-text-opacity, 1))
    }

    .dark\:text-white {
        --tw-text-opacity: 1;
        color: rgb(255 255 255/var(--tw-text-opacity, 1))
    }

    .dark\:hover\:bg-primary-500:hover {
        --tw-bg-opacity: 1;
        background-color: rgb(59 130 246/var(--tw-bg-opacity, 1))
    }

    .dark\:hover\:bg-primary-600:hover {
        --tw-bg-opacity: 1;
        background-color: rgb(37 99 235/var(--tw-bg-opacity, 1))
    }

    .dark\:hover\:bg-primary-900:hover {
        --tw-bg-opacity: 1;
        background-color: rgb(30 58 138/var(--tw-bg-opacity, 1))
    }

    .dark\:hover\:bg-slate-700:hover {
        --tw-bg-opacity: 1;
        background-color: rgb(51 65 85/var(--tw-bg-opacity, 1))
    }

    .dark\:hover\:bg-slate-700\/50:hover {
        background-color: rgba(51, 65, 85, .5)
    }

    .dark\:hover\:text-primary-400:hover,
    .group:hover .dark\:group-hover\:text-primary-400 {
        --tw-text-opacity: 1;
        color: rgb(96 165 250/var(--tw-text-opacity, 1))
    }
}

.\[\&_summary\:\:-webkit-details-marker\]\:hidden summary::-webkit-details-marker {
    display: none
}

/* Extra Product Options Styling */
.evp-purchase-actions .tm-extra-product-options input[type="text"],
.evp-purchase-actions .tm-extra-product-options input[type="password"],
.evp-purchase-actions .tm-extra-product-options input[type="email"],
.evp-purchase-actions .tm-extra-product-options textarea,
.evp-purchase-actions .tm-extra-product-options select {
    width: 100%;
    padding: 0.75rem 1rem;
    background-color: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 0.75rem;
    color: #0f172a;
    outline: none;
    transition: all 0.2s ease;
    margin-bottom: 0.5rem;
}

.evp-purchase-actions .tm-extra-product-options input:focus,
.evp-purchase-actions .tm-extra-product-options textarea:focus,
.evp-purchase-actions .tm-extra-product-options select:focus {
    background-color: #ffffff;
    border-color: #3b82f6;
    box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.1)
}

.dark .evp-purchase-actions .tm-extra-product-options input,
.dark .evp-purchase-actions .tm-extra-product-options textarea,
.dark .evp-purchase-actions .tm-extra-product-options select {
    background-color: #1e293b;
    border-color: #334155;
    color: #f8fafc
}

.evp-purchase-actions .tm-extra-product-options .tc-element-inner-wrap {
    margin-bottom: 0.75rem;
}