/*
 * NeaTech homepage polish, 2026-05-27.
 * Scoped to the WHMCS homepage so client-area and checkout screens keep Lagom defaults.
 */

.page-homepage .site.site-index {
    position: relative;
    overflow: hidden;
    background: #070a12;
    color: #d9e3f3;
}

.page-homepage .nt-home-hero {
    position: relative;
    overflow: hidden;
    padding: 56px 0 54px;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
    background:
        linear-gradient(135deg, rgba(7, 10, 18, .98) 0%, rgba(9, 18, 31, .98) 48%, rgba(18, 9, 23, .98) 100%),
        linear-gradient(90deg, rgba(30, 192, 225, .10), rgba(137, 92, 246, .10), rgba(255, 114, 44, .08));
}

.page-homepage .nt-home-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(255, 255, 255, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: linear-gradient(90deg, rgba(0, 0, 0, .85), rgba(0, 0, 0, .25));
}

.page-homepage .nt-home-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(118deg, transparent 0 54%, rgba(37, 214, 242, .12) 54% 55%, transparent 55% 100%),
        linear-gradient(124deg, transparent 0 62%, rgba(255, 122, 53, .10) 62% 63%, transparent 63% 100%);
}

.page-homepage .nt-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
    gap: 58px;
    align-items: center;
}

.page-homepage .nt-hero-copy {
    max-width: 720px;
}

.page-homepage .nt-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 34px;
    margin-bottom: 24px;
    padding: 7px 14px;
    border: 1px solid rgba(39, 213, 245, .28);
    border-radius: 8px;
    background: rgba(17, 31, 47, .58);
    color: #55d9ef;
    font-size: 13px;
    line-height: 1;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0;
}

.page-homepage .nt-hero-badge span {
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: #14e2a4;
    box-shadow: 0 0 18px rgba(20, 226, 164, .75);
}

.page-homepage .nt-hero-title {
    max-width: 760px;
    margin: 0;
    color: #f8fbff;
    font-size: 50px;
    line-height: 1.03;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: none;
}

.page-homepage .nt-hero-title span,
.page-homepage .site-section .section-title {
    background: linear-gradient(90deg, #35c8f7 0%, #8b5cf6 48%, #ff6a35 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.page-homepage .nt-hero-text {
    max-width: 620px;
    margin: 20px 0 0;
    color: #b4c0d4;
    font-size: 18px;
    line-height: 1.7;
}

.page-homepage .nt-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 26px;
}

.page-homepage .nt-hero-actions .btn {
    min-height: 56px;
    padding: 16px 26px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.1;
    box-shadow: none;
}

.page-homepage .nt-hero-actions .nt-btn-main,
.page-homepage .btn.btn-primary {
    border-color: transparent;
    background: linear-gradient(135deg, #21c7ed 0%, #7c5cff 54%, #ff7333 100%);
    color: #fff;
    box-shadow: 0 18px 40px rgba(33, 199, 237, .18), 0 14px 36px rgba(255, 115, 51, .12);
}

.page-homepage .nt-hero-actions .nt-btn-main:hover,
.page-homepage .btn.btn-primary:hover {
    filter: brightness(1.06);
    transform: translateY(-1px);
}

.page-homepage .nt-hero-actions .nt-btn-ghost {
    border: 1px solid rgba(35, 211, 242, .45);
    background: rgba(7, 14, 24, .42);
    color: #e8f7ff;
}

.page-homepage .nt-hero-actions .nt-btn-ghost:hover {
    border-color: rgba(255, 126, 54, .65);
    color: #fff;
    background: rgba(255, 126, 54, .08);
}

.page-homepage .nt-hero-perks {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    max-width: 620px;
    margin-top: 28px;
}

.page-homepage .nt-hero-perks div {
    min-width: 0;
}

.page-homepage .nt-hero-perks strong {
    display: block;
    color: #36c8f7;
    font-size: 34px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
}

.page-homepage .nt-hero-perks span {
    display: block;
    margin-top: 9px;
    color: #8d9ab0;
    font-size: 14px;
    line-height: 1.35;
}

.page-homepage .nt-hero-visual {
    position: relative;
    min-height: 400px;
}

.page-homepage .nt-service-console {
    position: absolute;
    top: 50%;
    left: 50%;
    width: min(100%, 430px);
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 8px;
    background: rgba(9, 13, 26, .76);
    box-shadow: 0 30px 80px rgba(0, 0, 0, .42), inset 0 1px 0 rgba(255, 255, 255, .08);
    backdrop-filter: blur(18px);
    transform: translate(-50%, -50%);
}

.page-homepage .nt-service-console::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 8px;
    padding: 1px;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(35, 205, 240, .7), rgba(139, 92, 246, .5), rgba(255, 115, 51, .55));
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask-composite: exclude;
}

