/****************************
 * Global style
*****************************/
/* Main sections */
.site-sticky {position:fixed; z-index:40; top:0; left:0; right:0;}
.site-header {position:relative; z-index:30;}
.site-content {position:relative; z-index:20;}
.site-footer {position:relative; z-index:10;}

/* Footer stick to bottom */
html, body {min-height:100vh;}
body {
    display:-webkit-box; display:-webkit-flex; display:-ms-flexbox; display:flex;
    -webkit-box-orient:vertical; -webkit-box-direction:normal; -webkit-flex-direction:column; -ms-flex-direction:column; flex-direction:column;
    -webkit-box-pack:justify; -webkit-justify-content:space-between; -ms-flex-pack:justify; justify-content:space-between;
}

/* Disables pull-to-refresh and overscroll glow effect.
Still keeps swipe navigations. */
body {
    overscroll-behavior-y:none;
}

/* Admin bar */
html.has-admin-bar {--admin-bar-height:32px;}
@media screen and (max-width:782px) {
    html.has-admin-bar {
        --admin-bar-height:0px;
        margin-top:0 !important;
    }
    html #wpadminbar {display:none;}
}

/* Admin bar can cause conflict with Woocommerce Selector (select-2 dropdown) */
/* Move a little bit, equal with wp-admin bar height */
body.admin-bar .select2-container--open .select2-dropdown {margin-top:-32px;}


/****************************
 * Editor style
****************************/
p:empty {display:none;}

/* Button group */
p.vii-button-group {display:flex; flex-wrap:wrap; gap:8px 11px;}
p[style*="text-align:center"].vii-button-group,
p[style*="text-align: center"].vii-button-group {justify-content:center;}

/* Force white text color */
.txt_color_white {
    --vii-color-heading:var(--vii-color-white);
    --vii-color-permalink:var(--vii-color-white);
    --vii-color-permalink-highlight:var(--vii-color-primary-highlight);
}

/* Text color */
.main_content .txt_color_primary {color:var(--vii-color-primary);}

/* Text alignment */
.txt_inline_block {display:inline-block;}
.txt_italic {font-style:italic;}
.txt_center_justify {text-align:justify; -moz-text-align-last:center; text-align-last:center; display:block;}

/* permalink > word break to avoid horizontal scroll */
.wpb_text_column p a:not([class]) {word-wrap:break-word;}

/* limit line */
[class*="vii-max-lines-"] {display:-webkit-box;-webkit-box-orient:vertical; overflow:hidden;}
.vii-max-lines-2 {-webkit-line-clamp:2;}
.vii-max-lines-3 {-webkit-line-clamp:3;}
.vii-max-lines-4 {-webkit-line-clamp:4;}
.vii-max-lines-10 {-webkit-line-clamp:10;}
.vii-max-lines-15 {-webkit-line-clamp:15;}

/* spacing */
.wpb_text_column p:has(.txt_highlight_heading_1) {--vii-spacing-paragraph:0;}
.wpb_text_column p:has(.txt_highlight_heading_1):not(:first-child),
.wpb_text_column [class*="txt_highlight_heading_"] + [class*="heading_"] {margin-top:-8px;}
.wpb_text_column p:has([class*="btn_primary"]):not(:first-child) {margin-top:28px;}
.wpb_text_column span[class*="heading_"] > span[class*="txt_highlight_heading_"] {padding-top:8px;}

@media only screen and (max-width:480px) {
    .wpb_text_column p:has(.txt_highlight_heading_1):not(:first-child),
    .wpb_text_column [class*="txt_highlight_heading_"] + [class*="heading_"] {margin-top:-4px;}
    .wpb_text_column span[class*="heading_"] > span[class*="txt_highlight_heading_"] {padding-top:4px;}
}

/****************************
 * Spacing
****************************/
/* the last element in a text block will have no spacing */
.wpb_text_column :last-child {margin-bottom:0;}

/* Spacing: Custom */
.no-margin-bottom {margin-bottom:0 !important;}
.margin-bottom-default {margin-bottom:var(--vii-spacing-default) !important;}
.margin-bottom-heading {margin-bottom:var(--vii-spacing-heading) !important;}
.margin-bottom-8px {margin-bottom:var(--vii-spacing-8) !important;}
.margin-bottom-12px {margin-bottom:var(--vii-spacing-12) !important;}
.margin-bottom-16px {margin-bottom:var(--vii-spacing-16) !important;}
.margin-bottom-20px {margin-bottom:var(--vii-spacing-20) !important;}
.margin-bottom-24px {margin-bottom:var(--vii-spacing-24) !important;}
.margin-bottom-40px {margin-bottom:var(--vii-spacing-40) !important;}
.margin-bottom-50px {margin-bottom:var(--vii-spacing-50) !important;}
.margin-bottom-56px {margin-bottom:var(--vii-spacing-56) !important;}
.margin-bottom-64px {margin-bottom:var(--vii-spacing-64) !important;}
.margin-bottom-72px {margin-bottom:var(--vii-spacing-72) !important;}
.margin-bottom-80px {margin-bottom:var(--vii-spacing-80) !important;}
.margin-bottom-96px {margin-bottom:var(--vii-spacing-96) !important;}
.margin-bottom-120px {margin-bottom:var(--vii-spacing-120) !important;}

