/* 
Theme Name:		 Legendary Toolkit Child
Theme URI:		 http://childtheme-generator.com/
Description:	 Legendary Toolkit Child is a child theme of Legendary Toolkit
Author:			 Legendary Lion
Author URI:		 http://childtheme-generator.com/
Template:		 legendary-toolkit
Version:		 1.0.6
Text Domain:	 legendary-toolkit-child
*/

/* ==========================================================================
   TYPOGRAPHY SYSTEM - Self-hosted fonts
   ========================================================================== */
@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('./assets/fonts/poppins/poppins-600.woff2') format('woff2');
}

@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('./assets/fonts/poppins/poppins-700.woff2') format('woff2');
}

@font-face {
    font-family: 'Poppins';
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url('./assets/fonts/poppins/poppins-900.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('./assets/fonts/inter/inter-400.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('./assets/fonts/inter/inter-500.woff2') format('woff2');
}

@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url('./assets/fonts/inter/inter-600.woff2') format('woff2');
}

:root {
    /* Role A: Brand/Hero - Poppins 900 uppercase */
    --brand-weight: 900;
    --brand-tracking: 0.05em;
    --brand-leading: 1.1;

    /* Role B: Structural - Poppins 700 */
    --structural-weight: 700;
    --structural-tracking: -0.01em;
    --structural-leading: 1.3;

    /* Role C: Reading - Inter */
    --reading-font: 'Inter', sans-serif;
    --reading-leading: 1.7;
}

/* Role A: Brand Headlines */
.hero-inner h1,
.hero-inner-item h1,
.hero-section h1 {
    font-weight: var(--brand-weight) !important;
    text-transform: uppercase !important;
    letter-spacing: var(--brand-tracking);
    line-height: var(--brand-leading);
}

/* ==========================================================================
   END TYPOGRAPHY SYSTEM
   ========================================================================== */

#frm_form_13_container form {
    overflow: none;
}

.bg-gradient-diagonal {
    background: linear-gradient(135deg, #323B53 0%, #172138 100%);
}

body h1,
body h2,
body h3,
body h4,
body h5,
body h6 {
    color: #2E364C;
    margin-top: 60px;
    padding-bottom: 0;
}

/* H1: Role A - Brand/Hero headlines */
body h1 {
    font-weight: var(--brand-weight);
    text-transform: uppercase;
    letter-spacing: var(--brand-tracking);
    line-height: var(--brand-leading);
}

/* H2-H6: Role B - Structural headings */
body h2,
body h3,
body h4,
body h5,
body h6 {
    font-weight: var(--structural-weight);
    text-transform: none;
    letter-spacing: var(--structural-tracking);
    line-height: var(--structural-leading);
}

.stage-title h3 {
    margin-top: 0;
}

.web-content-area .pre-footer-inner h2,
.slogan-section h2 {
    font-weight: var(--brand-weight);
    text-transform: uppercase;
    letter-spacing: var(--brand-tracking);
}

.fancybox__content :focus:not(.carousel__button.is-close) {
    outline: none;
}

.fancybox__content {
    width: 80% !important;
    height: 80% !important;
}

section.hero-section {
    margin-top: -70px !important;
}

.screenshot img {
    padding-top: 20px;
    padding-bottom: 20px;
}

.home header#masthead:not(.is-stuck) {
    background: transparent !important;
}

.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show>.btn-primary.dropdown-toggle,
.hero-inner a:hover,
.hero-inner a.btn:active {
    color: #2e364c;
}

a i {
    transition: .25s;
}

a:hover i,
a:focus i {
    color: #2e364c;
}

.btn-secondary {
    background: none !important;
}

.legendary-entry {
    max-width: 980px;
}

p:last-child {
    margin-bottom: 0;
}

body:not(.home) header#masthead:not(.is-stuck) {
    background: none;
}

#menu-header-menu li.btn {
    padding: 6px 10px;
}

#menu-header-menu li.btn:hover>a,
#menu-header-menu li.btn a:hover {
    color: #2e364c !important;
}

/* -----------------------------------------------------------------------------
   Prose Link Styling
   Only underline links within actual text content, not cards/buttons/nav
   ----------------------------------------------------------------------------- */
.blog-single__content a,
.entry-content a,
.page-content a,
#content .prose a,
#content article>.content a {
    text-decoration: underline;
    text-decoration-color: var(--blog-color-accent, #FF6D6D);
    text-underline-offset: 2px;
}

.blog-single__content a:hover,
.entry-content a:hover,
.page-content a:hover,
#content .prose a:hover {
    text-decoration-color: var(--blog-color-primary, #2E364C);
}

/* Exclude buttons and styled elements within prose */
.blog-single__content a.btn,
.blog-single__content a.button,
.blog-single__content a.wp-block-button__link,
.entry-content a.btn,
.entry-content a.button,
.entry-content a.wp-block-button__link {
    text-decoration: none;
}

.vc_tta-tabs-list a {
    text-decoration: none;
}

#content p {
    font-family: var(--reading-font);
    line-height: var(--reading-leading);
}

#content li {
    line-height: 200%;
    margin-top: 6px;
    font-size: 16px;
}

#content a.btn {
    text-decoration: none;
}

header#masthead .container {
    max-width: 100%;
}

body:not(.home) header#masthead {
    background: #2E364C !important;
}

.error404 #content>.row {
    justify-content: center;
}

a.nav-link {
    font-weight: 600 !important;
}

body #menu-wrapper #menu_top {
    background: #1C202D;
}


#primary {
    margin: 0 auto;
}

a.nav-link.btn.btn-primary {
    margin: 6px;
    padding: 10px 20px;
}

ul#menu-header-menu li a {
    text-transform: uppercase !important;
    min-width: max-content;
}

.navbar-brand {
    display: flex;
    align-items: center;
}

img#site_logo {
    max-width: 200px;
    width: auto !important;
    padding: 0;
}

body:not(.theme-preset-active) #masthead .navbar-nav>li>a.btn {
    padding: 10px 20px;
    margin: 6px;
}

body:not(.theme-preset-active) #masthead .navbar-nav>li>a.btn:hover,
body:not(.theme-preset-active) #masthead .navbar-nav>li>a.btn:active,
body:not(.theme-preset-active) #masthead .navbar-nav>li>a.btn:focus {
    color: #2E364C;
}

body:not(.theme-preset-active) #masthead.is-stuck .navbar-nav>li>a.btn {
    padding: 2px 20px;
    margin: 6px;
}

.hero-inner {
    padding: 130px 0;
    text-align: center;
    min-height: calc(100vh - 90px);
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    position: relative;
    z-index: 1;
}

.hero-inner * {
    color: #fff;
}

.hero-inner>* {
    width: 100%;
    display: block;
}

.hero-section {
    position: relative;
    background-size: cover;
}

.hero-section:before {
    content: "";
    height: 100%;
    width: 100%;
    background: #373737;
    opacity: 0.5;
    position: absolute;
    top: 0;
    left: 0;
}

.hero-section:after {
    content: "";
    height: 10px;
    width: 100%;
    background: #2E364C;
    opacity: 0.75;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    position: absolute;
    bottom: 0;
    left: 0;
}

.btn,
.frm_style_formidable-style.with_frm_style .frm_submit button {
    background: #2E364C;
    border: 4px solid #FFFFFF;
    box-sizing: border-box;
    box-shadow: 0px 2px 10px rgba(0, 0, 0, 0.25);
    border-radius: 13.3333px;
    padding: 10px 30px;
    font-weight: 700;
    color: #fff;
    font-size: 16px;
    font-weight: normal;
}

.with_frm_style select {
    padding: 0 20px;
}

.btn:hover,
.btn:focus,
.frm_style_formidable-style.with_frm_style .frm_submit button:hover,
.frm_style_formidable-style.with_frm_style .frm_submit button:focus {
    background: white !important;
    color: #2e364c;
    opacity: 1;
    border-color: #2E364C !important;
}

.btn {
    border: 4px solid white !important;
}

.hero-inner-item p {
    max-width: 750px;
    margin: 0 auto;
}

.hero-inner-item h1 {
    margin-bottom: 10px;
}

.hero-inner-item p {
    font-size: 18px;
    margin-bottom: 20px;
}

.hero-inner-item .btn {
    margin-top: 30px;
    padding-left: 45px;
    padding-right: 45px;
}

.hero-inner-item .btn:hover,
.hero-inner-item .btn:focus {
    background: #fff;
    color: #2E364C;
}

.logo-items {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}

.logo-item {
    padding: 20px;
    max-width: 220px;
}

.logo-cover {
    padding: 50px 0;
}

.intro-cover {
    background: #2E364C;
    padding: 90px 0 60px;
}

.intro-cover * {
    color: #fff;
}

.intro-tag {
    font-weight: 900;
    margin-bottom: 7px;
}

.intro-heading h3 {
    margin-bottom: 20px;
}

.intro-heading p {
    font-size: 18px;
}

.intro-heading {
    max-width: 815px;
    margin-bottom: 41px;
}

.intro-blocks {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;

}

.intro-block {
    width: calc(33.33% - 40px);
}

p.intro-block-title {
    text-transform: uppercase;
    margin-bottom: 10px;
}

.content-inner {
    min-height: 80vh;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    align-content: center;
    padding: 100px 0;
    /*max-width: 1280px;*/
    margin: 0 auto;
}

.content-inner p {
    font-size: 30px;
    color: #586073;
}

.workshop-cover {
    background: #2E364C;
    padding: 120px 0;
}

.workshop-cover * {
    color: #fff;
}

.workshop-content {
    width: 58%;
    padding-right: 15%;
}

.workshop-img {
    width: 42%;
}

.d-flex {
    display: flex;
    flex-wrap: wrap;
}

.workshop-date {
    background: url(/wp-content/uploads/2021/12/calendar.svg);
    background-repeat: no-repeat;
    background-position: left center;
    padding-left: 25px;
    line-height: 1.6;
    margin-bottom: 7px;
    font-style: italic;
}

.workshop-time {
    background: url(/wp-content/uploads/2021/12/clock.svg);
    background-repeat: no-repeat;
    background-position: center left;
    padding-left: 25px;
    font-style: italic;
    margin-bottom: 10px;
}

.workshop-cpt-header .workshop-date {
    background: url(/wp-content/uploads/2021/12/calendar-dark.svg);
    background-repeat: no-repeat;
    background-position: left center;
    color: #2E364C;
}

.workshop-cpt-header .workshop-time {
    background: url(/wp-content/uploads/2021/12/clock-dark.svg);
    background-repeat: no-repeat;
    background-position: left center;
    color: #2E364C;
}

.workshop-content h4 {
    margin-bottom: 34px;
    text-transform: uppercase;
}


.workshop-content p {
    line-height: 1.7;
}

.workshop-content ol {
    padding-left: 22px;
    margin-bottom: 70px;
}

.workshop-content ol li {
    margin-bottom: 8px;
}

.workshop-content .btn {
    background: #586073;
    padding: 14px 50px;
    width: 80%;
}

.workshop-content .btn:hover,
.workshop-content .btn:focus {
    background: #fff;
    color: #586073;
}

#footer-widget .col-12 {
    width: 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

#menu-footer-menu li a {
    color: #fff;
    background: transparent;
    font-size: 16px;
    text-transform: uppercase;
}

#menu-footer-menu li {
    display: inline-block;
    vertical-align: top;
    width: auto !important;
}

#menu-footer-menu {
    display: block !important;
    text-align: center
}

#footer-widget .widget {
    margin: 0;
}

#footer-widget {
    padding: 25px 0;
    background: #2E364C !important;
}

.site-info {
    text-align: center;
    font-size: 10px;
    color: #fff;
}

.workshop-content h2 {
    margin-bottom: 40px;
}

.stage-icon {
    width: 75px;
    height: 75px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    filter: drop-shadow(0px 5.33333px 5.33333px rgba(0, 0, 0, 0.25));
    background: #FF6F6F;
    border: 5px solid #FFFFFF;
    border-radius: 8px;
}

.stage-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 20px;
}

.stage-title {
    max-width: calc(100% - 75px);
    padding-left: 25px;
}

span.stage-tag {
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 0;
    display: inline-block;
    vertical-align: top;
    color: #2E364C;
}

.stage-title h3 {
    text-transform: uppercase;
    font-size: 32px;
}

.stages-cover {
    padding: 50px 0;
}

