/* =================================================================
 * NUMATEC v2 — Layer 2 of 3: homepage / CMS block views
 *
 * Re-styles all dynamic blocks rendered from the `block` table:
 * slideshow, platform/about, welcome/services, pack-apps (products),
 * cards/news, customers/partners, intro/vision/mission, counter,
 * review, history, human, award.
 *
 * Selectors mirror the existing markup in
 * application/modules/default/views/block/*.php so we don't have
 * to touch the dynamic block CMS to get the new look.
 * ================================================================= */

/* ---------- 11. Slideshow / hero ---------- */
.slideshow_main {
    position: relative;
    background: var(--nm-bg-deep);
    overflow: hidden;
}
.slideshow_main::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(11, 31, 51, .12) 0%, transparent 35%, rgba(11, 31, 51, .55) 100%),
        radial-gradient(circle at 50% 100%, rgba(230, 81, 0, .15) 0%, transparent 60%);
    pointer-events: none;
    z-index: 2;
}
.slideshow_main .owl-carousel,
.slideshow_main .slideshow { position: relative; z-index: 1; }
.slideshow_main .owl-item img,
.slideshow_main .slideshow img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}
.slideshow_main .owl-dots {
    position: absolute;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    display: flex !important;
    gap: 6px;
}
.slideshow_main .owl-dot {
    width: 28px;
    height: 4px;
    background: rgba(255, 255, 255, .35) !important;
    border-radius: 0 !important;
    transition: var(--nm-transition-fast);
}
.slideshow_main .owl-dot.active { background: var(--nm-accent) !important; width: 40px; }
.slideshow_main .owl-nav { display: none; }

/* Add a thin orange "data bar" under hero to hint at industrial feel */
.slideshow_main::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--nm-accent) 0%, var(--nm-accent-hover) 100%);
    z-index: 4;
}

/* ---------- 12. Platform / about home block ---------- */
.platform {
    background: var(--nm-bg-alt);
    background-image: var(--nm-grid-pattern);
    background-size: 32px 32px;
    padding: 96px 0;
    position: relative;
}
.platform::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 220px;
    height: 220px;
    background-image: repeating-linear-gradient(
        135deg,
        rgba(230, 81, 0, .08) 0,
        rgba(230, 81, 0, .08) 4px,
        transparent 4px,
        transparent 12px
    );
    z-index: 0;
    pointer-events: none;
}
.platform > .container { position: relative; z-index: 1; }

.platform .about_home {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: 64px;
    align-items: center;
}
.platform .about_home .about_left { width: auto; }
.platform .about_home .youtube,
.platform .about_home .image {
    border-radius: var(--nm-radius);
    overflow: hidden;
    box-shadow: var(--nm-shadow-lg);
    position: relative;
    background: #fff;
}
.platform .about_home .image {
    border: 1px solid var(--nm-border);
    padding: 12px;
}
.platform .about_home .image::before {
    content: "";
    position: absolute;
    inset: -14px;
    border: 1px solid var(--nm-accent);
    pointer-events: none;
    z-index: -1;
    border-radius: var(--nm-radius);
}
.platform .about_home .youtube iframe {
    width: 100%;
    height: 360px;
    display: block;
    border: 0;
}
.platform .about_home .image img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--nm-radius-sm);
}