.pt-default {padding-top:var(--vii-spacing-default);}
.pt-heading {padding-top:var(--vii-spacing-heading);}


/****************************
 * Miscellaneous
****************************/
/* Visibility Classes */
.hidden-mobile, .hidden-tablet-v, .hidden-tablet-h, .hidden-touch-devices {display:block;}
.show-mobile, .show-tablet-v, .show-tablet-h, .show-touch-devices {display:none;}

/****************************
 * Visibility Classes Responsive
****************************/
/* Touch devices */
@media only screen and (max-width:1180px) {
    /* Visibility Classes */
    .hidden-touch-devices {display:none;}
    .show-touch-devices {display:block;}
}

/* Tablet horizontal */
@media only screen and (max-width:1024px) {
    /* Visibility Classes */
    .hidden-tablet-h {display:none;}
    .show-tablet-h {display:block;}
}

/* Tablet vertical */
@media only screen and (max-width:768px) {
    /* Visibility Classes */
    .hidden-tablet-v {display:none;}
    .show-tablet-v {display:block;}
}

/* Mobile */
@media only screen and (max-width:480px) {
    /* Visibility Classes */
    .hidden-mobile {display:none;}
    .show-mobile {display:block;}
}

/* Full width */
.vii-full-width {margin-left:calc(-1 * var(--vii-gap-side) - 0.5px); margin-right:calc(-1 * var(--vii-gap-side));}

/* Background color */
.vii-bg-primary {background-color:var(--vii-color-primary); color:var(--vii-color-on-primary);}

/* A11y focus */
a:focus-visible,
button:focus-visible,
.a11y-focus:focus-visible {outline:2px solid var(--vii-color-primary); border-radius:3px; transition:none;}

/* disabled focus visible */
.a11y-disable a:focus-visible,
.a11y-disable button:focus-visible,
.a11y-disable:focus-visible {outline:none; border-radius:0;}

/* focus visible inset */
.a11y-focus-inset, .a11y-focus-inset a, .a11y-focus-inset button {position:relative;}
.a11y-focus-inset:focus-visible,
.a11y-focus-inset a:focus-visible, .a11y-focus-inset button:focus-visible {outline:none;}
.a11y-focus-inset:focus-visible:after,
.a11y-focus-inset a:focus-visible:after, .a11y-focus-inset button:focus-visible:after {
    content:""; z-index:1; position:absolute;
    inset:0; pointer-events:none; border:2px solid var(--vii-color-primary); border-radius:3px;
}

/* radius */
.vii-radius-4 {border-radius:var(--vii-radius-4);}
.vii-radius-8 {border-radius:var(--vii-radius-8);}
.vii-radius-12 {border-radius:var(--vii-radius-12);}

/* custom scrollbar */
/* Works on Chrome, Edge, and Safari */
body::-webkit-scrollbar,
.vii-custom-scroll-bar::-webkit-scrollbar {width:var(--vii-scroll-bar-width);}
body::-webkit-scrollbar-track,
.vii-custom-scroll-bar::-webkit-scrollbar-track {background:var(--vii-color-light-pink-1);}
body::-webkit-scrollbar-thumb,
.vii-custom-scroll-bar::-webkit-scrollbar-thumb {background-color:var(--vii-color-primary);}

/* Hover effect for image */
.vii-hover-image {position:relative; overflow:hidden;}
.vii-hover-image:before {
    content:"";
    position:absolute; inset:0; background:var(--vii-color-black); z-index:1; pointer-events:none;
    opacity:0; transition:opacity 0.3s;
}
.vii-hover-image img {transition:transform 0.3s;}
.hover-trigger:is(:hover, :focus) .vii-hover-image:before,
a.vii-hover-image:is(:hover, :focus):before, a:is(:hover, :focus) .vii-hover-image:before {opacity:0.3;}
.hover-trigger:is(:hover, :focus) .vii-hover-image img,
a.vii-hover-image:is(:hover, :focus) img, a:is(:hover, :focus) .vii-hover-image img {transform:scale(1.05);}


/****************************
 * Sticky element
****************************/
body .vii-sticky, body .vii-sticky-desktop-only {
    --offset:20px;
    --extra-offset:var(--admin-bar-height, 0px);

    position:sticky; left:0;
    top:calc(var(--extra-offset) + var(--offset));
    transition:var(--vii-transition);
}

/* follow breakpoint of VC */
@media only screen and (max-width:767px) {
    body .vii-sticky-desktop-only {position:static; top:unset;}
}

/****************************
 * truncate
****************************/
.truncate {
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
/* Hidden */
.hidden {display:none;}

/****************************
 * Shape Image
****************************/
.vii-mask {
    --mask-w:100%;
    --mask-ratio:1;
    --mask-url:none;

    width:var(--mask-w); aspect-ratio:var(--mask-ratio);
    -webkit-mask-image:var(--mask-url);
    mask-image:var(--mask-url);
    -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
    -webkit-mask-size:cover;mask-size:cover;
}