.stages-inner>.d-flex {
    align-items: center;
    max-width: 1280px;
    margin: 80px auto;
}

.stages-content {
    width: 55%;
}

.stage-title h3 {
    margin-bottom: 0;
}

.stages-img {
    width: 45%;
}

.stages-inner>.d-flex:nth-child(even) .stages-img {
    order: -1;
}

.stages-content-inner {
    max-width: 530px;
    padding-right: 30px;
}

.stages-content-inner .btn {
    width: 100%;
    padding: 14px 20px;
}

.stages-content-item p {
    font-size: 18px;
}

.stages-inner .d-flex:nth-child(3n+2) .stage-icon {
    background: #6EA0FF;
}

.stages-inner .d-flex:nth-child(3n) .stage-icon {
    background: #FFC56E;
}

.stages-inner>.d-flex:nth-child(even) .stages-content-inner {
    margin-left: auto;
    padding-left: 30px;
    padding-right: 0;
}

.tkmm-toggle span {
    background: #fff !important
}

ul#menu-header-menu>li {
    margin: 0 8px;
}

.dropdown-menu {
    padding: 0;
}

/* ==========================================================================
   CSS-based dropdown menus (replaces jQuery hover)
   ========================================================================== */

/* Hide all dropdown menus by default */
.navbar .dropdown>.dropdown-menu {
    display: none !important;
}

/* Show dropdown on hover and focus-within (for keyboard accessibility) */
.navbar .dropdown:hover>.dropdown-menu,
.navbar .dropdown:focus-within>.dropdown-menu {
    display: block !important;
}

/* Sub-sub menu (3rd level dropdown) positioning and width */
.dropdown.menu-item-has-children .dropdown.menu-item-has-children>.dropdown-menu {
    min-width: 18rem;
    width: max-content;
    max-width: 24rem;
    margin-top: 0 !important;
    top: -3px !important;
}

/* Ensure dropdown items show full text without truncation */
.dropdown-menu .dropdown-item {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
}

body:not(.home) #content.site-content {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
}

.workshop-cpt-header h4 {
    text-transform: uppercase;
}

.workshop-cpt-content,
.workshop-cpt-content p {
    color: #2E364C;
    line-height: 1.8;
}

.workshop-cpt-content-left {
    width: 55%;
    padding-right: 7%;
}

.workshop-img-right {
    width: 45%;
    padding: 30px 0;
}

.workshop-cpt-content ol {
    padding-left: 26px;
    margin-bottom: 25px;
}

.workshop-cpt-content ol li {
    margin: 5px 0;
}

.workshop-cpt-content .btn {
    width: 80%;
    padding-top: 15px;
    padding-bottom: 15px;
    font-weight: 400;
}

.workshop-cpt-item {
    margin-bottom: 70px;
    display: none;
}

.workshop-cpt-item.show {
    display: block;
}

.workshop-cpt-item:last-child {
    margin-bottom: 0;
}

.inner-banner-content {
    display: none;
}

.inner-banner-content.show {
    display: block;
}

.workshop-items-text {
    text-align: center;
    position: relative;
    margin-bottom: 80px;
}

.workshop-items-text span {
    background: #fff;
    position: relative;
    padding: 0 25px;
    color: #2E364C;
    text-transform: uppercase;
    font-weight: 900;
}

.workshop-items-text:before {
    content: "";
    height: 2px;
    width: 100%;
    background: #2E364C;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.inner-banner {
    position: relative;
    margin-top: -70px;
}

.inner-banner:before {
    content: "";
    height: 100%;
    width: 100%;
    background: linear-gradient(0deg, rgba(50, 59, 83, 0.5), rgba(50, 59, 83, 0.5)), linear-gradient(0deg, rgba(55, 55, 55, 0.5), rgba(55, 55, 55, 0.5));
    position: absolute;
    top: 0;
    left: 0;
}

.inner-banner .wpb_column {
    position: relative;
    max-width: 960px;
}

.inner-banner h1,
.inner-banner p {
    color: #fff;
}

.inner-banner h1 {
    text-transform: uppercase;
}

.inner-banner {
    min-height: 70vh;
    display: flex;
    flex-wrap: wrap;
    align-content: flex-end;
}

.services-left-content .wpb_wrapper {
    max-width: 520px;
}

.services-left-content p {
    font-size: 18px;
}


.services-left-content .vc_btn3-container {
    width: 100%;
}

.services-left-content .vc_btn3-container button {
    width: 100%;
    background: #2E364C !important;
    border: 4px solid #FFFFFF !important;
    box-sizing: border-box;
    box-shadow: 0px 2px 10px rgb(0 0 0 / 25%);
    border-radius: 13.3333px;
    padding: 14px 30px;
    font-weight: 700;
    color: #fff !important;
    font-size: 16px;
}

.services-left-content .vc_btn3-container button:hover,
.services-left-content .vc_btn3-container button:focus {
    background: #fff !important;
    color: #2E364C !important;
    border-color: #2E364C !important
}

.services-left-content h4 {
    text-transform: uppercase;
}

.align-items-center {
    align-items: center;
}

slide-drawer {
    display: none;
}

html {
    margin: 0 !important;
}

.inner-banner>div {
    position: relative;
}

.custom-inner-banner {
    padding-top: 150px;
    padding-bottom: 70px;
}

.single-page-content {
    padding: 40px 0;
}

#content .entry-title a {
    text-decoration: none;
    margin-top: 20px;
    display: block;
    text-transform: none;
    font-weight: 400;
}


.download-btn {
    font-weight: 900;
    font-size: 32px;
    padding-right: 50px;
    position: relative;
    background: url(../../../wp-content/uploads/2021/12/long-arrow-right.svg);
    background-repeat: no-repeat;
    background-position: right center;
}

.single-content-item {
    width: 70%;
    padding-right: 60px;
}

.single-sidebar {
    width: 30%;
}

.single-sidebar .widget-area {
    width: 100%;
    flex: 0 0 100%;
    max-width: 100%;
    background: #FFFFFF;
    border: 4px solid rgba(107, 107, 107, 0.05);
    box-sizing: border-box;
    border-radius: 12px;
    padding: 30px 20px;
    text-align: center;
}

.single-sidebar h5 {
    font-size: 16px;
    text-transform: uppercase;
}

.single-sidebar p {
    font-size: 14px;
    line-height: 1.8;
}

.bottom-content-section p {
    font-size: 20px;
}

.post-item-img {
    width: 390px;
}

.post-item-content {
    width: calc(100% - 390px);
    padding-left: 70px;
}

.post-item-img img {
    filter: drop-shadow(0px 1.54267px 6.17069px rgba(64, 64, 64, 0.4));
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-item-img {
    background: #FFFFFF;
    box-shadow: 0px 1.54267px 6.17069px rgba(64, 64, 64, 0.4);
    padding: 10px;
}

.post-items-cover {
    max-width: 1210px;
    margin: 0 auto;
}

.post-cpt-item {
    margin: 120px 0;
}

.post-item-content h4 {
    font-weight: 400;
    line-height: 1.4;
    margin-top: 0;
}

.post-item-content p {
    line-height: 1.8;
    color: #2E364C;
}

.post-item-content .btn {
    width: 100%;
    padding: 15px 30px;
}

.post-item-img a {
    display: block;
    padding-top: 100%;
    position: relative;
}

.blog-post-pagination {
    text-align: center;
}

.blog-post-pagination>* {
    height: 30px;
    width: 30px;
    border: 1px solid #2e364c;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
}

.blog-post-pagination>.current {
    background: #f3f3f3;
}

.blog-post-pagination {
    margin-bottom: 70px;
}

.single-post header#masthead,
.blog header#masthead {
    background: #2E364C !important;
}

.blog #main {
    margin-top: 30px;
}

.blog .container,
.single-full-content .single-content-item {
    max-width: 950px;
}

.single-full-content .single-content-item {
    margin: 0 auto;
    width: 100%;
    padding: 0;
}

.single-content-item h1 {
    font-weight: 400;
    font-size: 32px;
    line-height: 1.4;
    margin-bottom: 30px;
}

.single-content-img {
    background: #FFFFFF;
    box-shadow: 0px 2px 12px rgba(0, 0, 0, 0.25);
    padding: 15px;
    margin-bottom: 50px;
}

.single-content-img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.single-content-item p {
    line-height: 1.8;
    color: #2E364C;
}

.single-content-img-ratio {
    padding-top: 50%;
    position: relative;
}

.single-content-img-ratio:before {
    content: "";
    height: 100%;
    width: 100%;
    /*background: linear-gradient(0deg, rgba(50, 59, 83, 0.2), rgba(50, 59, 83, 0.2)), linear-gradient(0deg, rgba(55, 55, 55, 0.2), rgba(55, 55, 55, 0.2));*/
    position: absolute;
    top: 0;
    z-index: 1;
    left: 0;
}

.pre-title-label {
    margin: 0;
    font-weight: 600;
}

.custom-inner-banner h1 span.pppgs-title {
    font-size: 600;
}

span.tm {
    font-weight: 600;
}

.stage-explainer-banner {
    background: #1c202d;
}

.stage-explainer-banner h1 {
    font-size: 40px;
    color: white;
}

.stage-explainer-banner h1 span {
    font-size: 40px;
    color: white;
}

.stage-explainer-banner p {
    color: white;
}

.stage-explainer-banner-inner {
    padding: 50px;
}

h1.stage-one,
h2.stage-one,
h3.stage-one,
h4.stage-one,
h5.stage-one,
h6.stage-one,
p.stage-one {
    color: #FF6D6D;
}

h1.stage-two,
h2.stage-two,
h3.stage-two,
h4.stage-two,
h5.stage-two,
h6.stage-two,
p.stage-two {
    color: #6EA0FF;
}

h1.stage-three,
h2.stage-three,
h3.stage-three,
h4.stage-three,
h5.stage-three,
h6.stage-three,
p.stage-three {
    color: #FFC061;
}

.explainer-stage-progression {
    margin: 100px 0;
}

.stage-explanation-body h2 {
    margin-top: 100px;
}

.table-of-contents {
    margin-bottom: 100px;
}

.table-of-contents a {
    text-decoration: underline;
}

.section-anchor {
    position: relative;
    top: -120px;
}

.table-of-contents li {
    margin-bottom: 10px;
}

.tools-and-guides-content-section {
    margin-bottom: 50px;
}

.stage-explanation-body,
.explainer-stage-progression {
    max-width: 1180px;
    margin: 50px auto !important;
}

.tools-and-guides-sticky-sidebar {
    position: sticky;
    top: 100px;
    border: 4px solid rgba(227, 227, 227, .5);
    padding: 20px;
    border-radius: 4px;
    text-align: center;
    margin-bottom: 100px;
    font-size: 16px;
}

.tools-and-guides-sticky-sidebar p {
    font-size: 16px;
}

.tools-and-guides-sticky-sidebar .sidebar-image {
    padding: 10px;
    filter: drop-shadow(0px 1px 6px rgba(0, 0, 0, 0.15));
    background: white;
    margin: 20px;
}

.tools-and-guides-content .row {
    margin-bottom: 50px;
}

.tools-and-guides-content .row .col-sm {
    margin-top: 50px;
    margin-bottom: 50px;
}

.slogan-section {
    max-width: 1000px;
}

.tools-and-guides-content .btn {
    margin-bottom: 100px;
}

#page:not(.home #page) {
    margin-top: 0px;
}

#page:not(.home #page) {
    margin-top: var(--scrolling_logo_height);
}

blockquote p {
    margin: 50px 0 50px 0 !important;
    border-left: 2px solid var(--primary_color);
    padding-left: 10px;
    font-size: 1rem;
    color: #2e364c;
    font-style: italic;
    font-weight: 600;
}

.home header#masthead.is_transparent+#content {
    margin-top: - var(--logo_height) !important;
}

.home #primary {
    width: 100%;
}

.web-hero-left-content {
    padding-top: 50px;
    padding-bottom: 50px;
}


/*
legendary-css.css
*/

::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
    border-radius: 0px;
    background-color: #F5F5F5;
}

::-webkit-scrollbar {
    width: 2px;
    background-color: #F5F5F5;
    transition: 1s;
}

::-webkit-scrollbar-thumb {
    border-radius: 0px;
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
    background-color: #555;
}

.v-dialog.v-dialog--active {
    border: 1px solid rgba(255, 255, 255, .74);
}

