/* =============================================================================
 * MODULAR CSS IMPORTS
 * Phase 2: Extracted component-specific stylesheets
 * ============================================================================= */

@import url('tl-tables.css');

/* =============================================================================
 * PAGE-SPECIFIC LAYOUTS AND STYLING
 * ============================================================================= */

/* =============================================================================
 * 15-17. LAYOUT, SIDEBAR, SECTIONS
 * Page wrapper, header, navigation, footer, hero, CTA, portfolio blocks
 * ============================================================================= */
img {
    display: block;
    max-width: 100%;
    height: auto;
}
ul {
    list-style: square;
}
.list,
.list-icons {
    list-style: none;
    padding: 0;
}
.list li,
.list-icons li {
    padding: 5px 0;
}
.list-icons li i {
    min-width: 25px;
    text-align: center;
}
.list-inline {
    margin-top: 9px;
    margin-bottom: 8px;
}
.tl-header-top .list-inline {
    display: inline-block;
}
@media (min-width: 992px) and (max-width: 1199px) {
    .tl-header-top .list-inline > li {
        padding: 0;
    }
}
.table:not(.table-bordered) {
    border-bottom: 2px solid #f3f3f3;
    border-top: none;
}
.page-wrapper {
    background-color: var(--tl-body-bg);
}
.tl-header-top:not(.banner) {
    background-color: #f2f2f2;
    border-bottom: 1px solid #d0d0d0;
    padding: 4px 0;
}
.tl-header {
    border-top: 1px solid #fff;
    border-bottom: 2px solid #f1f1f1;
    background-color: #fcfcfc;
}
.tl-header.dark {
    border-bottom: none;
}
.tl-header-top.dark + .tl-header:not(.dark) {
    border-top-color: #ddd;
}
.tl-header-top:not(.dark) + .tl-header.dark {
    border-top-color: #303030;
}
.tl-header.tl-header-small {
    padding: 10px 0;
}
.dark .footer {
    background-color: #222;
}
.dark 
.scroll-spy .banner {
    min-height: 100px;
}
.banner.dark-translucent-bg,
.banner.default-translucent-bg,
.banner.light-translucent-bg {
    min-height: 250px;
    padding-top: 60px;
    padding-bottom: 20px;
}
.banner.banner-big-height {
    min-height: 550px;
    padding-top: 100px;
}
.main-container {
    padding: 50px 0;
}
.block {
    margin-bottom: 50px;
}
.section {
    padding: 20px 0;
}
.footer-top {
    padding: 20px 0;
}
.footer {
    padding: 40px 0;
    background-color: #fafafa;
}
.footer-content {
    padding: 20px 0;
}