.page-homepage .nt-console-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.page-homepage .nt-console-head img {
    width: auto;
    max-width: 72px;
    max-height: 42px;
    object-fit: contain;
}

.page-homepage .nt-console-head span {
    color: #8e9ab1;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0;
}

.page-homepage .nt-console-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 62px;
    margin-top: 16px;
    padding: 14px 16px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
}

.page-homepage .nt-console-line span,
.page-homepage .nt-console-line strong {
    position: relative;
    display: block;
    min-width: 0;
    color: #edf5ff;
    font-size: 14px;
    line-height: 1.25;
}

.page-homepage .nt-console-line span {
    padding-left: 18px;
    font-weight: 800;
}

.page-homepage .nt-console-line span::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    transform: translateY(-50%);
}

.page-homepage .nt-console-line strong {
    color: #a9b6ca;
    font-weight: 700;
    text-align: right;
}

.page-homepage .nt-line-cyan span::before {
    background: #25d6f2;
    box-shadow: 0 0 18px rgba(37, 214, 242, .85);
}

.page-homepage .nt-line-pink span::before {
    background: #ff49c4;
    box-shadow: 0 0 18px rgba(255, 73, 196, .76);
}

.page-homepage .nt-line-orange span::before {
    background: #ff7a35;
    box-shadow: 0 0 18px rgba(255, 122, 53, .75);
}

.page-homepage .nt-console-meter {
    height: 10px;
    margin-top: 18px;
    overflow: hidden;
    border-radius: 8px;
    background: rgba(255, 255, 255, .08);
}

.page-homepage .nt-console-meter span {
    display: block;
    height: 100%;
    border-radius: 8px;
    background: linear-gradient(90deg, #25d6f2, #8b5cf6, #ff7a35);
}

.page-homepage .nt-float-chip {
    position: absolute;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 48px;
    max-width: 220px;
    padding: 12px 16px;
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 8px;
    background: rgba(12, 17, 31, .78);
    color: #f6fbff;
    font-weight: 800;
    line-height: 1.2;
    text-decoration: none;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .28);
    backdrop-filter: blur(14px);
}

.page-homepage .nt-float-chip:hover {
    color: #fff;
    border-color: rgba(255, 255, 255, .22);
    transform: translateY(-2px);
}

.page-homepage .nt-float-chip span {
    width: 8px;
    height: 8px;
    flex: 0 0 auto;
    border-radius: 999px;
}

.page-homepage .nt-chip-a {
    top: -8px;
    right: 12px;
}

.page-homepage .nt-chip-a span {
    background: #21e39f;
    box-shadow: 0 0 16px rgba(33, 227, 159, .78);
}

.page-homepage .nt-chip-b {
    left: 8px;
    bottom: 78px;
}

.page-homepage .nt-chip-b span {
    background: #ff7a35;
    box-shadow: 0 0 16px rgba(255, 122, 53, .78);
}

.page-homepage .nt-chip-c {
    right: 34px;
    bottom: 16px;
}

.page-homepage .nt-chip-c span {
    background: #ff49c4;
    box-shadow: 0 0 16px rgba(255, 73, 196, .75);
}

.page-homepage .site-index .site-section {
    background: #070a12;
}

.page-homepage .site-index .site-section:not(.section-secondary):not(.section-primary) {
    border-top: 1px solid rgba(255, 255, 255, .07);
}

.page-homepage .nt-products-section {
    padding-top: 72px;
}

.page-homepage .site .site-section .section-title {
    max-width: 840px;
    margin-bottom: 42px;
    font-size: 42px;
    line-height: 1.1;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: none;
}