::selection {
    background: #2e364c;
    color: white;
}

::-moz-selection {
    background: #2e364c;
    color: white;
}

body.page-id-409 #masthead,
body.page-id-46 #masthead {
    background: #2e364c !important;
}

.stages-button-container .btn:not(:disabled):not(.disabled):focus,
.stages-button-container .btn-primary:not(:disabled):not(.disabled).active:focus,
.stages-button-container .btn-primary:not(:disabled):not(.disabled):active:focus {
    background: var(--primary_color) !important;
    border-color: var(--primary_color) !important;
    color: #fff !important;
}



#primary {
    width: 100%;
}

.web-hero-banner {
    background: rgba(0, 0, 0, 0) linear-gradient(270deg, rgb(50, 59, 83) 0%, rgba(0, 0, 0, 0.91) 100%) no-repeat scroll 0% 0%;
}

.web-hero-img {
    border-left: 4px solid white;
    height: 100%;
    width: 100%;
}

.web-solution-cover {
    background: #2e364c;
}

.pre-hero-header-lead {
    color: #fff;
    letter-spacing: 1px;
    font-weight: 200;
}

.pre-hero-line {
    display: inline-block;
    width: 40px;
    height: 2px;
    margin-right: 10px;
    background: #fff;
    position: relative;
    top: -3px;
}

.web-hero-banner .lead {
    max-width: 38rem
}

.web-cta-title {
    font-size: 3em;
    color: #fff
}

.web-stage-cover .lead {
    color: #586073;
}

.web-stage-cover h1 {
    color: #323b53
}

.web-content-area .text-white *:not(.btn) {
    color: #fff;
}

.web-stage-cover h3 {
    text-transform: uppercase;
}

.authority-amplifier img {
    max-width: 170px;
}

.web-content-area section {
    padding: 80px 0;
}

.web-content-area p {
    margin-bottom: 1rem;
    font-size: 18px;
    color: #7f8595;
    line-height: 1.7 !important;
}

.lead p {
    font-size: 1.25rem;
    font-weight: 300;
}

.web-content-area h1,
.web-content-area h2,
.web-content-area h3,
.web-content-area h4,
.web-content-area h5,
.web-content-area h6 {
    margin-top: 0;
    margin-bottom: .5rem;
    font-weight: 700;
    color: #2e364c;
}

.web-content-area h2 {
    text-transform: uppercase;
    font-size: 50px;
}

.web-content-area h1 sup,
.web-content-area h2 sup,
.web-content-area h3 sup {
    font-size: 12px;
    vertical-align: top;
    position: relative;
    top: 14px;
}

.web-content-area h6 {
    text-transform: uppercase;
    font-size: 16px;
    opacity: .8;
    letter-spacing: .15em;
}

.web-content-area .btn {
    text-transform: uppercase;
    letter-spacing: .15em;
}

.web-content-area b,
.web-content-area strong {
    font-weight: 600;
}

.price-card-icons {
    text-align: center;
    margin-top: -37px;
}

.price-card-icons img {
    max-width: 75px;
}

.price-card {
    transition: 0.25s ease;
}

.web-hero-arrow img {
    cursor: pointer;
}

.practice-item {
    position: relative;
}

.pre-footer-inner p {
    font-size: 20px;
}

.practice-item:before {
    content: "";
    height: 30px;
    width: 40px;
    background: url(../../../wp-content/uploads/2022/09/right-arrow-g.svg);
    position: absolute;
    right: -70px;
    top: 50%;
    background-position: center;
    background-repeat: no-repeat;
    transform: translateY(-50%);
}

.practice-item:last-child:before {
    display: none;
}

section.web-cta-cover {
    padding: 120px 0;
}

.web-testimonial-cover {
    background: #2e364c;
}

.testimonial-headshot {
    width: 150px;
    margin: 0 auto
}

.testimonial-headshot img {
    width: 149px;
    height: 149px;
    border: 5px solid #fff;
    border-radius: 150px;
    box-shadow: 0 0 5px rgb(0 0 0 / 30%);
}

.stage-description {
    font-style: italic;
    font-size: 14px
}

.review-card .review-author {
    display: inline-block;
    font-style: normal;
    font-weight: 700;
    font-size: 16px;
    line-height: 24px;
    color: #222;
    margin: 0;
    vertical-align: middle
}

.review-card .review-location {
    font-weight: 600;
    font-size: 14px;
    line-height: 18px;
    color: #9a9a9a;
    text-transform: uppercase;
}

.review-card .review-stars {
    margin-bottom: 1rem;
    max-height: 30px;
}

.review-card .review-verified-badge {
    display: inline-block
}

.review-card {
    text-align: center;
}

.review-card h4 {
    width: 100%;
}

.web-testimonial-slider>div {
    max-width: 910px;
    margin: 0 auto;
}

.web-testimonial-slider .slick-dots li {
    display: inline-block;
    vertical-align: top;
    line-height: 0 !important;
    font-size: 0 !important;
    margin: 0 5px !important;
}

.web-testimonial-slider .slick-dots li button {
    height: 7px;
    width: 7px;
    font-size: 0;
    border: 0;
    border-radius: 40px;
    display: inline-block;
    vertical-align: top;
    padding: 0;
    opacity: 0.2;
    margin: 4px;
}

.web-testimonial-slider .slick-dots {
    padding: 0;
    margin: 20px 0;
    text-align: center;
}

.web-testimonial-slider .slick-dots li.slick-active button {
    opacity: 1;
}

.web-calculator-cover label {
    font-size: 16px;
    vertical-align: top;
}

.marketItem-cover {
    margin-top: 70px !important;
}

.pre-footer-cover {
    padding: 10vw 0 !important;
}

.workshop-cpt-item-desc {
    text-align: center;
}

.cta-top {
    margin-top: 0;
    padding-top: 0;
}

.legendary-footer-links {
    background: var(--footer_background);
    padding: 10px;

}

.legendary-footer-links a {
    color: white;
}


#primary img {
    border: none !important;
    box-shadow: none !important;
}


blockquote p {
    margin: 0 0 1rem;
    letter-spacing: -1px;
    font-size: 20px !important;
    /* font-weight:100 !important; */
}

.team-member-row {
    margin-top: 200px;
}

.team-member-row:last-child {
    margin-bottom: 200px !important;
}

.team-member-row h2 {
    margin-top: 0px;
}

.member-info p:not(:last-child) {
    margin-bottom: 10px;
}

.location-text {
    color: #9A9A9A;
}

.team-content-column {
    padding-left: 100px !important;
}

.bio-text p {
    color: #000;
}

/*.page-id-4096 #frm_field_354_container .frm_radio, .page-id-4096 #frm_field_358_container .frm_radio, .page-id-4096 #frm_field_367_container .frm_radio {
    display:none !important;
}
.page-id-4096 #frm_field_354_container .frm_radio.visible, .page-id-4096 #frm_field_358_container .frm_radio.visible, .page-id-4096 #frm_field_367_container .frm_radio.visible
{
    display:block !important;
}*/

.page-id-3983 #frm_field_218_container .frm_radio,
.page-id-3983 #frm_field_224_container .frm_radio,
.page-id-3983 #frm_field_232_container .frm_radio {
    display: none !important;
}

.page-id-3983 #frm_field_218_container .frm_radio.visible,
.page-id-3983 #frm_field_224_container .frm_radio.visible,
.page-id-3983 #frm_field_232_container .frm_radio.visible {
    display: block !important;
}
























.page-id-3983 .frm_form_field {
    margin-bottom: 50px;
}

.page-id-3983 #content li,
.page-id-3983 #content p {
    font-size: 16px;
}

.page-id-3983 .frm_submit {
    margin: 40px 0;
}

.page-id-3983 .frm_button_submit,
.page-id-3983 .frm_save_draft {
    margin: 10px !important;
}

.page-id-3983 .inner-banner {
    display: none;
}

.page-id-3983 .with_frm_style .frm_repeat_sec {
    margin: 0 !important;
    border-bottom: none;

}


/* Make the repeater section use flex layout */
.frm_repeat_sec {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Ensure the input container takes up necessary space */
.frm_field_123_container {
    flex: 1;
}

/* Adjust the buttons container */
.frm_repeat_buttons {
    display: flex;
    gap: 5px;
    margin-left: 10px;
}

/* Optional: If you want to remove any default margins/padding */
.frm_repeat_buttons a.frm_button {
    margin: 0;
}

.page-id-3983 .frm_form_field.frm_repeat_buttons {
    margin: 0 0 20px 0;
}

.page-id-3983 .frm_style_formidable-style.with_frm_style .frm_top_container,
.page-id-3983 #frm_field_119_container {
    margin-bottom: 80px !important;
}

.page-id-3983 div#frm_field_119_container {
    margin-top: -60px;
}

.frm_style_formidable-style.with_frm_style .frm_section_heading {
    margin-bottom: 0px !important;
}

#frm_field_123-119-0_container {
    margin: 0 !important;
}

.frm_style_formidable-style.with_frm_style .frm-show-form .frm_section_heading h3[class*="frm_pos_"] {
    border: none;
}

.page-id-3983 .frm_repeat_sec .form-field {
    margin: 0 !important;
}

.page-id-3983 .frm_repeat_sec {
    align-items: end;
}

a.frm_add_form_row.frm_button {
    display: none;
}

.page-id-3983 a.frm_remove_form_row.frm_button,
a.frm_add_form_row.frm_button {
    padding: 4px 20px !important;
}

/* Ultimate Marketing Guide Styles */
.umg-section {
    margin-top: 270px;
    margin-bottom: 200px;
}

h1.umg-section-title {
    font-size: 60px !important;
    font-weight: 900 !important;
}

.umg-section h1 {
    font-size: 50px;
    text-transform: uppercase;
    margin-top: 0px;
    font-weight: 500;
}

.umg-section h2 {
    font-size: 32px;
    text-transform: uppercase;
    margin-top: 6rem;
}

.umg-section h3 {
    font-size: 28px;
}

.umg-section ul {
    padding: 0;
}

.umg-section li {
    display: block;
    background: url('/wp-content/uploads/2025/09/red-chevron.svg');
    background-position: left center;
    background-repeat: no-repeat;
    padding-left: 25px;
    margin-bottom: 15px;
}

.umg-section blockquote p {
    border-left-width: 10px;
    font-size: 20px;
    color: #7F8595;
    font-weight: 400;
}

.umg-section .frm_button_submit {
    border: 4px solid white !important;
    padding: 12px 100px !important;
}

/* End Ultimate Marketing Guide Styles */

.review-accordion-title a {
    font-size: 22px;
    color: var(--primary_color) !important;
    font-weight: 400;
    text-decoration: none;
}

.review-accordion .vc_tta-panel-heading {
    border-color: #586073 !important;
    border-width: 1px !important;
    border-radius: 0px !important;
}

.review-accordion .vc_tta-panel-heading:hover {
    background-color: transparent !important;
    opacity: 1 !important;
}

.vc_tta-color-white.vc_tta-style-outline .vc_tta-controls-icon::before {
    border-color: #AEAEAE !important;
}

.review-accordion .vc_tta-panel-body {
    border-color: #586073 !important;
    border-width: 1px !important;
    border-radius: 0px !important;
    background-color: #FAFAFA !important;
}

.frm_message h2 {
    margin-top: 0px;
}

.google-btn {
    margin-top: 20px;
}

.review-accordion h4 {
    margin-top: 0px;
}

.review-accordion .wpb_content_element {
    padding-top: 30px;
    padding-bottom: 30px;
}

.page-id-5142 .with_frm_style .frm_message {
    color: #7F8595;
    background-color: transparent;
    border-width: 0px;
}

.with_frm_style .frm_message p {
    color: #7F8595;
}

.review-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.5);
}

.review-modal-content {
    background-color: #fff;
    margin: 5% auto;
    margin-bottom: 5% !important;
    padding: 30px;
    border-radius: 10px;
    max-width: 1000px;
    text-align: center;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);
}

.review-modal-close {
    float: right;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    color: #888;
}

.review-modal-close:hover {
    color: #000;
}

.review-modal-content h3 {
    margin-top: 0px;
}

.signature-starter-hero {
    padding: 250px 0;
    border-bottom: 10px solid #2E364C;
}

.gold-text ul {
    padding: 0;
}