.platform .about_home .main { position: relative; }
.platform .about_home .main::before {
    content: "01 / SOLUTIONS";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.platform h2 {
    font-size: clamp(28px, 3vw, 40px);
    color: var(--nm-text);
    font-weight: 700;
    line-height: 1.18;
    padding: 0;
    margin-bottom: 20px;
}
.platform .title {
    font-family: var(--nm-font-mono);
    text-transform: uppercase;
    font-weight: 600;
    font-size: 12px;
    color: var(--nm-accent);
    letter-spacing: .15em;
}
.platform .content {
    font-size: 15px;
    line-height: 1.75;
    color: var(--nm-text-muted);
}
.platform p { padding-top: 0; }

/* Counter strip nested under .platform */
.platform .list_counter {
    margin-top: 56px;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    padding: 28px 16px;
    box-shadow: var(--nm-shadow);
    position: relative;
}
.platform .list_counter::before {
    content: "";
    position: absolute;
    top: 0;
    left: 24px;
    right: 24px;
    height: 3px;
    background: var(--nm-accent);
}

/* Generic counter list */
.list_counter {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: space-between;
    gap: 16px;
    margin-top: 56px;
}
.list_counter .counter {
    flex: 1 1 200px;
    text-align: center;
    padding: 12px 16px;
    position: relative;
}
.list_counter .counter + .counter::before {
    content: "";
    position: absolute;
    left: 0;
    top: 25%;
    bottom: 25%;
    width: 1px;
    background: var(--nm-border);
}
.list_counter .counter .number {
    font-family: var(--nm-font-display);
    font-size: clamp(36px, 4vw, 52px);
    font-weight: 800;
    color: var(--nm-primary);
    line-height: 1;
    letter-spacing: -.02em;
    display: inline-block;
}
.list_counter .counter .unit {
    font-family: var(--nm-font-mono);
    font-size: 18px;
    color: var(--nm-accent);
    margin-left: 4px;
    font-weight: 700;
    vertical-align: top;
    line-height: 1;
}
.list_counter .counter .name {
    font-family: var(--nm-font-mono);
    text-transform: uppercase;
    font-size: 11px;
    color: var(--nm-text-muted);
    margin-top: 10px;
    letter-spacing: .12em;
    font-weight: 600;
}

@media (max-width: 900px) {
    .platform { padding: 64px 0; }
    .platform .about_home { grid-template-columns: 1fr; gap: 40px; }
    .platform .about_home .youtube iframe { height: 280px; }
}

/* ---------- 13. Welcome / packages (services block) ---------- */
.welcome {
    background: var(--nm-bg-deep);
    background-image:
        linear-gradient(135deg, var(--nm-bg-deep) 0%, var(--nm-primary) 60%, var(--nm-primary-soft) 100%),
        var(--nm-grid-pattern-dark);
    background-blend-mode: normal, normal;
    color: #fff;
    padding: 96px 0;
    position: relative;
    overflow: hidden;
}
.welcome::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--nm-grid-pattern-dark);
    background-size: 32px 32px;
    opacity: .5;
    pointer-events: none;
}
.welcome::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 280px;
    height: 280px;
    background-image: repeating-linear-gradient(
        135deg,
        rgba(230, 81, 0, .12) 0,
        rgba(230, 81, 0, .12) 4px,
        transparent 4px,
        transparent 12px
    );
    pointer-events: none;
}
.welcome > .container { position: relative; z-index: 1; }

.packages { padding-top: 0; border-top: 0; }
.packages > .title { text-align: center; margin-bottom: 56px; color: #fff; }
.packages > .title::before {
    content: "02 / SERVICES";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.packages > .title h2 {
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin: 0 0 14px;
}
.packages > .title h3 {
    font-weight: 400;
    font-size: 16px;
    padding-top: 0;
    color: var(--nm-text-invert-muted);
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.65;
}

.packs {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin: 0;
    padding: 0;
}
.packs .pack {
    width: auto !important;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .12);
    border-radius: var(--nm-radius-md);
    padding: 28px 24px;
    text-align: left;
    box-shadow: none;
    transition: var(--nm-transition);
    backdrop-filter: blur(4px);
    margin: 0;
    position: relative;
    overflow: hidden;
}
.packs .pack::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--nm-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s ease;
}
.packs .pack:hover {
    background: rgba(255, 255, 255, .08);
    border-color: rgba(230, 81, 0, .4);
    transform: translateY(-4px);
}
.packs .pack:hover::before { transform: scaleX(1); }