.page-homepage .site .site-section .section-subtitle {
    color: #9da9bc;
}

.page-homepage .site-index .package,
.page-homepage .site-index .feature {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(27, 38, 59, .74), rgba(11, 16, 29, .84));
    box-shadow: 0 22px 64px rgba(0, 0, 0, .30);
}

.page-homepage .site-index .package::before,
.page-homepage .site-index .feature::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, #27d5f5, #8b5cf6, #ff7333);
    opacity: .82;
}

.page-homepage .site-index .package:hover,
.page-homepage .site-index .feature:hover {
    border-color: rgba(39, 213, 245, .32);
    transform: translateY(-4px);
}

.page-homepage .site-index .package-title,
.page-homepage .site-index .feature-title {
    color: #f7fbff;
    text-transform: none;
}

.page-homepage .site-index .package-desc,
.page-homepage .site-index .feature-desc {
    color: #b2bed0;
}

.page-homepage .site-index .package .price,
.page-homepage .site-index .package-starting-from {
    color: #fff;
}

.page-homepage .site-index .package .btn,
.page-homepage .site-index .site-section.text-center .btn {
    border-radius: 8px;
}

.page-homepage .site-index .section-secondary {
    background:
        linear-gradient(135deg, rgba(8, 17, 30, .96), rgba(17, 10, 25, .96)),
        linear-gradient(90deg, rgba(39, 213, 245, .08), rgba(255, 115, 51, .08));
}

.page-homepage .site-index .section-secondary.text-center {
    border-top: 1px solid rgba(255, 255, 255, .08);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.page-homepage .app-nav.app-nav-default {
    background: rgba(12, 18, 31, .78);
    backdrop-filter: blur(16px);
}

.page-homepage .app-nav .top-nav > li > a,
.page-homepage .app-nav .main-menu > li > a {
    transition: color .18s ease, background .18s ease;
}

@media (max-width: 1199.98px) {
    .page-homepage .nt-hero-title {
        font-size: 46px;
    }

    .page-homepage .nt-hero-grid {
        gap: 40px;
    }
}

@media (max-width: 991.98px) {
    .page-homepage .nt-home-hero {
        padding: 60px 0 56px;
    }

    .page-homepage .nt-hero-grid {
        grid-template-columns: 1fr;
    }

    .page-homepage .nt-hero-copy {
        max-width: none;
    }

    .page-homepage .nt-hero-title {
        font-size: 46px;
    }

    .page-homepage .nt-hero-visual {
        min-height: 360px;
    }
}

@media (max-width: 767.98px) {
    .page-homepage .app-nav .logo.visible-xs,
    .page-homepage .app-nav .logo.visible-sm {
        align-items: center;
        gap: 9px;
        text-decoration: none;
    }

    .page-homepage .app-nav .logo.visible-xs img,
    .page-homepage .app-nav .logo.visible-sm img {
        display: none;
    }

    .page-homepage .app-nav .logo.visible-xs::before,
    .page-homepage .app-nav .logo.visible-sm::before {
        content: "NT";
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        border-radius: 8px;
        background: linear-gradient(135deg, rgba(33, 199, 237, .18), rgba(255, 115, 51, .22));
        color: #ff7a35;
        font-size: 15px;
        font-weight: 900;
        letter-spacing: 0;
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .10);
    }

    .page-homepage .app-nav .logo.visible-xs::after,
    .page-homepage .app-nav .logo.visible-sm::after {
        content: "NeaTech";
        color: #f6fbff;
        font-size: 17px;
        font-weight: 900;
        letter-spacing: 0;
    }

    .page-homepage .nt-home-hero {
        padding: 96px 0 42px;
    }

    .page-homepage .nt-hero-badge {
        display: none;
    }

    .page-homepage .nt-hero-title {
        font-size: 38px;
    }

    .page-homepage .nt-hero-text {
        font-size: 16px;
        line-height: 1.6;
    }

    .page-homepage .nt-hero-perks {
        grid-template-columns: 1fr;
        gap: 16px;
        margin-top: 30px;
    }

    .page-homepage .nt-hero-actions .btn {
        width: 100%;
    }

    .page-homepage .nt-hero-visual {
        display: none;
    }

    .page-homepage .site .site-section .section-title {
        font-size: 32px;
    }
}