.gold-text li {
    color: #FFC56E;
    display: block;
    background: url('/wp-content/uploads/2025/10/gold-line.svg');
    background-repeat: no-repeat;
    background-position: left center;
    padding-left: 60px;
}

.wpb_content_element.gold-text {
    padding-bottom: 0px;
}

.signature-starter-hero-text h1 {
    margin-top: 0px;
}

.signature-starter-hero .btn-primary {
    border-width: 4px !important;
    border-radius: 12px !important;
    font-weight: bold !important;
    background: rgba(42, 45, 52, 0.50) !important;
}

.signature-starter-hero .btn-primary:hover {
    background: white !important;
    color: #2e364c !important;
    opacity: 1 !important;
    border-color: #2E364C !important;
}

.uppercase-heading h2 {
    text-transform: uppercase;
    margin-top: 0px;
}

.separator {
    border-bottom: 10px solid #2E364C;
}

.plan-table table tr td {
    color: #7F8595;
    padding: 20px 15px 20px 0px;
}

.plan-table tr td {
    border-top: .13rem solid #2E364C;
}

.comparison-table table tr td {
    color: #7F8595;
    padding: 20px 15px 20px 0px;
}

.mobile-table ul {
    margin-bottom: 0px;
    padding: 0;
    padding-top: 30px;
    padding-bottom: 30px;
}

.mobile-table ul:not(:last-of-type) {
    border-bottom: 1px solid #2E364C;
}

.mobile-table li {
    display: block;
    margin-top: 0px !important;
}

.mobile-table {
    display: none;
}

.row-top-bottom-padding {
    padding-top: 150px;
    padding-bottom: 150px;
}

.row-bottom-padding {
    padding-bottom: 150px;
}

.row-top-padding {
    padding-top: 150px;
}

.how-it-works-card h4 {
    margin-top: 0px;
}

.how-it-works-card {
    background-color: white;
    border-radius: 10px;
    box-shadow: 0 5.333px 53.333px 0 #D3DAE4;
    padding: 25px;
}

.how-it-works-card strong {
    color: #323B53;
}

.how-it-works-card .wpb_content_element {
    padding-top: 0px;
    padding-bottom: 0px;
}

.how-it-works-row {
    column-gap: 30px;
    display: flex;
}

.ss-accordion h4 a {
    color: white !important;
    text-decoration: none;
    font-weight: 700 !important;
    font-size: 20px !important;
}

.ss-accordion .vc_tta-panel-heading {
    background-color: #323B53 !important;
}

.ss-accordion p {
    color: #7F8595 !important;
}

.ss-accordion .vc_tta-panel-body {
    background-color: white !important;
    border-bottom: 1px solid #D3DAE4 !important;
    border-right: 1px solid #D3DAE4 !important;
    border-left: 1px solid #D3DAE4 !important;
}

.ss-accordion .vc_tta-controls-icon::before {
    border-color: white !important;
}

/* ==========================================================================
   BLOG STYLES - Contemporary Layout
   Uses typography system variables
   ========================================================================== */

/* Blog Custom Properties */
:root {
    --blog-max-width: 800px;
    --blog-wide-width: 1200px;
    --blog-card-radius: 12px;
    --blog-color-primary: #2E364C;
    --blog-color-text: #4a5568;
    --blog-color-text-light: #718096;
    --blog-color-accent: #FF6D6D;
    --blog-color-logo-accent: #f8981d;
    /* Logo/brand orange */
    --blog-color-border: #e2e8f0;
    --blog-color-bg-light: #f7fafc;
    --blog-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
    --blog-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
    --blog-shadow-lg: 0 8px 30px rgba(0, 0, 0, 0.12);
    --blog-transition: 0.2s ease;
    --header-height: 80px;
    /* Adjust if header height differs */
}

/* -----------------------------------------------------------------------------
   Blog Image Utilities - Aspect Ratios & Lazy Loading
   ----------------------------------------------------------------------------- */

/* Aspect Ratio Containers */
.blog-aspect-ratio {
    position: relative;
    overflow: hidden;
    background: var(--blog-color-bg-light);
}

.blog-aspect-ratio::before {
    content: '';
    display: block;
}

/* 16:9 ratio (featured images, hero) */
.blog-aspect-ratio--16-9::before {
    padding-top: 56.25%;
}

/* 3:2 ratio (cards, related posts) */
.blog-aspect-ratio--3-2::before {
    padding-top: 66.67%;
}

/* 4:3 ratio (square-ish) */
.blog-aspect-ratio--4-3::before {
    padding-top: 75%;
}

/* 1:1 ratio (square) */
.blog-aspect-ratio--1-1::before {
    padding-top: 100%;
}

/* Image inside aspect ratio container */
.blog-aspect-ratio img,
.blog-aspect-ratio svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Featured image base styles */
.blog-featured-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Placeholder image styling */
.blog-placeholder-image {
    background: linear-gradient(135deg, #1a1a2e 0%, #2d2d44 100%);
}

/* Native lazy loading support - images visible by default */
.blog-featured-image {
    opacity: 1;
}

/* Ensure SVG placeholders are always visible */
svg.blog-featured-image,
svg.blog-placeholder-image {
    opacity: 1;
}

/* Image hover effects for linked images */
.blog-card__image-link:hover .blog-featured-image,
.blog-related__image-link:hover .blog-featured-image {
    transform: scale(1.05);
}

.blog-card__image .blog-featured-image,
.blog-related__image .blog-featured-image {
    transition: transform 0.4s ease;
}

/* Placeholder doesn't scale on hover */
.blog-placeholder-image {
    transition: none;
}

.blog-card__image-link:hover .blog-placeholder-image,
.blog-related__image-link:hover .blog-placeholder-image {
    transform: none;
}

/* -----------------------------------------------------------------------------
   Blog Archive Section
   ----------------------------------------------------------------------------- */
.blog-archive-section {
    padding: 60px 20px;
    background: #fff;
}

.blog-archive-section #main {
    max-width: var(--blog-wide-width);
    margin: 0 auto;
}

/* Archive Header */
.blog-archive__header {
    text-align: center;
    margin-bottom: 3rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid var(--blog-color-border);
}

.blog-archive__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-weight: var(--structural-weight) !important;
    font-size: 2.5rem;
    color: var(--blog-color-primary);
    margin: 0 0 1rem;
    text-transform: none !important;
}

.blog-archive__description {
    font-family: var(--reading-font);
    font-size: 1.125rem;
    color: var(--blog-color-text-light);
    max-width: 600px;
    margin: 0 auto;
    line-height: var(--reading-leading);
}

