/***************************************
* Body text & Permalink
****************************************/
html:not(.wp-toolbar) body {
    color:var(--vii-color-text);
    background:var(--vii-color-bg);
    font-family:var(--vii-font-primary), sans-serif;
    font-size:var(--vii-size-body-normal);
    line-height:1.5; font-weight:500;
}
a, button {
    color:var(--vii-color-text);
    transition:var(--vii-transition);
}
a:hover, a:focus {color:var(--vii-color-permalink-highlight);}

/* Permalink */
.mceContentBody a:not([class*="btn_"]),
.wpb_text_column a:not([class*="btn_"]) {
    text-decoration:underline;
    color:var(--vii-color-permalink);
    /* font-weight:500; */
}
.mceContentBody a:not([class*="btn_"]):hover,
.mceContentBody a:not([class*="btn_"]):focus,
.mceContentBody a:not([class*="btn_"]):active,
.wpb_text_column a:not([class*="btn_"]):hover,
.wpb_text_column a:not([class*="btn_"]):focus,
.wpb_text_column a:not([class*="btn_"]):active {
    color:var(--vii-color-permalink-highlight); outline:0;
}

.wpb_text_column a[href^="mailto"],
.wpb_text_column a[href^="tel"] {text-decoration:none;}

/***************************************
* Headings
****************************************/
.mceContentBody h1, .mceContentBody h2, .mceContentBody h3, .mceContentBody h4, .mceContentBody h5, .mceContentBody h6,
.main_content h1, .main_content h2, .main_content h3, .main_content h4, .main_content h5, .main_content h6,
.main_content .heading_1, .main_content .heading_2, .main_content .heading_3, .main_content .heading_4, .main_content .heading_5, .main_content .heading_6,
.heading_1, .heading_2, .heading_3, .heading_4, .heading_5, .heading_6 {
    color:var(--vii-color-heading); margin-bottom:var(--vii-spacing-heading);
    font-family:var(--vii-font-primary), sans-serif; line-height:1.1; font-weight:300;
    letter-spacing:0.05em;
}
.mceContentBody h1, .main_content h1, .main_content .heading_1, .heading_1 {font-size:var(--vii-size-h1);}
.mceContentBody h2, .main_content h2, .main_content .heading_2, .heading_2 {font-size:var(--vii-size-h2); line-height:1.2; letter-spacing:0.02em;}
.mceContentBody h3, .main_content h3, .main_content .heading_3, .heading_3 {font-size:var(--vii-size-h3); line-height:1.25; letter-spacing:0;}
.mceContentBody h4, .main_content h4, .main_content .heading_4, .heading_4 {font-size:var(--vii-size-h4); line-height:1.2; letter-spacing:0.02em;}
.mceContentBody h5, .main_content h5, .main_content .heading_5, .heading_5 {font-size:var(--vii-size-h5); line-height:1.4; letter-spacing:0.02em; font-weight:500;}
.mceContentBody h6, .main_content h6, .main_content .heading_6, .heading_6 {font-size:var(--vii-size-h6); line-height:1.4; letter-spacing:0.02em; font-weight:500;}

/* override classes display block to respect line height */
h1 [class*="heading_"],
h2 [class*="heading_"],
h3 [class*="heading_"],
h4 [class*="heading_"],
h5 [class*="heading_"],
h6 [class*="heading_"] {display:block;}

/***************************************
* Text format
****************************************/
.txt_subtitle {
    font-weight:700; text-transform:uppercase;
    letter-spacing:0.05em;
    color:var(--vii-color-primary);
}
.txt_color_white .txt_subtitle {color:var(--vii-color-text-primary-900-dark); opacity:.5;}

.txt_size_body_small {font-size:var(--vii-size-body-small); letter-spacing:0.04em; line-height:1.7; font-weight:700;}
.txt_size_body_normal {font-size:var(--vii-size-body-normal);}
.txt_size_body_large {font-size:var(--vii-size-body-large);}