.packs .pack .image {
    height: 56px;
    width: 56px;
    overflow: hidden;
    background: rgba(230, 81, 0, .15);
    border: 1px solid rgba(230, 81, 0, .3);
    border-radius: var(--nm-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}
.packs .pack .image img {
    width: 32px;
    height: 32px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}
.packs .pack .title {
    font-family: var(--nm-font-display);
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    text-align: left;
    padding: 0;
    margin-bottom: 10px;
    line-height: 1.3;
}
.packages .title { text-align: left; }
.packs .pack .content {
    color: rgba(255, 255, 255, .7);
    font-size: 13.5px;
    line-height: 1.65;
    padding: 0;
    margin-bottom: 18px;
    min-height: 60px;
}
.packs .pack .cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--nm-accent);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 0;
    border-radius: 0;
    border-bottom: 1px solid transparent;
    transition: var(--nm-transition-fast);
}
.packs .pack .cta::after {
    content: "→";
    transition: transform .25s ease;
}
.packs .pack .cta:hover {
    background: transparent;
    color: var(--nm-accent-hover);
    border-bottom-color: var(--nm-accent-hover);
}
.packs .pack .cta:hover::after { transform: translateX(4px); }

.mslide { padding: 0; }

@media (max-width: 1100px) { .packs { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) {
    .welcome { padding: 64px 0; }
    .packs { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .packs .pack { padding: 22px 18px; }
}
@media (max-width: 480px) { .packs { grid-template-columns: 1fr; } }

/* ---------- 14. Products grid (pack-apps) ---------- */
.pack-apps {
    background: #fff;
    padding: 96px 0;
    position: relative;
}
.pack-apps.pack-apps + .pack-apps,
.pack-apps:nth-of-type(even) { background: var(--nm-bg-alt); }

.pack-apps > .container > .title {
    text-align: center;
    padding-bottom: 56px;
    position: relative;
}
.pack-apps > .container > .title::before {
    content: "03 / PRODUCTS";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.pack-apps .title h2 {
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    margin: 0 0 14px;
}
.pack-apps .title h3 {
    font-size: 16px;
    font-weight: 400;
    padding-top: 0;
    padding-bottom: 0;
    color: var(--nm-text-muted);
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.65;
}
.pack-apps .title h2.title_other {
    text-align: left;
    font-size: 24px;
    border-left: 4px solid var(--nm-accent);
    padding-left: 14px;
    margin-bottom: 0;
}

.pack-apps .apps {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin: 0;
    align-items: stretch;
    justify-content: stretch;
}
.pack-apps .apps .app {
    width: auto !important;
    margin: 0;
    color: var(--nm-text);
    text-decoration: none;
    display: block;
    text-align: left;
    transition: var(--nm-transition);
}
.pack-apps .apps .app .inner {
    margin: 0;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    padding: 0;
    box-shadow: var(--nm-shadow-sm);
    transition: var(--nm-transition);
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
}
.pack-apps .apps .app:hover .inner {
    border-color: var(--nm-accent);
    box-shadow: var(--nm-shadow-md);
    transform: translateY(-4px);
}
.pack-apps .apps .app .inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--nm-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .35s ease;
    z-index: 2;
}
.pack-apps .apps .app:hover .inner::before { transform: scaleX(1); }

.pack-apps .apps .app .logo {
    height: 200px;
    background: var(--nm-bg-alt);
    background-image: var(--nm-grid-pattern);
    background-size: 16px 16px;
    border-bottom: 1px solid var(--nm-border);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    overflow: hidden;
    position: relative;
}
.pack-apps .apps .app .logo img {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform .45s ease;
}
.pack-apps .apps .app:hover .logo img { transform: scale(1.06); }

.pack-apps .apps .app .name {
    font-family: var(--nm-font-mono);
    font-size: 11px;
    font-weight: 700;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .12em;
    padding: 18px 20px 6px;
    display: block;
}
.pack-apps .apps .app .subtitle {
    font-family: var(--nm-font-display);
    font-size: 16px;
    font-weight: 700;
    color: var(--nm-text);
    padding: 0 20px 8px;
    display: block;
    line-height: 1.35;
    min-height: 44px;
}
.pack-apps .apps .app .info {
    font-size: 13px;
    color: var(--nm-text-muted);
    line-height: 1.6;
    padding: 0 20px 16px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}
.pack-apps .apps .app .cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    background: var(--nm-bg-alt);
    border-top: 1px solid var(--nm-border);
    color: var(--nm-primary);
    font-family: var(--nm-font-sans);
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: .08em;
    cursor: pointer;
    margin-top: 0;
    transition: var(--nm-transition-fast);
}
.pack-apps .apps .app:hover .cta { background: var(--nm-primary); color: #fff; }
.pack-apps .apps .app .cta img {
    width: 14px;
    height: 14px;
    margin-right: 0;
    margin-left: auto;
    order: 2;
    filter: invert(15%) sepia(40%) saturate(800%) hue-rotate(195deg);
    transition: var(--nm-transition-fast);
}
.pack-apps .apps .app:hover .cta img { filter: brightness(0) invert(1); }
.pack-apps .apps .app .cta::before { order: 1; }
.pack-apps .apps .app .cta::after {
    content: "→";
    order: 3;
    margin-left: 8px;
    font-weight: 700;
    font-size: 14px;
}

@media (max-width: 1100px) { .pack-apps .apps { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) {
    .pack-apps { padding: 64px 0; }
    .pack-apps .apps { grid-template-columns: repeat(2, 1fr); gap: 16px; }
    .pack-apps .apps .app .logo { height: 160px; }
}
@media (max-width: 480px) { .pack-apps .apps { grid-template-columns: 1fr; } }

/* ---------- 15. News cards block ---------- */
.cards { padding: 96px 0; background: #fff; }
.cards.-alt {
    background: var(--nm-bg-alt);
    background-image: var(--nm-grid-pattern);
    background-size: 32px 32px;
}
.cards .header { text-align: center; margin-bottom: 56px; }
.cards .header::before {
    content: "04 / NEWS & INSIGHTS";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.cards .header .title {
    font-family: var(--nm-font-display);
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    margin-bottom: 14px;
    line-height: 1.2;
}
.cards .header .info {
    font-size: 16px;
    color: var(--nm-text-muted);
    padding: 0;
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.65;
}

.cards .items {
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    align-items: stretch;
}
.cards .items .item {
    width: auto;
    margin: 0;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    overflow: hidden;
    box-shadow: var(--nm-shadow-sm);
    transition: var(--nm-transition);
    display: flex;
    flex-direction: column;
}
.cards.-alt .items .item { box-shadow: var(--nm-shadow); }
.cards .items .item:hover {
    transform: translateY(-4px);
    border-color: var(--nm-accent);
    box-shadow: var(--nm-shadow-md);
}

.cards .items .item .image {
    position: relative;
    height: 0;
    padding-bottom: 56%;
    overflow: hidden;
    background: var(--nm-bg-alt);
}
.cards .items .item .image .inner {
    position: absolute;
    inset: 0;
    overflow: hidden;
    display: block;
    transition: none;
}
.cards .items .item .image .inner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: 0;
    transition: transform .55s ease;
}
.cards .items .item:hover .image .inner img { transform: scale(1.06); }

.cards .items .item .main { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.cards .items .item .main .title,
.cards .items .item .main .title a {
    font-family: var(--nm-font-display);
    font-size: 17px;
    font-weight: 700;
    color: var(--nm-text);
    line-height: 1.4;
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.cards.-alt .items .item .main .title,
.cards.-alt .items .item .main .title a {
    color: var(--nm-text);
}
.cards .items .item .main .title a:hover { color: var(--nm-accent); }

.cards .items .item .main .content {
    font-size: 13.5px;
    color: var(--nm-text-muted);
    padding-top: 0;
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
    margin-bottom: 16px;
}

.cards .items .item .main .subtitle a,
.btn_viewmore {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--nm-accent);
    font-family: var(--nm-font-sans);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: 0;
    margin-top: 0;
    border-radius: 0;
    border-bottom: 1px solid transparent;
    transition: var(--nm-transition-fast);
    text-align: left;
}
.cards .items .item .main .subtitle a:hover,
.btn_viewmore:hover {
    background: transparent;
    color: var(--nm-accent-hover);
    border-bottom-color: var(--nm-accent-hover);
}

.cards .cfooter { text-align: center; padding-top: 40px; }
.cards .cfooter .more {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    background: var(--nm-primary);
    color: #fff;
    font-family: var(--nm-font-sans);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    border-radius: var(--nm-radius);
    transition: var(--nm-transition);
}
.cards .cfooter .more:hover {
    background: var(--nm-accent);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: var(--nm-shadow-md);
}

.news_home {
    background: #fff;
    background-image: none;
    color: var(--nm-text);
}
.news_home .header .info { color: var(--nm-text-muted); }
.news_home .items .item { color: var(--nm-text); }

@media (max-width: 992px) { .cards .items { grid-template-columns: repeat(2, 1fr); gap: 20px; } }
@media (max-width: 600px) {
    .cards { padding: 64px 0; }
    .cards .items { grid-template-columns: 1fr; }
}

/* ---------- 16. Customers / partners block ---------- */
#customers {
    padding: 96px 0;
    background: #fff;
    text-align: center;
    position: relative;
}
#customers::before {
    content: "05 / TRUSTED PARTNERS";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
#customers > .container { position: relative; }
#customers .title {
    font-family: var(--nm-font-display);
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    padding-bottom: 12px;
    line-height: 1.2;
}
#customers .subtitle {
    font-size: 16px;
    color: var(--nm-text-muted);
    padding-bottom: 0;
    max-width: 720px;
    margin: 0 auto 32px;
    line-height: 1.65;
}
#customers .customers {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 24px;
    padding-top: 24px;
    align-items: center;
    justify-items: center;
    max-width: 100%;
}
#customers .customers .li {
    width: 100%;
    margin: 0;
    padding: 18px;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 2/1;
    transition: var(--nm-transition);
    filter: grayscale(1) opacity(.55);
}
#customers .customers .li:hover {
    filter: none;
    border-color: var(--nm-accent);
    box-shadow: var(--nm-shadow);
    transform: translateY(-2px);
}
#customers .customers .li img {
    width: auto;
    height: auto;
    max-width: 80%;
    max-height: 100%;
    object-fit: contain;
    margin: 0;
}
@media (max-width: 1100px) { #customers .customers { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px) { #customers { padding: 64px 0; } #customers .customers { grid-template-columns: repeat(3, 1fr); gap: 14px; } }
@media (max-width: 420px) { #customers .customers { grid-template-columns: repeat(2, 1fr); } }

/* ---------- 17. Intro / vision / mission block (about page) ---------- */
.wrap_intro {
    padding: 96px 0;
    background: #fff;
    position: relative;
}
.wrap_intro::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 260px;
    height: 260px;
    background-image: repeating-linear-gradient(135deg, rgba(230, 81, 0, .08) 0, rgba(230, 81, 0, .08) 4px, transparent 4px, transparent 12px);
    pointer-events: none;
    z-index: 0;
}
.wrap_intro .container { position: relative; z-index: 1; }
.wrap_intro .intro {}
.wrap_intro .content_intro {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    gap: 64px;
    align-items: center;
}
.wrap_intro .content_intro .left { position: relative; }
.wrap_intro .content_intro .left .khung {
    position: absolute;
    inset: -20px -20px 20px 20px;
    border: 2px solid var(--nm-accent);
    border-radius: var(--nm-radius);
    z-index: -1;
    pointer-events: none;
}
.wrap_intro .content_intro .left img {
    width: 100%;
    height: auto;
    border-radius: var(--nm-radius);
    box-shadow: var(--nm-shadow-lg);
    border: 6px solid #fff;
}
.wrap_intro .content_intro .left .youtube iframe {
    width: 100%;
    height: 320px;
    border-radius: var(--nm-radius);
    box-shadow: var(--nm-shadow-lg);
}
.wrap_intro .content_intro .right { padding-left: 0; }
.wrap_intro .content_intro .right h2 {
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    margin-bottom: 20px;
    line-height: 1.2;
    position: relative;
}
.wrap_intro .content_intro .right h2::before {
    content: "ABOUT NUMATEC";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.wrap_intro .contentck { font-size: 15px; line-height: 1.75; color: var(--nm-text-muted); }
.wrap_intro .contentck p { margin-bottom: 14px; }
.wrap_intro .contentck strong { color: var(--nm-text); }

@media (max-width: 992px) {
    .wrap_intro { padding: 64px 0; }
    .wrap_intro .content_intro { grid-template-columns: 1fr; gap: 36px; }
}

/* ---------- 17b. Counter wrap (about page) ---------- */
.wrap_counter {
    background: var(--nm-primary);
    background-image:
        linear-gradient(135deg, var(--nm-primary) 0%, var(--nm-bg-deep) 100%);
    color: #fff;
    padding: 56px 0;
    position: relative;
    overflow: hidden;
}
.wrap_counter::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--nm-grid-pattern-dark);
    background-size: 32px 32px;
    opacity: .4;
    pointer-events: none;
}
.wrap_counter > .container { position: relative; z-index: 1; }
.wrap_counter .list_counter { margin-top: 0; }
.wrap_counter .counter .number { color: #fff; }
.wrap_counter .counter .unit { color: var(--nm-accent); }
.wrap_counter .counter .name { color: rgba(255, 255, 255, .75); }
.wrap_counter .counter + .counter::before { background: rgba(255, 255, 255, .1); }

/* ---------- 18. Vision / mission section ---------- */
.wrap_vision_mission {
    padding: 96px 0;
    background: var(--nm-bg-alt);
    background-image: var(--nm-grid-pattern);
    background-size: 32px 32px;
}
.wrap_vision_mission .title_vimis {
    text-align: center;
    font-family: var(--nm-font-display);
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    margin-bottom: 56px;
    line-height: 1.2;
    position: relative;
}
.wrap_vision_mission .title_vimis::before {
    content: "06 / VISION & MISSION";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}

.wrap_tamnhin { margin-bottom: 48px; }
.tamnhin {
    display: flex;
    align-items: center;
    gap: 16px;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-left: 4px solid var(--nm-accent);
    padding: 20px 28px;
    border-radius: var(--nm-radius);
    box-shadow: var(--nm-shadow-sm);
    margin-bottom: 20px;
}
.tamnhin img {
    width: 36px;
    height: 36px;
    object-fit: contain;
    flex-shrink: 0;
}
.tamnhin span {
    font-family: var(--nm-font-display);
    font-size: 22px;
    font-weight: 700;
    color: var(--nm-text);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.content_tamnhin {
    font-size: 15px;
    line-height: 1.75;
    color: var(--nm-text-muted);
    padding: 0 0 0 20px;
    border-left: 1px dashed var(--nm-border-strong);
    margin-left: 20px;
}

.line_tamnhin {
    text-align: center;
    margin: 16px 0;
    opacity: .5;
}
.line_tamnhin img { display: inline-block; width: 180px; height: auto; }

.content_sumenh {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
    margin: 32px 0;
}
.content_sumenh .item {
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    overflow: hidden;
    text-align: center;
    box-shadow: var(--nm-shadow-sm);
    transition: var(--nm-transition);
    display: flex;
    flex-direction: column;
}
.content_sumenh .item:hover {
    transform: translateY(-4px);
    border-color: var(--nm-accent);
    box-shadow: var(--nm-shadow-md);
}
.content_sumenh .item img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}
.content_sumenh .item .title_sm {
    font-family: var(--nm-font-display);
    font-size: 18px;
    font-weight: 700;
    color: var(--nm-text);
    padding: 18px 18px 6px;
}
.content_sumenh .item .info_sm {
    font-size: 13.5px;
    color: var(--nm-text-muted);
    line-height: 1.6;
    padding: 0 18px 22px;
}

.yeuto_tannhin {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
    margin: 32px 0;
}
.yeuto_tannhin .item {
    background: #fff;
    border: 1px solid var(--nm-border);
    border-top: 4px solid var(--nm-accent);
    padding: 24px;
    border-radius: var(--nm-radius);
    box-shadow: var(--nm-shadow-sm);
    transition: var(--nm-transition);
    text-align: left;
}
.yeuto_tannhin .item:hover { transform: translateY(-4px); box-shadow: var(--nm-shadow-md); }
.yeuto_tannhin .title_yeuto {
    font-family: var(--nm-font-display);
    font-size: 17px;
    font-weight: 700;
    color: var(--nm-accent);
    margin-bottom: 10px;
    line-height: 1.3;
}
.yeuto_tannhin .info_yeuto {
    font-size: 13.5px;
    color: var(--nm-text-muted);
    line-height: 1.65;
}
.yeuto_tannhin .line { display: none; }

@media (max-width: 768px) { .wrap_vision_mission { padding: 64px 0; } }

/* ---------- 19. Reviews block ---------- */
#reviews {
    background: var(--nm-bg-alt);
    background-image: var(--nm-grid-pattern);
    background-size: 32px 32px;
    padding: 96px 0;
    margin-bottom: 0;
}
#reviews .title {
    font-family: var(--nm-font-display);
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    color: var(--nm-text);
    text-align: center;
    padding-bottom: 12px;
    line-height: 1.2;
    position: relative;
}
#reviews .title::before {
    content: "07 / CLIENT FEEDBACK";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