/* Category Filter */
.blog-category-filter {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.blog-category-filter__item {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.5rem 1.25rem;
    border-radius: 100px;
    background: var(--blog-color-bg-light);
    color: var(--blog-color-text);
    text-decoration: none;
    transition: var(--blog-transition);
}

.blog-category-filter__item:hover {
    background: var(--blog-color-primary);
    color: #fff;
    text-decoration: none;
}

.blog-category-filter__item.is-active {
    background: var(--blog-color-primary);
    color: #fff;
}

/* Tag Filter (secondary, subtler style) */
.blog-tag-filter {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.375rem;
    margin-bottom: 3rem;
}

.blog-tag-filter__item {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    padding: 0.375rem 1rem;
    border-radius: 100px;
    background: transparent;
    color: var(--blog-color-text-light);
    border: 1px solid var(--blog-color-bg-light, #e2e8f0);
    text-decoration: none;
    transition: var(--blog-transition);
}

.blog-tag-filter__item:hover {
    background: var(--blog-color-bg-light);
    color: var(--blog-color-text);
    border-color: var(--blog-color-bg-light);
    text-decoration: none;
}

.blog-tag-filter__item.is-active {
    background: var(--blog-color-accent, #FF6D6D);
    color: #fff;
    border-color: var(--blog-color-accent, #FF6D6D);
}

/* Archive Empty State */
.blog-archive__empty {
    text-align: center;
    padding: 4rem 2rem;
    background: #fff;
    border-radius: var(--blog-card-radius, 12px);
    box-shadow: var(--blog-shadow-sm);
    max-width: 500px;
    margin: 0 auto;
}

.blog-archive__empty-icon {
    margin-bottom: 1.5rem;
    color: var(--blog-color-text-light, #718096);
    opacity: 0.5;
}

.blog-archive__empty-title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--blog-color-primary, #2E364C);
    margin: 0 0 0.75rem;
}

.blog-archive__empty-text {
    font-family: var(--reading-font, 'Inter'), sans-serif;
    font-size: 1rem;
    color: var(--blog-color-text-light, #718096);
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

.blog-archive__empty-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

.blog-archive__empty-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.9375rem;
    font-weight: 600;
    border-radius: 100px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.blog-archive__empty-btn--primary {
    background: var(--blog-color-primary, #2E364C);
    color: #fff;
}

.blog-archive__empty-btn--primary:hover {
    background: var(--blog-color-accent, #FF6D6D);
}

.blog-archive__empty-btn--secondary {
    background: var(--blog-color-bg-light, #f1f5f9);
    color: var(--blog-color-text, #4a5568);
}

.blog-archive__empty-btn--secondary:hover {
    background: var(--blog-color-primary, #2E364C);
    color: #fff;
}

@media (max-width: 768px) {
    .blog-archive__empty {
        padding: 3rem 1.5rem;
    }

    .blog-archive__empty-title {
        font-size: 1.25rem;
    }

    .blog-archive__empty-actions {
        flex-direction: column;
    }

    .blog-archive__empty-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Blog Archive Grid */
.blog-archive-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

/* -----------------------------------------------------------------------------
   Blog Card (Archive View)
   ----------------------------------------------------------------------------- */
.blog-card {
    background: #fff;
    border-radius: var(--blog-card-radius);
    overflow: hidden;
    box-shadow: var(--blog-shadow-sm);
    transition: transform var(--blog-transition), box-shadow var(--blog-transition);
}

.blog-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--blog-shadow-lg);
}

.blog-card__image-link {
    display: block;
    text-decoration: none;
}

.blog-card__image {
    border-radius: var(--blog-card-radius) var(--blog-card-radius) 0 0;
}

/* Image styles now handled by .blog-aspect-ratio and .blog-featured-image utilities */

.blog-card__content {
    padding: 1.5rem;
}

.blog-card__category {
    display: inline-block;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--blog-color-accent);
    text-decoration: none;
    margin-bottom: 0.75rem;
    transition: color var(--blog-transition);
}

.blog-card__category:hover {
    color: #e55555;
}

.blog-card__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.25rem;
    font-weight: var(--structural-weight);
    line-height: 1.4;
    margin: 0 0 0.75rem;
    text-transform: none !important;
}

.blog-card__title a,
.blog-card__title a:hover,
.blog-card__title a:focus,
.blog-card__title a:visited {
    color: var(--blog-color-primary);
    text-decoration: none;
    transition: color var(--blog-transition);
}

.blog-card__title a:hover {
    color: var(--blog-color-accent);
}

.blog-card__meta {
    font-family: var(--reading-font);
    font-size: 0.8125rem;
    color: var(--blog-color-text-light);
    margin-bottom: 0.75rem;
}

.blog-card__meta-separator {
    margin: 0 0.5rem;
    opacity: 0.5;
}

.blog-card__excerpt {
    font-family: var(--reading-font);
    font-size: 0.9375rem;
    color: var(--blog-color-text);
    line-height: 1.6;
    margin-bottom: 1rem;
}

.blog-card__read-more {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-color-primary);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: gap var(--blog-transition);
}

.blog-card__read-more:hover {
    gap: 0.75rem;
    color: var(--blog-color-accent);
}

.blog-card__arrow {
    transition: transform var(--blog-transition);
}

/* -----------------------------------------------------------------------------
   Blog Archive List (Full-Width Horizontal Cards)
   ----------------------------------------------------------------------------- */
.blog-archive-list {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    max-width: 1000px;
    margin: 0 auto;
}

/* Horizontal Card */
.blog-card-horizontal {
    position: relative;
    display: grid;
    grid-template-columns: 400px 1fr;
    background: #fff;
    border-radius: var(--blog-card-radius);
    overflow: hidden;
    box-shadow: var(--blog-shadow-sm);
    transition: box-shadow var(--blog-transition);
    cursor: pointer;
}

.blog-card-horizontal:hover {
    box-shadow: var(--blog-shadow-lg);
}

.blog-card-horizontal__image {
    position: relative;
    height: 100%;
    min-height: 280px;
    overflow: hidden;
    background: var(--blog-color-bg-light);
}

.blog-card-horizontal__image .blog-featured-image,
.blog-card-horizontal__image .blog-placeholder-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: 0;
    transition: transform 0.4s ease;
}

.blog-card-horizontal:hover .blog-card-horizontal__image .blog-featured-image,
.blog-card-horizontal:hover .blog-card-horizontal__image .blog-placeholder-image {
    transform: scale(1.05);
}

.blog-card-horizontal__content {
    padding: 2rem 2.5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Taxonomy container (categories + tags) */
.blog-card-horizontal__taxonomy {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
    position: relative;
    z-index: 2;
}

.blog-card-horizontal__category {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #fff;
    background: var(--blog-color-accent, #FF6D6D);
    border-radius: 100px;
    text-decoration: none;
    transition: background var(--blog-transition);
}

.blog-card-horizontal__category:hover {
    background: #e55555;
}

.blog-card-horizontal__tag {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--blog-color-text-light, #718096);
    background: var(--blog-color-bg-light, #f1f5f9);
    border-radius: 100px;
    text-decoration: none;
    transition: all var(--blog-transition);
}

.blog-card-horizontal__tag:hover {
    background: var(--blog-color-primary, #2E364C);
    color: #fff;
}

.blog-card-horizontal__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.5rem;
    font-weight: var(--structural-weight);
    line-height: 1.35;
    margin: 0 0 1rem;
    text-transform: none !important;
}

.blog-card-horizontal__title a,
.blog-card-horizontal__title a:hover,
.blog-card-horizontal__title a:focus,
.blog-card-horizontal__title a:visited {
    color: var(--blog-color-primary);
    text-decoration: none;
    transition: color var(--blog-transition);
}

.blog-card-horizontal__title a:hover,
.blog-card-horizontal:hover .blog-card-horizontal__title a {
    color: var(--blog-color-accent);
}

/* Stretched link - makes entire card clickable */
.blog-card-horizontal__link::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
}

.blog-card-horizontal__excerpt {
    font-family: var(--reading-font);
    font-size: 1rem;
    color: var(--blog-color-text);
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.blog-card-horizontal__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: auto;
}

.blog-card-horizontal__meta {
    font-family: var(--reading-font);
    font-size: 0.875rem;
    color: var(--blog-color-text-light);
}

.blog-card-horizontal__meta-separator {
    margin: 0 0.5rem;
    opacity: 0.5;
}

.blog-card-horizontal__cta {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.9375rem;
    font-weight: 600;
    color: #fff;
    background: var(--blog-color-primary);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border-radius: 100px;
    transition: background var(--blog-transition), gap var(--blog-transition);
}

/* CTA changes on card hover */
.blog-card-horizontal:hover .blog-card-horizontal__cta {
    background: var(--blog-color-accent);
    gap: 0.75rem;
}

.blog-card-horizontal__arrow {
    transition: transform var(--blog-transition);
}

/* Override #content a underline for horizontal cards */
#content .blog-card-horizontal__title a,
#content .blog-card-horizontal__category,
#content .blog-card-horizontal__cta {
    text-decoration: none;
}

/* -----------------------------------------------------------------------------
   404 Error Page
   ----------------------------------------------------------------------------- */
.error-404-section {
    padding: 80px 20px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    min-height: 80vh;
}

.error-404-container {
    max-width: 900px;
    margin: 0 auto;
}

.error-404__header {
    text-align: center;
    margin-bottom: 3rem;
}

.error-404__code {
    display: block;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 8rem;
    font-weight: 900;
    line-height: 1;
    color: var(--blog-color-primary, #2E364C);
    opacity: 0.1;
    margin-bottom: -2rem;
}

.error-404__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--blog-color-primary, #2E364C);
    margin: 0 0 1rem;
}

.error-404__description {
    font-family: var(--reading-font, 'Inter'), sans-serif;
    font-size: 1.125rem;
    color: var(--blog-color-text-light, #718096);
    max-width: 500px;
    margin: 0 auto;
    line-height: 1.7;
}

.error-404__section-title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--blog-color-primary, #2E364C);
    margin: 0 0 1.25rem;
    text-align: center;
}

/* Search Box */
.error-404__search {
    background: #fff;
    padding: 2rem;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    margin-bottom: 2.5rem;
}

.error-404__search-form {
    display: flex;
    gap: 0.75rem;
    max-width: 600px;
    margin: 0 auto;
}

.error-404__search-input {
    flex: 1;
    padding: 1rem 1.25rem;
    font-family: var(--reading-font, 'Inter'), sans-serif;
    font-size: 1rem;
    border: 2px solid #e2e8f0;
    border-radius: 100px;
    outline: none;
    transition: border-color 0.2s ease;
}

.error-404__search-input:focus {
    border-color: var(--blog-color-primary, #2E364C);
}

.error-404__search-button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 1.75rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background: var(--blog-color-primary, #2E364C);
    border: none;
    border-radius: 100px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.error-404__search-button:hover {
    background: var(--blog-color-accent, #FF6D6D);
}

/* Popular Posts */
.error-404__popular {
    margin-bottom: 2.5rem;
}

.error-404__posts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

.error-404__post-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    text-decoration: none;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.error-404__post-card:hover {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
}

.error-404__post-image {
    flex-shrink: 0;
    width: 70px;
    height: 70px;
    border-radius: 8px;
    overflow: hidden;
    background: var(--blog-color-bg-light, #f1f5f9);
}

.error-404__post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.error-404__post-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: rgba(0, 0, 0, 0.1);
    background: linear-gradient(135deg, #1a1a2e 0%, #2d2d44 100%);
    color: rgba(255, 255, 255, 0.2);
}

.error-404__post-content {
    flex: 1;
    min-width: 0;
}

.error-404__post-title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--blog-color-primary, #2E364C);
    margin: 0 0 0.25rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.error-404__post-date {
    font-family: var(--reading-font, 'Inter'), sans-serif;
    font-size: 0.8125rem;
    color: var(--blog-color-text-light, #718096);
}

/* Categories */
.error-404__categories {
    margin-bottom: 2.5rem;
}

.error-404__category-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

.error-404__category-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--blog-color-text, #4a5568);
    background: #fff;
    border-radius: 100px;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    transition: all 0.2s ease;
}

.error-404__category-link:hover {
    background: var(--blog-color-primary, #2E364C);
    color: #fff;
}

.error-404__category-count {
    font-size: 0.75rem;
    padding: 0.125rem 0.5rem;
    background: rgba(0, 0, 0, 0.08);
    border-radius: 100px;
}

.error-404__category-link:hover .error-404__category-count {
    background: rgba(255, 255, 255, 0.2);
}

/* Quick Links */
.error-404__quick-links {
    margin-bottom: 2.5rem;
}

.error-404__links-grid {
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.error-404__quick-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1.5rem 2rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    text-decoration: none;
    transition: all 0.2s ease;
    min-width: 100px;
}

.error-404__quick-link svg {
    color: var(--blog-color-primary, #2E364C);
    transition: color 0.2s ease;
}

.error-404__quick-link span {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--blog-color-text, #4a5568);
    transition: color 0.2s ease;
}

.error-404__quick-link:hover {
    background: var(--blog-color-primary, #2E364C);
    transform: translateY(-2px);
}

.error-404__quick-link:hover svg,
.error-404__quick-link:hover span {
    color: #fff;
}

/* Contact CTA */
.error-404__cta {
    text-align: center;
    padding: 3rem 2rem;
    background: var(--blog-color-primary, #2E364C);
    border-radius: 16px;
    color: #fff;
}

.error-404__cta-title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 0.75rem;
}

.error-404__cta-text {
    font-family: var(--reading-font, 'Inter'), sans-serif;
    font-size: 1rem;
    opacity: 0.9;
    margin: 0 0 1.5rem;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

.error-404__cta-button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem 2rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--blog-color-primary, #2E364C);
    background: #fff;
    border-radius: 100px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.error-404__cta-button:hover {
    background: var(--blog-color-accent, #FF6D6D);
    color: #fff;
    gap: 0.75rem;
}

/* 404 Responsive */
@media (max-width: 768px) {
    .error-404-section {
        padding: 60px 15px;
    }

    .error-404__code {
        font-size: 5rem;
        margin-bottom: -1rem;
    }

    .error-404__title {
        font-size: 1.75rem;
    }

    .error-404__description {
        font-size: 1rem;
    }

    .error-404__search-form {
        flex-direction: column;
    }

    .error-404__search-button {
        justify-content: center;
    }

    .error-404__posts-grid {
        grid-template-columns: 1fr;
    }

    .error-404__links-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }

    .error-404__quick-link {
        padding: 1.25rem 1rem;
    }

    .error-404__cta {
        padding: 2rem 1.5rem;
    }

    .error-404__cta-title {
        font-size: 1.25rem;
    }
}

/* -----------------------------------------------------------------------------
   Blog Single Post
   ----------------------------------------------------------------------------- */
.blog-single-section {
    padding: 60px 20px;
    background: #fff;
}

.blog-single-section #main {
    max-width: 1200px;
    margin: 0 auto;
}

/* Narrower width for posts without TOC sidebar */
.blog-single-section.no-toc #main {
    max-width: var(--blog-max-width);
}

/* Override #content a underline for navigation/card elements */
#content .blog-post-nav a,
#content .blog-related a,
#content .blog-breadcrumbs a,
#content .blog-share a,
#content .blog-single__tags a,
#content .blog-card__title a,
#content .blog-single__category {
    text-decoration: none;
}

/* Breadcrumbs */
.blog-breadcrumbs {
    font-family: var(--reading-font);
    font-size: 0.875rem;
    color: var(--blog-color-text-light);
    margin-bottom: 2rem;
}

.blog-breadcrumbs a {
    color: var(--blog-color-text-light);
    text-decoration: none;
    transition: color var(--blog-transition);
}

.blog-breadcrumbs a:hover {
    color: var(--blog-color-accent);
}

.blog-breadcrumbs__separator {
    margin: 0 0.5rem;
    opacity: 0.5;
}

.blog-breadcrumbs__current {
    color: var(--blog-color-text);
}

/* Single Post Header */
.blog-single__header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.blog-single__meta {
    font-family: var(--reading-font);
    font-size: 0.875rem;
    color: var(--blog-color-text-light);
    margin-bottom: 1rem;
}

.blog-single__category {
    color: var(--blog-color-accent);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
}

.blog-single__category:hover {
    color: #e55555;
}

.blog-single__author {
    color: var(--blog-color-text);
    font-weight: 500;
    text-decoration: none;
    transition: color var(--blog-transition);
}

.blog-single__author:hover {
    color: var(--blog-color-accent);
}

#content .blog-single__author {
    text-decoration: none;
}

.blog-single__meta-separator {
    margin: 0 0.75rem;
    opacity: 0.4;
}

.blog-single__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 2.5rem;
    font-weight: var(--structural-weight) !important;
    line-height: 1.25;
    color: var(--blog-color-primary);
    margin: 0;
    text-transform: none !important;
    letter-spacing: -0.02em;
}

/* Header Tags (subtle pills above title) */
.blog-single__tags-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.blog-single__tag-pill {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--blog-color-text-light, #718096);
    background: var(--blog-color-bg-light, #f1f5f9);
    border-radius: 100px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.blog-single__tag-pill:hover {
    background: var(--blog-color-primary, #2E364C);
    color: #fff;
}

/* Featured Image */
.blog-single__featured-image {
    margin-bottom: 3rem;
    border-radius: var(--blog-card-radius);
    overflow: hidden;
}

.blog-single__featured-image img {
    width: 100%;
    height: auto;
    display: block;
}

/* Reading Progress Bar */
.blog-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: #2E364C;
    /* Match header background */
    z-index: 99999;
    /* Above header */
}

.blog-progress-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: var(--progress, 0%);
    background: var(--blog-color-logo-accent, #f8981d);
    transition: width 0.1s linear;
}

/* Push header down on single posts to make room for progress bar */
.single-post #masthead {
    top: 3px !important;
}

.single-post #masthead.is-stuck {
    top: 3px !important;
}

/* Admin bar adjustments (32px admin bar height) */
.single-post.admin-bar .blog-progress-bar {
    top: 32px;
}

.single-post.admin-bar #masthead {
    top: 35px !important;
    /* 32px admin bar + 3px progress bar */
}

.single-post.admin-bar #masthead.is-stuck {
    top: 35px !important;
}

/* Mobile admin bar is 46px */
@media screen and (max-width: 782px) {
    .single-post.admin-bar .blog-progress-bar {
        top: 46px;
    }

    .single-post.admin-bar #masthead {
        top: 49px !important;
        /* 46px admin bar + 3px progress bar */
    }

    .single-post.admin-bar #masthead.is-stuck {
        top: 49px !important;
    }
}

/* Table of Contents - Layout */
/* Fix sticky positioning - ensure all parents allow it */
body,
html,
#page,
#content,
.blog-single-section,
#primary,
#main,
.blog-single,
.blog-single__layout {
    overflow: visible !important;
    transform: none !important;
    perspective: none !important;
    filter: none !important;
    will-change: auto !important;
    contain: none !important;
}

/* Allow featured image to keep its overflow: hidden for aspect ratio */
.blog-single__featured-image {
    overflow: hidden !important;
}

.blog-single__layout {
    display: block;
    position: relative;
    height: auto;
    min-height: 100%;
}

.blog-single__main {
    width: 100%;
}

/* Desktop Layout with Sidebar */
@media (min-width: 1024px) {
    .blog-single__layout {
        display: flex;
        gap: 2rem;
        align-items: flex-start;
        height: auto;
    }

    .blog-single__main {
        flex: 1;
        min-width: 0;
    }
}

/* Table of Contents - Desktop Sidebar */
.blog-toc-sidebar {
    display: none;
}

@media (min-width: 1024px) {
    .blog-toc-sidebar {
        display: block;
        width: 280px;
        flex-shrink: 0;
        /* CRITICAL: Sidebar container must be taller than sticky element for sticky to work */
        /* It should match the height of the main content column */
        align-self: stretch;
    }

    .blog-toc-sidebar__sticky {
        position: -webkit-sticky !important;
        position: sticky !important;
        top: 100px !important;
        background: var(--blog-color-bg-light);
        border-radius: var(--blog-card-radius);
        padding: 1.5rem;
        max-height: calc(100vh - 120px);
        overflow-y: auto;
        scrollbar-width: thin;
        scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
        z-index: 10;
    }

    .blog-toc-sidebar__sticky::-webkit-scrollbar {
        width: 6px;
    }

    .blog-toc-sidebar__sticky::-webkit-scrollbar-track {
        background: transparent;
    }

    .blog-toc-sidebar__sticky::-webkit-scrollbar-thumb {
        background: rgba(0, 0, 0, 0.2);
        border-radius: 3px;
    }

    .blog-toc-sidebar__sticky::-webkit-scrollbar-thumb:hover {
        background: rgba(0, 0, 0, 0.3);
    }

    .blog-toc-sidebar__title {
        font-family: var(--all_font_family, 'Poppins'), sans-serif;
        font-size: 1rem;
        font-weight: 600;
        color: var(--blog-color-primary);
        margin: 0 0 1rem;
        text-transform: none !important;
    }

    /* Adjust for admin bar */
    .admin-bar .blog-toc-sidebar__sticky {
        top: 132px;
        max-height: calc(100vh - 152px);
    }
}

/* WordPress admin bar - mobile */
@media screen and (min-width: 1024px) and (max-width: 782px) {
    .admin-bar .blog-toc-sidebar__sticky {
        top: 146px;
        max-height: calc(100vh - 166px);
    }
}

/* Table of Contents - Mobile Toggle Button */
.blog-toc-mobile-toggle {
    display: none;
    position: fixed;
    bottom: 80px;
    right: 1.5rem;
    width: 56px;
    height: 56px;
    background: var(--blog-color-primary);
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 999;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.3s ease, transform 0.3s ease, background-color 0.2s ease;
    align-items: center;
    justify-content: center;
}

.blog-toc-mobile-toggle.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.blog-toc-mobile-toggle:hover {
    background: var(--blog-color-accent);
}

@media (max-width: 1023px) {
    .blog-toc-mobile-toggle {
        display: flex;
    }
}

/* Table of Contents - Mobile Drawer */
.blog-toc-drawer {
    position: fixed;
    top: 0;
    right: 0;
    width: 320px;
    max-width: 85vw;
    height: 100vh;
    background: white;
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.15);
    z-index: 10000;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    overflow-y: auto;
}

.blog-toc-drawer.is-open {
    transform: translateX(0);
}

.blog-toc-drawer__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--blog-color-border);
    position: sticky;
    top: 0;
    background: white;
    z-index: 1;
}

.blog-toc-drawer__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--blog-color-primary);
    margin: 0;
    text-transform: none !important;
}

.blog-toc-drawer__close {
    background: none;
    border: none;
    color: var(--blog-color-text);
    cursor: pointer;
    padding: 0.5rem;
    margin: -0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s ease;
}

.blog-toc-drawer__close:hover {
    color: var(--blog-color-primary);
}

.blog-toc-drawer__nav {
    padding: 1.5rem;
}

.blog-toc-drawer__backdrop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.blog-toc-drawer__backdrop.is-visible {
    opacity: 1;
    visibility: visible;
}

@media (min-width: 1024px) {

    .blog-toc-drawer,
    .blog-toc-drawer__backdrop {
        display: none;
    }
}

/* TOC List Styles (Shared) */
.blog-toc__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.blog-toc__item {
    margin-bottom: 0.75rem;
}

/* Three-level hierarchy */
.blog-toc__item--h1 {
    padding-left: 0;
    font-weight: 600;
}

.blog-toc__item--h2 {
    padding-left: 1rem;
}

.blog-toc__item--h3 {
    padding-left: 2rem;
    font-size: 0.875rem;
}

.blog-toc__link {
    display: block;
    font-family: var(--reading-font);
    font-size: 0.9375rem;
    color: var(--blog-color-text);
    text-decoration: none;
    transition: color 0.2s ease, padding-left 0.2s ease;
    line-height: 1.5;
    position: relative;
}

.blog-toc__link:hover {
    color: var(--blog-color-accent);
}

.blog-toc__link.is-active {
    color: var(--blog-color-primary);
    font-weight: 500;
}

/* Active indicator on desktop sidebar */
@media (min-width: 1024px) {
    .blog-toc__link.is-active::before {
        content: '';
        position: absolute;
        left: -1.5rem;
        top: 50%;
        transform: translateY(-50%);
        width: 3px;
        height: 20px;
        background: var(--blog-color-primary);
        border-radius: 2px;
    }
}

/* Single Post Content */
.blog-single__content {
    font-family: var(--reading-font);
    font-size: 1.125rem;
    line-height: var(--reading-leading);
    color: var(--blog-color-text);
}

.blog-single__content p {
    margin-bottom: 1.75rem;
}

.blog-single__content h2,
.blog-single__content h3,
.blog-single__content h4 {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    color: var(--blog-color-primary);
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    font-weight: var(--structural-weight);
    text-transform: none !important;
    line-height: var(--structural-leading);
}

.blog-single__content h2 {
    font-size: 1.75rem;
}

.blog-single__content h3 {
    font-size: 1.5rem;
}

.blog-single__content h4 {
    font-size: 1.25rem;
}

.blog-single__content img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 2rem 0;
}