@media (max-width: 479.98px) {
    .page-homepage .nt-hero-title {
        font-size: 32px;
    }

    .page-homepage .nt-console-head,
    .page-homepage .nt-console-line {
        align-items: flex-start;
        flex-direction: column;
    }

    .page-homepage .nt-console-line strong {
        text-align: left;
    }
}

.page-homepage .app-nav .logo.hidden-sm.hidden-xs.hidden-md {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
}

.page-homepage .app-nav .logo.hidden-sm.hidden-xs.hidden-md img {
    display: none;
}

.page-homepage .app-nav .logo.hidden-sm.hidden-xs.hidden-md::before {
    content: "";
    display: block;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    background: #c9c9c9 url("/templates/lagom2/assets/img/logo/neatech-mark-gray-20260527.png") center / cover no-repeat;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, .12), 0 10px 28px rgba(0, 0, 0, .22);
}

.page-homepage .nt-hero-service-panel {
    position: relative;
    width: min(100%, 520px);
    margin-left: auto;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, .11);
    border-radius: 8px;
    background: rgba(9, 13, 26, .78);
    box-shadow: 0 30px 80px rgba(0, 0, 0, .36), inset 0 1px 0 rgba(255, 255, 255, .08);
    backdrop-filter: blur(18px);
}

.page-homepage .nt-hero-service-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    height: 3px;
    border-radius: 8px 8px 0 0;
    background: linear-gradient(90deg, #27d5f5, #8b5cf6, #ff7333);
}

.page-homepage .nt-panel-head {
    display: flex;
    align-items: center;
    gap: 14px;
    padding-bottom: 18px;
    margin-bottom: 18px;
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.page-homepage .nt-panel-head img {
    width: 52px;
    height: 52px;
    border-radius: 8px;
    object-fit: cover;
}

.page-homepage .nt-panel-head span,
.page-homepage .nt-section-kicker {
    display: block;
    color: #55d9ef;
    font-size: 12px;
    line-height: 1.2;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0;
}

.page-homepage .nt-panel-head strong {
    display: block;
    margin-top: 4px;
    color: #f6fbff;
    font-size: 18px;
    line-height: 1.25;
}

.page-homepage .nt-hero-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.page-homepage .nt-hero-mini-card,
.page-homepage .nt-service-card {
    position: relative;
    display: block;
    min-width: 0;
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(22, 29, 48, .82), rgba(11, 15, 29, .90));
    color: #f7fbff;
    text-decoration: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.page-homepage .nt-hero-mini-card {
    min-height: 158px;
    padding: 18px;
}

.page-homepage .nt-hero-mini-card:hover,
.page-homepage .nt-service-card:hover {
    color: #fff;
    border-color: rgba(39, 213, 245, .36);
    transform: translateY(-3px);
}

.page-homepage .nt-card-code,
.page-homepage .nt-service-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    height: 38px;
    padding: 0 10px;
    border-radius: 8px;
    color: #fff;
    font-size: 13px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
}

.page-homepage .nt-cyan,
.page-homepage .nt-service-card:nth-child(2n) .nt-service-icon {
    background: rgba(33, 199, 237, .18);
    color: #4cdbf2;
}

.page-homepage .nt-orange,
.page-homepage .nt-service-card:nth-child(2n+1) .nt-service-icon {
    background: rgba(255, 115, 51, .18);
    color: #ff8b46;
}

.page-homepage .nt-violet,
.page-homepage .nt-service-card:nth-child(3n) .nt-service-icon {
    background: rgba(139, 92, 246, .20);
    color: #a993ff;
}

.page-homepage .nt-pink,
.page-homepage .nt-service-card:nth-child(4n) .nt-service-icon {
    background: rgba(255, 73, 196, .18);
    color: #ff7bd7;
}

.page-homepage .nt-hero-mini-card strong,
.page-homepage .nt-service-card h3 {
    display: block;
    margin: 18px 0 0;
    color: #f7fbff;
    font-weight: 900;
    line-height: 1.2;
    text-transform: none;
}