@media (max-width: 991px) {
    .tl-sidebar {
        margin-top: 40px;
    }
    .footer-content {
        padding: 10px 0;
    }
}
@media (max-width: 767px) {
    .tl-header.full-width {
        padding: 0 15px;
    }
}
.tl-boxed .page-wrapper {
    margin-right: auto;
    margin-left: auto;
    position: relative;
    -webkit-box-shadow: 0 0 10px #cacaca;
    box-shadow: 0 0 10px #cacaca;
}
@media (min-width: 768px) {
    .tl-boxed .page-wrapper {
        width: 750px;
    }
}
@media (min-width: 992px) {
    .tl-boxed .page-wrapper {
        width: 970px;
    }
}
@media (min-width: 1200px) {
    .tl-boxed .page-wrapper {
        width: 1170px;
    }
}
.white-bg {
    background-color: #fff;
}
.light-gray-bg {
    background-color: #fafafa;
    border-top: 1px solid #f3f3f3;
    border-bottom: 1px solid #f3f3f3;
}
.footer-top.light-gray-bg {
    background-color: #f5f5f5;
    border-top: 1px solid #eaeaea;
    border-bottom: 1px solid #eaeaea;
}
.dark-bg {
    background-color: #373737;
    color: #cdcdcd;
}
.dark-bg + .dark-bg:not(.tl-image-box) {
    background-color: #555;
}
.dark-bg + .dark-bg + .dark-bg {
    background-color: #373737;
}
.dark-bg h1,
.dark-bg h2,
.dark-bg h3,
.dark-bg h4,
.dark-bg h5,
.dark-bg h6 {
    color: #fff;
}
.dark-bg a:not(.btn) {
    text-decoration: underline;
    color: #cdcdcd;
}
.dark-bg a:not(.btn):hover {
    text-decoration: none;
    color: #cdcdcd;
}
.default-bg {
    color: #fff;
}
.default-bg h1,
.default-bg h2,
.default-bg h3,
.default-bg h4,
.default-bg h5,
.default-bg h6 {
    color: #fff;
}
.default-bg a:not(.btn) {
    text-decoration: underline;
    color: #fff;
}
.default-bg a:not(.btn):hover {
    text-decoration: none;
    color: #fff;
}
.fixed-bg {
    background-attachment: fixed;
    background-position: 0 0;
    background-size: cover;
}
.dark-translucent-bg,
.default-translucent-bg,
.light-translucent-bg,
.tl-two-col-translucent-bg {
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-position: 50% 0;
    background-repeat: no-repeat;
    z-index: 1;
    position: relative;
    overflow: hidden;
}
.dark-translucent-bg:after,
.default-translucent-bg:after,
.light-translucent-bg:after,
.tl-two-col-translucent-bg:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0) scale(1, 1);
}
.dark-translucent-bg > div,
.default-translucent-bg > div,
.light-translucent-bg > div,
.tl-two-col-translucent-bg > div {
    z-index: 3;
    position: relative;
}
.light-translucent-bg {
    color: #333;
    border-bottom: 1px solid #dadada;
    border-top: 1px solid #dadada;
}
.light-translucent-bg:after {
    background-color: rgba(255, 255, 255, 0.7);
}
.light-translucent-bg.slight:after {
    background-color: rgba(255, 255, 255, 0.85);
}
.light-translucent-bg.hovered:hover:after {
    background-color: rgba(255, 255, 255, 0.8);
}
.dark-translucent-bg:after {
    background-color: rgba(0, 0, 0, 0.5);
}
.dark-translucent-bg.hovered:hover:after {
    background-color: rgba(0, 0, 0, 0.6);
}
.dark-translucent-bg,
.dark-translucent-bg h1,
.dark-translucent-bg h2,
.dark-translucent-bg h3,
.dark-translucent-bg h4,
.dark-translucent-bg h5,
.dark-translucent-bg h6 {
    color: #fff;
}
.dark-translucent-bg a:not(.btn) {
    text-decoration: underline;
    color: #fff;
}
.dark-translucent-bg a:not(.btn):hover {
    text-decoration: none;
    color: #fff;
}
.tl-two-col-translucent-bg {
    color: #333;
}
.tl-two-col-translucent-bg:after {
    background-color: rgba(255, 255, 255, 0.7);
}
@media (min-width: 992px) {
    .tl-two-col-translucent-bg:after {
        background: -moz-linear-gradient(
            left,
            rgba(255, 255, 255, 0.7) 50%,
            rgba(0, 0, 0, 0.5) 50%
        );
        background: -webkit-gradient(left, rgba(255, 255, 255, 0.7) 50%, rgba(0, 0, 0, 0.5) 50%);
        background: -webkit-linear-gradient(
            left,
            rgba(255, 255, 255, 0.7) 50%,
            rgba(0, 0, 0, 0.5) 50%
        );
        background: -o-linear-gradient(left, rgba(255, 255, 255, 0.7) 50%, rgba(0, 0, 0, 0.5) 50%);
        background: -ms-linear-gradient(left, rgba(255, 255, 255, 0.7) 50%, rgba(0, 0, 0, 0.5) 50%);
        background: linear-gradient(to right, rgba(255, 255, 255, 0.7) 50%, rgba(0, 0, 0, 0.5) 50%);
    }
    .tl-two-col-translucent-bg .container > .row > div + div,
    .tl-two-col-translucent-bg .container > .row > div + div h1,
    .tl-two-col-translucent-bg .container > .row > div + div h2,
    .tl-two-col-translucent-bg .container > .row > div + div h3,
    .tl-two-col-translucent-bg .container > .row > div + div h4,
    .tl-two-col-translucent-bg .container > .row > div + div h5,
    .tl-two-col-translucent-bg .container > .row > div + div h6 {
        color: #fff;
    }
    .tl-two-col-translucent-bg .container > .row > div + div a:not(.btn) {
        text-decoration: underline;
        color: #fff;
    }
    .tl-two-col-translucent-bg .container > .row > div + div a:not(.btn):hover {
        text-decoration: none;
        color: #fff;
    }
}
.default-translucent-bg,
.default-translucent-bg h1,
.default-translucent-bg h2,
.default-translucent-bg h3,
.default-translucent-bg h4,
.default-translucent-bg h5,
.default-translucent-bg h6 {
    color: #fff;
}
.default-translucent-bg a:not(.btn) {
    text-decoration: underline;
    color: #fff;
}
.default-translucent-bg a:not(.btn):hover {
    text-decoration: none;
    color: #fff;
}
.default-hovered {
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.light-gray-bg.default-hovered:hover * {
    color: #fff;
}
.position-bottom {
    position: absolute !important;
    bottom: 0;
    width: 100%;
}
.tl-animated-text {
    overflow: hidden;
}
@media (min-width: 768px) {
    .tl-animated-text h2 {
        -webkit-transition: all 0.2s ease-in-out;
        -o-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
        position: absolute;
        top: 0;
        width: 100%;
    }
    .tl-animated-text h2 + h2 {
        opacity: 0;
        -webkit-transform: scale(1.15);
        -moz-transform: scale(1.15);
        -ms-transform: scale(1.15);
        -o-transform: scale(1.15);
        transform: scale(1.15);
    }
    .tl-animated-text:hover h2 {
        opacity: 0;
        -webkit-transform: scale(0.85);
        -moz-transform: scale(0.85);
        -ms-transform: scale(0.85);
        -o-transform: scale(0.85);
        transform: scale(0.85);
    }
    .tl-animated-text:hover h2 + h2 {
        opacity: 1;
        -webkit-transform: scale(1);
        -moz-transform: scale(1);
        -ms-transform: scale(1);
        -o-transform: scale(1);
        transform: scale(1);
    }
}
@media (max-width: 767px) {
    .tl-animated-text h2 + h2 {
        display: none;
    }
}
.tl-fixed-header-on .tl-header.fixed {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 1006;
    opacity: 0;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
}
.tl-fixed-header-on .tl-header.fixed.object-visible {
    opacity: 1;
}
.tl-fixed-header-on .tl-header.fixed.hc-element-visible {
    opacity: 1;
}
.tl-fixed-header-on .tl-header.fixed:not(.dark) {
    border-bottom: 1px solid #f1f1f1;
    background-color: rgba(255, 255, 255, 0.95);
}
.tl-fixed-header-on.tl-boxed .tl-header.fixed {
    left: auto;
    -webkit-transition: left linear 0s !important;
    -o-transition: left linear 0s !important;
    transition: left linear 0s !important;
}
.tl-fixed-header-on .tl-header .logo {
    margin-bottom: -2px;
}
.tl-fixed-header-on .tl-header.fixed.animated {
    -webkit-animation-duration: 0.4s;
    animation-duration: 0.4s;
}
.tl-fixed-header-on .tl-header-dropdown-buttons {
    padding-top: 10px;
}
.tl-fixed-header-on .tl-header-dropdown-buttons .btn-group .dropdown-menu {
    margin-top: 17px;
}
.tl-fixed-header-on .dark .tl-header-dropdown-buttons .btn-group .dropdown-menu {
    margin-top: 16px;
}
@media (min-width: 768px) {
    .tl-fixed-header-on.tl-boxed .tl-header.fixed {
        width: 750px;
    }
}
@media (min-width: 992px) {
    .tl-fixed-header-on .tl-header .logo,
    .tl-fixed-header-on .tl-header .site-slogan {
        display: block;
    }
    .tl-fixed-header-on.tl-boxed .tl-header.fixed {
        width: 970px;
    }
    .tl-fixed-header-on .tl-header-first {
        padding: 7px 0 0 0;
        -webkit-transition: all 0.2s ease-in-out;
        -o-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
    }
    .tl-fixed-header-on .tl-main-navigation .navbar-nav > li > a {
        padding-top: 21px;
        padding-bottom: 21px;
    }
    .fixed.tl-header .tl-main-navigation.animated .navbar-nav > li > a {
        -webkit-transition: all 0.2s ease-in-out;
        -o-transition: all 0.2s ease-in-out;
        transition: all 0.2s ease-in-out;
    }
}
@media (min-width: 1200px) {
    .tl-fixed-header-on.tl-boxed .tl-header.fixed {
        width: 1170px;
    }
}
.separator {
    width: 100%;
    margin: 20px auto 15px;
    position: relative;
    height: 1px;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0) scale(1, 1);
}
.separator:after {
    height: 1px;
    background: #e8e8e8;
    background: -moz-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 35%,
        rgba(0, 0, 0, 0.09) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, transparent),
        color-stop(35%, rgba(0, 0, 0, 0.09)),
        color-stop(70%, rgba(0, 0, 0, 0.09)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 35%,
        rgba(0, 0, 0, 0.09) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 35%,
        rgba(0, 0, 0, 0.09) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 35%,
        rgba(0, 0, 0, 0.09) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        transparent 0,
        rgba(0, 0, 0, 0.09) 35%,
        rgba(0, 0, 0, 0.09) 70%,
        transparent 100%
    );
    position: absolute;
    bottom: -1px;
    content: "";
    width: 100%;
    left: 0;
}
.dark-bg:not(.banner) .separator:after {
    background: #505050;
    background: -moz-linear-gradient(left, #373737 0, #505050 35%, #505050 70%, #373737 100%);
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #373737),
        color-stop(35%, #505050),
        color-stop(70%, #505050),
        color-stop(100%, #373737)
    );
    background: -webkit-linear-gradient(left, #373737 0, #505050 35%, #505050 70%, #373737 100%);
    background: -o-linear-gradient(left, #373737 0, #505050 35%, #505050 70%, #373737 100%);
    background: -ms-linear-gradient(left, #373737 0, #505050 35%, #505050 70%, #373737 100%);
    background: linear-gradient(to right, #373737 0, #505050 35%, #505050 70%, #373737 100%);
}
#footer.dark .separator:after {
    background: #505050;
    background: -moz-linear-gradient(left, #222 0, #505050 35%, #505050 70%, #222 100%);
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #222),
        color-stop(35%, #505050),
        color-stop(70%, #505050),
        color-stop(100%, #222)
    );
    background: -webkit-linear-gradient(left, #222 0, #505050 35%, #505050 70%, #222 100%);
    background: -o-linear-gradient(left, #222 0, #505050 35%, #505050 70%, #222 100%);
    background: -ms-linear-gradient(left, #222 0, #505050 35%, #505050 70%, #222 100%);
    background: linear-gradient(to right, #222 0, #505050 35%, #505050 70%, #222 100%);
}
.dark-translucent-bg .separator:after,
.default-bg .separator:after,
.default-translucent-bg .separator:after,
.light.separator:after {
    background: rgba(255, 255, 255, 0.5);
    background: -moz-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 35%,
        rgba(255, 255, 255, 0.5) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, rgba(255, 255, 255, 0)),
        color-stop(35%, rgba(255, 255, 255, 0.5)),
        color-stop(70%, rgba(255, 255, 255, 0.5)),
        color-stop(100%, rgba(255, 255, 255, 0))
    );
    background: -webkit-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 35%,
        rgba(255, 255, 255, 0.5) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -o-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 35%,
        rgba(255, 255, 255, 0.5) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -ms-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 35%,
        rgba(255, 255, 255, 0.5) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: linear-gradient(
        to right,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 35%,
        rgba(255, 255, 255, 0.5) 70%,
        rgba(255, 255, 255, 0) 100%
    );
}
@media (min-width: 992px) {
    .tl-two-col-translucent-bg .container > .row > div + div .separator:after {
        background: rgba(255, 255, 255, 0.5);
        background: -moz-linear-gradient(
            left,
            rgba(255, 255, 255, 0) 0,
            rgba(255, 255, 255, 0.5) 35%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -webkit-gradient(
            linear,
            left top,
            right top,
            color-stop(0, rgba(255, 255, 255, 0)),
            color-stop(35%, rgba(255, 255, 255, 0.5)),
            color-stop(70%, rgba(255, 255, 255, 0.5)),
            color-stop(100%, rgba(255, 255, 255, 0))
        );
        background: -webkit-linear-gradient(
            left,
            rgba(255, 255, 255, 0) 0,
            rgba(255, 255, 255, 0.5) 35%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -o-linear-gradient(
            left,
            rgba(255, 255, 255, 0) 0,
            rgba(255, 255, 255, 0.5) 35%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -ms-linear-gradient(
            left,
            rgba(255, 255, 255, 0) 0,
            rgba(255, 255, 255, 0.5) 35%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: linear-gradient(
            to right,
            rgba(255, 255, 255, 0) 0,
            rgba(255, 255, 255, 0.5) 35%,
            rgba(255, 255, 255, 0.5) 70%,
            rgba(255, 255, 255, 0) 100%
        );
    }
}
.dark.separator:after,
.light-translucent-bg .separator:after,
.tl-two-col-translucent-bg .container > .row > div .separator:after {
    background: rgba(0, 0, 0, 0.5);
    background: -moz-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 35%,
        rgba(0, 0, 0, 0.4) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, transparent),
        color-stop(35%, rgba(0, 0, 0, 0.4)),
        color-stop(70%, rgba(0, 0, 0, 0.4)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 35%,
        rgba(0, 0, 0, 0.4) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 35%,
        rgba(0, 0, 0, 0.4) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 35%,
        rgba(0, 0, 0, 0.4) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        transparent 0,
        rgba(0, 0, 0, 0.4) 35%,
        rgba(0, 0, 0, 0.4) 70%,
        transparent 100%
    );
}
h3 + .separator,
h4 + .separator,
h5 + .separator {
    margin-top: 15px;
}
.separator-2,
.separator-3 {
    width: 100%;
    margin-bottom: 15px;
    position: relative;
    height: 1px;
}
.separator-2:after {
    height: 1px;
    background: #d1d1d1;
    background: -moz-linear-gradient(
        left,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, rgba(0, 0, 0, 0.18)),
        color-stop(35%, rgba(0, 0, 0, 0.12)),
        color-stop(70%, rgba(0, 0, 0, 0.05)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
}
.dark-bg .separator-2:after {
    background: #666;
    background: -moz-linear-gradient(left, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #666),
        color-stop(35%, #555),
        color-stop(70%, #444),
        color-stop(100%, #373737)
    );
    background: -webkit-linear-gradient(left, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -o-linear-gradient(left, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -ms-linear-gradient(left, #666 0, #555 35%, #444 70%, #373737 100%);
    background: linear-gradient(to right, #666 0, #555 35%, #444 70%, #373737 100%);
}
#footer.dark .separator-2:after {
    background: #444;
    background: -moz-linear-gradient(left, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #444),
        color-stop(35%, #393939),
        color-stop(70%, #323232),
        color-stop(100%, #222)
    );
    background: -webkit-linear-gradient(left, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -o-linear-gradient(left, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -ms-linear-gradient(left, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: linear-gradient(to right, #444 0, #393939 35%, #323232 70%, #222 100%);
}
.dark.separator-2:after,
.light-translucent-bg .separator-2:after,
.tl-two-col-translucent-bg .container > .row > div .separator-2:after {
    background: rgba(0, 0, 0, 0.5);
    background: -moz-linear-gradient(
        left,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, rgba(0, 0, 0, 0.5)),
        color-stop(35%, rgba(232, 232, 232, 0.4)),
        color-stop(70%, rgba(232, 232, 232, 0.2)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
}
.dark-translucent-bg .separator-2:after,
.default-bg .separator-2:after,
.default-translucent-bg .separator-2:after,
.light.separator-2:after {
    background: rgba(255, 255, 255, 0.5);
    background: -moz-linear-gradient(
        left,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, rgba(255, 255, 255, 0.5)),
        color-stop(35%, rgba(232, 232, 232, 0.4)),
        color-stop(70%, rgba(232, 232, 232, 0.2)),
        color-stop(100%, rgba(255, 255, 255, 0))
    );
    background: -webkit-linear-gradient(
        left,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -o-linear-gradient(
        left,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -ms-linear-gradient(
        left,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: linear-gradient(
        to right,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
}
@media (min-width: 992px) {
    .tl-two-col-translucent-bg .container > .row > div + div .separator-2:after {
        background: rgba(255, 255, 255, 0.5);
        background: -moz-linear-gradient(
            left,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -webkit-gradient(
            linear,
            left top,
            right top,
            color-stop(0, rgba(255, 255, 255, 0.5)),
            color-stop(35%, rgba(232, 232, 232, 0.4)),
            color-stop(70%, rgba(232, 232, 232, 0.2)),
            color-stop(100%, rgba(255, 255, 255, 0))
        );
        background: -webkit-linear-gradient(
            left,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -o-linear-gradient(
            left,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -ms-linear-gradient(
            left,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: linear-gradient(
            to right,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
    }
}
.separator-3:after {
    height: 1px;
    background: #d1d1d1;
    background: -moz-linear-gradient(
        right,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        right top,
        left top,
        color-stop(0, rgba(0, 0, 0, 0.18)),
        color-stop(35%, rgba(0, 0, 0, 0.12)),
        color-stop(70%, rgba(0, 0, 0, 0.05)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        right,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        right,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        right,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to left,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.12) 35%,
        rgba(0, 0, 0, 0.05) 70%,
        transparent 100%
    );
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
}
.dark-bg .separator-3:after {
    background: #666;
    background: -moz-linear-gradient(right, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -webkit-gradient(
        linear,
        right top,
        left top,
        color-stop(0, #666),
        color-stop(35%, #555),
        color-stop(70%, #444),
        color-stop(100%, #373737)
    );
    background: -webkit-linear-gradient(right, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -o-linear-gradient(right, #666 0, #555 35%, #444 70%, #373737 100%);
    background: -ms-linear-gradient(right, #666 0, #555 35%, #444 70%, #373737 100%);
    background: linear-gradient(to left, #666 0, #555 35%, #444 70%, #373737 100%);
}
#footer.dark .separator-3:after {
    background: #444;
    background: -moz-linear-gradient(right, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -webkit-gradient(
        linear,
        right top,
        left top,
        color-stop(0, #444),
        color-stop(35%, #393939),
        color-stop(70%, #323232),
        color-stop(100%, #222)
    );
    background: -webkit-linear-gradient(right, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -o-linear-gradient(right, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: -ms-linear-gradient(right, #444 0, #393939 35%, #323232 70%, #222 100%);
    background: linear-gradient(to left, #444 0, #393939 35%, #323232 70%, #222 100%);
}
.dark.separator-3:after,
.light-translucent-bg .separator-3:after,
.tl-two-col-translucent-bg .container > .row > div .separator-3:after {
    background: rgba(0, 0, 0, 0.5);
    background: -moz-linear-gradient(
        right,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        right top,
        left top,
        color-stop(0, rgba(0, 0, 0, 0.5)),
        color-stop(35%, rgba(232, 232, 232, 0.4)),
        color-stop(70%, rgba(232, 232, 232, 0.2)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        right,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -o-linear-gradient(
        right,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        right,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
    background: linear-gradient(
        to left,
        rgba(0, 0, 0, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        transparent 100%
    );
}
.dark-translucent-bg .separator-3:after,
.default-bg .separator-3:after,
.default-translucent-bg .separator-3:after,
.light.separator-3:after {
    background: rgba(255, 255, 255, 0.5);
    background: -moz-linear-gradient(
        right,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -webkit-gradient(
        linear,
        right top,
        left top,
        color-stop(0, rgba(255, 255, 255, 0.5)),
        color-stop(35%, rgba(232, 232, 232, 0.4)),
        color-stop(70%, rgba(232, 232, 232, 0.2)),
        color-stop(100%, rgba(255, 255, 255, 0))
    );
    background: -webkit-linear-gradient(
        right,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -o-linear-gradient(
        right,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -ms-linear-gradient(
        right,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
    background: linear-gradient(
        to left,
        rgba(255, 255, 255, 0.5) 0,
        rgba(232, 232, 232, 0.4) 35%,
        rgba(232, 232, 232, 0.2) 70%,
        rgba(255, 255, 255, 0) 100%
    );
}
@media (min-width: 992px) {
    .tl-two-col-translucent-bg .container > .row > div + div .separator-3:after {
        background: rgba(255, 255, 255, 0.5);
        background: -moz-linear-gradient(
            right,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -webkit-gradient(
            linear,
            right top,
            left top,
            color-stop(0, rgba(255, 255, 255, 0.5)),
            color-stop(35%, rgba(232, 232, 232, 0.4)),
            color-stop(70%, rgba(232, 232, 232, 0.2)),
            color-stop(100%, rgba(255, 255, 255, 0))
        );
        background: -webkit-linear-gradient(
            right,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -o-linear-gradient(
            right,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: -ms-linear-gradient(
            right,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
        background: linear-gradient(
            to left,
            rgba(255, 255, 255, 0.5) 0,
            rgba(232, 232, 232, 0.4) 35%,
            rgba(232, 232, 232, 0.2) 70%,
            rgba(255, 255, 255, 0) 100%
        );
    }
}
.footer-content .separator-2,
.footer-content .separator-3 {
    margin-bottom: 25px;
}
.separator.with-icon {
    margin: 55px 0;
}
.separator.with-icon:after {
    background: -moz-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.09) 75%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, transparent),
        color-stop(25%, rgba(0, 0, 0, 0.09)),
        color-stop(45%, transparent),
        color-stop(55%, transparent),
        color-stop(75%, rgba(0, 0, 0, 0.09)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.09) 75%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.09) 75%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.09) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.09) 75%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        transparent 0,
        rgba(0, 0, 0, 0.09) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.09) 75%,
        transparent 100%
    );
}
.dark-bg:not(.banner) .separator.with-icon:after {
    background: -moz-linear-gradient(
        left,
        #373737 0,
        #505050 25%,
        #373737 45%,
        #373737 55%,
        #505050 75%,
        #373737 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #373737),
        color-stop(25%, #505050),
        color-stop(45%, #373737),
        color-stop(55%, #373737),
        color-stop(75%, #505050),
        color-stop(100%, #373737)
    );
    background: -webkit-linear-gradient(
        left,
        #373737 0,
        #505050 25%,
        #373737 45%,
        #373737 55%,
        #505050 75%,
        #373737 100%
    );
    background: -o-linear-gradient(
        left,
        #373737 0,
        #505050 25%,
        #373737 45%,
        #373737 55%,
        #505050 75%,
        #373737 100%
    );
    background: -ms-linear-gradient(
        left,
        #373737 0,
        #505050 25%,
        #373737 45%,
        #373737 55%,
        #505050 75%,
        #373737 100%
    );
    background: linear-gradient(
        to right,
        #373737 0,
        #505050 25%,
        #373737 45%,
        #373737 55%,
        #505050 75%,
        #373737 100%
    );
}
#footer.dark .separator.with-icon:after {
    background: #505050;
    background: -moz-linear-gradient(
        left,
        #222 0,
        #505050 25%,
        #222 45%,
        #222 55%,
        #505050 75%,
        #222 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, #222),
        color-stop(25%, #505050),
        color-stop(45%, #222),
        color-stop(55%, #222),
        color-stop(75%, #505050),
        color-stop(100%, #222)
    );
    background: -webkit-linear-gradient(
        left,
        #222 0,
        #505050 25%,
        #222 45%,
        #222 55%,
        #505050 75%,
        #222 100%
    );
    background: -o-linear-gradient(
        left,
        #222 0,
        #505050 25%,
        #222 45%,
        #222 55%,
        #505050 75%,
        #222 100%
    );
    background: -ms-linear-gradient(
        left,
        #222 0,
        #505050 25%,
        #222 45%,
        #222 55%,
        #505050 75%,
        #222 100%
    );
    background: linear-gradient(
        to right,
        #222 0,
        #505050 25%,
        #222 45%,
        #222 55%,
        #505050 75%,
        #222 100%
    );
}
.dark-translucent-bg .separator.with-icon:after,
.default-bg .separator.with-icon:after,
.default-translucent-bg .separator.with-icon:after,
.light.separator.with-icon:after {
    background: rgba(255, 255, 255, 0.5);
    background: -moz-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 0) 45%,
        rgba(255, 255, 255, 0) 55%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, rgba(255, 255, 255, 0)),
        color-stop(25%, rgba(255, 255, 255, 0.5)),
        color-stop(45%, rgba(255, 255, 255, 0)),
        color-stop(55%, rgba(255, 255, 255, 0)),
        color-stop(75%, rgba(255, 255, 255, 0.5)),
        color-stop(100%, rgba(255, 255, 255, 0))
    );
    background: -webkit-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 0) 45%,
        rgba(255, 255, 255, 0) 55%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -o-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 0) 45%,
        rgba(255, 255, 255, 0) 55%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background: -ms-linear-gradient(
        left,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 0) 45%,
        rgba(255, 255, 255, 0) 55%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
    background: linear-gradient(
        to right,
        rgba(255, 255, 255, 0) 0,
        rgba(255, 255, 255, 0.5) 25%,
        rgba(255, 255, 255, 0) 45%,
        rgba(255, 255, 255, 0) 55%,
        rgba(255, 255, 255, 0.5) 75%,
        rgba(255, 255, 255, 0) 100%
    );
}
.dark.separator.with-icon:after,
.light-translucent-bg .separator.with-icon:after {
    background: rgba(0, 0, 0, 0.5);
    background: -moz-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.4) 75%,
        transparent 100%
    );
    background: -webkit-gradient(
        linear,
        left top,
        right top,
        color-stop(0, transparent),
        color-stop(25%, rgba(0, 0, 0, 0.4)),
        color-stop(45%, transparent),
        color-stop(55%, transparent),
        color-stop(75%, rgba(0, 0, 0, 0.4)),
        color-stop(100%, transparent)
    );
    background: -webkit-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.4) 75%,
        transparent 100%
    );
    background: -o-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.4) 75%,
        transparent 100%
    );
    background: -ms-linear-gradient(
        left,
        transparent 0,
        rgba(0, 0, 0, 0.4) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.4) 75%,
        transparent 100%
    );
    background: linear-gradient(
        to right,
        transparent 0,
        rgba(0, 0, 0, 0.4) 25%,
        transparent 45%,
        transparent 55%,
        rgba(0, 0, 0, 0.4) 75%,
        transparent 100%
    );
}
.separator.with-icon i {
    font-size: 36px;
    position: absolute;
    width: 80px;
    height: 80px;
    text-align: center;
    left: 50%;
    top: 50%;
    margin-top: -40px;
    margin-left: -40px;
    line-height: 77px;
    z-index: 5;
}
.separator.with-icon i.bordered {
    border-width: 1px;
    border-style: solid;
    border-color: rgba(0, 0, 0, 0.04);
    background-color: rgba(0, 0, 0, 0.02);
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
}
.dark-translucent-bg .separator.with-icon i.bordered,
.default-bg .separator.with-icon i.bordered,
.default-translucent-bg .separator.with-icon i.bordered {
    border-color: rgba(255, 255, 255, 0.1);
    background-color: rgba(255, 255, 255, 0.05);
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
}
.object-non-visible {
    opacity: 0;
}
.object-non-visible.object-visible,
.object-visible {
    opacity: 1;
}
.absolute-positioned-top {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}
.absolute-positioned-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    top: auto;
    width: 100%;
}
.pl-5 {
    padding-left: 5px;
}
.pl-10 {
    padding-left: 10px;
}
.pl-20 {
    padding-left: 20px;
}
.pr-5 {
    padding-right: 5px;
}
.pr-10 {
    padding-right: 10px;
}
.pr-20 {
    padding-right: 20px;
}
.p-20 {
    padding: 20px;
}
.p-30 {
    padding: 30px;
}
.p-40 {
    padding: 40px;
}
.ph-20 {
    padding-left: 20px;
    padding-right: 20px;
}
.ph-30 {
    padding-left: 30px;
    padding-right: 30px;
}
.ph-40 {
    padding-left: 40px;
    padding-right: 40px;
}
.pv-20 {
    padding-top: 20px;
    padding-bottom: 20px;
}
.pv-30 {
    padding-top: 30px;
    padding-bottom: 30px;
}
.pv-40 {
    padding-top: 40px;
    padding-bottom: 40px;
}
.pv-45 {
    padding-top: 45px;
    padding-bottom: 45px;
}
.mt-5 {
    margin-top: 5px;
}
.mb-5 {
    margin-bottom: 5px;
}
.mt-10 {
    margin-top: 10px;
}
.mb-10 {
    margin-bottom: 10px;
}
.mt-20 {
    margin-top: 20px;
}
.mb-20 {
    margin-bottom: 20px;
}
.space-top {
    padding-top: 20px;
}
.space-bottom {
    padding-bottom: 20px;
}
.margin-top-clear {
    margin-top: 0 !important;
}
.margin--bottom-clear {
    margin-bottom: 0 !important;
}
.margin-clear {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.padding-top-clear {
    padding-top: 0 !important;
}
.padding-bottom-clear {
    padding-bottom: 0 !important;
}
.padding-ver-clear {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
}
.padding-hor-clear {
    padding-right: 0 !important;
    padding-left: 0 !important;
}
.border-bottom-clear {
    border-bottom: none !important;
}
.border-top-clear {
    border-top: none !important;
}
.border-clear {
    border: none !important;
}
.circle {
    -webkit-border-radius: 100% !important;
    -moz-border-radius: 100% !important;
    border-radius: 100% !important;
}
.radius-clear {
    -webkit-border-radius: 0 !important;
    -moz-border-radius: 0 !important;
    border-radius: 0 !important;
}
@media (max-width: 767px) {
    .text-center-xs {
        text-align: center;
    }
}
.hidden-xs-up {
    display: none !important;
}
@media (max-width: 575px) {
    .hidden-xs-down {
        display: none !important;
    }
}
@media (min-width: 576px) {
    .hidden-sm-up {
        display: none !important;
    }
}
@media (max-width: 767px) {
    .hidden-sm-down {
        display: none !important;
    }
}
@media (min-width: 768px) {
    .hidden-md-up {
        display: none !important;
    }
}
@media (max-width: 991px) {
    .hidden-md-down {
        display: none !important;
    }
}
@media (min-width: 992px) {
    .hidden-lg-up {
        display: none !important;
    }
}
@media (max-width: 1199px) {
    .hidden-lg-down {
        display: none !important;
    }
}
@media (min-width: 1200px) {
    .hidden-xl-up {
        display: none !important;
    }
}
.hidden-xl-down {
    display: none !important;
}
.hc-element-invisible {
    opacity: 0;
}
.hc-element-invisible.hc-element-visible,
.hc-element-visible {
    opacity: 1;
}
.tl-header-top {
    font-size: 12px;
    color: #777;
    font-weight: 300;
}
.tl-header-top.colored,
.tl-header-top.dark {
    color: #fff;
}
.tl-header-top.colored a {
    color: #fff;
    text-decoration: underline;
}
.tl-header-top.colored a:hover {
    text-decoration: none;
}
@media (min-width: 992px) and (max-width: 1199px) {
    .tl-header-top {
        font-size: 11px;
    }
}
.tl-header.dark {
    color: #cacaca;
}
.footer {
    font-size: 14px;
    line-height: 1.5;
}
.footer h2.title {
    font-size: 22px;
    text-transform: none;
    margin-bottom: 10px;
}

.subfooter p {
    margin-bottom: 0;
}
.subfooter.default-bg {
    color: #fff;
}

@media (max-width: 575px) {
    .nav.nav-pills {
        display: block;
    }
    .nav.nav-pills .nav-item {
        display: inline-block;
    }
}
.dark-bg .nav-pills > li .nav-link,
.dark-translucent-bg .nav-pills > li .nav-link {
    text-decoration: none;
}
.dark-bg .nav-pills > li .nav-link.active,
.dark-bg .nav-pills > li .nav-link.active:focus,
.dark-bg .nav-pills > li .nav-link:focus,
.dark-translucent-bg .nav-pills > li .nav-link.active,
.dark-translucent-bg .nav-pills > li .nav-link.active:focus,
.dark-translucent-bg .nav-pills > li .nav-link:focus {
    color: #fff;
    border-bottom-color: #fff;
}
.footer-content .nav.flex-column > li > a {
    padding: 5px 0;
}
.footer-content .nav.flex-column > li > a:after {
    top: 5px;
}
.dark .footer-content .nav.flex-column > li > a,
.dark .footer-content .nav.flex-column > li > a.active,
.dark .footer-content .nav.flex-column > li > a.active:focus,
.dark .footer-content .nav.flex-column > li > a:focus {
    color: #999;
}
.tl-knob-container {
    margin: 10px;
    position: relative;
    display: inline-block;
}
.tl-knob-container canvas {
    width: 132px;
    height: 132px;
    margin: 0 auto;
}
@media (min-width: 1200px) {
    .tl-knob-container canvas {
        width: 169px;
        height: 169px;
    }
}
.dropdown-toggle--no-caret::after {
    margin: 0;
    border-width: 0;
    border: none;
}
.colored .dropdown-menu,
.dark .dropdown-menu,
.dark-bg .dropdown-menu {
    color: #fff;
    font-size: 0.9rem;
}
.dropdown-menu .divider {
    background-color: #ededed;
    height: 1px;
    margin: 9px 0;
    overflow: hidden;
}
.dropdown-menu-right {
    right: 0;
    left: auto;
}
form {
    margin: 20px 0;
}
textarea {
    resize: vertical;
}
textarea.form-control {
    height: auto;
}
.tl-sidebar form {
    margin: 5px 0 20px 0;
}
.form-control {
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    background-color: #fff;
    height: 40px;
    font-weight: 300;
    font-size: 14px;
    padding-right: 30px;
    border-color: #e1e1e1;
    color: #777;
    position: relative;
    -webkit-appearance: none;
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
}
.form-control.form-control-lg,
.form-control.form-control-sm {
    height: auto;
}
.form-control.radius-50 {
    -webkit-border-radius: var(--tl-radius-full);
    -moz-border-radius: var(--tl-radius-full);
    border-radius: var(--tl-radius-full);
}
.form-inline .form-control-lg {
    height: 48px;
}
.form-inline [type="submit"] {
    margin-top: 0;
    margin-bottom: 0;
}
@media (min-width: 576px) {
    .form-control-lg {
        min-width: 350px;
    }
}
@media (max-width: 575px) {
    .form-inline {
        display: block !important;
    }
}
.form-control:focus {
    border-color: #999;
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.075);
}
select.form-control {
    padding-right: 5px;
    -webkit-appearance: menulist;
}
select[multiple].form-control {
    -webkit-appearance: listbox;
    height: auto;
}
.form-control::-moz-placeholder {
    color: inherit;
}
.form-control:-ms-input-placeholder {
    color: inherit;
}
.form-control::-webkit-input-placeholder {
    color: inherit;
}
.input-group-text {
    background-color: #f1f1f1;
    border-color: #e1e1e1;
    min-height: 40px;
}
.form-list > div {
    padding: 7px 15px;
    border-bottom: 1px solid #ddd;
    background-color: #f3f3f3;
    margin: 6px 0;
    display: block;
}
.checkbox label,
.radio label,
form label {
    font-weight: 300;
}
fieldset {
    padding: 10px 25px;
    margin: 15px 0;
    border: 1px solid #ddd;
    background-color: #fafafa;
}
fieldset legend {
    display: block;
    width: auto;
    padding: 3px 10px;
    margin-bottom: 0;
    font-size: 15px;
    line-height: inherit;
    color: #333;
    border: 1px solid #ddd;
    background-color: #fff;
}
fieldset .form-control,
fieldset .form-control:focus {
    -webkit-box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.12);
    box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.12);
    border-color: #f3f3f3;
}
.form-check {
    margin-bottom: 5px;
}
.has-feedback {
    position: relative;
}
.has-feedback label ~ .form-control-feedback {
    top: 29px;
}
.has-feedback label.sr-only ~ .form-control-feedback {
    top: 0;
}
.has-feedback .form-control-feedback {
    width: 40px;
    height: 40px;
    line-height: 40px !important;
    top: 0;
    right: 0;
    color: #777;
    position: absolute;
    text-align: center;
    margin-top: 0;
}
.has-feedback .form-control-lg + .form-control-feedback,
.has-feedback label.sr-only ~ .form-control-lg + .form-control-feedback {
    height: 48px;
    top: 4px;
}
.form-control[disabled],
.form-control[readonly],
fieldset[disabled] .form-control {
    opacity: 0.5;
}
.dark-bg .form-control {
    background-color: rgba(255, 255, 255, 0.15);
    border-color: #353535;
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.8);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.8);
    color: #cdcdcd;
}
.dark-bg .is-invalid.form-control:focus,
.dark-bg .is-valid.form-control:focus,
.dark-bg .is-warning.form-control:focus {
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.8);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.8);
}
.dark-bg .input-group-text {
    background-color: rgba(255, 255, 255, 0.2);
    border-color: #000;
}
.dark-bg .form-control:focus,
.dark-bg .is-invalid.form-control:focus,
.dark-bg .is-valid.form-control:focus,
.dark-bg .is-warning.form-control:focus {
    background-color: rgba(255, 255, 255, 0.25);
}
.dark-bg .has-feedback .form-control-feedback {
    color: #cdcdcd;
}
.default-bg .form-control {
    background-color: rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.35);
    box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.35);
    color: #fff;
}
.default-bg .is-invalid.form-control:focus,
.default-bg .is-valid.form-control:focus,
.default-bg .is-warning.form-control:focus {
    -webkit-box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.35);
    box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.35);
}
.default-bg .input-group-text {
    background-color: rgba(0, 0, 0, 0.2);
}
.default-bg .form-control:focus {
    background-color: rgba(0, 0, 0, 0.1);
}
.default-bg .has-feedback .form-control-feedback {
    color: #fff;
}
.default-bg .form-check.disabled .form-check-label {
    color: rgba(255, 255, 255, 0.8);
}
.dark .form-control {
    -webkit-box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.6);
    box-shadow: inset 0 2px 3px rgba(0, 0, 0, 0.6);
    color: #ccc;
    background-color: rgba(255, 255, 255, 0.1);
    border-color: #373737;
}
.dark .form-control:focus {
    background-color: rgba(255, 255, 255, 0.15);
}
.dark .has-feedback .form-control-feedback {
    color: #cdcdcd;
}
.dark .footer-content .form-control {
    border-color: #222;
}
.dark-bg .is-valid .checkbox,
.dark-bg .is-valid .checkbox-inline,
.dark-bg .is-valid .control-label,
.dark-bg .is-valid .form-control-feedback,
.dark-bg .is-valid .help-block,
.dark-bg .is-valid .radio,
.dark-bg .is-valid .radio-inline,
.dark-bg .is-valid.checkbox label,
.dark-bg .is-valid.checkbox-inline label,
.dark-bg .is-valid.radio label,
.dark-bg .is-valid.radio-inline label {
    color: #15c019;
}
.dark-bg .is-warning .checkbox,
.dark-bg .is-warning .checkbox-inline,
.dark-bg .is-warning .control-label,
.dark-bg .is-warning .form-control-feedback,
.dark-bg .is-warning .help-block,
.dark-bg .is-warning .radio,
.dark-bg .is-warning .radio-inline,
.dark-bg .is-warning.checkbox label,
.dark-bg .is-warning.checkbox-inline label,
.dark-bg .is-warning.radio label,
.dark-bg .is-warning.radio-inline label {
    color: #e5af51;
}
.dark-bg .is-invalid .checkbox,
.dark-bg .is-invalid .checkbox-inline,
.dark-bg .is-invalid .control-label,
.dark-bg .is-invalid .form-control-feedback,
.dark-bg .is-invalid .help-block,
.dark-bg .is-invalid .radio,
.dark-bg .is-invalid .radio-inline,
.dark-bg .is-invalid.checkbox label,
.dark-bg .is-invalid.checkbox-inline label,
.dark-bg .is-invalid.radio label,
.dark-bg .is-invalid.radio-inline label {
    color: #ef4f4c;
}
.is-valid.form-control,
.is-valid.form-control:focus {
    border-color: #65bb66;
}
.is-warning.form-control,
.is-warning.form-control:focus {
    border-color: #e8c782;
}
.is-invalid.form-control,
.is-invalid.form-control:focus {
    border-color: #e83a37;
}
.default-bg .is-invalid.form-control,
.default-bg .is-invalid.form-control:focus,
.default-bg .is-valid.form-control,
.default-bg .is-valid.form-control:focus,
.default-bg .is-warning.form-control,
.default-bg .is-warning.form-control:focus {
    border-color: #fff;
    color: #fff;
}
.default-bg .invalid-feedback,
.default-bg .valid-feedback,
.default-bg .warning-feedback {
    color: #fff;
}
.is-invalid.form-control:focus,
.is-valid.form-control:focus,
.is-warning.form-control:focus {
    -webkit-box-shadow: none;
    box-shadow: none;
}
.has-error .error {
    font-weight: 400;
    margin-bottom: 5px;
    display: block;
}
.warning-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 80%;
    color: #e8c782;
}
.form-control.is-warning ~ .warning-feedback {
    display: block;
}
    background-color: transparent;
    border-width: 0 0 1px 0;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    font-size: 22px;
    padding: 10px 20px;
    height: auto;
}
.text-white .form-style-2 .form-control {
    border-color: rgba(255, 255, 255, 0.3);
}
.text-white .form-style-2 .form-control:focus,
.text-white .form-style-2 .form-control:hover {
    border-color: #fff;
    background-color: transparent;
}
.form-style-2 .has-feedback label.sr-only ~ .form-control-feedback {
    top: 8px;
    font-size: 24px;
}
.alert {
    margin: 20px 0;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
    border: none;
}
.alert-success {
    color: #2a5f2b;
    background-color: #bcdab0;
}
.alert-info {
    color: #1a4e68;
    background-color: #c6e8fa;
}
.alert-warning {
    color: #72582b;
    background-color: #f7f0ce;
}
.alert-icon {
    padding-left: 70px;
    position: relative;
}
.alert-icon i {
    position: absolute;
    font-size: 28px;
    left: 21px;
    top: 13px;
    width: 30px;
    text-align: center;
}
.alert .close {
    font-weight: 400;
    opacity: 0.4;
    top: 0;
}
    position: relative;
    background-color: #fff;
}
.light-gray-bg.hc-shadow,
.light-gray-bg.hc-shadow-narrow {
    background-color: #fafafa;
}
.bordered {
    border: 1px solid #f1f1f1;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
}
.dark-bg .bordered {
    border: 1px solid #555;
}
.hc-shadow *,
.hc-shadow-narrow * {
    position: relative;
    z-index: 3;
}
.hc-shadow-narrow:before,
.hc-shadow:before {
    position: absolute;
    left: 0;
    height: 60%;
    bottom: 0;
    width: 100%;
    content: "";
    background-color: #fff;
    z-index: 2;
}
.light-gray-bg.hc-shadow-narrow:before,
.light-gray-bg.hc-shadow:before {
    background-color: #fafafa;
}
.hc-shadow-narrow:after,
.hc-shadow:after {
    content: "";
    position: absolute;
    height: 50%;
    width: 96%;
    left: 50%;
    bottom: 2px;
    margin-left: -48%;
    -webkit-box-shadow: 0 5px 7px #999;
    box-shadow: 0 5px 7px #999;
    z-index: 1;
    border-radius: 10%;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}
.hc-shadow-narrow:after {
    width: 90%;
    margin-left: -45%;
}
.hc-shadow-narrow:hover:after,
.hc-shadow:hover:after {
    bottom: 10px;
}
.hc-shadow-2 {
    -webkit-box-shadow: 0 10px 6px -6px #999;
    box-shadow: 0 10px 6px -6px #999;
    -webkit-transition: all 0.25s ease-in-out;
    -o-transition: all 0.25s ease-in-out;
    transition: all 0.25s ease-in-out;
}
.hc-shadow-2:hover {
    -webkit-box-shadow: 0 18px 24px -9px #999;
    box-shadow: 0 18px 24px -9px #999;
}

.tl-image-box .body {
    padding: 15px;
}
.tl-image-box .body h3 {
    margin-top: 0;
}
.tl-image-box .body p:last-child {
    margin-bottom: 0;
}
.tl-image-box.style-4 {
    border: none;
}
.tl-image-box.style-3-b {
    display: block;
    margin-bottom: 40px;
}
.tl-image-box.style-3-b .body {
    padding: 10px 0;
}
.tl-image-box--shadowed {
    -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
    -webkit-transition: all 0.25s ease-in-out;
    -o-transition: all 0.25s ease-in-out;
    transition: all 0.25s ease-in-out;
}
.tl-image-box--shadowed:hover {
    -webkit-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
}
@media (min-width: 768px) {
    .tl-image-box.style-3-b .body {
        padding: 0;
    }
}
@media (max-width: 991px) {
    .tl-image-box.style-4 {
        margin-bottom: 30px;
    }
}
.tl-header .navbar-nav li .nav-link {
    color: #333;
    font-size: 16px;
    padding: 28px 15px 27px 15px;
    z-index: 102;
    border: none;
    border-bottom: 1px solid transparent;
    border-right: 1px solid transparent;
    border-left: 1px solid transparent;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
}
.tl-header .tl-main-navigation.animated .navbar-nav li a {
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
.tl-header .navbar-nav li.dropdown .nav-link {
    padding-right: 20px;
}
@media (min-width: 992px) and (max-width: 1200px) {
    .tl-header .navbar-nav li .nav-link {
        padding: 28px 12px 27px 12px;
    }
    .tl-header .navbar-nav li.dropdown .nav-link {
        padding-right: 18px;
    }
}
.tl-header .navbar-nav .active.show > .nav-link,
.tl-header .navbar-nav .show > .nav-link,
.tl-header .navbar-nav li .nav-link.show,
.tl-header .navbar-nav li .nav-link:focus,
.tl-header .navbar-nav li .nav-link:hover,
.tl-header .navbar-nav li.show .nav-link.active {
    background-color: #fff;
    border-bottom-color: #fff;
    border-right: 1px solid #f5f5f5;
    border-left: 1px solid #f5f5f5;
    z-index: 106;
}
.tl-header .scrollspy .navbar-nav li .nav-link:focus,
.tl-header .scrollspy .navbar-nav li .nav-link:hover {
    background-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
}
.tl-header .navbar-nav .active > .nav-link,
.tl-header .navbar-nav li .nav-link.active {
    background-color: transparent;
}
.tl-header .navbar-nav .dropdown-toggle::after {
    font-family: "Font Awesome 5 Free";
    font-weight: var(--tl-weight-bold);
    content: "\f107";
    position: absolute;
    top: 51%;
    left: auto;
    right: 0;
    line-height: 20px;
    font-size: 14px;
    border: none;
    width: 20px;
    height: 20px;
    margin: 0;
    text-align: center;
    margin-top: -10px;
}
@media (min-width: 992px) {
    .tl-header.centered .navbar-nav .nav-item a.nav-link {
        padding-top: 15px !important;
        padding-bottom: 15px !important;
        border-top: 1px solid transparent;
    }
    .tl-header.centered:not(.dark) .tl-main-navigation .navbar-nav .nav-item.dropdown a.nav-link:focus,
    .tl-header.centered:not(.dark) .tl-main-navigation .navbar-nav .nav-item.show a.nav-link,
    .tl-header.centered:not(.dark) .tl-main-navigation .navbar-nav .nav-item.show a.nav-link:focus,
    .tl-header.centered:not(.dark) .tl-main-navigation .navbar-nav .nav-item.show a.nav-link:hover {
        border-top: 1px solid #f5f5f5;
    }
}
@media (min-width: 1200px) {
    .tl-header .navbar-nav > li {
        margin: 0 0 0 10px;
    }
    .tl-header .navbar-nav > li:first-child {
        margin: 0;
    }
}
@media (max-width: 767px) {
    .tl-header .navbar-nav li .nav-link {
        padding: 10px 15px;
    }
}
.tl-header .navbar-nav li ul {
    min-width: 14rem;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    padding: 0;
    margin: 0;
    margin-top: -1px;
    background-color: #fff;
    -webkit-box-shadow: 0 6px 24px rgba(0, 0, 0, 0.06);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.06);
    border-width: 1px;
    border-style: solid;
    border-color: #f1f1f1;
    border-top-color: transparent;
    z-index: 101;
}
.tl-header .navbar-nav li li a {
    padding: 10px 20px;
    display: block;
    font-size: 14px;
    color: #333;
    border-bottom: 1px solid #f7f7f7;
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
    position: relative;
    text-align: left;
}
.tl-header .navbar-nav li .active > a,
.tl-header .navbar-nav li .show > a,
.tl-header .navbar-nav li li a.active,
.tl-header .navbar-nav li li a.show,
.tl-header .navbar-nav li li a:focus,
.tl-header .navbar-nav li li a:hover {
    background-color: #fcfcfc;
    border-color: #f7f7f7;
    text-decoration: none;
}
.tl-header .navbar-nav ul .dropdown-toggle::after {
    content: "\f105";
    right: 5px;
}
.tl-header .navbar-nav ul ul {
    top: -1px;
    left: 100% !important;
    right: auto;
    border-top: 1px solid #f7f7f7;
}
.tl-header .container-fluid .navbar-nav ul.to-left {
    right: 100% !important;
    left: auto !important;
}
@media (max-width: 1610px) {
    .tl-header .navbar-nav ul.to-left {
        right: 100% !important;
        left: auto !important;
    }
}
@media (min-width: 992px) {
    .tl-header.centered .col-md-12 .navbar {
        position: static;
    }
}
@media (min-width: 1200px) {
    .tl-main-navigation .navbar-nav > li:first-child {
        margin: 0;
    }
}
#offcanvas.animated .dropdown-menu .show .dropdown-menu,
#offcanvas.animated .show .dropdown-menu,
.animated.tl-main-navigation .navbar-nav .show .dropdown-menu {
    -webkit-animation-duration: 0.3s;
    animation-duration: 0.3s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-name: fadeInUpSmall;
    animation-name: fadeInUpSmall;
}
.animated.tl-main-navigation .dropdown-menu .show .dropdown-menu {
    -webkit-animation-name: fadeInLeftSmall;
    animation-name: fadeInLeftSmall;
}
header .container-fluid .animated.tl-main-navigation .dropdown-menu .show .dropdown-menu.to-left {
    -webkit-animation-name: fadeInRightSmall;
    animation-name: fadeInRightSmall;
}
@media (max-width: 1610px) {
    .animated.tl-main-navigation .dropdown-menu .show .dropdown-menu.to-left {
        -webkit-animation-name: fadeInRightSmall;
        animation-name: fadeInRightSmall;
    }
}
.tl-header .navbar-brand {
    padding: 13px 0;
    margin-right: 0;
}
.tl-header .navbar-toggler {
    top: 19px;
    right: 0;
}
.navbar-light .navbar-toggler {
    border-color: #ccc;
}
.navbar-light .navbar-toggler:focus,
.navbar-light .navbar-toggler:hover {
    background-color: #fafafa;
}
@media (max-width: 991px) {
    .tl-header .navbar-nav {
        padding-bottom: 20px;
    }
    .tl-header .navbar-nav li .nav-link {
        border-bottom: 1px solid #f3f3f3;
        padding: 10px 15px;
    }
    .tl-header .navbar-nav > li:last-child a.nav-link {
        border-bottom: 1px solid transparent;
    }
    .tl-header .navbar-nav .active > a,
    .tl-header .navbar-nav .active > a:focus,
    .tl-header .navbar-nav .active > a:hover,
    .tl-header .navbar-nav li > a:focus,
    .tl-header .navbar-nav li > a:hover {
        background-color: #fff;
        border-bottom-color: transparent;
    }
    .navbar-toggleable-md .navbar-nav .dropdown-menu {
        -webkit-box-shadow: none;
        box-shadow: none;
    }
    .tl-header .navbar-nav .dropdown-menu {
        background-color: #fff;
    }
    .tl-header .navbar-nav .badge {
        right: 30px;
    }
    .tl-header .navbar-nav .show .dropdown-menu .dropdown-header,
    .tl-header .navbar-nav .show .dropdown-menu > li > a {
        padding: 12px 15px 12px 40px;
        border-color: #f9f9f9;
    }
    .tl-header .navbar-nav .show .dropdown-menu .dropdown-menu > li > a {
        padding-left: 60px;
    }
    .tl-header .navbar-nav .show .dropdown-menu .dropdown-menu .dropdown-menu > li > a {
        padding-left: 80px;
    }
    .tl-header .navbar-nav .dropdown-toggle::after {
        color: #999;
        top: 22px;
        right: 10px;
    }
    .tl-header .navbar-nav .dropdown .dropdown .dropdown-toggle::after {
        right: 10px;
    }
}
.dark.tl-header .navbar-nav li .nav-link {
    color: #ccc;
    border-bottom: 1px solid transparent;
    text-shadow: 1px 1px rgba(0, 0, 0, 0.6);
}
.transparent-header .dark.tl-header .navbar-nav li .nav-link {
    color: #e1e1e1;
}
.dark.tl-header .navbar-nav .active .nav-link,
.dark.tl-header .navbar-nav .active .nav-link:focus,
.dark.tl-header .navbar-nav .active .nav-link:hover,
.dark.tl-header .navbar-nav li .nav-link:focus,
.dark.tl-header .navbar-nav li .nav-link:hover {
    background-color: transparent;
    color: #fff;
    border-right: 1px solid transparent;
    border-left: 1px solid transparent;
    z-index: 106;
}
.dark.tl-header .navbar-nav .dropdown .nav-link:focus,
.dark.tl-header .navbar-nav .show .nav-link,
.dark.tl-header .navbar-nav .show .nav-link:focus,
.dark.tl-header .navbar-nav .show .nav-link:hover {
    background-color: rgba(0, 0, 0, 0.15);
    color: #fff;
    border-right: 1px solid transparent;
    border-left: 1px solid transparent;
    z-index: 106;
}
.dark.tl-header .dropdown-menu {
    border: none;
}
.dark.tl-header .mega-menu .dropdown-menu {
    z-index: 103;
}
.dark.tl-header .dropdown-menu > li > a,
.dark.tl-header .navbar-nav .mega-menu .menu > li > a {
    color: #ccc;
    text-shadow: 1px 1px rgba(0, 0, 0, 0.7);
}
.dark.tl-header .mega-menu .menu > li > a:focus,
.dark.tl-header .mega-menu .menu > li > a:hover {
    background-color: rgba(0, 0, 0, 0.2);
    color: #fff;
}
.dark.tl-header .dropdown-menu .menu > .active > a,
.dark.tl-header .dropdown-menu .menu > .active > a:focus,
.dark.tl-header .dropdown-menu .menu > .active > a:hover,
.dark.tl-header .dropdown-menu > .active > a,
.dark.tl-header .dropdown-menu > .active > a:focus,
.dark.tl-header .dropdown-menu > .active > a:hover,
.dark.tl-header .dropdown-menu > li > a:focus,
.dark.tl-header .dropdown-menu > li > a:hover,
.dark.tl-header .navbar-nav .show > a,
.dark.tl-header .navbar-nav .show > a:focus,
.dark.tl-header .navbar-nav .show > a:hover {
    background-color: rgba(0, 0, 0, 0.2);
    color: #fff;
}
.dark.tl-header .dropdown .dropdown > a:before {
    color: #ccc;
    top: 13px;
}
.dark.tl-header .dropdown .dropdown.show > a:before {
    color: #fff;
}
.dark .navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.55);
    background-color: transparent;
}
.dark .navbar .navbar-toggler:focus,
.dark .navbar .navbar-toggler:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.7);
}
.dark .navbar .navbar-toggler .navbar-toggler-icon {
    background-image: none;
    position: relative;
    font-weight: 300;
    text-align: center;
}
.dark .navbar .navbar-toggler .navbar-toggler-icon:after {
    font-family: "Font Awesome 5 Free";
    font-weight: var(--tl-weight-bold);
    width: 30px;
    height: 30px;
    content: "\f0c9";
    color: rgba(255, 255, 255, 0.5);
    font-size: 24px;
    position: absolute;
    top: 0;
    left: 0;
    line-height: 30px;
}
.dark .navbar .navbar-collapse,
.dark .navbar .navbar-form {
    border-color: #121212;
}
@media (max-width: 991px) {
    .dark .tl-main-navigation .navbar-nav .show .dropdown-menu {
        background-color: rgba(0, 0, 0, 0.5);
        border: none;
    }
    .dark .tl-main-navigation .navbar-nav .show .dropdown-menu .dropdown-header,
    .dark .tl-main-navigation .navbar-nav .show .dropdown-menu > li > a {
        color: #ccc;
        border-color: rgba(255, 255, 255, 0.08);
    }
    .dark.tl-header .navbar-nav .show .dropdown-menu > .active > a,
    .dark.tl-header .navbar-nav .show .dropdown-menu > .active > a:focus,
    .dark.tl-header .navbar-nav .show .dropdown-menu > .active > a:hover,
    .dark.tl-header .navbar-nav .show .dropdown-menu > li > a:focus,
    .dark.tl-header .navbar-nav .show .dropdown-menu > li > a:hover,
    .dark.tl-header .navbar-nav > .active > a,
    .dark.tl-header .navbar-nav > .active > a:focus,
    .dark.tl-header .navbar-nav > .active > a:hover,
    .dark.tl-header .navbar-nav > li > a:focus,
    .dark.tl-header .navbar-nav > li > a:hover {
        color: #fff;
        background-color: rgba(0, 0, 0, 0.2);
    }
    .dark .navbar-nav .dropdown.show > .dropdown-toggle::after {
        color: #fff;
    }
}
@media (min-width: 992px) {
    .tl-header:not(.dark) .tl-main-navigation--style-2 .navbar-nav li:not(.active) .nav-link {
        color: #333;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav .active.show > .nav-link,
    .tl-header .tl-main-navigation--style-2 .navbar-nav .show > .nav-link,
    .tl-header .tl-main-navigation--style-2 .navbar-nav li .nav-link.show,
    .tl-header .tl-main-navigation--style-2 .navbar-nav li .nav-link:focus,
    .tl-header .tl-main-navigation--style-2 .navbar-nav li .nav-link:hover,
    .tl-header .tl-main-navigation--style-2 .navbar-nav li.show .nav-link.active {
        background-color: transparent;
        border-bottom-color: transparent;
        border-right: 1px solid transparent;
        border-left: 1px solid transparent;
    }
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav .active.show > .nav-link,
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav .show > .nav-link,
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav li .nav-link.show,
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav li .nav-link:focus,
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav li .nav-link:hover,
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav li.show .nav-link.active {
        background-color: transparent;
        border-bottom-color: transparent;
        border-right: 1px solid transparent;
        border-left: 1px solid transparent;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav li ul {
        -webkit-border-radius: 7px;
        -moz-border-radius: 7px;
        border-radius: 7px;
        margin-top: 0;
        -webkit-box-shadow: 0 4px 29px rgba(0, 0, 0, 0.1);
        box-shadow: 0 4px 29px rgba(0, 0, 0, 0.1);
        border-top-color: #f1f1f1;
    }
    .tl-header.dark .tl-main-navigation--style-2 .navbar-nav li ul {
        margin-top: -2px;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav li li a {
        border-bottom-color: transparent;
        padding: 12px 25px;
        font-size: 15px;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav li.mega-menu .menu > li > a {
        padding: 7px 0;
        border-bottom: none;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav li ul ul {
        margin-left: 5px;
        margin-right: 5px;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav ul.dropdown-menu > li:first-child > a {
        border-radius: 5px 5px 0 0;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav ul.dropdown-menu > li:last-child > a {
        border-radius: 0 0 5px 5px;
    }
    .tl-header .tl-main-navigation--style-2 .navbar-nav .dropdown-toggle.nav-link::after {
        font-size: 10px;
        right: 3px;
    }
}
#logo img:hover,
#logo-mobile img:hover {
    opacity: 0.8;
}
.tl-header.centered #logo img {
    margin: 0 auto;
}
#logo-footer {
    margin-bottom: 20px;
}
.social-links {
    list-style: none;
    font-size: 0;
    margin-top: 20px;
    margin-bottom: 20px;
    padding-left: 0;
}
.social-links li {
    display: inline-block;
    margin: 0 2px 2px 0;
}
.social-links li a {
    width: 40px;
    height: 40px;
    display: block;
    text-align: center;
    font-size: 18px;
    border: 1px solid #e7e7e7;
    color: #cdcdcd;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}
.social-links li a i {
    line-height: 40px;
}
.social-links li a:hover {
    background-color: transparent;
}
.social-links.animated-effect-1 li a {
    -webkit-transition: color 0.4s;
    -o-transition: color 0.4s;
    transition: color 0.4s;
    position: relative;
    z-index: 1;
}
.social-links.animated-effect-1 li a:hover {
    color: #fff !important;
    -webkit-transition: color 0.3s;
    -o-transition: color 0.3s;
    transition: color 0.3s;
}
.social-links.animated-effect-1 li a:after {
    pointer-events: none;
    position: absolute;
    width: 100%;
    height: 100%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    content: "";
    top: 0;
    left: 0;
    padding: 0;
    z-index: -1;
    -webkit-transition:
        -webkit-transform 0.4s,
        opacity 0.4s,
        background-color 0.4s;
    -moz-transition:
        -moz-transform 0.4s,
        opacity 0.4s,
        background-color 0.4s;
    transition:
        transform 0.4s,
        opacity 0.4s,
        background-color 0.4s;
    -webkit-transform: scale(1.4);
    -moz-transform: scale(1.4);
    -ms-transform: scale(1.4);
    -o-transform: scale(1.4);
    transform: scale(1.4);
    opacity: 0;
}
.social-links.animated-effect-1 li a:hover:after {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    -webkit-transition:
        -webkit-transform 0s,
        opacity 0.3s,
        background-color 0.3s;
    -moz-transition:
        -moz-transform 0s,
        opacity 0.3s,
        background-color 0.3s;
    transition:
        transform 0s,
        opacity 0.3s,
        background-color 0.3s;
}
.social-links.animated-effect-1:not(.circle) li a:after {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}
.social-links.default li a {
    color: #fff;
}
.social-links.default li a:hover {
    background-color: #fff;
    color: #777;
}
.dark .social-links li a {
    background-color: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(0, 0, 0, 0.1);
    color: #fff;
}
.dark.social-links li a {
    background-color: rgba(0, 0, 0, 0.6);
    border: 1px solid rgba(0, 0, 0, 0.1);
    color: #fff;
}
.dark.social-links li a:hover {
    background-color: rgba(0, 0, 0, 0.8);
    color: #fff;
    border-color: rgba(0, 0, 0, 0.8);
}
.colored .social-links li a {
    background-color: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(0, 0, 0, 0.01);
    color: #fff;
}
.tl-header-top .social-links {
    margin: 0;
    display: inline-block;
    margin-top: 2px;
}
.footer-content .social-links li {
    margin: 0 5px 5px 0;
}
.footer-content .social-links li a {
    color: #777;
    background-color: transparent;
    border-color: #777;
}
.footer-content .social-links li a:hover {
    color: #fff;
    background-color: #777;
    border-color: #777;
}
.text-white .social-links li a {
    color: #fff;
    border-color: #fff;
}
.text-white .social-links li a:focus,
.text-white .social-links li a:hover {
    color: #333;
    background-color: #fff;
    border-color: #fff;
}
.social-links.small li a {
    width: 30px;
    height: 30px;
    font-size: 14px;
}
.social-links.small li a i {
    line-height: 29px;
}
.social-links.large li a {
    width: 60px;
    height: 60px;
    font-size: 24px;
}
.social-links.large li a i {
    line-height: 60px;
}
.social-links.square li a,
.square {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}
.social-links.circle li a {
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
}
.social-links.animated-effect-1 li.twitter a:hover {
    border-color: #55acee;
}
.btn.twitter,
.colored.social-links li.twitter a,
.social-links.animated-effect-1 li.twitter a:after,
.social-links:not(.animated-effect-1) li.twitter a:hover {
    background-color: #55acee;
    border-color: #55acee;
    color: #fff;
}
.social-links.animated-effect-1 li.skype a:hover {
    border-color: #00aff0;
}
.btn.skype,
.colored.social-links li.skype a,
.social-links.animated-effect-1 li.skype a:after,
.social-links:not(.animated-effect-1) li.skype a:hover {
    background-color: #00aff0;
    border-color: #00aff0;
    color: #fff;
}
.social-links.animated-effect-1 li.linkedin a:hover {
    border-color: #0976b4;
}
.btn.linkedin,
.colored.social-links li.linkedin a,
.social-links.animated-effect-1 li.linkedin a:after,
.social-links:not(.animated-effect-1) li.linkedin a:hover {
    background-color: #0976b4;
    border-color: #0976b4;
    color: #fff;
}
.social-links.animated-effect-1 li.youtube a:hover {
    border-color: #b31217;
}
.btn.youtube,
.colored.social-links li.youtube a,
.social-links.animated-effect-1 li.youtube a:after,
.social-links:not(.animated-effect-1) li.youtube a:hover {
    background-color: #b31217;
    border-color: #b31217;
    color: #fff;
}
.social-links.animated-effect-1 li.flickr a:hover {
    border-color: #ff0084;
}
.btn.flickr,
.colored.social-links li.flickr a,
.social-links.animated-effect-1 li.flickr a:after,
.social-links:not(.animated-effect-1) li.flickr a:hover {
    background-color: #ff0084;
    border-color: #ff0084;
    color: #fff;
}
.social-links.animated-effect-1 li.facebook a:hover {
    border-color: #3b5998;
}
.btn.facebook,
.colored.social-links li.facebook a,
.social-links.animated-effect-1 li.facebook a:after,
.social-links:not(.animated-effect-1) li.facebook a:hover {
    background-color: #3b5998;
    border-color: #3b5998;
    color: #fff;
}
.social-links.animated-effect-1 li.pinterest a:hover {
    border-color: #cb2027;
}
.btn.pinterest,
.colored.social-links li.pinterest a,
.social-links.animated-effect-1 li.pinterest a:after,
.social-links:not(.animated-effect-1) li.pinterest a:hover {
    background-color: #cb2027;
    border-color: #cb2027;
    color: #fff;
}
.social-links.animated-effect-1 li.instagram a:hover {
    border-color: #517fa4;
}
.btn.instagram,
.colored.social-links li.instagram a,
.social-links.animated-effect-1 li.instagram a:after,
.social-links:not(.animated-effect-1) li.instagram a:hover {
    background-color: #517fa4;
    border-color: #517fa4;
    color: #fff;
}
.social-links.animated-effect-1 li.vimeo a:hover {
    border-color: #aad450;
}
.btn.vimeo,
.colored.social-links li.vimeo a,
.social-links.animated-effect-1 li.vimeo a:after,
.social-links:not(.animated-effect-1) li.vimeo a:hover {
    background-color: #aad450;
    border-color: #aad450;
    color: #fff;
}
.social-links.animated-effect-1 li.tumblr a:hover {
    border-color: #32506d;
}
.btn.tumblr,
.colored.social-links li.tumblr a,
.social-links.animated-effect-1 li.tumblr a:after,
.social-links:not(.animated-effect-1) li.tumblr a:hover {
    background-color: #32506d;
    border-color: #32506d;
    color: #fff;
}
.social-links.animated-effect-1 li.soundcloud a:hover {
    border-color: #ff3a00;
}
.btn.soundcloud,
.colored.social-links li.soundcloud a,
.social-links.animated-effect-1 li.soundcloud a:after,
.social-links:not(.animated-effect-1) li.soundcloud a:hover {
    background-color: #ff3a00;
    border-color: #ff3a00;
    color: #fff;
}
.social-links.animated-effect-1 li.foursquare a:hover {
    border-color: #0072b1;
}
.btn.foursquare,
.colored.social-links li.foursquare a,
.social-links.animated-effect-1 li.foursquare a:after,
.social-links:not(.animated-effect-1) li.foursquare a:hover {
    background-color: #0072b1;
    border-color: #0072b1;
    color: #fff;
}
.social-links.animated-effect-1 li.dribbble a:hover {
    border-color: #ea4c89;
}
.btn.dribbble,
.colored.social-links li.dribbble a,
.social-links.animated-effect-1 li.dribbble a:after,
.social-links:not(.animated-effect-1) li.dribbble a:hover {
    background-color: #ea4c89;
    border-color: #ea4c89;
    color: #fff;
}
.social-links.animated-effect-1 li.xing a:hover {
    border-color: #126567;
}
.btn.xing,
.colored.social-links li.xing a,
.social-links.animated-effect-1 li.xing a:after,
.social-links:not(.animated-effect-1) li.xing a:hover {
    background-color: #126567;
    border-color: #126567;
    color: #fff;
}
.social-links.animated-effect-1 li.behance a:hover {
    border-color: #126567;
}
.btn.behance,
.colored.social-links li.behance a,
.social-links.animated-effect-1 li.behance a:after,
.social-links:not(.animated-effect-1) li.behance a:hover {
    background-color: #053eff;
    border-color: #053eff;
    color: #fff;
}
.social-links.animated-effect-1 li.vine a:hover {
    border-color: #126567;
}
.btn.vine,
.colored.social-links li.vine a,
.social-links.animated-effect-1 li.vine a:after,
.social-links:not(.animated-effect-1) li.vine a:hover {
    background-color: #00a478;
    border-color: #00a478;
    color: #fff;
}
.social-links.animated-effect-1 li.stumbleupon a:hover {
    border-color: #126567;
}
.btn.stumbleupon,
.colored.social-links li.stumbleupon a,
.social-links.animated-effect-1 li.stumbleupon a:after,
.social-links:not(.animated-effect-1) li.stumbleupon a:hover {
    background-color: #f74425;
    border-color: #f74425;
    color: #fff;
}
.social-links .dropdown > button {
    padding: 1px 15px 0;
    font-size: 16px;
    color: #999;
    text-align: center;
    min-width: 0;
    margin: 0;
    background-color: transparent;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}
.social-links .dropdown > button i {
    width: 15px;
}
.tl-header-top.colored .social-links .dropdown.show > button > i:before,
.tl-header-top.colored .social-links .dropdown > button > i:before {
    color: #fff;
}
.tl-header-top .social-links .dropdown.show > button > i:before {
    content: "\f00d";
}
.social-links .dropdown-menu {
    z-index: 103;
    padding: 5px;
    min-width: 270px;
    margin-top: 6px;
    font-size: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    background-color: #f2f2f2;
    border: 1px solid #d0d0d0;
    border-top: none;
}
.colored .social-links .dropdown-menu li a i,
.dark .social-links .dropdown-menu li a i,
.social-links .dropdown-menu li a {
    padding: 0;
    line-height: 30px;
    color: #fff;
}
.social-links .dropdown-menu li a i {
    padding-left: 0;
}
.social-links .dropdown-menu li a:hover i {
    color: #fff;
}
.tl-header-dropdown-buttons {
    padding-top: 20px;
}
.tl-header-dropdown-buttons .btn-group:first-child {
    margin-right: 5px;
}
.tl-header-dropdown-buttons .btn-group > .btn {
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    width: 40px;
    height: 40px;
    padding: 0;
    line-height: 38px;
    text-align: center;
    background-color: #f2f2f2;
    border: 1px solid #e9e9e9;
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    margin: 0;
}
.tl-header-dropdown-buttons .btn-group > .btn:hover {
    color: #fff;
}
.tl-header-dropdown-buttons .btn-group .dropdown-menu {
    z-index: 103;
    padding: 20px;
    min-width: 280px;
    margin-top: 20px;
    top: 100%;
    border: none;
    -webkit-border-radius: 0 0 5px 5px;
    -moz-border-radius: 0 0 5px 5px;
    border-radius: 0 0 5px 5px;
}
.dark .tl-header-dropdown-buttons .btn-group .dropdown-menu {
    margin-top: 19px;
}
.dark .tl-header-dropdown-buttons .cart {
    color: #cacaca;
}
.tl-header-dropdown-buttons .btn-group.show > .btn {
    color: #fff;
}
.tl-header.centered .tl-header-dropdown-buttons .btn-group .dropdown-menu {
    margin-top: 8px;
}
.colored .tl-header-dropdown-buttons .btn-group > .btn,
.dark .tl-header-dropdown-buttons .btn-group > .btn {
    background-color: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(0, 0, 0, 0.15);
    text-shadow: 1px 1px rgba(0, 0, 0, 0.7);
    color: #cdcdcd;
}
.colored .tl-header-dropdown-buttons .btn-group > .btn:hover,
.dark .tl-header-dropdown-buttons .btn-group > .btn:hover {
    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(0, 0, 0, 0.25);
}
.colored .tl-header-dropdown-buttons .btn-group.show > .btn,
.dark .tl-header-dropdown-buttons .btn-group.show > .btn {
    background-color: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(0, 0, 0, 0.25);
}
.btn-group.show .dropdown-animation {
    -webkit-animation-duration: 0.3s;
    animation-duration: 0.3s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-name: fadeIn;
    animation-name: fadeIn;
}
.search-box .form-group {
    margin-bottom: 0;
}
.call-to-action a,
.call-to-action h1 {
    margin: 0;
}
.call-to-action p {
    margin-bottom: 10px;
}
@media (max-width: 767px) {
    .call-to-action .text-right {
        text-align: left;
    }
}
.counter {
    display: block;
    font-size: 32px;
    line-height: 1;
}
.pricing-tables {
    margin: 60px 0 0;
}
.plan {
    text-align: center;
    margin-bottom: 40px !important;
}
.plan.round-corners .tl-header {
    -webkit-border-radius: 25px 25px 0 0;
    -moz-border-radius: 25px 25px 0 0;
    border-radius: 25px 25px 0 0;
}
.plan.round-corners ul,
.plan.round-corners ul li:last-child {
    -webkit-border-radius: 0 0 25px 25px;
    -moz-border-radius: 0 0 25px 25px;
    border-radius: 0 0 25px 25px;
}
.plan .tl-header {
    padding: 0;
    margin: 0 -1px;
    border: none;
}
.plan .tl-header h3 {
    font-size: 36px;
    margin: 0;
    line-height: 36px;
    font-weight: 300;
    padding: 15px 0 10px;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-top: none;
}
.plan .tl-header .price {
    font-size: 28px;
    padding: 8px 0 10px;
    font-weight: 300;
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    line-height: 1;
    color: #fff;
}
.plan ul {
    margin: 0;
    padding: 0;
    font-size: 14px;
    list-style: none;
}
.plan ul li {
    padding: 12px 0;
    font-size: 13px;
    border-bottom: 1px solid #f3f3f3;
    border-top: 1px solid #fff;
    color: #333;
}
.plan ul.text-large li {
    font-size: 16px;
}
.plan.best-value ul li {
    padding: 15px 0;
}

.circle-head .plan .tl-header {
    padding: 0;
    border: none;
    width: 160px;
    height: 160px;
    -webkit-border-radius: 100%;
    -moz-border-radius: 100%;
    border-radius: 100%;
    margin: 20px auto;
    padding: 10px 0;
}
.circle-head .plan .tl-header h3 {
    font-size: 26px;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding-top: 27px;
}
.circle-head .plan .tl-header .price {
    height: 80px;
    border: none;
    padding-top: 15px;
    font-size: 22px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
}
.stripped .plan ul {
    -webkit-box-shadow: 0 -15px 32px 0 #cacaca inset;
    box-shadow: 0 -15px 32px 0 #cacaca inset;
    background: #fdfdfd;
}
.stripped .plan ul li {
    border: 1px solid #ececec;
    border-top: none;
    color: #666;
}
.stripped .plan ul li:nth-child(even) {
    -webkit-box-shadow: 0 0 40px #e4e4e4 inset;
    box-shadow: 0 0 40px #e4e4e4 inset;
    background: #fff;
    border-right: 1px solid #e2e2e2;
    border-bottom: 1px solid #e2e2e2;
}
@media (min-width: 768px) {
    .best-value.plan {
        top: -30px;
        position: relative;
        z-index: 2;
    }
}
#map-canvas {
    height: 450px;
}
#map-canvas.small {
    height: 347px;
}
#collapseMap:not(.show) {
    overflow: hidden;
    height: 0;
    -webkit-transition: height 0.3s ease-in-out;
    -o-transition: height 0.3s ease-in-out;
    transition: height 0.3s ease-in-out;
}
#collapseMap.in {
    height: 450px;
}
.footer-content #map-canvas {
    height: 300px;
}
#map-canvas img {
    max-width: inherit;
}
.tags-cloud {
    font-size: 0;
}
.tag {
    display: inline-block;
    margin: 0 3px 3px 0;
}
.tag a {
    padding: 3px 10px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    color: #fff;
    display: block;
    font-size: 11px;
}
.tag a:hover {
    background-color: #fff;
    text-decoration: none;
}
.dark .tag a {
    color: #777;
    background-color: transparent;
    border: 1px solid #333;
}
.dark .tag a:hover {
    color: #fff;
    background-color: #777;
    border-color: #777;
    text-decoration: none;
}
.icons-block i {
    display: inline-block;
    font-size: 30px;
    color: #999;
}
.scrollToTop {
    color: #fff;
    position: fixed;
    bottom: 5px;
    right: 5px;
    width: 50px;
    height: 50px;
    text-align: center;
    cursor: pointer;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 1005;
    -webkit-backface-visibility: hidden;
    -webkit-transform: translateZ(0);
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
    opacity: 0;
}
.scrollToTop.fadeToTop {
    -webkit-animation-name: fadeToTop;
    animation-name: fadeToTop;
    -webkit-animation-duration: 0.4s;
    animation-duration: 0.4s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}
@-webkit-keyframes fadeToTop {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, 100%, 0);
        transform: translate3d(0, 100%, 0);
    }
    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}
@keyframes fadeToTop {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, 100%, 0);
        -ms-transform: translate3d(0, 100%, 0);
        transform: translate3d(0, 100%, 0);
    }
    100% {
        opacity: 1;
        -webkit-transform: none;
        -ms-transform: none;
        transform: none;
    }
}
.scrollToTop.fadeToBottom {
    -webkit-animation-name: fadeToBottom;
    animation-name: fadeToBottom;
    -webkit-animation-duration: 0.4s;
    animation-duration: 0.4s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}
@-webkit-keyframes fadeToBottom {
    0% {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        -webkit-transform: translate3d(0, 100%, 0);
        transform: translate3d(0, 100%, 0);
    }
}
@keyframes fadeToBottom {
    0% {
        opacity: 1;
        -webkit-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
    }
    100% {
        opacity: 0;
        -webkit-transform: translate3d(0, 100%, 0);
        -ms-transform: translate3d(0, 100%, 0);
        transform: translate3d(0, 100%, 0);
    }
}
.scrollToTop i {
    line-height: 48px;
    font-size: 26px;
}
.scrollToTop:hover {
    background-color: rgba(0, 0, 0, 0.6);
}
@media (max-width: 767px) {
    .scrollToTop {
        width: 40px;
        height: 40px;
        background-color: rgba(0, 0, 0, 0.4);
    }
    .scrollToTop i {
        line-height: 40px;
        font-size: 20px;
    }
}
.slider-banner-container,
.slider-revolution-5-container {
    width: 100%;
    position: relative;
    padding: 0;
    direction: ltr;
}
.slider-banner-fullscreen,
.slider-banner-fullwidth {
    width: 100%;
    position: relative;
}
.slider-banner-container ul.slides,
.slider-revolution-5-container ul.slides {
    display: none;
}




.btn.moving {
    padding: 10px 0 20px;
    -webkit-font-smoothing: antialiased;
}
.btn.moving i {
    display: block;
    font-size: 24px;
    line-height: 1px;
    height: 10px;
    color: #fff;
    opacity: 1;
}
.btn.moving i + i {
    opacity: 0.66;
}
.btn.moving i + i + i {
    opacity: 0.33;
}
.moving i + i + i {
    -webkit-animation: opacity_first 2s linear infinite;
    -moz-animation: opacity_first 2s linear infinite;
    -ms-animation: opacity_first 2s linear infinite;
    -o-animation: opacity_first 2s linear infinite;
    animation: opacity_first 2s linear infinite;
    -webkit-transition: none !important;
    -o-transition: none !important;
    transition: none !important;
}
.moving i + i {
    -webkit-animation: opacity_second 2s linear infinite;
    -moz-animation: opacity_second 2s linear infinite;
    -ms-animation: opacity_second 2s linear infinite;
    -o-animation: opacity_second 2s linear infinite;
    animation: opacity_second 2s linear infinite;
    -webkit-transition: none !important;
    -o-transition: none !important;
    transition: none !important;
}
.moving > i {
    -webkit-animation: opacity_third 2s linear infinite;
    -moz-animation: opacity_third 2s linear infinite;
    -ms-animation: opacity_third 2s linear infinite;
    -o-animation: opacity_third 2s linear infinite;
    animation: opacity_third 2s linear infinite;
    -webkit-transition: none !important;
    -o-transition: none !important;
    transition: none !important;
}
@-webkit-keyframes opacity_first {
    0% {
        opacity: 0.33;
    }
    24.91% {
        opacity: 1;
    }
    49.833% {
        opacity: 0;
    }
}
@keyframes opacity_first {
    0% {
        opacity: 0.33;
    }
    24.91% {
        opacity: 1;
    }
    49.833% {
        opacity: 0;
    }
}
@-webkit-keyframes opacity_second {
    0% {
        opacity: 0.66;
    }
    16.66% {
        opacity: 1;
    }
    41.5833% {
        opacity: 0;
    }
}
@keyframes opacity_second {
    0% {
        opacity: 0.66;
    }
    16.66% {
        opacity: 1;
    }
    41.5833% {
        opacity: 0;
    }
}
@-webkit-keyframes opacity_third {
    0% {
        opacity: 1;
    }
    33.33% {
        opacity: 0;
    }
}
@keyframes opacity_third {
    0% {
        opacity: 1;
    }
    33.33% {
        opacity: 0;
    }
}
@media (max-width: 767px) {
    .btn.moving {
        position: absolute;
        bottom: -100px;
        left: 50%;
        margin-left: -18px;
    }
}







@media (max-width: 991px) {
    .slideshow .icon.large {
        font-size: 24px;
        width: 90px;
        height: 90px;
        line-height: 88px;
    }
    .slideshow .icon.small {
        font-size: 15px;
        width: 35px;
        height: 35px;
        line-height: 35px;
    }
}
@media (max-width: 767px) {
    .slideshow .icon.large {
        font-size: 18px;
        width: 60px;
        height: 60px;
        line-height: 58px;
    }
}
@media (max-width: 575px) {
    .slideshow .icon.large {
        font-size: 18px;
        width: 35px;
        height: 35px;
        line-height: 33px;
    }
}


@media (max-width: 767px) {

}

/* =============================================================================
 * 18. TYPOGRAPHY SCHEME
 * Font families: Roboto (body text), Raleway (headings), Pacifico (logo)
 * ============================================================================= */

.navbar .navbar-nav,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Raleway, sans-serif;
}
body {
    font-family: Roboto, sans-serif;
}
button,
input,
optgroup,
select,
textarea {
    font-family: Roboto, sans-serif;
}
.logo-font {
    font-family: Pacifico, cursive, sans-serif;
}
body {
    font-size: 16px;
    line-height: 1.5;
    color: #777;
    background-color: #fff;
    font-weight: 300;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #333;
    line-height: 1.2;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: #333;
}
.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6 {
    color: #fff;
}
.text-white h1 a,
.text-white h2 a,
.text-white h3 a,
.text-white h4 a,
.text-white h5 a,
.text-white h6 a {
    color: #fff;
    text-decoration: underline;
}
.dark h1,
.dark h2,
.dark h3,
.dark h4,
.dark h5,
.dark h6 {
    color: #fff;
}
.dark h1 a,
.dark h2 a,
.dark h3 a,
.dark h4 a,
.dark h5 a,
.dark h6 a {
    color: #fff;
}
.dark .footer h1,
.dark .footer h2,
.dark .footer h3,
.dark .footer h4,
.dark .footer h5,
.dark .footer h6 {
    color: #999;
}
.dark .footer h1 a,
.dark .footer h2 a,
.dark .footer h3 a,
.dark .footer h4 a,
.dark .footer h5 a,
.dark .footer h6 a {
    color: #999;
}
h1 {
    font-size: 33px;
    font-weight: var(--tl-weight-bold);
}
h1.logo-font {
    text-transform: none;
    font-weight: 300;
    font-size: 50px;
}
h1.large {
    font-size: 45px;
    font-weight: 300;
    letter-spacing: 0.1em;
}
h2 {
    font-size: 29px;
    margin-bottom: 15px;
}
h2.logo-font {
    text-transform: none;
}
h3 {
    font-size: 27px;
    font-weight: var(--tl-weight-bold);
}
h4 {
    font-size: 19px;
    font-weight: var(--tl-weight-bold);
}
h5 {
    font-size: 15px;
    text-transform: uppercase;
    font-weight: var(--tl-weight-bold);
}
h6 {
    font-size: 13px;
    font-weight: var(--tl-weight-bold);
}
@media screen and (min-width: 768px) {
    h1.extra-large {
        font-size: 130px;
        font-weight: var(--tl-weight-bold);
    }
}
@media screen and (max-width: 767px) {
    h1.extra-large {
        font-size: 60px;
        font-weight: var(--tl-weight-bold);
    }
}
.page-title {
    margin-top: 0;
}
@media (min-width: 992px) {
    .title {
        margin-top: 0;
    }
}
.tl-sidebar .title {
    margin-top: 3px;
}
p {
    margin-bottom: 15px;
}
p.large {
    font-size: 18px;
    line-height: 1.4;
    margin-bottom: 30px;
}
a {
    -webkit-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}
a:active,
a:focus {
    outline: 0;
}
.link-dark {
    color: #333;
    text-decoration: none !important;
}
.link-dark:hover {
    color: #333;
    text-decoration: underline !important;
}
.dark .footer .link-dark {
    color: #777;
    text-decoration: none !important;
}
.dark .footer .link-dark:hover {
    color: #777;
    text-decoration: underline !important;
}
.link-light {
    color: #fff;
    text-decoration: none !important;
}
.link-light:hover {
    color: #fff;
    text-decoration: underline !important;
}
blockquote {
    border-left: none;
    display: inline-block;
    margin: 20px auto 20px;
    font-size: 16px;
    position: relative;
    padding: 10px 25px;
}
blockquote:after {
    content: """;
    width: 25px;
    height: 25px;
    line-height: 36px;
    font-size: 36px;
    font-family: "PT Serif", serif;
    position: absolute;
    top: 12px;
    left: 0;
    color: #cdcdcd;
}
.blockquote:before {
    font-family: "PT Serif", serif;
    content: """;
    font-size: 40px;
}
blockquote.inline {
    padding: 0;
}
blockquote.inline p {
    width: 60%;
    display: inline-block;
    margin: 0;
}
blockquote.inline footer {
    width: 37%;
    display: inline-block;
    padding-left: 5px;
}
blockquote.inline:after {
    top: 0;
}
pre {
    padding: 20px;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    background-color: #fafafa;
    border: 1px solid #f1f1f1;
}
.text-muted {
    color: #999 !important;
}
.text-white {
    color: #fff !important;
}

hr {
    border-color: #eee;
}
.dark hr {
    border-color: #333;
}

 * Tutorial sidebar (desktop sticky + mobile drawer)
 * Sidebar menu navigation (tl-sidebar-menu)
 * Share links, site slogan visibility
 * ============================================================================= */

.hidden {
    display: none !important;
}

/* --- Tutorial Sidebar: Desktop (>=992px) --- */
@media (min-width: 992px) {
    .tutorial-sidebar-col {
        padding-left: 0;
        padding-right: 0;
        display: block !important;
    }
    .tutorial-sidebar-inner {
        position: sticky;
        top: 80px;
        max-height: calc(100vh - 90px);
        overflow-y: auto;
        padding: 0;
        border-right: 1px solid #e9ecef;
        background: var(--tl-body-bg);
    }
    /* Hide tutorial sidebar toggle on desktop */
    .tl-tut-sidebar-toggle {
        display: none !important;
    }
}

/* --- Tutorial Sidebar: Mobile (<992px) --- */
@media (max-width: 991.98px) {
    /* Hide sidebar column on mobile by default */
    .tutorial-sidebar-col {
        display: none !important;
        position: fixed;
        top: 68px;
        left: 0;
        width: 280px;
        max-width: 85vw;
        height: calc(100vh - 68px);
        background: #fff;
        border-right: 1px solid #e9ecef;
        box-shadow: 4px 0 20px rgba(0,0,0,.1);
        z-index: 1050;
        overflow-y: auto;
        padding: 0;
    }
    
    /* Show sidebar when toggled on mobile */
    .tutorial-sidebar-col.tl-sidebar-visible {
        display: block !important;
    }
    
    /* Tutorial sidebar toggle button (left of logo) */
    .tl-tut-sidebar-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        border-radius: 8px;
        background: rgba(56,189,248,.1);
        border: 1px solid rgba(56,189,248,.25);
        color: #38bdf8;
        cursor: pointer;
        font-size: 0.9rem;
        margin-right: 8px;
        transition: background 0.2s, border-color 0.2s;
        order: -1;
    }
    .tl-tut-sidebar-toggle:hover {
        background: rgba(56,189,248,.2);
        border-color: rgba(56,189,248,.4);
    }

    /* Hide site slogan on tablet/mobile */
    .site-slogan {
        display: none !important;
    }
}

/* --- Sidebar Menu (tl-sidebar-menu) --- */
.tl-sidebar-menu {
    font-size: 0.875rem;
}

.tl-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 12px;
    background: none;
    color: #333;
    font-size: 1rem;
    font-weight: var(--tl-weight-semibold);
    margin-bottom: 4px;
    text-align: center;
}

.tl-sidebar-header i {
    font-size: 1.1rem;
}

.tl-sidebar-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.tl-sidebar-nav ul li a {
    display: block;
    padding: 7px 12px;
    color: #444;
    text-decoration: none;
    border-left: 3px solid transparent;
    line-height: 1.4;
    transition:
        background 0.15s,
        color 0.15s;
}

.tl-sidebar-nav ul li a:hover {
    background: #f8f9fa;
    color: var(--tl-accent);
    border-left-color: var(--tl-accent);
}

.tl-sidebar-nav ul li a.active {
    background: #fff5f4;
    color: var(--tl-accent);
    border-left-color: var(--tl-accent);
    font-weight: var(--tl-weight-semibold);
}

/* --- Collapsible Menu Sections --- */
.tl-sidebar-nav .tl-menu-section {
    margin: 0;
}

.tl-sidebar-nav .tl-menu-section > a.tl-section-toggle {
    display: flex;
    align-items: center;
    padding: 10px 12px;
    color: #333;
    font-weight: var(--tl-weight-semibold);
    text-decoration: none;
    background: #f0f0f0;
    border-left: 3px solid #ccc;
    cursor: pointer;
    transition: all 0.2s ease;
}

.tl-sidebar-nav .tl-menu-section > a.tl-section-toggle:hover {
    background: #e8e8e8;
    color: var(--tl-accent);
    border-left-color: var(--tl-accent);
}

.tl-sidebar-nav .tl-menu-section .tl-section-icon {
    font-size: 0.7rem;
    margin-right: 8px;
    transition: transform 0.2s ease;
}

.tl-sidebar-nav .tl-menu-section.tl-section-open .tl-section-icon {
    transform: rotate(90deg);
}

.tl-sidebar-nav .tl-menu-section .tl-section-items {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.tl-sidebar-nav .tl-menu-section.tl-section-open .tl-section-items {
    max-height: 1000px;
}

.tl-sidebar-nav .tl-menu-section .tl-section-items li a {
    padding-left: 32px;
    font-size: 0.85rem;
    border-left-color: transparent;
}

.tl-sidebar-nav .tl-menu-section .tl-section-items li a:hover {
    background: #f8f9fa;
    color: var(--tl-accent);
    border-left-color: var(--tl-accent);
}

.tl-sidebar-nav .tl-menu-section .tl-section-items li a.active {
    background: #fff5f4;
    color: var(--tl-accent);
    border-left-color: var(--tl-accent);
    font-weight: var(--tl-weight-semibold);
}

/* --- Sidebar Share Links --- */
.tl-sidebar-share {
    margin-top: 8px;
    padding: 8px 12px;
    background: #f8f9fa;
    display: flex;
    align-items: center;
    gap: 10px;
}

.tl-sidebar-share > span {
    font-size: 0.7rem;
    font-weight: var(--tl-weight-semibold);
    color: #888;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.tl-share-links {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.tl-share-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #fff;
    color: #555;
    font-size: 0.75rem;
    border: 1px solid #dee2e6;
    text-decoration: none;
    transition:
        background 0.15s,
        color 0.15s,
        border-color 0.15s;
}

.tl-share-links a:hover {
    background: var(--tl-accent);
    color: #fff;
    border-color: var(--tl-accent);
}


/* ==============================================================================
   SHARED ARTICLE/CONTENT SYSTEM
   Unified styles for tutorials, blogs, and interview question pages.
   These three page types share identical layout patterns.
   ============================================================================== */

/* -- Article Container -------------------------------------------------------- */
.tl-article {
  max-width: 900px;
  margin: 0 auto;
  padding: var(--tl-space-8) var(--tl-space-4);
}

/* -- Article Typography ------------------------------------------------------- */
.tl-article h1 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--tl-weight-extrabold);
  color: var(--tl-heading-color);
  line-height: var(--tl-leading-tight);
  margin-bottom: var(--tl-space-4);
}
.tl-article h2 {
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: var(--tl-weight-bold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-10);
  margin-bottom: var(--tl-space-4);
  padding-bottom: var(--tl-space-2);
  border-bottom: 2px solid var(--tl-border);
}
.tl-article h3 {
  font-size: clamp(1.15rem, 2.5vw, 1.5rem);
  font-weight: var(--tl-weight-bold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-8);
  margin-bottom: var(--tl-space-3);
}
.tl-article h4 {
  font-size: var(--tl-text-lg);
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-6);
  margin-bottom: var(--tl-space-2);
}
.tl-article p {
  font-size: var(--tl-text-base);
  line-height: var(--tl-leading-relaxed);
  color: var(--tl-body-color);
  margin-bottom: var(--tl-space-4);
  text-align: justify;
  text-justify: inter-word;
}

/* Keep the header logo mark clean even when legacy global anchor hover rules load. */
.tl-mh-logo,
.tl-mh-logo:hover,
.tl-mh-logo:focus,
.tl-mh-logo:active,
.tl-mh-logo:visited,
.tl-mh-logo *,
.tl-mh-logo:hover *,
.tl-mh-logo:focus *,
.tl-mh-logo:active * {
    text-decoration: none !important;
    -webkit-text-decoration: none !important;
    text-decoration-line: none !important;
    text-decoration-color: transparent !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
}
.tl-article ul,
.tl-article ol {
  margin-bottom: var(--tl-space-4);
  padding-left: var(--tl-space-6);
}
.tl-article li {
  margin-bottom: var(--tl-space-2);
  line-height: var(--tl-leading-relaxed);
}
.tl-article a {
  color: var(--tl-sky-dark);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--tl-duration-base);
}
.tl-article a:hover {
  color: var(--tl-sky);
}
.tl-article .tl-share-btn,
.tl-article .tl-share-btn:hover,
.tl-article .tl-share-btn:focus,
.tl-article .tl-share-btn:active {
  text-decoration: none !important;
  text-decoration-line: none !important;
  border-bottom: 0 !important;
}
.tl-article .tl-share-twitter { color: #1da1f2; }
.tl-article .tl-share-linkedin { color: #0077b5; }
.tl-article .tl-share-facebook { color: #1877f2; }
.tl-article .tl-share-reddit { color: #ff4500; }
.tl-article .tl-share-whatsapp { color: #25d366; }
.tl-article strong {
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
}
.tl-article blockquote {
  border-left: 4px solid var(--tl-sky);
  padding: var(--tl-space-4) var(--tl-space-5);
  margin: var(--tl-space-6) 0;
  background: var(--tl-surface-alt);
  border-radius: 0 var(--tl-radius-md) var(--tl-radius-md) 0;
  font-style: italic;
  color: var(--tl-gray-700);
}

/* -- Article Content Blocks --------------------------------------------------- */
.tl-article-note {
  padding: var(--tl-space-4) var(--tl-space-5);
  margin: var(--tl-space-6) 0;
  border-radius: var(--tl-radius-lg);
  border-left: 4px solid;
  font-size: var(--tl-text-sm);
  line-height: var(--tl-leading-relaxed);
}
.tl-article-note--info {
  background: var(--tl-info-light);
  border-color: var(--tl-info);
  color: #0c5460;
}
.tl-article-note--warning {
  background: var(--tl-warning-light);
  border-color: var(--tl-warning);
  color: #856404;
}
.tl-article-note--tip {
  background: var(--tl-success-light);
  border-color: var(--tl-success);
  color: #155724;
}

/* -- Article Tables ----------------------------------------------------------- */
.tl-article table {
  width: 100%;
  margin: var(--tl-space-6) 0;
  border-collapse: collapse;
  border-radius: var(--tl-radius-lg);
  overflow: hidden;
  border: 1px solid var(--tl-border);
  font-size: var(--tl-text-sm);
}
.tl-article table th {
  background: var(--tl-surface-alt);
  padding: var(--tl-space-3) var(--tl-space-4);
  text-align: left;
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
  border-bottom: 2px solid var(--tl-border);
}
.tl-article table td {
  padding: var(--tl-space-3) var(--tl-space-4);
  border-bottom: 1px solid var(--tl-border);
  color: var(--tl-body-color);
}
.tl-article table tbody tr:hover {
  background: var(--tl-surface-alt);
}
.tl-article table tbody tr:last-child td {
  border-bottom: none;
}

/* -- Article Sidebar ---------------------------------------------------------- */
.tl-article-sidebar {
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  scrollbar-width: thin;
}

/* -- Table of Contents -------------------------------------------------------- */
.tl-article-toc {
  background: var(--tl-surface-alt);
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-lg);
  padding: var(--tl-space-5);
  margin-bottom: var(--tl-space-6);
}
.tl-article-toc h3 {
  font-size: var(--tl-text-sm);
  font-weight: var(--tl-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--tl-heading-color);
  margin: 0 0 var(--tl-space-3);
  padding: 0;
  border: none;
}
.tl-article-toc ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.tl-article-toc li {
  margin-bottom: var(--tl-space-1);
}
.tl-article-toc a {
  display: block;
  padding: var(--tl-space-1) var(--tl-space-2);
  color: var(--tl-muted);
  font-size: var(--tl-text-sm);
  text-decoration: none;
  border-radius: var(--tl-radius-sm);
  transition: color var(--tl-duration-base), background var(--tl-duration-base);
}
.tl-article-toc a:hover {
  color: var(--tl-sky-dark);
  background: rgba(56, 189, 248, 0.05);
}
.tl-article-toc a.active {
  color: var(--tl-sky-dark);
  font-weight: var(--tl-weight-medium);
  background: rgba(56, 189, 248, 0.08);
}

/* -- FAQ Section -------------------------------------------------------------- */
.tl-article-faq {
  margin: var(--tl-space-10) 0;
}
.tl-article-faq h2 {
  border: none;
  padding: 0;
}
.tl-article-faq details {
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-lg);
  margin-bottom: var(--tl-space-3);
  overflow: hidden;
  transition: box-shadow var(--tl-duration-base);
}
.tl-article-faq details[open] {
  box-shadow: var(--tl-shadow-sm);
}
.tl-article-faq summary {
  padding: var(--tl-space-4) var(--tl-space-5);
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background var(--tl-duration-base);
}
.tl-article-faq summary:hover {
  background: var(--tl-surface-alt);
}
.tl-article-faq summary::after {
  content: '+';
  font-size: var(--tl-text-xl);
  color: var(--tl-muted);
  transition: transform var(--tl-duration-base);
}
.tl-article-faq details[open] summary::after {
  content: '-';
}
.tl-article-faq details > div,
.tl-article-faq details > p {
  padding: 0 var(--tl-space-5) var(--tl-space-4);
  color: var(--tl-body-color);
  line-height: var(--tl-leading-relaxed);
}

/* -- Author Section ----------------------------------------------------------- */
.tl-article-author {
  display: flex;
  gap: var(--tl-space-4);
  padding: var(--tl-space-6);
  margin: var(--tl-space-10) 0;
  background: var(--tl-surface-alt);
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-xl);
}
.tl-article-author img {
  width: 64px;
  height: 64px;
  border-radius: var(--tl-radius-full);
  object-fit: cover;
  flex-shrink: 0;
}
.tl-article-author h4 {
  margin: 0 0 var(--tl-space-1);
  font-size: var(--tl-text-base);
  font-weight: var(--tl-weight-bold);
}
.tl-article-author p {
  margin: 0;
  font-size: var(--tl-text-sm);
  color: var(--tl-muted);
}

/* -- Responsive Article ------------------------------------------------------- */
@media (max-width: 768px) {
  .tl-article {
    padding: var(--tl-space-5) var(--tl-space-3);
  }
  .tl-article-sidebar {
    position: static;
    max-height: none;
  }
  .tl-article-author {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .tl-article table {
    display: block;
    overflow-x: auto;
  }
}


/* ===============================================================================
   PHASE 1: AUTH PAGES (from tl-pages-auth.css)
   =============================================================================== */


/* ===============================================================================
   PHASE 2A: AUTHENTICATION PAGES (from tl-pages-auth.css)
   =============================================================================== */

/* -- Auth Container (full-height centered layout) -- */
.tl-auth-container {
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  background: linear-gradient(135deg, var(--tl-dark-bg) 0%, #1e3a5f 60%, var(--tl-dark-bg) 100%);
}

/* -- Auth Card (main form container) -- */
.tl-auth-card {
  background: rgba(255, 255, 255, 0.95);
  border-radius: var(--tl-radius-xl);
  box-shadow: var(--tl-shadow-2xl);
  padding: 40px;
  max-width: 420px;
  width: 100%;
}

.tl-auth-card h2 {
  color: var(--tl-heading-color);
  font-size: var(--tl-text-2xl);
  font-weight: var(--tl-weight-bold);
  margin-bottom: var(--tl-space-2);
  text-align: center;
}

.tl-auth-card .tl-auth-subtitle {
  color: var(--tl-muted);
  font-size: var(--tl-text-sm);
  text-align: center;
  margin-bottom: var(--tl-space-6);
}

/* -- Form Group (label + input wrapper) -- */
.tl-auth-form-group {
  margin-bottom: var(--tl-space-5);
}

.tl-auth-form-group label {
  display: block;
  color: var(--tl-body-color);
  font-weight: var(--tl-weight-semibold);
  margin-bottom: var(--tl-space-2);
  font-size: var(--tl-text-sm);
}

.tl-auth-form-group input,
.tl-auth-form-group textarea {
  width: 100%;
  padding: var(--tl-space-3) var(--tl-space-3);
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-md);
  font-size: var(--tl-text-sm);
  font-family: inherit;
  transition: all var(--tl-duration-base) var(--tl-ease-default);
  background: var(--tl-surface-alt);
  color: var(--tl-body-color);
}

.tl-auth-form-group input:focus,
.tl-auth-form-group textarea:focus {
  outline: none;
  background: var(--tl-surface);
  border-color: var(--tl-sky);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.1);
}

.tl-auth-form-group input.is-invalid {
  border-color: var(--tl-danger);
  background: #fef2f2;
}

.tl-auth-form-group .tl-invalid-feedback {
  color: var(--tl-danger);
  font-size: var(--tl-text-xs);
  margin-top: var(--tl-space-1);
  display: block;
}

/* -- Checkbox (remember me, terms, etc.) -- */
.tl-auth-checkbox {
  display: flex;
  align-items: center;
  gap: var(--tl-space-2);
  margin-bottom: var(--tl-space-5);
}

.tl-auth-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--tl-sky);
}

.tl-auth-checkbox label {
  margin: 0;
  cursor: pointer;
  color: var(--tl-body-color);
  font-size: var(--tl-text-sm);
  font-weight: var(--tl-weight-normal);
}

/* -- Buttons -- */
.tl-auth-btn {
  width: 100%;
  padding: var(--tl-space-3) var(--tl-space-4);
  border: none;
  border-radius: var(--tl-radius-md);
  font-size: var(--tl-text-sm);
  font-weight: var(--tl-weight-semibold);
  cursor: pointer;
  transition: all var(--tl-duration-base) var(--tl-ease-default);
  margin-bottom: var(--tl-space-3);
}

.tl-auth-btn-primary {
  background: var(--tl-sky);
  color: var(--tl-dark-bg);
}

.tl-auth-btn-primary:hover {
  background: var(--tl-sky-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(56, 189, 248, 0.2);
}

.tl-auth-btn-primary:active {
  transform: translateY(0);
}

/* -- Divider (or/and separator) -- */
.tl-auth-divider {
  display: flex;
  align-items: center;
  gap: var(--tl-space-3);
  margin: var(--tl-space-6) 0;
  color: var(--tl-border);
}

.tl-auth-divider::before,
.tl-auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--tl-border);
}

/* -- Links (forgot password, sign up, etc.) -- */
.tl-auth-links {
  display: flex;
  flex-direction: column;
  gap: var(--tl-space-3);
  text-align: center;
}

.tl-auth-links a {
  color: var(--tl-sky);
  text-decoration: none;
  font-size: var(--tl-text-sm);
  transition: color var(--tl-duration-base) var(--tl-ease-default);
}

.tl-auth-links a:hover {
  color: var(--tl-sky-dark);
  text-decoration: underline;
}

/* -- Alerts (success, error, info) -- */
.tl-auth-alert {
  padding: var(--tl-space-3) var(--tl-space-3);
  border-radius: var(--tl-radius-md);
  margin-bottom: var(--tl-space-5);
  font-size: var(--tl-text-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--tl-space-2);
}

.tl-auth-alert-success {
  background: var(--tl-success-light);
  color: var(--tl-success-dark);
  border: 1px solid var(--tl-success);
}

.tl-auth-alert-error {
  background: var(--tl-danger-light);
  color: var(--tl-danger-dark);
  border: 1px solid var(--tl-danger);
}

.tl-auth-alert i {
  margin-top: 2px;
  flex-shrink: 0;
}

/* -- Terms & Conditions -- */
.tl-auth-terms {
  font-size: var(--tl-text-xs);
  color: var(--tl-muted);
  text-align: center;
  margin-top: var(--tl-space-4);
}

.tl-auth-terms a {
  color: var(--tl-sky);
  text-decoration: none;
}

.tl-auth-terms a:hover {
  text-decoration: underline;
}

/* -- Dark Mode Overrides -- */
[data-theme="dark"] .tl-auth-container {
  background: linear-gradient(135deg, var(--tl-dark-bg) 0%, #1e3a5f 60%, var(--tl-dark-bg) 100%);
}

[data-theme="dark"] .tl-auth-card {
  background: var(--tl-surface);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  border: 1px solid var(--tl-border);
}

[data-theme="dark"] .tl-auth-card h2 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-auth-subtitle {
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-auth-form-group label {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-auth-form-group input,
[data-theme="dark"] .tl-auth-form-group textarea {
  background: var(--tl-surface-alt);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-auth-form-group input:focus,
[data-theme="dark"] .tl-auth-form-group textarea:focus {
  background: var(--tl-surface);
  border-color: var(--tl-sky);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.2);
}

[data-theme="dark"] .tl-auth-form-group input.is-invalid {
  border-color: var(--tl-danger);
  background: rgba(239, 68, 68, 0.1);
}

[data-theme="dark"] .tl-auth-checkbox label {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-auth-btn-primary {
  background: var(--tl-sky);
  color: var(--tl-dark-bg);
}

[data-theme="dark"] .tl-auth-btn-primary:hover {
  background: var(--tl-sky-dark);
}

[data-theme="dark"] .tl-auth-divider {
  color: var(--tl-border);
}

[data-theme="dark"] .tl-auth-divider::before,
[data-theme="dark"] .tl-auth-divider::after {
  background: var(--tl-border);
}

[data-theme="dark"] .tl-auth-links a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-auth-links a:hover {
  color: var(--tl-sky-dark);
}

[data-theme="dark"] .tl-auth-alert-success {
  background: rgba(34, 197, 94, 0.1);
  color: #86efac;
  border-color: var(--tl-success);
}

[data-theme="dark"] .tl-auth-alert-error {
  background: rgba(239, 68, 68, 0.1);
  color: #fca5a5;
  border-color: var(--tl-danger);
}

[data-theme="dark"] .tl-auth-terms {
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-auth-terms a {
  color: var(--tl-sky);
}

/* -- Responsive -- */
@media (max-width: 576px) {
  .tl-auth-container {
    padding: 20px 16px;
    min-height: calc(100vh - 100px);
  }

  .tl-auth-card {
    padding: 24px;
  }

  .tl-auth-card h2 {
    font-size: var(--tl-text-xl);
  }
}


/* ===============================================================================
   PHASE 2B: HOME PAGE COMPONENTS (from tl-pages-home.css)
   =============================================================================== */

/* ═══════════════════════════════════════════════════════════════════════════════
   TL-PAGES-HOME.CSS — Home Page Components
   
   Styles for home page sections including hero, cards, sections, and CTAs.
   Extracted from tl-dark-mode.css for better organization.
   ═══════════════════════════════════════════════════════════════════════════════ */

/* -- Hero Section -------------------------------------------------------------- */
.tl-hl-hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--tl-dark-bg) 0%, #1e3a5f 50%, var(--tl-dark-bg) 100%);
  overflow: hidden;
}

.tl-hl-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../../../images/background/home-background.webp') center/cover no-repeat;
  opacity: .08;
}

.tl-hl-hero-grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(99,179,237,.06) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(99,179,237,.06) 1px, transparent 1px);
  background-size: 60px 60px;
}

.tl-hl-hero-glow {
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(56,189,248,.15) 0%, transparent 70%);
  top: -100px; right: -100px;
  pointer-events: none;
}

.tl-hl-hero-content { position: relative; z-index: 2; }

.tl-hl-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(56,189,248,.12);
  border: 1px solid rgba(56,189,248,.3);
  color: #7dd3fc;
  padding: 6px 16px;
  border-radius: var(--tl-radius-full);
  font-size: .8rem;
  font-weight: var(--tl-weight-semibold);
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 24px;
}

.tl-hl-hero h1 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: var(--tl-weight-extrabold);
  color: #fff;
  line-height: 1.15;
  margin-bottom: 20px;
}

.tl-hl-hero h1 span { color: var(--tl-sky); }

.tl-hl-hero p.lead {
  color: var(--tl-border);
  font-size: 1.15rem;
  max-width: 560px;
  margin-bottom: 36px;
}

.tl-hl-search-wrap {
  position: relative;
  max-width: 540px;
  margin-bottom: 40px;
}

.tl-hl-search-wrap input {
  width: 100%;
  padding: 16px 56px 16px 20px;
  border-radius: var(--tl-radius-lg);
  border: 1.5px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.07);
  color: #fff;
  font-size: 1rem;
  outline: none;
  transition: border-color .2s, background .2s;
  backdrop-filter: blur(8px);
}

.tl-hl-search-wrap input::placeholder { color: var(--tl-dark-text); }

.tl-hl-search-wrap input:focus { 
  border-color: var(--tl-sky); 
  background: rgba(255,255,255,.1); 
  box-shadow: 0 0 0 3px rgba(56,189,248,.28); 
}

.tl-hl-search-wrap button {
  position: absolute;
  right: 8px; top: 50%;
  transform: translateY(-50%);
  background: var(--tl-sky);
  border: none;
  border-radius: var(--tl-radius-md);
  width: 40px; height: 40px;
  color: var(--tl-dark-bg);
  cursor: pointer;
  font-size: 1rem;
  transition: background .2s;
}

.tl-hl-search-wrap button:hover { background: #7dd3fc; }

.tl-hl-hero-btns { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 48px; }

.tl-hl-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--tl-sky); color: var(--tl-dark-bg);
  padding: 13px 28px; border-radius: var(--tl-radius-lg);
  font-weight: var(--tl-weight-bold); font-size: .95rem;
  text-decoration: none;
  transition: background .2s, transform .15s;
}

.tl-hl-btn-primary:hover { 
  background: #7dd3fc; 
  transform: translateY(-2px); 
  color: var(--tl-dark-bg); 
  text-decoration: none; 
}

.tl-hl-btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: var(--tl-border);
  padding: 13px 28px; border-radius: var(--tl-radius-lg);
  border: 1.5px solid rgba(255,255,255,.2);
  font-weight: var(--tl-weight-semibold); font-size: .95rem;
  text-decoration: none;
  transition: border-color .2s, color .2s, transform .15s;
}

.tl-hl-btn-outline:hover { 
  border-color: var(--tl-sky); 
  color: var(--tl-sky); 
  transform: translateY(-2px); 
  text-decoration: none; 
}

/* -- Focus Visible States ------------------------------------------------------ */
.tl-mh-secbar a:focus-visible,
.tl-mh-nav a:focus-visible,
.tl-mh-nav button:focus-visible,
.tl-mh-mobile-drawer a:focus-visible,
.tl-hl-home-hub-card:focus-visible,
.tl-hl-tut-card:focus-visible,
.tl-hl-iq-card:focus-visible,
.tl-hl-svc-link:focus-visible,
.tl-hl-btn-primary:focus-visible,
.tl-hl-btn-outline:focus-visible,
.tl-hl-search-wrap button:focus-visible,
.tl-hl-search-wrap input:focus-visible {
  outline: 3px solid #facc15;
  outline-offset: 3px;
}

/* -- Stats Section ------------------------------------------------------------- */
.tl-hl-stats { display: flex; flex-wrap: wrap; gap: 32px; }

.tl-hl-stat-num { 
  font-size: 1.6rem; 
  font-weight: var(--tl-weight-extrabold); 
  color: #fff; 
  line-height: 1; 
}

.tl-hl-stat-label { 
  font-size: .78rem; 
  color: var(--tl-dark-text); 
  text-transform: uppercase; 
  letter-spacing: .06em; 
  margin-top: 2px; 
}

/* -- Hero Visual (Orbit) ------------------------------------------------------- */
.tl-hl-hero-visual { position: relative; z-index: 2; display: flex; justify-content: center; align-items: center; }

.tl-hl-orbit { width: 340px; height: 340px; position: relative; }

.tl-hl-orbit-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(56,189,248,.15);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}

.tl-hl-orbit-ring:nth-child(1) { width: 100%; height: 100%; }
.tl-hl-orbit-ring:nth-child(2) { width: 70%; height: 70%; border-color: rgba(56,189,248,.1); }
.tl-hl-orbit-ring:nth-child(3) { width: 40%; height: 40%; border-color: rgba(56,189,248,.2); }

.tl-hl-orbit-center {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 80px; height: 80px;
  background: linear-gradient(135deg, #1e3a5f, var(--tl-dark-bg));
  border-radius: 50%;
  border: 2px solid rgba(56,189,248,.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem; color: var(--tl-sky);
  box-shadow: 0 0 40px rgba(56,189,248,.2);
}

.tl-hl-orbit-icon {
  position: absolute;
  width: 44px; height: 44px;
  background: var(--tl-dark-bg-alt);
  border: 1.5px solid rgba(56,189,248,.25);
  border-radius: var(--tl-radius-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; color: var(--tl-sky);
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
}

/* -- Home Hub Section ---------------------------------------------------------- */
.tl-hl-home-hub {
  padding: 44px 0;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-bottom: 1px solid var(--tl-border);
}

.tl-hl-home-hub-copy .tl-hl-section-title {
  font-size: clamp(1.9rem, 3.8vw, 3.1rem);
  max-width: 460px;
  margin-bottom: 12px;
}

.tl-hl-home-hub-copy .tl-hl-section-sub {
  margin-bottom: 0;
  max-width: 520px;
  font-size: 1rem;
}

.tl-hl-home-hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
}

.tl-hl-home-hub-card {
  display: block;
  padding: 20px 18px;
  background: var(--tl-surface-alt);
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-xl);
  text-decoration: none;
  color: var(--tl-dark-bg);
  min-width: 0;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}

.tl-hl-home-hub-card:hover {
  text-decoration: none;
  color: var(--tl-dark-bg);
  border-color: var(--tl-sky);
  box-shadow: 0 12px 30px rgba(56,189,248,.12);
  transform: translateY(-3px);
}

.tl-hl-home-hub-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--tl-radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  font-size: 1.35rem;
}

/* Home Hub Icons - Light Mode (6 variants) */
.tl-hub-icon--tutorials {
  background: #dbeafe;
}

.tl-hub-icon--tutorials i {
  color: #1e40af;
}

.tl-hub-icon--interview {
  background: #e9d5ff;
}

.tl-hub-icon--interview i {
  color: #6b21a8;
}

.tl-hub-icon--compiler {
  background: #cffafe;
}

.tl-hub-icon--compiler i {
  color: #0891b2;
}

.tl-hub-icon--tools {
  background: #fed7aa;
}

.tl-hub-icon--tools i {
  color: #92400e;
}

.tl-hub-icon--blogs {
  background: #dcfce7;
}

.tl-hub-icon--blogs i {
  color: #15803d;
}

.tl-hub-icon--help {
  background: #fce7f3;
}

.tl-hub-icon--help i {
  color: #be185d;
}

.tl-hl-home-hub-card strong {
  display: block;
  font-size: .96rem;
  line-height: 1.35;
}

.tl-hl-home-hub-card span {
  display: block;
  margin-top: 5px;
  color: var(--tl-muted);
  font-size: .84rem;
}

.tl-hl-home-hub-note {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: var(--tl-radius-xl);
  background: #eff6ff;
  color: #334155;
  font-size: .86rem;
  line-height: 1.6;
}

.tl-hl-home-hub-note strong {
  color: var(--tl-dark-bg);
}

.tl-hl-home-section-head {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 8px;
  padding: 0 12px;
}

.tl-hl-home-section-head .tl-hl-section-sub {
  margin-left: auto;
  margin-right: auto;
  max-width: 820px;
}

/* -- Sections ------------------------------------------------------------------ */
.tl-hl-section { padding: 80px 0; }

.tl-hl-section-alt { background: var(--tl-surface-alt); }

.tl-hl-section-title {
  font-size: clamp(2rem, 4.2vw, 3.4rem);
  font-weight: var(--tl-weight-extrabold);
  color: var(--tl-dark-bg);
  margin-bottom: 14px;
  line-height: 1.08;
  letter-spacing: 0;
}

.tl-hl-section .tl-hl-section-title,
.tl-hl-home-hub .tl-hl-section-title {
  color: var(--tl-dark-bg);
}

.tl-hl-home-section-head .tl-hl-section-title span {
  color: var(--tl-sky-dark);
}

.tl-hl-section-title.light { color: #fff; }

.tl-hl-section-sub {
  color: #334155;
  font-size: 1.1rem;
  line-height: 1.7;
  margin-bottom: 48px;
}

.tl-hl-section-sub.light { color: var(--tl-border); }

.tl-hl-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  background: linear-gradient(180deg, #dff4ff 0%, #bae6fd 100%);
  color: #075985;
  padding: 6px 18px;
  border-radius: var(--tl-radius-full);
  border: 1px solid #bfdbfe;
  font-size: .82rem;
  font-weight: var(--tl-weight-extrabold);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 18px;
  box-shadow: 0 8px 20px rgba(14, 165, 233, .12);
}

.tl-hl-pill.light { background: rgba(56,189,248,.25); color: #e0f2fe; }

/* -- Tutorial Cards ------------------------------------------------------------ */
.tl-hl-tut-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin-bottom: 32px; }

.tl-hl-tut-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid #dbe7f3;
  border-radius: var(--tl-radius-2xl);
  padding: 18px 18px 20px;
  text-align: left;
  text-decoration: none;
  color: var(--tl-dark-bg);
  transition: border-color .2s, transform .2s, box-shadow .2s, background .2s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
  height: 100%;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .04);
}

.tl-hl-tut-card:hover {
  border-color: #93c5fd;
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(37, 99, 235, .12);
  text-decoration: none;
  color: var(--tl-dark-bg);
  background: #ffffff;
}

.tl-hl-tut-card:focus-visible {
  border-color: #2563eb;
  box-shadow: 0 0 0 4px rgba(37, 99, 235, .22), 0 18px 38px rgba(37, 99, 235, .12);
  text-decoration: none;
}

.tl-hl-card-topline {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 16px;
  min-width: 0;
  overflow: hidden;
}

.tl-hl-card-chip,
.tl-hl-card-level {
  display: inline-flex;
  align-items: center;
  border-radius: var(--tl-radius-full);
  padding: 4px 10px;
  font-size: .68rem;
  font-weight: var(--tl-weight-bold);
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tl-hl-card-chip--tutorial,
.tl-hl-card-chip--service { background: #e0f2fe; }

.tl-hl-card-chip--tutorial { color: #0369a1; }

.tl-hl-card-chip--interview {
  background: #ede9fe;
  color: #6d28d9;
}

.tl-hl-card-chip--service { color: #075985; }

.tl-hl-card-level {
  background: var(--tl-surface-alt);
  color: #475569;
  border: 1px solid var(--tl-border);
}

.tl-hl-tut-icon {
  width: 60px;
  height: 60px;
  border-radius: var(--tl-radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  margin: 0 0 16px;
}

.tl-hl-tut-name { 
  font-size: 1rem; 
  font-weight: var(--tl-weight-bold); 
  margin-bottom: 8px; 
  line-height: 1.35; 
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 100%;
  width: 100%;
}

.tl-hl-card-copy {
  margin: 0;
  color: #475569;
  font-size: .84rem;
  line-height: 1.65;
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 100%;
  width: 100%;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tl-hl-card-action {
  margin-top: auto;
  padding-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--tl-dark-bg);
  font-size: .82rem;
  font-weight: var(--tl-weight-bold);
}

/* -- Interview Question Cards ------------------------------------------------- */
.tl-hl-iq-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin-bottom: 32px; }

.tl-hl-iq-card {
  background: linear-gradient(180deg, #ffffff 0%, #fbfaff 100%);
  border: 1px solid #e2defd;
  border-radius: var(--tl-radius-2xl);
  padding: 18px 18px 20px;
  text-align: left;
  transition: border-color .2s, transform .2s, box-shadow .2s, background .2s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-decoration: none;
  color: var(--tl-dark-bg);
  min-width: 0;
  height: 100%;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .04);
  overflow: hidden;
}

.tl-hl-iq-card:hover {
  border-color: #c4b5fd;
  transform: translateY(-4px);
  box-shadow: 0 18px 38px rgba(109, 40, 217, .12);
  text-decoration: none;
  color: var(--tl-dark-bg);
  background: #ffffff;
}

.tl-hl-iq-card:focus-visible {
  border-color: #6d28d9;
  box-shadow: 0 0 0 4px rgba(109, 40, 217, .2), 0 18px 38px rgba(109, 40, 217, .12);
  text-decoration: none;
}

.tl-hl-iq-icon { 
  width: 60px; 
  height: 60px; 
  border-radius: var(--tl-radius-xl); 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 1.7rem; 
  margin: 0 0 16px; 
}

/* Interview Question Icons - Light Mode (22 variants) */
.tl-iq-icon--javascript {
  background: #fef3c7;
}

.tl-iq-icon--javascript i {
  color: #ca8a04;
}

.tl-iq-icon--react {
  background: #cffafe;
}

.tl-iq-icon--react i {
  color: #0891b2;
}

.tl-iq-icon--angular {
  background: #fce7f3;
}

.tl-iq-icon--angular i {
  color: #be185d;
}

.tl-iq-icon--nodejs {
  background: #dcfce7;
}

.tl-iq-icon--nodejs i {
  color: #15803d;
}

.tl-iq-icon--python {
  background: #dbeafe;
}

.tl-iq-icon--python i {
  color: #1e40af;
}

.tl-iq-icon--java {
  background: #fed7aa;
}

.tl-iq-icon--java i {
  color: #92400e;
}

.tl-iq-icon--typescript {
  background: #dbeafe;
}

.tl-iq-icon--typescript i {
  color: #1e40af;
}

.tl-iq-icon--spring {
  background: #dcfce7;
}

.tl-iq-icon--spring i {
  color: #15803d;
}

.tl-iq-icon--php {
  background: #e9d5ff;
}

.tl-iq-icon--php i {
  color: #6b21a8;
}

.tl-iq-icon--vue {
  background: #dcfce7;
}

.tl-iq-icon--vue i {
  color: #15803d;
}

.tl-iq-icon--mysql {
  background: #cffafe;
}

.tl-iq-icon--mysql i {
  color: #0891b2;
}

.tl-iq-icon--mongodb {
  background: #ccfbf1;
}

.tl-iq-icon--mongodb i {
  color: #0d9488;
}

.tl-iq-icon--dsa {
  background: #fef08a;
}

.tl-iq-icon--dsa i {
  color: #ca8a04;
}

.tl-iq-icon--dbms {
  background: #e9d5ff;
}

.tl-iq-icon--dbms i {
  color: #6b21a8;
}

.tl-iq-icon--c {
  background: #dbeafe;
}

.tl-iq-icon--c i {
  color: #1e40af;
}

.tl-iq-icon--cpp {
  background: #dbeafe;
}

.tl-iq-icon--cpp i {
  color: #1e40af;
}

.tl-iq-icon--html {
  background: #fed7aa;
}

.tl-iq-icon--html i {
  color: #92400e;
}

.tl-iq-icon--css {
  background: #dbeafe;
}

.tl-iq-icon--css i {
  color: #1e40af;
}

.tl-iq-icon--os {
  background: #fed7aa;
}

.tl-iq-icon--os i {
  color: #92400e;
}

.tl-iq-icon--networking {
  background: #ccfbf1;
}

.tl-iq-icon--networking i {
  color: #0d9488;
}

.tl-iq-icon--aws {
  background: #fef3c7;
}

.tl-iq-icon--aws span {
  color: #b45309;
}

.tl-iq-icon--viewall {
  background: #f3f4f6;
}

.tl-iq-icon--viewall i {
  color: #6b7280;
}

.tl-hl-iq-name { 
  font-size: 1rem; 
  font-weight: var(--tl-weight-bold); 
  margin-bottom: 8px; 
  line-height: 1.35; 
  overflow-wrap: anywhere;
  min-width: 0;
  overflow: hidden;
}

.tl-hl-tut-badge-row { display: flex; justify-content: center; }

.tl-hl-tile-badge { 
  display: inline-block; 
  font-size: .65rem; 
  font-weight: var(--tl-weight-bold); 
  letter-spacing: .05em; 
  text-transform: uppercase; 
  padding: 2px 8px; 
  border-radius: var(--tl-radius-2xl); 
}

.tl-hl-tile-badge--tut { background: #e0f2fe; color: #0369a1; }
.tl-hl-tile-badge--iq  { background: #ede9fe; color: #6d28d9; }
.tl-hl-tile-badge--free { background: #dcfce7; color: #15803d; }

/* -- Service Cards ------------------------------------------------------------- */
/* Services now use the same .tl-hl-tut-card styling as tutorials and interview questions */
/* No additional CSS needed - unified card system */

/* -- Stats Banner -------------------------------------------------------------- */
.tl-hl-stats-banner { 
  background: linear-gradient(135deg, #0284c7, var(--tl-dark-bg)); 
  padding: 60px 0; 
}

.tl-hl-stat-box { text-align: center; }

.tl-hl-stat-box .num { 
  font-size: 2.4rem; 
  font-weight: var(--tl-weight-extrabold); 
  color: #fff; 
}

.tl-hl-stat-box .lbl { 
  font-size: .85rem; 
  color: var(--tl-border); 
  text-transform: uppercase; 
  letter-spacing: .06em; 
}

/* -- Why Us Section ------------------------------------------------------------ */
.tl-hl-why-item h5 { 
  font-size: .95rem; 
  font-weight: var(--tl-weight-bold); 
  color: var(--tl-dark-bg); 
  margin-bottom: 4px; 
}

.tl-hl-why-item p { 
  font-size: .85rem; 
  color: var(--tl-muted); 
  margin: 0; 
}

/* -- CTA Section --------------------------------------------------------------- */
.tl-hl-cta {
  background: linear-gradient(135deg, var(--tl-dark-bg) 0%, #1e3a5f 100%);
  border-radius: 24px; 
  padding: 60px 48px;
  text-align: center; 
  position: relative; 
  overflow: hidden;
}

.tl-hl-cta::before {
  content: ''; 
  position: absolute;
  width: 400px; 
  height: 400px;
  background: radial-gradient(circle, rgba(56,189,248,.12) 0%, transparent 70%);
  top: -100px; 
  right: -100px; 
  pointer-events: none;
}

.tl-hl-cta h2 { 
  color: #fff; 
  font-size: clamp(1.6rem, 3vw, 2.2rem); 
  font-weight: var(--tl-weight-extrabold); 
  margin-bottom: 12px; 
}

.tl-hl-cta p { 
  color: var(--tl-border); 
  font-size: 1rem; 
  margin-bottom: 32px; 
}

/* -- Compiler Card ------------------------------------------------------------- */
.tl-hl-compiler-card {
  background: linear-gradient(135deg, var(--tl-dark-bg-alt), var(--tl-dark-bg));
  border: 1.5px solid rgba(56,189,248,.2);
  border-radius: var(--tl-radius-2xl); 
  padding: 40px 32px;
  display: flex; 
  align-items: center; 
  gap: 32px; 
  flex-wrap: wrap;
}

.tl-hl-compiler-card .icon-wrap { 
  width: 72px; 
  height: 72px; 
  flex-shrink: 0; 
  background: rgba(56,189,248,.1); 
  border-radius: 18px; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  font-size: 2rem; 
  color: var(--tl-sky); 
}

.tl-hl-compiler-card h3 { 
  color: #fff; 
  font-size: 1.3rem; 
  font-weight: var(--tl-weight-bold); 
  margin-bottom: 6px; 
}

.tl-hl-compiler-card p { 
  color: var(--tl-border); 
  font-size: .9rem; 
  margin: 0; 
}

/* -- Reduced Motion Support ---------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .tl-mh-nav *,
  .tl-hl-hero *,
  .tl-hl-section *,
  .tl-hl-home-hub *,
  .tl-hl-cta * {
    animation: none !important;
    scroll-behavior: auto !important;
    transition: none !important;
  }

  .tl-hl-btn-primary:hover,
  .tl-hl-btn-outline:hover,
  .tl-hl-home-hub-card:hover,
  .tl-hl-tut-card:hover,
  .tl-hl-iq-card:hover,
  .tl-hl-svc-card:hover {
    transform: none !important;
  }
}

/* -- Responsive Design --------------------------------------------------------- */
@media (max-width: 768px) {
  .tl-hl-hero { min-height: auto; padding: 80px 0 48px; }
  .tl-hl-orbit { display: none; }
  .tl-hl-home-hub { padding: 26px 0; }
  .tl-hl-home-hub-copy .tl-hl-section-title { max-width: 100%; }
  .tl-hl-cta { padding: 32px 20px; }
  .tl-hl-compiler-card { flex-direction: column; text-align: center; }
  .tl-hl-hero h1 { font-size: clamp(1.8rem, 6vw, 2.4rem); }
  .tl-hl-hero p.lead { font-size: 1rem; }
  .tl-hl-search-wrap { max-width: 100%; }
  .tl-hl-hero-btns { flex-direction: column; gap: 10px; }
  .tl-hl-btn-primary, .tl-hl-btn-outline { width: 100%; justify-content: center; padding: 12px 20px; }
  .tl-hl-stats { gap: 20px; }
  .tl-hl-section { padding: 48px 0; }
  .tl-hl-section-sub { margin-bottom: 28px; }
  .tl-hl-section-title { font-size: clamp(1.7rem, 7vw, 2.35rem); }
  .tl-hl-section-sub { font-size: 1rem; }
  .tl-hl-tut-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; margin-bottom: 24px; }
  .tl-hl-tut-card { padding: 16px; border-radius: var(--tl-radius-xl); }
  .tl-hl-iq-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 14px; margin-bottom: 24px; }
  .tl-hl-iq-card { padding: 16px; border-radius: var(--tl-radius-xl); }
  .tl-hl-tut-icon,
  .tl-hl-iq-icon { width: 48px; height: 48px; font-size: 1.35rem; margin-bottom: 12px; }
  .tl-hl-tut-name,
  .tl-hl-iq-name { font-size: .88rem; }
  .tl-hl-card-topline { margin-bottom: 12px; }
  .tl-hl-card-copy { font-size: .78rem; }
  .tl-hl-card-action { padding-top: 12px; font-size: .76rem; }
  .tl-hl-stats-banner { padding: 36px 0; }
  .tl-hl-stat-box .num { font-size: 1.8rem; }
  .tl-hl-compiler-card { padding: 28px 20px; }
}

@media (max-width: 480px) {
  .tl-hl-hero { padding: 72px 0 40px; }
  .tl-hl-home-hub-grid { grid-template-columns: 1fr; }
  .tl-hl-tut-grid,
  .tl-hl-iq-grid { grid-template-columns: 1fr; }
  .tl-hl-stats { gap: 16px; }
  .tl-hl-stat-num { font-size: 1.3rem; }
}




/* ===============================================================================
   PHASE 2C: LEGACY (from tl-pages-legacy.css)
   =============================================================================== */


/* =============================================================================
   TL-PAGES-LEGACY.CSS — Legacy Component Styles
   
   Backward compatibility for legacy components and patterns
   These should be gradually migrated to use design tokens from tl-tokens.css
   ============================================================================= */

/* -- Legacy Layout Components -------------------------------------------------- */
.page-wrapper {
    background-color: var(--tl-body-bg);
}

.dark .footer {
    background-color: #222;
}

.dark 

.scroll-spy .banner {
    min-height: 100px;
}

.banner.dark-translucent-bg,
.banner.default-translucent-bg,
.banner.light-translucent-bg {
    min-height: 250px;
    padding-top: 60px;
    padding-bottom: 20px;
}

.banner.banner-big-height {
    min-height: 550px;
    padding-top: 100px;
}

.main-container {
    padding: 50px 0;
}

.block {
    margin-bottom: 50px;
}

.section {
    padding: 20px 0;
}

.footer-top {
    padding: 20px 0;
}

.footer {
    padding: 40px 0;
    background-color: #fafafa;
}

.footer-content {
    padding: 20px 0;
}



@media (max-width: 991px) {
    .sidebar {
        margin-top: 40px;
    }
    .footer-content {
        padding: 10px 0;
    }
}

/* -- Legacy Table Styles ------------------------------------------------------- */
.table:not(.table-bordered) {
    border-bottom: 2px solid #f3f3f3;
}

.table > thead > tr > th {
    vertical-align: bottom;
    border-bottom: 1px solid #eaeaea;
    background-color: #eaeaea;
    color: #333;
    font-weight: 400;
}

.table-colored > thead > tr > th {
    color: #fff;
}

tbody {
    background-color: #fff;
}

.table > tbody > tr > td,
.table > tbody > tr > th,
.table > tfoot > tr > td,
.table > tfoot > tr > th,
.table > thead > tr > td,
.table > thead > tr > th {
    padding: 8px 15px;
    border-top: 1px solid #f3f3f3;
}

.table-striped tbody {
    background-color: #fff;
}

.table-striped > tbody > tr:nth-child(odd) > td,
.table-striped > tbody > tr:nth-child(odd) > th {
    background-color: #f5f5f5;
}

.table-striped.table > tbody > tr > td {
    border-color: #e8e8e8;
}

.table-bordered > tbody > tr > td,
.table-bordered > tbody > tr > th,
.table-bordered > tfoot > tr > td,
.table-bordered > tfoot > tr > th,
.table-bordered > thead > tr > td,
.table-bordered > thead > tr > th {
    border-color: #f3f3f3;
}

.table-hover > tbody > tr:hover {
    background-color: rgba(0, 0, 0, 0.04);
}

.dark .table:not(.table-bordered) {
    border-bottom: 2px solid rgba(255, 255, 255, 0.07);
}

.dark .table > tbody {
    background-color: transparent;
}

.dark .table > tbody > tr > td {
    border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.dark .table > thead > tr > th {
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    background-color: rgba(0, 0, 0, 0.15);
    color: #f1f1f1;
    font-weight: 400;
    border-top: none;
}

/* -- Legacy List Styles -------------------------------------------------------- */
ul {
    list-style: square;
}

.list,
.list-icons {
    list-style: none;
    padding: 0;
}

.list li,
.list-icons li {
    padding: 5px 0;
}

.list-icons li i {
    min-width: 25px;
    text-align: center;
}

.list-inline {
    margin-top: 9px;
    margin-bottom: 8px;
}

/* -- Image Styles -------------------------------------------------------------- */
img {
    display: block;
    max-width: 100%;
    height: auto;
}



/* ===============================================================================
   PHASE 2D: SHARED (from tl-pages-shared.css)
   =============================================================================== */


/* ═══════════════════════════════════════════════════════════════════════════════
   TL-PAGES-SHARED.CSS — Shared Article/Content System
   
   Unified styles for tutorials, blogs, and interview question pages.
   These three page types share identical layout patterns and components.
   
   Components:
   - Article container and typography
   - Content blocks (notes, warnings, tips)
   - Tables
   - Sidebar (sticky)
   - Table of Contents
   - FAQ sections
   - Author sections
   - Related content
   - Code blocks (via tl-pages.css)
   ═══════════════════════════════════════════════════════════════════════════════ */

/* -- Article Container -------------------------------------------------------- */
.tl-article {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--tl-space-4);
}

/* -- Article Typography ------------------------------------------------------- */
.tl-article h1 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--tl-weight-extrabold);
  color: var(--tl-heading-color);
  margin-bottom: var(--tl-space-4);
  line-height: var(--tl-leading-tight);
}

.tl-article h2 {
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: var(--tl-weight-bold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-8);
  margin-bottom: var(--tl-space-4);
  padding-bottom: var(--tl-space-3);
  border-bottom: 2px solid var(--tl-border);
}

.tl-article h3 {
  font-size: clamp(1.15rem, 2.5vw, 1.5rem);
  font-weight: var(--tl-weight-bold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-6);
  margin-bottom: var(--tl-space-3);
}

.tl-article h4 {
  font-size: var(--tl-text-lg);
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
  margin-top: var(--tl-space-4);
  margin-bottom: var(--tl-space-2);
}

.tl-article p {
  font-size: var(--tl-text-base);
  line-height: var(--tl-leading-relaxed);
  color: var(--tl-body-color);
  margin-bottom: var(--tl-space-4);
  text-align: justify;
  text-justify: inter-word;
}

.tl-article ul,
.tl-article ol {
  margin-bottom: var(--tl-space-4);
  padding-left: var(--tl-space-6);
}

.tl-article li {
  margin-bottom: var(--tl-space-2);
  line-height: var(--tl-leading-relaxed);
  color: var(--tl-body-color);
}

.tl-article a {
  color: var(--tl-sky-dark);
  text-decoration: underline;
  font-weight: var(--tl-weight-medium);
  transition: color var(--tl-duration-base);
}

.tl-article a:hover {
  color: var(--tl-sky);
  text-decoration: none;
}

.tl-article strong {
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
}

.tl-article blockquote {
  border-left: 4px solid var(--tl-sky);
  padding: var(--tl-space-4) var(--tl-space-5);
  margin: var(--tl-space-4) 0;
  background: var(--tl-surface-alt);
  border-radius: var(--tl-radius-md);
  font-style: italic;
  color: var(--tl-muted);
}

/* -- Article Content Blocks --------------------------------------------------- */
.tl-article-note {
  padding: var(--tl-space-4) var(--tl-space-5);
  margin: var(--tl-space-6) 0;
  border-left: 4px solid;
  border-radius: var(--tl-radius-md);
  line-height: var(--tl-leading-relaxed);
  background: var(--tl-surface-alt);
}

.tl-article-note--info {
  background: var(--tl-info-light);
  border-color: var(--tl-info);
  color: #0c5460;
}

.tl-article-note--warning {
  background: var(--tl-warning-light);
  border-color: var(--tl-warning);
  color: #856404;
}

.tl-article-note--tip {
  background: var(--tl-success-light);
  border-color: var(--tl-success);
  color: #155724;
}

.tl-article-note--danger {
  background: var(--tl-danger-light);
  border-color: var(--tl-danger);
  color: #721c24;
}

/* -- Article Tables ----------------------------------------------------------- */
.tl-article table {
  width: 100%;
  margin: var(--tl-space-6) 0;
  border-collapse: collapse;
  border-radius: var(--tl-radius-lg);
  overflow: hidden;
  font-size: var(--tl-text-sm);
  box-shadow: var(--tl-shadow-sm);
}

.tl-article table th {
  background: var(--tl-surface-alt);
  padding: var(--tl-space-3) var(--tl-space-4);
  font-weight: var(--tl-weight-semibold);
  text-align: left;
  border-bottom: 2px solid var(--tl-border);
  color: var(--tl-heading-color);
}

.tl-article table td {
  padding: var(--tl-space-3) var(--tl-space-4);
  border-bottom: 1px solid var(--tl-border);
  color: var(--tl-body-color);
}

.tl-article table tbody tr:hover {
  background: var(--tl-surface-alt);
}

.tl-article table tbody tr:last-child td {
  border-bottom: none;
}

/* Dark mode table styles */
[data-theme="dark"] .tl-article table th {
  background: rgba(255, 255, 255, 0.05);
  border-bottom-color: var(--tl-border);
}

[data-theme="dark"] .tl-article table td {
  border-bottom-color: var(--tl-border);
}

/* -- Article Sidebar ---------------------------------------------------------- */
.tl-article-sidebar {
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}

/* -- Table of Contents -------------------------------------------------------- */
.tl-article-toc {
  background: var(--tl-surface-alt);
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-lg);
  padding: var(--tl-space-4);
  margin-bottom: var(--tl-space-6);
}

.tl-article-toc h3 {
  font-size: var(--tl-text-sm);
  font-weight: var(--tl-weight-bold);
  margin: 0 0 var(--tl-space-3) 0;
  padding: 0;
  border: none;
  color: var(--tl-heading-color);
}

.tl-article-toc ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tl-article-toc li {
  margin-bottom: var(--tl-space-1);
}

.tl-article-toc a {
  display: block;
  padding: var(--tl-space-1) var(--tl-space-2);
  color: var(--tl-sky-dark);
  text-decoration: none;
  font-size: var(--tl-text-sm);
  transition: color var(--tl-duration-base), background var(--tl-duration-base);
}

.tl-article-toc a:hover {
  color: var(--tl-sky);
  background: rgba(56, 189, 248, 0.05);
  border-radius: var(--tl-radius-md);
}

.tl-article-toc a.active {
  color: var(--tl-sky);
  font-weight: var(--tl-weight-medium);
  background: rgba(56, 189, 248, 0.1);
  border-radius: var(--tl-radius-md);
}

/* -- FAQ Section -------------------------------------------------------------- */
.tl-article-faq {
  margin: var(--tl-space-10) 0;
}

.tl-article-faq h2 {
  border: none;
  padding: 0;
  margin-bottom: var(--tl-space-4);
}

.tl-article-faq details {
  border: 1px solid var(--tl-border);
  border-radius: var(--tl-radius-lg);
  margin-bottom: var(--tl-space-3);
  transition: box-shadow var(--tl-duration-base);
}

.tl-article-faq details[open] {
  box-shadow: var(--tl-shadow-sm);
}

.tl-article-faq summary {
  padding: var(--tl-space-4) var(--tl-space-5);
  padding-right: calc(var(--tl-space-5) + 32px);
  font-weight: var(--tl-weight-semibold);
  color: var(--tl-heading-color);
  cursor: pointer;
  user-select: none;
  display: block;
  position: relative;
  transition: background var(--tl-duration-base);
}

.tl-article-faq summary:hover {
  background: var(--tl-surface-alt);
}

.tl-article-faq summary::after {
  content: '+';
  position: absolute;
  right: var(--tl-space-5);
  top: 50%;
  transform: translateY(-50%);
  font-size: var(--tl-text-xl);
  font-weight: var(--tl-weight-bold);
  transition: transform var(--tl-duration-base);
}

.tl-article-faq details[open] summary::after {
  content: '-';
  transform: translateY(-50%);
}

.tl-article-faq details > div,
.tl-article-faq details > p {
  padding: 0 var(--tl-space-5) var(--tl-space-4);
  color: var(--tl-body-color);
  line-height: var(--tl-leading-relaxed);
}

/* -- Author Section ----------------------------------------------------------- */
.tl-article-author {
  display: flex;
  gap: var(--tl-space-4);
  padding: var(--tl-space-4) var(--tl-space-5);
  margin: var(--tl-space-8) 0;
  background: var(--tl-surface-alt);
  border-radius: var(--tl-radius-xl);
}

.tl-article-author img {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.tl-article-author h4 {
  margin: 0 0 var(--tl-space-1) 0;
  font-size: var(--tl-text-base);
}

.tl-article-author .tl-author-role {
  font-size: var(--tl-text-sm);
  color: var(--tl-muted);
  margin-bottom: var(--tl-space-2);
}

.tl-article-author p {
  margin: 0;
  font-size: var(--tl-text-sm);
  line-height: var(--tl-leading-snug);
}

/* -- Related Content ---------------------------------------------------------- */
.tl-article-related {
  margin: var(--tl-space-10) 0;
  padding: var(--tl-space-6);
  background: var(--tl-surface-alt);
  border-radius: var(--tl-radius-lg);
}

.tl-article-related h3 {
  margin-top: 0;
  margin-bottom: var(--tl-space-4);
}

.tl-article-related ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tl-article-related li {
  margin-bottom: var(--tl-space-3);
}

.tl-article-related a {
  display: flex;
  align-items: center;
  gap: var(--tl-space-2);
  padding: var(--tl-space-2) var(--tl-space-3);
  border-radius: var(--tl-radius-md);
  transition: background var(--tl-duration-base);
}

.tl-article-related a:hover {
  background: rgba(56, 189, 248, 0.1);
}

/* -- Responsive Design -------------------------------------------------------- */
@media (max-width: 768px) {
  .tl-article {
    padding: 0 var(--tl-space-3);
  }

  .tl-article h1 {
    font-size: 1.5rem;
  }

  .tl-article h2 {
    font-size: 1.25rem;
    margin-top: var(--tl-space-6);
  }

  .tl-article h3 {
    font-size: 1.1rem;
  }

  .tl-article-sidebar {
    position: static;
    max-height: none;
    margin-top: var(--tl-space-6);
  }

  .tl-article-author {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .tl-article-author img {
    width: 80px;
    height: 80px;
  }

  .tl-article table {
    font-size: var(--tl-text-xs);
  }

  .tl-article table th,
  .tl-article table td {
    padding: var(--tl-space-2) var(--tl-space-3);
  }
}

@media (max-width: 576px) {
  .tl-article {
    padding: 0 var(--tl-space-2);
  }

  .tl-article h1 {
    font-size: 1.25rem;
  }

  .tl-article h2 {
    font-size: 1.1rem;
  }

  .tl-article h3 {
    font-size: 1rem;
  }

  .tl-article-note {
    padding: var(--tl-space-3) var(--tl-space-4);
  }

  .tl-article-toc {
    padding: var(--tl-space-3);
  }

  .tl-article-author {
    padding: var(--tl-space-3) var(--tl-space-4);
  }
}

/* -- Dark Mode Support -------------------------------------------------------- */
[data-theme="dark"] .tl-article h1,
[data-theme="dark"] .tl-article h2,
[data-theme="dark"] .tl-article h3,
[data-theme="dark"] .tl-article h4 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article h2 {
  border-bottom-color: var(--tl-border);
}

[data-theme="dark"] .tl-article p,
[data-theme="dark"] .tl-article li {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-article a:hover {
  color: #7dd3fc;
}

[data-theme="dark"] .tl-article strong {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article blockquote {
  background: rgba(255, 255, 255, 0.05);
  border-left-color: var(--tl-sky);
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-article-note {
  background: rgba(255, 255, 255, 0.05);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article-note--info {
  background: rgba(3, 105, 161, 0.15);
  border-color: #0284c7;
  color: #7dd3fc;
}

[data-theme="dark"] .tl-article-note--warning {
  background: rgba(180, 83, 9, 0.15);
  border-color: #ea580c;
  color: #fdba74;
}

[data-theme="dark"] .tl-article-note--tip {
  background: rgba(34, 197, 94, 0.15);
  border-color: #22c55e;
  color: #86efac;
}

[data-theme="dark"] .tl-article-note--danger {
  background: rgba(239, 68, 68, 0.15);
  border-color: #ef4444;
  color: #fca5a5;
}

[data-theme="dark"] .tl-article table {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .tl-article table th {
  background: rgba(255, 255, 255, 0.08);
  border-bottom-color: var(--tl-border);
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article table td {
  border-bottom-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article table tbody tr:hover {
  background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .tl-article-toc {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-article-toc h3 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-toc a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-article-toc a:hover {
  color: #7dd3fc;
  background: rgba(56, 189, 248, 0.1);
}

[data-theme="dark"] .tl-article-toc a.active {
  color: #7dd3fc;
  background: rgba(56, 189, 248, 0.15);
}

[data-theme="dark"] .tl-article-faq details {
  border-color: var(--tl-border);
  background: rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .tl-article-faq details[open] {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .tl-article-faq summary {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-faq summary:hover {
  background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .tl-article-faq details > div,
[data-theme="dark"] .tl-article-faq details > p {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article-author {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--tl-border);
}

[data-theme="dark"] .tl-article-author h4 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-author .tl-author-role {
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-article-author p {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article-related {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--tl-border);
}

[data-theme="dark"] .tl-article-related h3 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-related a {
  color: var(--tl-body-color);
  text-decoration: none;
}

[data-theme="dark"] .tl-article-related a:hover {
  background: rgba(56, 189, 248, 0.15);
  color: var(--tl-sky);
}



/* ===============================================================================
   PHASE 2F: SYNTAX (from tl-pages-syntax.css)
   =============================================================================== */


/* ═══════════════════════════════════════════════════════════════════════════════
   TL-PAGES-SYNTAX.CSS — Code Syntax Highlighting
   
   PrismJS 1.19.0 theme for syntax highlighting code blocks
   Supports 50+ programming languages and markup formats
   
   Reference: https://prismjs.com/
   ═══════════════════════════════════════════════════════════════════════════════ */

/* -- Base Code Styling -------------------------------------------------------- */
code[class*="language-"],
pre[class*="language-"] {
  color: black;
  background: none;
  text-shadow: 0 1px white;
  font-family: var(--tl-font-mono);
  font-size: 1em;
  text-align: left;
  white-space: pre;
  word-spacing: normal;
  word-break: normal;
  word-wrap: normal;
  line-height: 1.5;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  -webkit-hyphens: none;
  -moz-hyphens: none;
  -ms-hyphens: none;
  hyphens: none;
}

pre[class*="language-"]::-moz-selection,
pre[class*="language-"] ::-moz-selection,
code[class*="language-"]::-moz-selection,
code[class*="language-"] ::-moz-selection {
  text-shadow: none;
  background: #b3d4fc;
}

pre[class*="language-"]::selection,
pre[class*="language-"] ::selection,
code[class*="language-"]::selection,
code[class*="language-"] ::selection {
  text-shadow: none;
  background: #b3d4fc;
}

@media print {
  code[class*="language-"],
  pre[class*="language-"] {
    text-shadow: none;
  }
}

/* -- Code Blocks -------------------------------------------------------------- */
pre[class*="language-"] {
  padding: 1em;
  margin: 0.5em 0;
  overflow: auto;
}

:not(pre) > code[class*="language-"],
pre[class*="language-"] {
  background: #f5f2f0;
}

/* -- Inline Code -------------------------------------------------------------- */
:not(pre) > code[class*="language-"] {
  padding: 0.1em;
  border-radius: 0.3em;
  white-space: normal;
}

/* -- Token Colors ------------------------------------------------------------- */
.token.comment,
.token.prolog,
.token.doctype,
.token.cdata {
  color: slategray;
}

.token.punctuation {
  color: #999;
}

.token.namespace {
  opacity: 0.7;
}

.token.property,
.token.tag,
.token.boolean,
.token.number,
.token.constant,
.token.symbol,
.token.deleted {
  color: #905;
}

.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.builtin,
.token.inserted {
  color: #690;
}

.token.operator,
.token.entity,
.token.url,
.language-css .token.string,
.style .token.string {
  color: #9a6e3a;
  background: none;
}

.token.atrule,
.token.attr-value,
.token.keyword {
  color: #07a;
}

.token.function,
.token.class-name {
  color: #dd4a68;
}

.token.regex,
.token.important,
.token.variable {
  color: #e90;
}

.token.important,
.token.bold {
  font-weight: bold;
}

.token.italic {
  font-style: italic;
}

.token.entity {
  cursor: help;
}

/* -- Code Toolbar ------------------------------------------------------------- */
div.code-toolbar {
  position: relative;
}

div.code-toolbar > .toolbar {
  position: absolute;
  top: 0.3em;
  right: 0.2em;
  transition: opacity 0.3s ease-in-out;
  opacity: 0;
  z-index: 10;
}

div.code-toolbar:hover > .toolbar {
  opacity: 1;
}

div.code-toolbar:focus-within > .toolbar {
  opacity: 1;
}

div.code-toolbar > .toolbar .toolbar-item {
  display: inline-block;
}

div.code-toolbar > .toolbar a {
  cursor: pointer;
}

div.code-toolbar > .toolbar button {
  background: none;
  border: 0;
  color: inherit;
  font: inherit;
  line-height: normal;
  overflow: visible;
  padding: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

div.code-toolbar > .toolbar a,
div.code-toolbar > .toolbar button,
div.code-toolbar > .toolbar span {
  color: #bbb;
  font-size: 0.8em;
  padding: 0 0.5em;
  background: #f5f2f0;
  background: rgba(224, 224, 224, 0.2);
  box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.2);
  border-radius: 0.5em;
  transition: all 0.2s ease;
}

div.code-toolbar > .toolbar a:hover,
div.code-toolbar > .toolbar a:focus,
div.code-toolbar > .toolbar button:hover,
div.code-toolbar > .toolbar button:focus,
div.code-toolbar > .toolbar span:hover,
div.code-toolbar > .toolbar span:focus {
  color: inherit;
  text-decoration: none;
  background: rgba(224, 224, 224, 0.4);
}

/* -- Dark Mode Support -------------------------------------------------------- */
[data-theme="dark"] code[class*="language-"],
[data-theme="dark"] pre[class*="language-"] {
  color: #e2e8f0;
  background: #1e293b;
  text-shadow: none;
}

[data-theme="dark"] :not(pre) > code[class*="language-"],
[data-theme="dark"] pre[class*="language-"] {
  background: #0f172a;
}

[data-theme="dark"] pre[class*="language-"]::-moz-selection,
[data-theme="dark"] pre[class*="language-"] ::-moz-selection,
[data-theme="dark"] code[class*="language-"]::-moz-selection,
[data-theme="dark"] code[class*="language-"] ::-moz-selection {
  background: rgba(56, 189, 248, 0.3);
}

[data-theme="dark"] pre[class*="language-"]::selection,
[data-theme="dark"] pre[class*="language-"] ::selection,
[data-theme="dark"] code[class*="language-"]::selection,
[data-theme="dark"] code[class*="language-"] ::selection {
  background: rgba(56, 189, 248, 0.3);
}

[data-theme="dark"] .token.comment,
[data-theme="dark"] .token.prolog,
[data-theme="dark"] .token.doctype,
[data-theme="dark"] .token.cdata {
  color: #64748b;
}

[data-theme="dark"] .token.punctuation {
  color: #cbd5e1;
}

[data-theme="dark"] .token.property,
[data-theme="dark"] .token.tag,
[data-theme="dark"] .token.boolean,
[data-theme="dark"] .token.number,
[data-theme="dark"] .token.constant,
[data-theme="dark"] .token.symbol,
[data-theme="dark"] .token.deleted {
  color: #f87171;
}

[data-theme="dark"] .token.selector,
[data-theme="dark"] .token.attr-name,
[data-theme="dark"] .token.string,
[data-theme="dark"] .token.char,
[data-theme="dark"] .token.builtin,
[data-theme="dark"] .token.inserted {
  color: #86efac;
}

[data-theme="dark"] .token.operator,
[data-theme="dark"] .token.entity,
[data-theme="dark"] .token.url,
[data-theme="dark"] .language-css .token.string,
[data-theme="dark"] .style .token.string {
  color: #fbbf24;
}

[data-theme="dark"] .token.atrule,
[data-theme="dark"] .token.attr-value,
[data-theme="dark"] .token.keyword {
  color: #38bdf8;
}

[data-theme="dark"] .token.function,
[data-theme="dark"] .token.class-name {
  color: #c084fc;
}

[data-theme="dark"] .token.regex,
[data-theme="dark"] .token.important,
[data-theme="dark"] .token.variable {
  color: #fb923c;
}

[data-theme="dark"] div.code-toolbar > .toolbar a,
[data-theme="dark"] div.code-toolbar > .toolbar button,
[data-theme="dark"] div.code-toolbar > .toolbar span {
  color: #94a3b8;
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 2px 0 0 rgba(0, 0, 0, 0.4);
}

[data-theme="dark"] div.code-toolbar > .toolbar a:hover,
[data-theme="dark"] div.code-toolbar > .toolbar a:focus,
[data-theme="dark"] div.code-toolbar > .toolbar button:hover,
[data-theme="dark"] div.code-toolbar > .toolbar button:focus,
[data-theme="dark"] div.code-toolbar > .toolbar span:hover,
[data-theme="dark"] div.code-toolbar > .toolbar span:focus {
  background: rgba(255, 255, 255, 0.15);
  color: #e2e8f0;
}

/* -- Responsive Design -------------------------------------------------------- */
@media (max-width: 768px) {
  pre[class*="language-"] {
    padding: 0.75em;
    margin: 0.5em 0;
    font-size: 0.9em;
  }

  div.code-toolbar > .toolbar {
    top: 0.2em;
    right: 0.1em;
  }

  div.code-toolbar > .toolbar a,
  div.code-toolbar > .toolbar button,
  div.code-toolbar > .toolbar span {
    font-size: 0.7em;
    padding: 0 0.4em;
  }
}

@media (max-width: 576px) {
  pre[class*="language-"] {
    padding: 0.5em;
    font-size: 0.85em;
    overflow-x: auto;
  }

  :not(pre) > code[class*="language-"] {
    padding: 0.05em 0.1em;
    font-size: 0.9em;
  }
}



/* ===============================================================================
   PHASE 2G: TYPOGRAPHY (from tl-pages-typography.css)
   =============================================================================== */


/* =============================================================================
   TL-PAGES-TYPOGRAPHY.CSS — Typography & Brand Colors
   
   Font families, sizes, weights, and brand color overrides
   Extracted from tl-pages.css for better organization
   ============================================================================= */

/* -- Font Families -------------------------------------------------------------- */
.navbar .navbar-nav,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Raleway, sans-serif;
}

body {
    font-family: Roboto, sans-serif;
}

button,
input,
optgroup,
select,
textarea {
    font-family: Roboto, sans-serif;
}

.logo-font {
    font-family: Pacifico, cursive, sans-serif;
}

/* -- Base Typography ------------------------------------------------------------ */
body {
    font-size: 16px;
    line-height: 1.5;
    color: #777;
    background-color: #fff;
    font-weight: 300;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: #333;
    line-height: 1.2;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: #333;
}

.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6 {
    color: #fff;
}

/* -- Brand Colors (Legacy) ------------------------------------------------------ */
/* Note: These are legacy colors. New components should use CSS variables from tl-tokens.css */

a {
    color: #dc5b5b;
}

a:hover {
    color: #c15050;
}

a:focus,
a:active {
    color: #c15050;
}



.text-default {
    color: #dc5b5b;
}

.table.table-colored {
    border-bottom-color: #dc5b5b;
}

.table-colored > thead > tr > th {
    border-color: #dc5b5b;
    background-color: #dc5b5b;
    color: #fff;
}

.default-bg {
    background-color: #dc5b5b;
    color: #fff;
}

.default-bg-50 {
    background-color: rgba(220, 91, 91, 0.5);
    color: #fff;
}

.default-translucent-bg:after {
    background-color: rgba(220, 91, 91, 0.7);
}

.default-translucent-bg.hovered:hover:after {
    background-color: rgba(220, 91, 91, 0.8);
}

.default-hovered:hover:after,
.default-hovered:hover {
    background-color: #dc5b5b;
}

.btn-default {
    background-color: #dc5b5b;
    border-color: #c15050;
}

.btn-default:hover,
.btn-default:focus,
.btn-default.focus,
.btn-default:active,
.btn-default.active,
.show > .dropdown-toggle.btn-default {
    background-color: #c15050;
    border-color: #c15050;
}

.btn-default.disabled,
.btn-default[disabled],
fieldset[disabled] .btn-default {
    background-color: #dc5b5b;
    border-color: #c15050;
}

.btn-default-transparent {
    border-color: #dc5b5b;
}

.btn-default-transparent:hover,
.btn-default-transparent:focus,
.btn-default-transparent.focus,
.btn-default-transparent:active,
.btn-default-transparent.active,
.show > .dropdown-toggle.btn-default-transparent {
    background-color: #c15050;
    border-color: #c15050;
}

.default-bg .btn-default,
.default-translucent-bg .btn-default,
.default-bg .btn-default-transparent,
.default-translucent-bg .btn-default-transparent {
    color: #dc5b5b;
}

.btn-white:hover,
.btn-white:focus,
.btn-white.focus,
.btn-white:active,
.btn-white.active,
.show > .dropdown-toggle.btn-white {
    color: #c15050;
}

.btn-animation:hover:before,
.btn-animation:focus:before {
    background: #c15050;
}

ul.pagination .page-item .page-link:hover,
ul.pagination .page-item .page-link:focus {
    background-color: #c15050;
    border-color: #c15050;
}

ul.pagination .page-item.active .page-link,
.page-item.active .page-link:hover,
.page-item.active .page-link:focus {
    background-color: #dc5b5b;
    border-color: #dc5b5b;
}

.banner .breadcrumb .breadcrumb-item a:hover {
    color: #c15050;
}

.banner .dark.breadcrumb-container {
    background-color: rgba(58, 51, 51, 0.6);
}

.nav-pills.style-2 > li .nav-link.active,
.nav-pills.style-2 > li .nav-link.active:hover,
.nav-pills.style-2 > li .nav-link.active:focus,
.nav-pills.style-2 > li .nav-link:hover,
.nav-pills.style-2 > li .nav-link:focus {
    color: #dc5b5b;
}

.nav.flex-column > li .nav-link.active,
.nav.flex-column > li .nav-link.active:hover,
.nav.flex-column > li .nav-link.active:focus,
.nav.flex-column > li .nav-link:hover,
.nav.flex-column > li .nav-link:focus {
    color: #dc5b5b;
}

.nav-pills > li .nav-link.active:after {
    color: #dc5b5b;
}

.nav.flex-column:not(.list-style-icons) > li .nav-link.active:hover:after,
.nav.flex-column:not(.list-style-icons) > li .nav-link.active:focus:after,
.nav.flex-column:not(.list-style-icons) > li .nav-link:hover:after,
.nav.flex-column:not(.list-style-icons) > li .nav-link:focus:after {
    color: #c15050;
}

.nav.flex-column.list-style-icons > li .nav-link.active > i,
.nav.flex-column.list-style-icons > li .nav-link:hover > i,
.nav.flex-column.list-style-icons > li .nav-link:focus > i {
    color: #c15050;
}

.dark .footer-content .nav.flex-column > li > a.active:hover,
.dark .footer-content .nav.flex-column > li > a:hover {
    color: #c15050;
}

.progress-bar-default {
    background-color: #dc5b5b;
}

.default-bg .form-control {
    border-color: #c15050;
}

.default-bg .input-group-addon {
    border-color: #c15050;
}

.icon.default-bg {
    background-color: #dc5b5b;
}

.icon.light-bg {
    color: #dc5b5b;
}

.modal-content .modal-header {
    background-color: #dc5b5b;
}

header:not(.dark) .dropdown-menu > li > a:hover i,
header:not(.dark) .dropdown-menu > li.active > a i {
    color: #dc5b5b;
}

.navbar-light .navbar-toggler:hover,
.navbar-light .navbar-toggler:focus {
    border-color: #c15050;
}

.social-links li a:hover {
    border-color: #c15050;
    color: #c15050;
}

.social-links.animated-effect-1 li a:after {
    background-color: #dc5b5b;
}

.social-links.default li a {
    background-color: #dc5b5b;
    border: 1px solid #c15050;
}

.media:hover .icon {
    color: #dc5b5b;
    border: 1px solid #dc5b5b;
}

.tag a {
    background-color: #dc5b5b;
    border: 1px solid #c15050;
}

.tag a:hover {
    color: #dc5b5b;
    border-color: #c15050;
}




/* ===============================================================================
   PAGE BANNER COMPONENT — Reusable hero banner styling
   =============================================================================== */

/* ===============================================================================
   PAGE BANNER COMPONENT
   ===============================================================================
   Reusable hero banner with BEM naming and variant support
   Variants: primary, secondary, success, warning, danger, info
   =============================================================================== */

.tl-page-banner {
  position: relative;
  overflow: hidden;
  padding: 20px 0 48px;
}

/* ── Base Variant: Primary (Default) ── */
.tl-page-banner--primary {
  background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 60%, #0f172a 100%);
}

/* ── Variant: Secondary ── */
.tl-page-banner--secondary {
  background: linear-gradient(135deg, #1e293b 0%, #334155 60%, #1e293b 100%);
}

/* ── Variant: Success ── */
.tl-page-banner--success {
  background: linear-gradient(135deg, #064e3b 0%, #047857 60%, #064e3b 100%);
}

/* ── Variant: Warning ── */
.tl-page-banner--warning {
  background: linear-gradient(135deg, #78350f 0%, #b45309 60%, #78350f 100%);
}

/* ── Variant: Danger ── */
.tl-page-banner--danger {
  background: linear-gradient(135deg, #7f1d1d 0%, #dc2626 60%, #7f1d1d 100%);
}

/* ── Variant: Info ── */
.tl-page-banner--info {
  background: linear-gradient(135deg, #0c4a6e 0%, #0284c7 60%, #0c4a6e 100%);
}

/* ── Background Elements ── */
.tl-page-banner__background {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.tl-page-banner__grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(99, 179, 237, 0.05) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(99, 179, 237, 0.05) 1px, transparent 1px);
  background-size: 50px 50px;
}

.tl-page-banner__glow {
  position: absolute;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(56, 189, 248, 0.12) 0%, transparent 70%);
  top: -150px;
  right: -100px;
}

/* ── Content Container ── */
.tl-page-banner__content {
  position: relative;
  z-index: 2;
  text-align: center;
}

/* ── Badge ── */
.tl-page-banner__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px;
  margin-bottom: 16px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 50px;
  border: 1px solid;
}

/* Badge variants */
.tl-page-banner--primary .tl-page-banner__badge {
  background: rgba(56, 189, 248, 0.12);
  border-color: rgba(56, 189, 248, 0.3);
  color: #38bdf8;
}

.tl-page-banner--secondary .tl-page-banner__badge {
  background: rgba(148, 163, 184, 0.12);
  border-color: rgba(148, 163, 184, 0.3);
  color: #94a3b8;
}

.tl-page-banner--success .tl-page-banner__badge {
  background: rgba(16, 185, 129, 0.12);
  border-color: rgba(16, 185, 129, 0.3);
  color: #10b981;
}

.tl-page-banner--warning .tl-page-banner__badge {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.3);
  color: #f59e0b;
}

.tl-page-banner--danger .tl-page-banner__badge {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.3);
  color: #ef4444;
}

.tl-page-banner--info .tl-page-banner__badge {
  background: rgba(3, 169, 244, 0.12);
  border-color: rgba(3, 169, 244, 0.3);
  color: #03a9f4;
}

/* ── Title ── */
.tl-page-banner__title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.2;
}

/* ── Subtitle ── */
.tl-page-banner__subtitle {
  font-size: 1rem;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}

.tl-page-banner--primary .tl-page-banner__subtitle {
  color: #94a3b8;
}

.tl-page-banner--secondary .tl-page-banner__subtitle {
  color: #cbd5e1;
}

.tl-page-banner--success .tl-page-banner__subtitle {
  color: #a7f3d0;
}

.tl-page-banner--warning .tl-page-banner__subtitle {
  color: #fcd34d;
}

.tl-page-banner--danger .tl-page-banner__subtitle {
  color: #fca5a5;
}

.tl-page-banner--info .tl-page-banner__subtitle {
  color: #81d4fa;
}

/* ── Actions (CTA Buttons) ── */
.tl-page-banner__actions {
  margin-top: 24px;
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .tl-page-banner {
    padding: 16px 0 32px;
  }

  .tl-page-banner__content {
    text-align: center;
  }

  .tl-page-banner__title {
    font-size: clamp(1.5rem, 3vw, 2rem);
  }

  .tl-page-banner__subtitle {
    font-size: 0.9rem;
  }

  .tl-page-banner__glow {
    width: 300px;
    height: 300px;
    top: -100px;
    right: -50px;
  }
}

/* ── Dark Mode Support ── */
@media (prefers-color-scheme: dark) {
  .tl-page-banner__subtitle {
    opacity: 0.9;
  }
}

/* ── Reduced Motion Support ── */
@media (prefers-reduced-motion: reduce) {
  .tl-page-banner__glow {
    animation: none;
  }
}

/* ===============================================================================
   END OF FILE
   =============================================================================== */


/* ===============================================================================
   DARK MODE SUPPORT - Comprehensive Dark Theme
   =============================================================================== */

/* Main content areas */
[data-theme="dark"] .page-wrapper {
  background-color: var(--tl-body-bg);
}

[data-theme="dark"] body.tl-tutorial-layout .main-container {
  background: var(--tl-body-bg) !important;
}

/* Cards and containers */
[data-theme="dark"] .tl-card,
[data-theme="dark"] .iq-page .iq-q-card,
[data-theme="dark"] section .tl-grid .tl-card {
  background: var(--tl-surface) !important;
  border-color: var(--tl-border) !important;
  color: var(--tl-body-color) !important;
}

[data-theme="dark"] .tl-card:hover,
[data-theme="dark"] section .tl-grid .tl-card:hover {
  background: var(--tl-surface) !important;
  border-color: var(--tl-sky) !important;
}

/* Form controls */
[data-theme="dark"] .form-control,
[data-theme="dark"] .tl-input {
  background-color: var(--tl-surface-alt);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .tl-input:focus {
  background-color: var(--tl-surface);
  border-color: var(--tl-sky);
  color: var(--tl-body-color);
}

[data-theme="dark"] .form-control::placeholder {
  color: var(--tl-muted);
}

/* Tables */
[data-theme="dark"] tbody,
[data-theme="dark"] .table-striped tbody,
[data-theme="dark"] .table-responsive .table tbody tr,
[data-theme="dark"] :where(.tl-tutorial-layout, .tl-home-layout) .table-responsive > .table tbody tr {
  background-color: var(--tl-surface) !important;
}

[data-theme="dark"] .table th {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
  border-color: var(--tl-border);
}

[data-theme="dark"] .table td {
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

/* Dropdowns and menus */
[data-theme="dark"] .dropdown-menu {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
}

[data-theme="dark"] .dropdown-item {
  color: var(--tl-body-color);
}

[data-theme="dark"] .dropdown-item:hover,
[data-theme="dark"] .dropdown-item:focus {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
}

/* Modals */
[data-theme="dark"] .modal-content {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .modal-header {
  background-color: var(--tl-surface-alt);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .modal-body {
  color: var(--tl-body-color);
}

/* Alerts */
[data-theme="dark"] .alert {
  background-color: var(--tl-surface-alt);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

/* Buttons */
[data-theme="dark"] .btn-default {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .btn-default:hover {
  background-color: var(--tl-surface-alt);
  border-color: var(--tl-sky);
  color: var(--tl-body-color);
}

/* Nav tabs */
[data-theme="dark"] .nav-tabs {
  border-color: var(--tl-border);
}

[data-theme="dark"] .nav-tabs .nav-link {
  color: var(--tl-muted);
}

[data-theme="dark"] .nav-tabs .nav-link.active {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

/* List groups */
[data-theme="dark"] .list-group-item {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .list-group-item.active {
  background-color: var(--tl-sky);
  border-color: var(--tl-sky);
  color: var(--tl-dark-bg);
}

/* Badges */
[data-theme="dark"] .badge {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
}

/* Links */
[data-theme="dark"] a {
  color: var(--tl-sky);
}

[data-theme="dark"] a:hover {
  color: #7dd3fc;
}

/* Headings */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
  color: var(--tl-heading-color);
}

/* Horizontal rules */
[data-theme="dark"] hr {
  border-color: var(--tl-border);
}

/* Code blocks */
[data-theme="dark"] code {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
}

[data-theme="dark"] pre {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
  border-color: var(--tl-border);
}

/* Responsive table cards */
[data-theme="dark"] :where(.tl-tutorial-layout, .tl-home-layout) .tl-card-table > .tl-table tr {
  background: var(--tl-surface) !important;
  border-color: var(--tl-border) !important;
}

[data-theme="dark"] :where(.tl-tutorial-layout, .tl-home-layout) .tl-table-responsive {
  background: var(--tl-surface);
  border-color: var(--tl-border);
}


/* ===============================================================================
   DARK MODE - BLOG & ARTICLE PAGES
   =============================================================================== */

/* Article content */
[data-theme="dark"] .tl-article {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article h1,
[data-theme="dark"] .tl-article h2,
[data-theme="dark"] .tl-article h3,
[data-theme="dark"] .tl-article h4,
[data-theme="dark"] .tl-article h5,
[data-theme="dark"] .tl-article h6 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article h2 {
  border-bottom-color: var(--tl-border);
}

[data-theme="dark"] .tl-article p,
[data-theme="dark"] .tl-article li {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-article a:hover {
  color: #7dd3fc;
}

[data-theme="dark"] .tl-article strong {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article blockquote {
  background-color: rgba(56, 189, 248, 0.05);
  border-left-color: var(--tl-sky);
  color: var(--tl-body-color);
}

/* Article notes/callouts */
[data-theme="dark"] .tl-article-note {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article-note--info {
  background-color: rgba(3, 105, 161, 0.15);
  border-color: #0284c7;
  color: #7dd3fc;
}

[data-theme="dark"] .tl-article-note--warning {
  background-color: rgba(180, 83, 9, 0.15);
  border-color: #ea580c;
  color: #fed7aa;
}

[data-theme="dark"] .tl-article-note--tip {
  background-color: rgba(34, 197, 94, 0.15);
  border-color: #22c55e;
  color: #86efac;
}

[data-theme="dark"] .tl-article-note--danger {
  background-color: rgba(239, 68, 68, 0.15);
  border-color: #ef4444;
  color: #fca5a5;
}

/* Article tables */
[data-theme="dark"] .tl-article table {
  background-color: var(--tl-surface);
  border-color: var(--tl-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .tl-article table th {
  background-color: var(--tl-surface-alt);
  border-bottom-color: var(--tl-border);
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article table td {
  border-bottom-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article table tbody tr:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

/* Article TOC (Table of Contents) */
[data-theme="dark"] .tl-article-toc {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-article-toc h3 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-toc a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-article-toc a:hover {
  color: #7dd3fc;
  background-color: rgba(56, 189, 248, 0.1);
}

[data-theme="dark"] .tl-article-toc a.active {
  color: #7dd3fc;
  background-color: rgba(56, 189, 248, 0.15);
}

/* Article FAQ */
[data-theme="dark"] .tl-article-faq details {
  border-color: var(--tl-border);
  background-color: rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .tl-article-faq details[open] {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .tl-article-faq summary {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-faq summary:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .tl-article-faq details > div,
[data-theme="dark"] .tl-article-faq details > p {
  color: var(--tl-body-color);
}

/* Article author box */
[data-theme="dark"] .tl-article-author {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-article-author h4 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-author .tl-author-role {
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-article-author p {
  color: var(--tl-body-color);
}

/* Article related posts */
[data-theme="dark"] .tl-article-related {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-article-related h3 {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-article-related a {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-article-related a:hover {
  background-color: rgba(56, 189, 248, 0.15);
  color: var(--tl-sky);
}

/* Code blocks in articles */
[data-theme="dark"] .tl-article code {
  background-color: var(--tl-surface-alt);
  color: #fbbf24;
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-article pre {
  background-color: var(--tl-surface-alt);
  color: var(--tl-body-color);
  border-color: var(--tl-border);
}

/* ===============================================================================
   DARK MODE - SIDEBAR & NAVIGATION
   =============================================================================== */

/* Tutorial sidebar */
[data-theme="dark"] .tutorial-sidebar-inner {
  background: var(--tl-body-bg);
  border-right-color: var(--tl-border);
}

/* Sidebar menu */
[data-theme="dark"] .tl-sidebar-menu {
  background: var(--tl-body-bg);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-sidebar-header {
  background: var(--tl-surface-alt);
  color: var(--tl-heading-color);
  border-bottom-color: var(--tl-border);
}

[data-theme="dark"] .tl-sidebar-header i {
  color: var(--tl-sky);
}

/* Sidebar navigation links */
[data-theme="dark"] .tl-sidebar-nav ul li a {
  color: var(--tl-body-color);
  background: transparent;
}

[data-theme="dark"] .tl-sidebar-nav ul li a:hover {
  background: rgba(56, 189, 248, 0.1);
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-sidebar-nav ul li a.active {
  background: rgba(232, 76, 61, 0.15);
  color: var(--tl-accent);
}

/* Collapsible menu sections */
[data-theme="dark"] .tl-sidebar-nav .tl-menu-section > a.tl-section-toggle {
  color: var(--tl-body-color);
  background: transparent;
}

[data-theme="dark"] .tl-sidebar-nav .tl-menu-section > a.tl-section-toggle:hover {
  background: rgba(56, 189, 248, 0.1);
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-sidebar-nav .tl-menu-section .tl-section-icon {
  color: var(--tl-muted);
}

/* Sidebar section items */
[data-theme="dark"] .tl-sidebar-nav .tl-menu-section .tl-section-items li a {
  color: var(--tl-body-color);
  background: transparent;
}

[data-theme="dark"] .tl-sidebar-nav .tl-menu-section .tl-section-items li a:hover {
  background: rgba(56, 189, 248, 0.1);
  color: var(--tl-sky);
}

/* General sidebar */
[data-theme="dark"] .tl-sidebar {
  background: var(--tl-body-bg);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-sidebar .title {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-sidebar a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-sidebar a:hover {
  color: #7dd3fc;
}

/* Sidebar form elements */
[data-theme="dark"] .tl-sidebar form {
  background: var(--tl-body-bg);
}

[data-theme="dark"] .tl-sidebar form input,
[data-theme="dark"] .tl-sidebar form select,
[data-theme="dark"] .tl-sidebar form textarea {
  background: var(--tl-surface-alt);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-sidebar form input:focus,
[data-theme="dark"] .tl-sidebar form select:focus,
[data-theme="dark"] .tl-sidebar form textarea:focus {
  background: var(--tl-surface);
  border-color: var(--tl-sky);
  color: var(--tl-body-color);
}

/* Sidebar widgets */
[data-theme="dark"] .tl-sidebar .widget {
  background: var(--tl-surface);
  border-color: var(--tl-border);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-sidebar .widget-title {
  background: var(--tl-surface-alt);
  color: var(--tl-heading-color);
  border-color: var(--tl-border);
}

/* Sidebar lists */
[data-theme="dark"] .tl-sidebar ul {
  background: var(--tl-body-bg);
}

[data-theme="dark"] .tl-sidebar ul li {
  border-color: var(--tl-border);
}

[data-theme="dark"] .tl-sidebar ul li a {
  color: var(--tl-sky);
}

[data-theme="dark"] .tl-sidebar ul li a:hover {
  background: rgba(56, 189, 248, 0.1);
  color: #7dd3fc;
}

/* Sidebar toggle button */
[data-theme="dark"] .tl-tut-sidebar-toggle {
  background: transparent;
  border-color: rgba(148, 163, 184, 0.25);
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-tut-sidebar-toggle:hover {
  background: rgba(56, 189, 248, 0.1);
  border-color: rgba(56, 189, 248, 0.4);
  color: var(--tl-sky);
}

/* Mobile sidebar overlay */
[data-theme="dark"] .tutorial-sidebar-col {
  background: var(--tl-body-bg);
}

/* Sidebar scrollbar */
[data-theme="dark"] .tutorial-sidebar-inner::-webkit-scrollbar {
  width: 8px;
}

[data-theme="dark"] .tutorial-sidebar-inner::-webkit-scrollbar-track {
  background: var(--tl-surface-alt);
}

[data-theme="dark"] .tutorial-sidebar-inner::-webkit-scrollbar-thumb {
  background: var(--tl-border);
  border-radius: 4px;
}

[data-theme="dark"] .tutorial-sidebar-inner::-webkit-scrollbar-thumb:hover {
  background: rgba(56, 189, 248, 0.5);
}


/* ===============================================================================
   KEY POINTS / TAKEAWAYS COMPONENT
   =============================================================================== */

.tl-key-points {
  background: #f0fdf4;
  border: 1.5px solid #bbf7d0;
  border-radius: 12px;
  padding: 18px 20px;
  margin: 24px 0;
}

.tl-key-points-header {
  font-size: 0.75rem;
  font-weight: 700;
  color: #15803d;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tl-key-points-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-key-points-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 0.88rem;
  color: #166534;
  line-height: 1.6;
}

.tl-key-points-item i {
  color: #22c55e;
  margin-top: 3px;
  flex-shrink: 0;
  font-size: 0.75rem;
}

/* Dark mode - Key Points */
[data-theme="dark"] .tl-key-points {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.3);
}

[data-theme="dark"] .tl-key-points-header {
  color: #86efac;
}

[data-theme="dark"] .tl-key-points-item {
  color: #86efac;
}

[data-theme="dark"] .tl-key-points-item i {
  color: #22c55e;
}


/* ===============================================================================
   RELATED RESOURCES COMPONENT
   =============================================================================== */

.tl-related-resources {
  background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
  border: 2px solid #0ea5e9;
  border-radius: 16px;
  padding: 24px;
  margin: 32px 0;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.tl-related-resources-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
}

.tl-related-resources-icon {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, #0ea5e9, #0284c7);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.tl-related-resources-title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
  color: #0c4a6e;
}

.tl-related-resources-subtitle {
  margin: 0;
  font-size: 0.875rem;
  color: #0369a1;
}

.tl-related-resources-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.tl-resource-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px;
  background: #fff;
  border: 2px solid #e0f2fe;
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}

.tl-resource-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 20px -5px rgba(14, 165, 233, 0.3);
  border-color: #0ea5e9;
}

.tl-resource-card-bg {
  position: absolute;
  top: -20px;
  right: -20px;
  width: 80px;
  height: 80px;
  opacity: 0.1;
  border-radius: 50%;
}

.tl-resource-card-content {
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
  z-index: 1;
}

.tl-resource-card-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.1rem;
}

.tl-resource-card-icon--interview {
  background: linear-gradient(135deg, #fef3c7, #fde68a);
  color: #d97706;
}

.tl-resource-card-icon--compiler {
  background: linear-gradient(135deg, #d1fae5, #a7f3d0);
  color: #059669;
}

.tl-resource-card-icon--tutorial {
  background: linear-gradient(135deg, #ede9fe, #ddd6fe);
  color: #7c3aed;
}

.tl-resource-card-icon--mcq {
  background: linear-gradient(135deg, #fef3c7, #fde68a);
  color: #d97706;
}

.tl-resource-card-text {
  flex: 1;
}

.tl-resource-card-title {
  font-weight: 700;
  font-size: 0.95rem;
  color: #0c4a6e;
  margin-bottom: 2px;
}

.tl-resource-card-subtitle {
  font-size: 0.75rem;
  color: #0369a1;
}

.tl-resource-card-desc {
  font-size: 0.8rem;
  color: #64748b;
  line-height: 1.4;
  position: relative;
  z-index: 1;
}

.tl-resource-card-cta {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.75rem;
  font-weight: 600;
  margin-top: 4px;
  position: relative;
  z-index: 1;
}

.tl-resource-card-cta i {
  font-size: 0.7rem;
}

.tl-related-resources-footer {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #bae6fd;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 0.8rem;
  color: #0369a1;
}

.tl-related-resources-stat {
  display: flex;
  align-items: center;
  gap: 6px;
}

.tl-related-resources-stat i {
  color: #0ea5e9;
}

/* Dark mode - Related Resources */
[data-theme="dark"] .tl-related-resources {
  background: linear-gradient(135deg, rgba(3, 105, 161, 0.15) 0%, rgba(6, 182, 212, 0.1) 100%);
  border-color: rgba(6, 182, 212, 0.4);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .tl-related-resources-title {
  color: #7dd3fc;
}

[data-theme="dark"] .tl-related-resources-subtitle {
  color: #06b6d4;
}

[data-theme="dark"] .tl-resource-card {
  background: var(--tl-surface);
  border-color: rgba(6, 182, 212, 0.2);
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-resource-card:hover {
  border-color: #06b6d4;
  box-shadow: 0 10px 20px -5px rgba(6, 182, 212, 0.3);
}

[data-theme="dark"] .tl-resource-card-title {
  color: var(--tl-heading-color);
}

[data-theme="dark"] .tl-resource-card-subtitle {
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-resource-card-desc {
  color: var(--tl-body-color);
}

[data-theme="dark"] .tl-related-resources-footer {
  border-top-color: rgba(6, 182, 212, 0.2);
  color: var(--tl-muted);
}

[data-theme="dark"] .tl-related-resources-stat i {
  color: #06b6d4;
}


/* ===============================================================================
   COMMON MISTAKES COMPONENT
   =============================================================================== */

.tl-common-mistakes {
  background: #fff7ed;
  border: 1.5px solid #fed7aa;
  border-radius: 12px;
  padding: 20px 22px;
  margin: 24px 0;
}

.tl-common-mistakes-header {
  font-size: 0.75rem;
  font-weight: 700;
  color: #c2410c;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tl-common-mistakes-item {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.tl-common-mistakes-item--divider {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #fed7aa;
}

.tl-code-comparison {
  display: flex;
  gap: 8px;
  margin-bottom: 6px;
  align-items: flex-start;
}

.tl-code-badge {
  font-size: 0.7rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 4px;
  flex-shrink: 0;
  margin-top: 2px;
}

.tl-code-badge--wrong {
  background: #fee2e2;
  color: #dc2626;
}

.tl-code-badge--right {
  background: #dcfce7;
  color: #16a34a;
}

.tl-code-snippet {
  font-size: 0.82rem;
  padding: 3px 8px;
  border-radius: 5px;
  font-family: monospace;
}

.tl-code-snippet--wrong {
  color: #dc2626;
  background: #fff1f2;
}

.tl-code-snippet--right {
  color: #16a34a;
  background: #f0fdf4;
}

.tl-code-tip {
  font-size: 0.83rem;
  color: #92400e;
  margin-top: 4px;
  padding-left: 4px;
}

.tl-code-tip i {
  color: #f59e0b;
  margin-right: 5px;
}



/* ===============================================================================
   POPULAR TUTORIALS SECTION (tl-related-bar)
   =============================================================================== */

.tl-related-bar {
  background: #f8fafc;
  padding: 2rem 0;
  border-top: 1px solid #e2e8f0;
  color: #1a202c;
}

.tl-related-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.tl-related-header {
  margin-bottom: 1.25rem;
}

.tl-related-title {
  font-size: 1.25rem;
  font-weight: 800;
  color: #1a202c !important;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.tl-related-title-icon {
  color: #f97316;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 1em;
  height: 1em;
  font-family: "Font Awesome 5 Free";
  font-size: 1em;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
}

.tl-related-title-icon::before {
  content: "\f06d";
}

.tl-tutorial-cards {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.tl-tutorial-cards li {
  min-width: 0;
}

.tl-tutorial-card {
  background: white;
  border: 2px solid #e2e8f0;
  border-radius: 12px;
  padding: 0.875rem 0.5rem;
  text-decoration: none !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.3s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
}

.tl-tutorial-card:hover,
.tl-tutorial-card:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
  text-decoration: none !important;
}

.tl-tutorial-card:focus-visible {
  outline: 3px solid #2563eb;
  outline-offset: 3px;
}

/* Light mode card color variants */
.tl-tutorial-card--html {
  border-color: #e2e8f0;
}

.tl-tutorial-card--html:hover,
.tl-tutorial-card--html:focus-visible {
  border-color: #e34f26;
}

.tl-tutorial-card--css {
  border-color: #e2e8f0;
}

.tl-tutorial-card--css:hover,
.tl-tutorial-card--css:focus-visible {
  border-color: #264de4;
}

.tl-tutorial-card--js {
  border-color: #e2e8f0;
}

.tl-tutorial-card--js:hover,
.tl-tutorial-card--js:focus-visible {
  border-color: #d97706;
}

.tl-tutorial-card--python {
  border-color: #e2e8f0;
}

.tl-tutorial-card--python:hover,
.tl-tutorial-card--python:focus-visible {
  border-color: #3776ab;
}

.tl-tutorial-card--java {
  border-color: #e2e8f0;
}

.tl-tutorial-card--java:hover,
.tl-tutorial-card--java:focus-visible {
  border-color: #c76a05;
}

.tl-tutorial-card--php {
  border-color: #e2e8f0;
}

.tl-tutorial-card--php:hover,
.tl-tutorial-card--php:focus-visible {
  border-color: #777bb4;
}

.tl-tutorial-card--angular {
  border-color: #e2e8f0;
}

.tl-tutorial-card--angular:hover,
.tl-tutorial-card--angular:focus-visible {
  border-color: #dd0031;
}

.tl-tutorial-card--react {
  border-color: #e2e8f0;
}

.tl-tutorial-card--react:hover,
.tl-tutorial-card--react:focus-visible {
  border-color: #087ea4;
}

.tl-tutorial-card--node {
  border-color: #e2e8f0;
}

.tl-tutorial-card--node:hover,
.tl-tutorial-card--node:focus-visible {
  border-color: #339933;
}

.tl-tutorial-card--dsa {
  border-color: #e2e8f0;
}

.tl-tutorial-card--dsa:hover,
.tl-tutorial-card--dsa:focus-visible {
  border-color: #c21872;
}

.tl-tutorial-card--mongodb {
  border-color: #e2e8f0;
}

.tl-tutorial-card--mongodb:hover,
.tl-tutorial-card--mongodb:focus-visible {
  border-color: #2f7d32;
}

.tl-tutorial-card--mysql {
  border-color: #e2e8f0;
}

.tl-tutorial-card--mysql:hover,
.tl-tutorial-card--mysql:focus-visible {
  border-color: #00758f;
}

.tl-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
  transition: transform 0.3s ease;
  flex-shrink: 0;
}

.tl-tutorial-card:hover .tl-card-icon,
.tl-tutorial-card:focus-visible .tl-card-icon {
  transform: scale(1.1);
}

.tl-card-icon i {
  font-size: 1.25rem;
  text-decoration: none !important;
}

/* Light mode icon colors and backgrounds */
.tl-tutorial-card--html .tl-card-icon {
  background: #fff5f5;
}

.tl-tutorial-card--html .tl-card-icon i {
  color: #e34f26;
}

.tl-tutorial-card--css .tl-card-icon {
  background: #eff6ff;
}

.tl-tutorial-card--css .tl-card-icon i {
  color: #264de4;
}

.tl-tutorial-card--js .tl-card-icon {
  background: #fffbeb;
}

.tl-tutorial-card--js .tl-card-icon i {
  color: #d97706;
}

.tl-tutorial-card--python .tl-card-icon {
  background: #eff6ff;
}

.tl-tutorial-card--python .tl-card-icon i {
  color: #3776ab;
}

.tl-tutorial-card--java .tl-card-icon {
  background: #fffbeb;
}

.tl-tutorial-card--java .tl-card-icon i {
  color: #c76a05;
}

.tl-tutorial-card--php .tl-card-icon {
  background: #f5f3ff;
}

.tl-tutorial-card--php .tl-card-icon i {
  color: #777bb4;
}

.tl-tutorial-card--angular .tl-card-icon {
  background: #fff1f2;
}

.tl-tutorial-card--angular .tl-card-icon i {
  color: #dd0031;
}

.tl-tutorial-card--react .tl-card-icon {
  background: #ecfeff;
}

.tl-tutorial-card--react .tl-card-icon i {
  color: #087ea4;
}

.tl-tutorial-card--node .tl-card-icon {
  background: #f0fdf4;
}

.tl-tutorial-card--node .tl-card-icon i {
  color: #339933;
}

.tl-tutorial-card--dsa .tl-card-icon {
  background: #fdf2f8;
}

.tl-tutorial-card--dsa .tl-card-icon i {
  color: #c21872;
}

.tl-tutorial-card--mongodb .tl-card-icon {
  background: #f0fdf4;
}

.tl-tutorial-card--mongodb .tl-card-icon i {
  color: #2f7d32;
}

.tl-tutorial-card--mysql .tl-card-icon {
  background: #ecfeff;
}

.tl-tutorial-card--mysql .tl-card-icon i {
  color: #00758f;
}

.tl-card-title {
  font-size: 0.8125rem;
  font-weight: 700;
  color: #1a202c;
  margin: 0;
  line-height: 1.2;
  text-decoration: none !important;
}

.tl-tutorial-card:hover .tl-card-title,
.tl-tutorial-card:focus-visible .tl-card-title {
  text-decoration: none !important;
}

@media (prefers-reduced-motion: reduce) {
  .tl-tutorial-card,
  .tl-card-icon {
    transition: none;
  }

  .tl-tutorial-card:hover,
  .tl-tutorial-card:focus-visible,
  .tl-tutorial-card:hover .tl-card-icon,
  .tl-tutorial-card:focus-visible .tl-card-icon {
    transform: none;
  }

  .tl-tutorial-cards {
    grid-template-columns: repeat(6, 1fr);
  }
}

@media (max-width: 768px) {
  .tl-related-bar {
    padding: 1.5rem 0;
  }

  .tl-related-title {
    font-size: 1.125rem;
  }

  .tl-tutorial-cards {
    grid-template-columns: repeat(4, 1fr);
    gap: 0.625rem;
  }

  .tl-tutorial-card {
    padding: 0.75rem 0.375rem;
  }

  .tl-card-icon {
    width: 36px;
    height: 36px;
  }

  .tl-card-icon i {
    font-size: 1.125rem;
  }

  .tl-card-title {
    font-size: 0.75rem;
  }
}

@media (max-width: 480px) {
  .tl-tutorial-cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
  }
}

/* Final logo decoration guard: keep the brand/slogan free of legacy hover underlines. */
.tl-mh-logo,
.tl-mh-logo:hover,
.tl-mh-logo:focus,
.tl-mh-logo:active,
.tl-mh-logo:visited,
.tl-mh-logo *,
.tl-mh-logo:hover *,
.tl-mh-logo:focus *,
.tl-mh-logo:active *,
.tl-mh-logo-slogan,
.tl-mh-logo:hover .tl-mh-logo-slogan,
.tl-mh-logo:focus .tl-mh-logo-slogan,
.tl-mh-logo:active .tl-mh-logo-slogan {
  text-decoration: none !important;
  -webkit-text-decoration-line: none !important;
  text-decoration-line: none !important;
  text-decoration-color: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
}