.blog-single__content img.alignleft {
    float: left;
    margin: 0.5rem 1.5rem 1rem 0;
}

.blog-single__content img.alignright {
    float: right;
    margin: 0.5rem 0 1rem 1.5rem;
}

.blog-single__content img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.blog-single__content blockquote {
    margin: 2rem 0;
    padding: 1.5rem 2rem;
    border-left: 4px solid var(--blog-color-accent);
    background: var(--blog-color-bg-light);
    border-radius: 0 8px 8px 0;
}

.blog-single__content blockquote p {
    margin: 0;
    font-size: 1.125rem;
    font-style: italic;
    color: var(--blog-color-text);
}

.blog-single__content ul,
.blog-single__content ol {
    margin-bottom: 1.75rem;
    padding-left: 1.5rem;
}

.blog-single__content li {
    margin-bottom: 0.5rem;
    line-height: 1.7;
}

/* Drop Cap */
.blog-single__content>p:first-of-type::first-letter {
    float: left;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 4rem;
    font-weight: var(--brand-weight);
    line-height: 0.8;
    padding-right: 0.75rem;
    padding-top: 0.25rem;
    color: var(--blog-color-primary);
}

/* -----------------------------------------------------------------------------
   Blog Social Share
   ----------------------------------------------------------------------------- */
.blog-share {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1.5rem 0;
    margin: 2.5rem 0;
    border-top: 1px solid var(--blog-color-border);
    border-bottom: 1px solid var(--blog-color-border);
}

.blog-share__label {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-color-primary);
}

.blog-share__buttons {
    display: flex;
    gap: 0.5rem;
}

.blog-share__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.8125rem;
    font-weight: 500;
    border-radius: 6px;
    text-decoration: none;
    transition: var(--blog-transition);
    border: none;
    cursor: pointer;
}

.blog-share__btn--linkedin {
    background: #0077b5;
    color: #fff;
}

.blog-share__btn--linkedin:hover {
    background: #005582;
    color: #fff;
}

.blog-share__btn--twitter {
    background: #1da1f2;
    color: #fff;
}

.blog-share__btn--twitter:hover {
    background: #0c85d0;
    color: #fff;
}

.blog-share__btn--facebook {
    background: #1877f2;
    color: #fff;
}

.blog-share__btn--facebook:hover {
    background: #0c5dc7;
    color: #fff;
}

.blog-share__btn--copy {
    background: var(--blog-color-bg-light);
    color: var(--blog-color-text);
}

.blog-share__btn--copy:hover {
    background: var(--blog-color-primary);
    color: #fff;
}

.blog-share__btn.is-copied {
    background: #48bb78;
    color: #fff;
}

/* Toast Notification */
.blog-toast {
    position: fixed;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: #1a1a2e;
    color: #fff;
    padding: 1rem 1.5rem;
    border-radius: 100px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.9375rem;
    font-weight: 500;
    opacity: 0;
    visibility: hidden;
    transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;
    z-index: 9999;
}

.blog-toast.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    visibility: visible;
}

.blog-toast svg {
    color: #48bb78;
    flex-shrink: 0;
}

.blog-toast__message {
    white-space: nowrap;
}

/* -----------------------------------------------------------------------------
   Blog Post Footer
   ----------------------------------------------------------------------------- */
.blog-single__footer {
    margin-top: 3rem;
}

/* Tags */
.blog-single__tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 2rem;
}

.blog-single__tags-label {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--blog-color-primary);
}

.blog-single__tag {
    display: inline-block;
    padding: 0.375rem 0.875rem;
    font-family: var(--reading-font);
    font-size: 0.8125rem;
    background: var(--blog-color-bg-light);
    color: var(--blog-color-text);
    border-radius: 100px;
    text-decoration: none;
    transition: var(--blog-transition);
}

.blog-single__tag:hover {
    background: var(--blog-color-accent);
    color: #fff;
}

/* Author Bio */
.blog-author {
    display: flex;
    gap: 1.5rem;
    padding: 2rem;
    background: var(--blog-color-bg-light);
    border-radius: var(--blog-card-radius);
    text-decoration: none;
    transition: transform var(--blog-transition), box-shadow var(--blog-transition);
}

a.blog-author:hover {
    transform: translateY(-2px);
    box-shadow: var(--blog-shadow-md);
}

#content a.blog-author,
#content a.blog-author:hover {
    text-decoration: none;
    margin-bottom: 2rem;
}

.blog-author__avatar {
    flex-shrink: 0;
}

.blog-author__avatar img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
}

.blog-author__info {
    flex: 1;
}