#reviews .subtitle {
    font-size: 16px;
    color: var(--nm-text-muted);
    text-align: center;
    padding-bottom: 32px;
    max-width: 720px;
    margin: 0 auto;
    line-height: 1.65;
}

.list_review {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
    gap: 24px;
    margin-top: 24px;
}
.list_review .item {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 0;
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    box-shadow: var(--nm-shadow-sm);
    overflow: hidden;
    margin-bottom: 0;
    transition: var(--nm-transition);
}
.list_review .item:hover { box-shadow: var(--nm-shadow-md); border-color: var(--nm-steel-300); }
.list_review .item .info {
    width: 38%;
    padding: 22px 18px;
    background: var(--nm-bg-alt);
    border: 0;
    border-right: 1px solid var(--nm-border);
    text-align: center;
    border-radius: 0;
}
.list_review .item .message {
    width: 62%;
    padding: 22px 24px;
}
.message_box {
    background: transparent;
    border-radius: 0;
    padding: 0;
    position: static;
    font-size: 14px;
    line-height: 1.7;
    color: var(--nm-text-muted);
}
.message_box::before {
    content: "“";
    font-family: var(--nm-font-display);
    font-size: 48px;
    color: var(--nm-accent);
    line-height: .5;
    display: block;
    margin-bottom: 16px;
}
.picture_review {
    margin-bottom: 12px;
}
.picture_review img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 3px solid var(--nm-accent);
    margin: 0 auto;
    object-fit: cover;
}
.name_review {
    font-family: var(--nm-font-display);
    font-weight: 700;
    font-size: 15px;
    color: var(--nm-text);
}
.info_review {
    border-top: 1px solid var(--nm-border-strong);
    padding-top: 8px;
    margin-top: 8px;
    font-size: 12px;
    color: var(--nm-text-muted);
}
.left-bottom:after { display: none; }
.mess_right { margin-left: 0; }
.mess_left { margin-bottom: 8px; }