/* White turns gray if is inside Editor */
body[class*="wp-editor"] {--vii-color-white:#ccc;}

/* Colors */
.txt_color_white {color:var(--vii-color-text-primary-900-dark);}
.txt_color_black {color:var(--vii-color-black);}
.txt_color_primary {color:var(--vii-color-primary);}


/* Alignments */
.txt_group {display:inline-block;}
.txt_uppercase {text-transform:uppercase;}


/***************************************
* Buttons
****************************************/
a.btn_primary {}

/* button primary */
[class*="btn_primary"] {
    --btn-bg-color:var(--vii-color-black); --btn-color:var(--vii-color-white);
    --btn-color-hover:var(--vii-color-white);
    --btn-height:43px;

    display:inline-flex; align-items:center; justify-content:center; gap:5px 10px;
    position:relative; overflow:hidden;
    font-weight:700; font-size:12px; letter-spacing:0.06em; text-decoration:none; text-transform:uppercase;
    background:var(--btn-bg-color); color:var(--btn-color);
    padding:5px 20px; min-height:var(--btn-height); min-width:140px; border-radius:var(--btn-height);
}
[class*="btn_primary"]:after {
    font-family:var(--vii-font-icomoon), fantasy; content:"\e925";
    line-height:1; font-size:10px;
}
[class*="btn_primary"]:hover, [class*="btn_primary"]:focus {text-decoration:none; color:var(--btn-color-hover);}
[class*="btn_primary"]:focus-visible {border-radius:var(--btn-height);}


/***************************************
* List
****************************************/
/* Default unordered list for text block */
.mceContentBody ul,
.wpb_text_column ul {list-style:none; margin:0;}
.wpb_text_column ul ul {padding-top:15px;}

.mceContentBody ul:not(:last-child),
.wpb_text_column ul:not(:last-child) {margin-bottom:var(--vii-spacing-paragraph);}

.mceContentBody ul > li,
.wpb_text_column ul > li {padding:0 0 0 18px; position:relative;}

.mceContentBody ul > li:not(:last-child),
.wpb_text_column ul > li:not(:last-child) {margin-bottom:15px;}

.mceContentBody ul > li:before,
.wpb_text_column ul > li:before {
    content:""; position:absolute; top:.4em; left:0;
    width:6px; height:6px; border-radius:50px;
    border:2px solid var(--vii-color-primary);
}

.mceContentBody ul ul > li:before,
.wpb_text_column ul ul > li:before {background:#fff;}


/***************************************
* Paragraph
****************************************/
.mceContentBody p:not(:last-child), .main_content p:not(:last-child) {margin-bottom:var(--vii-spacing-paragraph);}

/* large spacing */
p.with_large_spacing {--vii-spacing-paragraph:var(--vii-spacing-48);}

/* black bg */
p.bg_black {
    --vii-color-heading:var(--vii-color-text-primary-900-dark);

    background:var(--vii-color-black); color:var(--vii-color-text-primary-900-dark);
    padding:clamp(20px, 5vw, var(--vii-spacing-48));
}
p.bg_black [class*="heading_"] {padding-top:var(--vii-spacing-32); display:inline-block; margin-bottom:0;}

/***************************************
* Table
****************************************/
.mceContentBody table, .main_content table {margin-bottom:var(--vii-spacing-paragraph);}

/* table no border */
table.no_border {}
table.no_border tr td {width:auto !important; border:1px dashed #ccc;}
.main_content table.no_border tr {border:none !important; background:unset !important;}
.main_content table.no_border tr td {
    height:auto !important;
    vertical-align:middle;

    /* clear style from default table */
    padding:0 20px 0 0; border:none !important; background:unset !important; display:inline-block;
}
.main_content table.no_border tr:not(:last-child) td {padding-bottom:var(--vii-spacing-10);}


/***************************************
* HR tag
****************************************/
.mceContentBody hr, .main_content hr {margin-bottom:var(--vii-spacing-paragraph);}


/***************************************
* Editor Image
****************************************/
/* Image tag: with and without caption */
.wpb_text_column :where(p > img, .wp-caption > img) {margin-bottom:0;}

/* With-caption wrapper */
.wp-caption {width:fit-content; margin-bottom:var(--vii-spacing-paragraph);}

/* Has link */
/* Single image with link only have hover effect if inside site-content */
.mceContentBody .wp-caption a,
.site-content .wp-caption a {display:block; position:relative; overflow:hidden;}
.mceContentBody .wp-caption a:before,
.site-content .wp-caption a:before {
    content:"";
    position:absolute; inset:0; z-index:1; background:#000; opacity:0;
    transition:opacity .3s ease;
}
.mceContentBody .wp-caption a img,
.site-content .wp-caption a img {width:100%; transition:transform .3s ease;}
.mceContentBody .wp-caption a:hover:before,
.site-content .wp-caption a:hover:before {opacity:.3;}
.mceContentBody .wp-caption a:hover img,
.site-content .wp-caption a:hover img {transform:scale(1.02);}

/* Alignment */
.wp-caption.alignleft .wp-caption-text,
.wp-caption.alignleft .wp-caption-dd {text-align:left;}
.wp-caption.aligncenter .wp-caption-text,
.wp-caption.aligncenter .wp-caption-dd {text-align:center;}
.wp-caption.alignright .wp-caption-text,
.wp-caption.alignright .wp-caption-dd {text-align:right;}

/* Caption text */
.wp-caption-text {padding-top:5px;}