.blog-author__label {
    font-family: var(--reading-font);
    font-size: 0.8125rem;
    color: var(--blog-color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.blog-author__name {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.25rem;
    font-weight: var(--structural-weight);
    color: var(--blog-color-primary);
    margin: 0.25rem 0 0.5rem;
    text-transform: none !important;
}

.blog-author__bio {
    font-family: var(--reading-font);
    font-size: 0.9375rem;
    color: var(--blog-color-text);
    line-height: 1.6;
    margin: 0;
}

/* -----------------------------------------------------------------------------
   Author Archive Page
   ----------------------------------------------------------------------------- */
.blog-author-archive .blog-archive-grid {
    margin-top: 2rem;
}

.blog-author-header {
    display: flex;
    align-items: flex-start;
    gap: 2rem;
    padding: 3rem;
    background: linear-gradient(135deg, var(--blog-color-primary) 0%, #1a202c 100%);
    border-radius: var(--blog-card-radius);
    margin-bottom: 2rem;
}

.blog-author-header__avatar {
    flex-shrink: 0;
}

.blog-author-header__avatar img {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid rgba(255, 255, 255, 0.2);
}

.blog-author-header__info {
    flex: 1;
}

.blog-author-header__name {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 2rem;
    font-weight: var(--structural-weight);
    color: #fff;
    margin: 0 0 1rem;
    text-transform: none !important;
}

.blog-author-header__bio {
    font-family: var(--reading-font);
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.7;
    margin: 0 0 1rem;
    max-width: 600px;
}

.blog-author-header__meta {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.blog-author-header__post-count {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.7);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Author Archive Responsive */
@media (max-width: 768px) {
    .blog-author-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 2rem;
    }

    .blog-author-header__avatar img {
        width: 120px;
        height: 120px;
    }

    .blog-author-header__name {
        font-size: 1.5rem;
    }

    .blog-author-header__bio {
        font-size: 0.9375rem;
    }

    .blog-author-header__meta {
        justify-content: center;
    }
}

/* Post Navigation */
.blog-single__navigation {
    display: flex;
    justify-content: space-between;
    padding-top: 2rem;
    border-top: 1px solid var(--blog-color-border);
}

.blog-single__nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--blog-color-text);
    text-decoration: none;
    padding: 0.75rem 1.25rem;
    border-radius: 8px;
    transition: var(--blog-transition);
}

.blog-single__nav-link:hover {
    background: var(--blog-color-bg-light);
    color: var(--blog-color-accent);
}

.blog-single__nav-link--next {
    margin-left: auto;
}

.blog-single__nav-arrow {
    font-size: 1.25rem;
}

/* -----------------------------------------------------------------------------
   Blog Post Navigation Cards (Prev/Next)
   ----------------------------------------------------------------------------- */
.blog-post-nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    margin-top: 3rem;
    padding-top: 3rem;
    border-top: 1px solid var(--blog-color-border);
}

.blog-post-nav__card,
.blog-post-nav__card:hover,
.blog-post-nav__card:focus,
.blog-post-nav__card:visited,
#content .blog-post-nav__card {
    display: block;
    text-decoration: none;
    background: #fff;
    border-radius: var(--blog-card-radius);
    overflow: hidden;
    box-shadow: var(--blog-shadow-sm);
    transition: transform var(--blog-transition), box-shadow var(--blog-transition);
}

.blog-post-nav__card:hover {
    transform: translateY(-4px);
    box-shadow: var(--blog-shadow-lg);
}

.blog-post-nav__label {
    display: block;
    padding: 0.75rem 1rem;
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--blog-color-text-light);
    background: var(--blog-color-bg-light);
}

.blog-post-nav__card--prev .blog-post-nav__label {
    text-align: left;
}

.blog-post-nav__card--next .blog-post-nav__label {
    text-align: right;
}

.blog-post-nav__content {
    display: flex;
    gap: 1rem;
    padding: 1rem;
}

.blog-post-nav__card--next .blog-post-nav__content {
    flex-direction: row-reverse;
    text-align: right;
}

.blog-post-nav__image {
    flex-shrink: 0;
    width: 120px;
    border-radius: 8px;
    overflow: hidden;
}

.blog-post-nav__info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.blog-post-nav__category {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--blog-color-accent);
    margin-bottom: 0.25rem;
}

.blog-post-nav__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1rem;
    font-weight: var(--structural-weight);
    line-height: 1.4;
    color: var(--blog-color-primary);
    margin: 0 0 0.25rem;
    text-transform: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-post-nav__card:hover .blog-post-nav__title {
    color: var(--blog-color-accent);
}

.blog-post-nav__date {
    font-family: var(--reading-font);
    font-size: 0.75rem;
    color: var(--blog-color-text-light);
}

/* Single card (only prev or next exists) */
.blog-post-nav__card:only-child {
    grid-column: span 1;
}

.blog-post-nav__card--next:only-child {
    grid-column: 2;
}

/* Responsive */
@media (max-width: 768px) {
    .blog-post-nav {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .blog-post-nav__card--next:only-child {
        grid-column: 1;
    }

    .blog-post-nav__image {
        width: 100px;
    }

    .blog-post-nav__title {
        font-size: 0.9375rem;
    }
}

@media (max-width: 480px) {
    .blog-post-nav__content {
        flex-direction: column;
    }

    .blog-post-nav__card--next .blog-post-nav__content {
        flex-direction: column;
        text-align: left;
    }

    .blog-post-nav__card--next .blog-post-nav__label {
        text-align: left;
    }

    .blog-post-nav__image {
        width: 100%;
        height: 140px;
    }

    .blog-post-nav__image.blog-aspect-ratio--3-2::before {
        padding-top: 50%;
    }
}

/* -----------------------------------------------------------------------------
   Blog Newsletter CTA
   ----------------------------------------------------------------------------- */
.blog-newsletter {
    background: linear-gradient(135deg, var(--blog-color-primary) 0%, #1a202c 100%);
    border-radius: var(--blog-card-radius);
    padding: 3rem;
    margin: 3rem 0;
    text-align: center;
}

.blog-newsletter__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.75rem;
    font-weight: var(--structural-weight);
    color: #fff;
    margin: 0 0 0.75rem;
    text-transform: none !important;
}

.blog-newsletter__description {
    font-family: var(--reading-font);
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.8);
    margin: 0 0 1.5rem;
}

.blog-newsletter__privacy {
    font-family: var(--reading-font);
    font-size: 0.8125rem;
    color: rgba(255, 255, 255, 0.6);
    margin-top: 1rem;
}

/* -----------------------------------------------------------------------------
   Blog Related Posts
   ----------------------------------------------------------------------------- */
.blog-related {
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid var(--blog-color-border);
}

.blog-related__title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1.5rem;
    font-weight: var(--structural-weight);
    color: var(--blog-color-primary);
    margin: 0 0 2rem;
    text-transform: none !important;
}

.blog-related__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.blog-related__item {
    background: #fff;
    border-radius: var(--blog-card-radius);
    overflow: hidden;
    box-shadow: var(--blog-shadow-sm);
    transition: var(--blog-transition);
}

.blog-related__item:hover {
    box-shadow: var(--blog-shadow-md);
}

.blog-related__image {
    border-radius: 8px;
}

/* Image styles now handled by .blog-aspect-ratio and .blog-featured-image utilities */

.blog-related__content {
    padding: 1rem 1.25rem;
}

.blog-related__item-title {
    font-family: var(--all_font_family, 'Poppins'), sans-serif;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.4;
    margin: 0 0 0.5rem;
    text-transform: none !important;
}

.blog-related__item-title a {
    color: var(--blog-color-primary);
    text-decoration: none;
    transition: color var(--blog-transition);
}

.blog-related__item-title a:hover {
    color: var(--blog-color-accent);
}

.blog-related__date {
    font-family: var(--reading-font);
    font-size: 0.8125rem;
    color: var(--blog-color-text-light);
}

/* Back to Top Button */
.blog-back-to-top {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 48px;
    height: 48px;
    background: var(--blog-color-primary);
    color: #fff;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: var(--blog-transition);
    box-shadow: var(--blog-shadow-md);
    z-index: 999;
}

.blog-back-to-top:hover {
    background: var(--blog-color-accent);
    transform: translateY(-2px);
}

.blog-back-to-top.is-visible {
    opacity: 1;
    visibility: visible;
}

/* ==========================================================================
   BLOG RESPONSIVE STYLES
   ========================================================================== */

/* Tablet - 2 column grid */
@media (max-width: 1024px) {
    .blog-archive-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }

    .blog-related__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .blog-single__title {
        font-size: 2rem;
    }

    /* Horizontal cards - smaller image */
    .blog-card-horizontal {
        grid-template-columns: 320px 1fr;
    }

    .blog-card-horizontal__image {
        min-height: 240px;
    }

    .blog-card-horizontal__content {
        padding: 1.5rem 2rem;
    }

    .blog-card-horizontal__title {
        font-size: 1.35rem;
    }
}

/* Medium tablets - stack horizontal cards */
@media (max-width: 900px) {
    .blog-card-horizontal {
        grid-template-columns: 1fr;
    }

    .blog-card-horizontal__image {
        min-height: 220px;
    }
}

/* Mobile */
@media (max-width: 768px) {

    .blog-archive-section,
    .blog-single-section {
        padding: 40px 15px;
    }

    .blog-archive__title {
        font-size: 2rem;
    }

    .blog-archive-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .blog-category-filter {
        gap: 0.375rem;
    }

    .blog-category-filter__item {
        font-size: 0.8125rem;
        padding: 0.375rem 1rem;
    }

    .blog-tag-filter {
        gap: 0.25rem;
    }

    .blog-tag-filter__item {
        font-size: 0.6875rem;
        padding: 0.3rem 0.75rem;
    }

    .blog-card__content {
        padding: 1.25rem;
    }

    .blog-card__title {
        font-size: 1.125rem;
    }

    /* Horizontal cards - stack vertically on mobile */
    .blog-card-horizontal {
        grid-template-columns: 1fr;
    }

    .blog-card-horizontal__image {
        min-height: 200px;
    }

    .blog-card-horizontal__content {
        padding: 1.5rem;
    }

    .blog-card-horizontal__title {
        font-size: 1.25rem;
    }

    .blog-card-horizontal__excerpt {
        font-size: 0.9375rem;
        margin-bottom: 1rem;
    }

    .blog-card-horizontal__footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .blog-card-horizontal__cta {
        width: 100%;
        justify-content: center;
    }

    .blog-single__title {
        font-size: 1.75rem;
    }

    .blog-single__content {
        font-size: 1rem;
    }

    .blog-single__content h2 {
        font-size: 1.5rem;
    }

    .blog-single__content h3 {
        font-size: 1.25rem;
    }

    .blog-single__content>p:first-of-type::first-letter {
        font-size: 3rem;
    }

    .blog-share {
        flex-direction: column;
        align-items: flex-start;
    }

    .blog-author {
        flex-direction: column;
        text-align: center;
        padding: 1.5rem;
    }

    .blog-author__avatar img {
        width: 64px;
        height: 64px;
    }

    .blog-single__navigation {
        flex-direction: column;
        gap: 1rem;
    }

    .blog-single__nav-link--next {
        margin-left: 0;
    }

    .blog-newsletter {
        padding: 2rem 1.5rem;
    }

    .blog-newsletter__title {
        font-size: 1.5rem;
    }

    .blog-related__grid {
        grid-template-columns: 1fr;
    }

    .blog-related__title {
        font-size: 1.25rem;
    }

    .blog-back-to-top {
        width: 40px;
        height: 40px;
        bottom: 1rem;
        right: 1rem;
    }
}

/* Small Mobile */
@media (max-width: 480px) {
    .blog-single__title {
        font-size: 1.5rem;
    }

    .blog-single__meta {
        font-size: 0.8125rem;
    }

    .blog-toc-mobile-toggle {
        bottom: 70px;
        right: 1rem;
        width: 50px;
        height: 50px;
    }

    .blog-toc-drawer {
        width: 280px;
    }

    .blog-share__buttons {
        flex-wrap: wrap;
    }

    .blog-share__btn {
        font-size: 0.75rem;
        padding: 0.375rem 0.75rem;
    }
}

/* ==========================================================================
   END BLOG STYLES
   ========================================================================== */

@media (max-width: 767px) {
    .mobile-table {
        display: block;
    }

    .desktop-table {
        display: none;
    }

    .how-it-works-row {
        display: block;
        padding-right: 15px;
        padding-left: 15px;
    }

    .how-it-works-card {
        margin-top: 30px;
    }

    .center-image {
        text-align: center !important;
    }
}