@media (max-width: 600px) {
    .list_review { grid-template-columns: 1fr; }
    .list_review .item .info, .list_review .item .message { width: 100%; }
    .list_review .item .info { border-right: 0; border-bottom: 1px solid var(--nm-border); }
}

/* ---------- 20. History (về chúng tôi) ---------- */
.wrap_history {
    padding: 96px 0;
    background: #fff;
}
.wrap_history .title {
    text-align: center;
    font-size: clamp(28px, 3vw, 40px);
    font-weight: 700;
    margin-bottom: 56px;
    color: var(--nm-text);
}
.wrap_history .title::before {
    content: "08 / HISTORY";
    display: block;
    font-family: var(--nm-font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--nm-accent);
    text-transform: uppercase;
    letter-spacing: .18em;
    margin-bottom: 14px;
}
.list_history {
    position: relative;
    max-width: 760px;
    margin: 0 auto;
    padding: 0 0 0 32px;
}
.list_history::before {
    content: "";
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--nm-border);
}
.list_history .item {
    position: relative;
    padding: 0 0 32px 28px;
}
.list_history .item::before {
    content: "";
    position: absolute;
    left: -28px;
    top: 4px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--nm-accent);
    box-shadow: 0 0 0 4px #fff, 0 0 0 5px var(--nm-border-strong);
}
.list_history .year {
    font-family: var(--nm-font-mono);
    font-size: 14px;
    font-weight: 700;
    color: var(--nm-accent);
    letter-spacing: .04em;
}
.list_history .info {
    font-size: 14px;
    color: var(--nm-text-muted);
    line-height: 1.65;
    margin-top: 4px;
}