.page-homepage .nt-hero-mini-card strong {
    font-size: 18px;
}

.page-homepage .nt-hero-mini-card small,
.page-homepage .nt-service-card p {
    display: block;
    margin: 9px 0 0;
    color: #9da9bc;
    font-size: 14px;
    line-height: 1.55;
}

.page-homepage .nt-services-section {
    position: relative;
    z-index: 2;
    padding: 74px 0 72px;
    border-top: 1px solid rgba(255, 255, 255, .07);
    background:
        linear-gradient(180deg, #070a12 0%, #0a0d18 100%),
        linear-gradient(90deg, rgba(39, 213, 245, .06), rgba(255, 115, 51, .05));
}

.page-homepage .nt-section-kicker {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 14px;
}

.page-homepage .nt-section-kicker span {
    width: 28px;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, #27d5f5, #ff7333);
}

.page-homepage .nt-service-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
    margin-top: 42px;
}

.page-homepage .nt-service-card {
    min-height: 218px;
    padding: 28px;
}

.page-homepage .nt-service-card h3 {
    font-size: 19px;
}

.page-homepage .nt-service-card strong {
    display: inline-block;
    margin-top: 18px;
    color: #ff8b46;
    font-size: 14px;
    line-height: 1.2;
}

.page-homepage .site-index .features {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 28px 24px;
    margin-left: 0;
    margin-right: 0;
}

.page-homepage .site-index .features > [class*="col-"] {
    display: flex;
    width: auto;
    max-width: none;
    padding-left: 0;
    padding-right: 0;
    margin-bottom: 0;
}

.page-homepage .site-index .features::before,
.page-homepage .site-index .features::after {
    display: none;
}

.page-homepage .site-index .feature.feature-xs-left {
    width: 100%;
    min-height: 246px;
    padding: 34px 24px 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
}

.page-homepage .site-index .feature.feature-xs-left .feature-icon {
    position: static;
    width: 74px;
    height: 74px;
    margin: 0 auto 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: rgba(255, 255, 255, .045);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .08);
}

.page-homepage .site-index .feature.feature-xs-left .feature-icon svg {
    width: 48px;
    height: 48px;
}

.page-homepage .site-index .feature.feature-xs-left .feature-content {
    width: 100%;
    padding: 0;
    margin: 0;
}

.page-homepage .site-index .feature.feature-xs-left .feature-title {
    margin: 0 0 14px;
    font-size: 20px;
    line-height: 1.3;
}

.page-homepage .site-index .feature.feature-xs-left .feature-desc {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
}

.page-homepage .footer-company-logo.logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 196px;
    height: 54px;
    padding: 8px 14px;
    border-radius: 8px;
    background: #d2d2d2;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .20);
}

.page-homepage .footer-company-logo.logo img {
    display: none;
}

.page-homepage .footer-company-logo.logo::before {
    content: "";
    width: 100%;
    height: 100%;
    background: url("/templates/lagom2/assets/img/logo/neatech-wordmark-header-20260527.png") center / contain no-repeat;
}

@media (max-width: 1199.98px) {
    .page-homepage .app-nav .logo.hidden-sm.hidden-xs.hidden-md {
        display: none !important;
    }

    .page-homepage .nt-service-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .page-homepage .nt-hero-service-panel {
        width: 100%;
        margin: 0;
    }

    .page-homepage .nt-service-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .page-homepage .site-index .features {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .page-homepage .app-nav .logo.visible-xs::before,
    .page-homepage .app-nav .logo.visible-sm::before {
        content: "";
        background: #c9c9c9 url("/templates/lagom2/assets/img/logo/neatech-mark-gray-20260527.png") center / cover no-repeat;
    }

    .page-homepage .nt-services-section {
        padding: 52px 0;
    }

    .page-homepage .nt-service-grid {
        grid-template-columns: 1fr;
        gap: 14px;
        margin-top: 30px;
    }

    .page-homepage .nt-service-card {
        min-height: 0;
        padding: 24px;
    }

    .page-homepage .site-index .feature.feature-xs-left {
        min-height: 0;
        padding: 28px 22px;
    }

    .page-homepage .site-index .features {
        grid-template-columns: 1fr;
    }
}