@media (max-width: 1280px) {
    body h1 {
        font-size: 40px;
    }

    body h2 {
        font-size: 36px;
    }

    body h4 {
        font-size: 27px;
    }

    .logo-items {
        justify-content: center;
    }

    .workshop-content h2 {
        margin-bottom: 30px;
    }

    .workshop-content h4 {
        margin-bottom: 30px;
    }

    .workshop-content {
        padding-right: 10%;
    }

    body #menu-wrapper>div {
        width: 100%;
        padding: 10px;
        text-align: center;
    }

    ul#mobile_menu li a {
        color: #fff !important;
        font-weight: 500;
    }

    body #menu-wrapper {
        justify-content: flex-start;
    }

    body #mobile_menu {
        padding: 20px 0 !important;
    }

    /*    body #menu-wrapper ul{
        justify-content: flex-start;
    }*/
    section.web-cta-cover {
        padding: 90px 0;
    }

    .web-content-area h2 {
        font-size: 46px;
    }

    .mb-5,
    .my-5 {
        margin-bottom: 2rem !important;
    }
}

@media (max-width: 1199px) {
    slide-drawer {
        display: block;
    }

    body h1 {
        font-size: 40x;
    }

    .workshop-content {
        width: 50%;
        padding-right: 30px;
    }

    .workshop-img {
        width: 50%;
    }

    .content-inner p {
        font-size: 26px;
    }

    .bottom-content-section p {
        font-size: 26px;
    }

    .workshop-cover {
        padding: 100px 0;
    }

    .stage-title h3 {
        font-size: 28px;
    }

    .stages-inner>.d-flex {
        margin: 60px auto;
    }

    .content-inner {
        padding: 70px 0;
    }

    .content-inner {
        min-height: 1px;
    }

    .hero-inner {
        min-height: 70vh;
    }

    #menu-footer-menu li a {
        padding: 0 10px;
    }

    .post-cpt-item {
        margin: 80px 0;
    }

    .web-content-area section {
        padding: 60px 0;
    }

    .web-content-area h2 {
        font-size: 42px;
    }

    .web-stage-cover h3 {
        font-size: 28px;
    }

    .pre-footer-inner p {
        font-size: 18px;
    }
}

@media (max-width: 1023px) {
    body h2 {
        font-size: 40px;
    }

    .stage-title h3 {
        font-size: 24px;
    }

    body h4 {
        font-size: 24px;
    }

    .workshop-content .btn {
        padding-left: 30px;
        padding-right: 30px;
    }

    .inner-banner {
        min-height: 40vh;
    }

    .single-content-item {
        width: 60%;
        padding-right: 20px;
    }

    .single-sidebar {
        width: 40%;
    }

    .single-page-content {
        padding: 70px 0px;
    }

    .download-btn {
        font-size: 22px;
    }

    .single-content-item h1 {
        font-size: 28px;
    }

    .post-item-img {
        width: 340px;
    }

    .post-item-content {
        width: calc(100% - 340px);
        padding-left: 30px;
    }

    .post-cpt-item {
        margin: 60px 0;
    }

    .web-content-area p {
        font-size: 16px;
    }
}

@media (max-width: 980px) {
    .practice-item:before {
        left: 0;
        margin: 0 auto;
        top: auto;
        bottom: -20px;
        transform: rotate(90deg);
        right: 0;
    }

    .practice-item {
        padding-bottom: 40px;
        margin-bottom: 20px;
    }

    .practice-item:last-child {
        padding-bottom: 0;
        margin-bottom: 0;
    }

    .web-content-area h2 {
        font-size: 36px;
    }

    .web-hero-item-block {
        height: auto !important;
    }

    .web-hero-img {
        border-left: 0;
        height: auto;
        width: 100%;
        min-height: 100vw;
    }

    .authority-amplifier img {
        max-width: 150px;
    }

    .web-content-area p {
        font-size: 15px;
    }

    .web-hero-arrow {
        text-align: center;
    }

    .calBlock-item {
        margin-bottom: 15px;
    }

    .marketItem-inner {
        margin-top: 20px;
    }
}

@media (max-width: 767px) {
    .team-content-column {
        padding-left: 0px !important;
    }

    .team-member-row {
        margin-top: 100px;
    }

    .team-member-row:last-child {
        margin-bottom: 100px !important;
    }

    html body,
    p {
        font-size: 16px;
    }

    body h1 {
        font-size: 34px;
    }

    body h2 {
        font-size: 30px;
    }

    body h3 {
        font-size: 24px;
    }

    body h4 {
        font-size: 22px;
    }

    .hero-inner-item .btn {
        font-size: 14px;
        padding-left: 30px;
        padding-right: 30px;
        margin-top: 10px;
    }

    .hero-inner-item p {
        font-size: 16px;
    }

    .hero-inner {
        padding: 80px 0;
    }

    .logo-item {
        max-width: 33.33%;
    }

    .stages-content {
        width: 100%;
        margin-bottom: 20px;
    }

    .stages-img {
        width: 100%;
    }

    .stages-img img {
        max-width: 100%;
    }

    .stages-inner>.d-flex {
        margin: 30px auto;
    }

    .stages-inner>.d-flex:nth-child(even) .stages-img {
        order: 0;
    }

    .stages-inner>.d-flex:nth-child(even) .stages-content-inner {
        padding-left: 0;
        margin-left: 0;
    }

    .stages-content-inner {
        padding-right: 0;
    }

    .workshop-img {
        width: 100%;
    }

    .workshop-content {
        width: 100%;
        padding-right: 0;
        margin-bottom: 20px;
    }

    .workshop-content ol {
        margin-bottom: 30px;
    }

    .content-inner {
        min-height: 1px;
    }

    .content-inner p {
        font-size: 18px;
    }

    .bottom-content-section p {
        font-size: 18px;
    }

    .content-inner {
        padding: 50px 0;
    }

    .intro-heading p {
        font-size: 16px;
    }

    div.content-bottom-only {
        padding: 60px 0 !important;
    }

    div.inner-banner {
        padding-bottom: 30px !important;
        padding-top: 120px !important;
        min-height: 1px;
    }

    .workshop-cpt-content-left {
        width: 100%;
        padding-right: 0;
    }

    .workshop-img-right {
        width: 100%;
        order: -1;
        margin-bottom: 30px;
    }

    .inner-banner .vc_column-inner {
        padding-left: 0;
        padding-right: 0;
    }

    div.workshop-padding {
        margin: 60px 0 !important;
    }

    .workshop-items-text {
        margin-bottom: 40px;
    }

    .single-content-item {
        width: 100%;
        padding-right: 0;
        margin-bottom: 40px;
    }

    .single-sidebar {
        width: 100%;
    }

    .custom-inner-banner {
        padding-top: 125px;
        padding-bottom: 40px;
    }

    .mobile-order-1 {
        order: -1;
    }

    .stages-content-inner .btn {
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .stage-title {
        padding-left: 15px;
    }

    .intro-heading {
        margin-bottom: 20px;
    }

    .vc_custom_1638967523607 {
        padding-top: 50px !important;
        padding-bottom: 50px !important;
    }

    .single-content-img {
        padding: 10px;
    }

    .single-content-item h1 {
        font-size: 24px;
        margin-bottom: 20px;
    }

    .single-post .single-page-content {
        margin-top: 40px;
    }

    .single-content-img {
        margin-bottom: 30px;
    }

    #menu-footer-menu li a {
        font-size: 14px;
    }

    .post-item-img {
        width: 100%;
    }

    .post-item-content {
        width: 100%;
        padding-left: 0;
        margin-top: 30px;
    }

    .post-item-content .btn {
        padding-top: 12px;
        padding-bottom: 12px;
    }

    .web-content-area h6 {
        font-size: 14px;
    }

    .web-stage-cover h3 {
        font-size: 24px;
    }

    .web-content-area h2 {
        font-size: 32px;
    }

    .web-content-area section {
        padding: 40px 0;
    }

    .btn {
        border-width: 2px !important;
        font-size: 14px;
    }

    .web-content-area p {
        font-size: 15px;
    }

    .authority-amplifier img {
        max-width: 110px;
        margin: 10px !important;
    }

    .web-content-area h2 {
        font-size: 26px;
    }

    .web-content-area .btn {
        letter-spacing: .08em;
    }

    .intro-max-block p {
        font-size: 16px;
    }

    .marketItem-inner {
        animation: fadevisible 0.6s ease;
        transform-origin: center;
        display: none;
    }

    @keyframes fadevisible {
        0% {
            transform: scale(0.6);
        }

        100% {
            transform: scale(1);
        }
    }

    .marketItem-inner.active {
        display: block;
    }
}

@media (max-width: 640px) {
    .intro-block {
        width: calc(100% - 40px);
    }

    img#site_logo {
        max-width: 160px !important;
    }

    .hero-inner {
        padding: 90px 0 50px;
    }

    .logo-item {
        max-width: 50%;
        padding: 14px;
    }

    .intro-cover {
        padding: 60px 0 40px;
    }

    .stages-content-item p {
        font-size: 16px;
    }

    .stage-title h3 {
        font-size: 24px;
    }

    .workshop-cover {
        padding: 70px 0;
    }

    .workshop-content .btn {
        width: auto;
    }

    #menu-footer-menu li {
        width: 100% !important;
        padding: 10px;
    }

    body #menu-wrapper li a {
        padding: 10px 20px;
    }

    div.inner-banner {
        padding-bottom: 10px !important;
        padding-top: 90px !important;
    }

    .workshop-cpt-content .btn {
        width: 100%;
    }

    .download-btn {
        font-size: 18px;
        background-size: 22px;
        padding-right: 35px;
    }

    body h1 {
        font-size: 30px;
    }

    .single-content-img {
        padding: 7px;
    }

    .single-content-item h1 {
        font-size: 22px;
    }

    .stage-explainer-banner-inner {
        padding: 50px 0;
    }

    .stage-explainer-banner-inner img {
        padding: 20px 0;
    }

    .stages-content {
        top: 100px;
    }

    .stages-img {
        margin-bottom: 40px;
    }

    .stages-content-block {
        flex-direction: column-reverse;
    }

    .stages-content-item {
        margin-bottom: 100px;
    }

    .stage-explainer-banner-inner h1 {
        font-size: 30px;
    }

    .stage-explainer-banner-inner h1 span {
        font-size: 30px;
    }

    .tools-and-guides-sticky-sidebar {
        padding: 8px;
    }

    .tools_and_guides-template-default .single-page-content .container {
        padding: 0;
    }

    .inner-banner .wpb_column {
        padding: 10px;
    }

    .stages-content-block:last-child .stages-content-item {
        margin-bottom: 0 !important;
    }

    .intro-block {
        padding-right: 0;
    }

    .pre-footer-cover {
        padding: 60px 0 !important;
    }
}

@media (max-width: 480px) {
    .stage-block-content-item {
        width: 100%;
        margin-left: 0 !important;
        margin-top: 7px;
    }

    .price-card-icons img {
        max-width: 55px;
    }

    .price-card-icons {
        margin-top: -27px;
    }
}

.btn.btn-outline {
    background: none !important;
    color: var(--primary_color);
}

.row {
    margin-right: inherit;
    margin-left: inherit;
}

.btn-disabled {
    opacity: 0.2;
}


.quote-intro {
    margin-top: -60px !important;
}


.custom-quote-template-default {
    background: #2e364c;

}

.custom-quote-template-default h1 {
    text-transform: uppercase;
}



.custom-quote-template-default p,
.custom-quote-template-default h1,
.custom-quote-template-default h2,
.custom-quote-template-default h3,
.custom-quote-template-default h4,
.custom-quote-template-default h5,
.custom-quote-template-default h6,
.custom-quote-template-default li {
    color: white;
}

.custom-quote-template-default h2,
.custom-quote-template-default h3,
.custom-quote-template-default h4,
.custom-quote-template-default h5,
.custom-quote-template-default h6 {
    font-weight: 500;
}


.custom-quote-template-default #content li,
.custom-quote-template-default #content p {
    line-height: 140%;
}






@media all and (max-width: 600px) and (min-width:200px) {

    #content .btn,
    #content a.btn {
        width: 100%;
        padding: 10px 15px;
    }

    .custom-inner-banner-item {
        padding: 20px;
    }

    .stage-explainer-banner {
        left: 0px !important;
    }

    .intro-block {
        padding-top: 60px;
    }
}

table tr td {
    border: 1px solid white;
    color: white;
    padding: 10px;
}

.frm_form_field .frm_checkbox,
.frm_form_field .frm_checkbox+.frm_checkbox,
.frm_form_field .frm_radio,
.frm_form_field .frm_radio+.frm_radio {
    margin: 10px 0;
}