/* ---------- 21. Human / team ---------- */
.wrap_human { padding: 96px 0; background: var(--nm-bg-alt); background-image: var(--nm-grid-pattern); background-size: 32px 32px; }
.wrap_human .title { text-align: center; margin-bottom: 56px; font-size: clamp(28px, 3vw, 40px); font-weight: 700; color: var(--nm-text); }
.wrap_human .title::before {
    content: "09 / OUR TEAM";
    display: block; font-family: var(--nm-font-mono);
    font-size: 12px; font-weight: 600; color: var(--nm-accent);
    text-transform: uppercase; letter-spacing: .18em; margin-bottom: 14px;
}
.list_human { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 24px; }
.list_human .item {
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius-md);
    overflow: hidden;
    text-align: center;
    box-shadow: var(--nm-shadow-sm);
    transition: var(--nm-transition);
}
.list_human .item:hover { transform: translateY(-4px); box-shadow: var(--nm-shadow-md); }
.list_human .item img { width: 100%; height: 240px; object-fit: cover; }
.list_human .item .name { font-family: var(--nm-font-display); font-size: 16px; font-weight: 700; color: var(--nm-text); padding: 16px 12px 4px; }
.list_human .item .position { font-family: var(--nm-font-mono); font-size: 11px; color: var(--nm-accent); text-transform: uppercase; letter-spacing: .12em; padding: 0 12px 18px; }

/* ---------- 22. Award / certification ---------- */
.wrap_award { padding: 96px 0; background: #fff; }
.wrap_award .title { text-align: center; margin-bottom: 56px; font-size: clamp(28px, 3vw, 40px); font-weight: 700; color: var(--nm-text); }
.wrap_award .title::before {
    content: "10 / CERTIFICATIONS";
    display: block; font-family: var(--nm-font-mono);
    font-size: 12px; font-weight: 600; color: var(--nm-accent);
    text-transform: uppercase; letter-spacing: .18em; margin-bottom: 14px;
}
.list_award { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 24px; }
.list_award .item {
    background: #fff;
    border: 1px solid var(--nm-border);
    border-radius: var(--nm-radius);
    padding: 16px;
    text-align: center;
    transition: var(--nm-transition);
}
.list_award .item:hover {
    border-color: var(--nm-accent);
    box-shadow: var(--nm-shadow);
    transform: translateY(-2px);
}
.list_award .item img { max-width: 100%; height: 200px; object-fit: contain; margin: 0 auto 12px; }
.list_award .item .name { font-size: 13px; color: var(--nm-text-muted); }
