* {
    padding: 0;
    margin: 0;
    /* font-family: Urbanist; */
}
p,h1,h2{
    padding: 0;
    margin: 0;
}

/* header */
.header {
    position:relative;
    height: 164.05px;
}

.header-fixed{
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
    position:fixed;
    top: 0;
    z-index: 1000;
    width: 100%;
    background: #ffffff;
}

.header-top {
    height: 48px;
    padding: 0;
    background: #1e5bb8;
    font-size: 16px;
    font-weight: 400;
    color: #ffffff;
    line-height: 19.2px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
}

.navbar-expand-lg .navbar-nav .dropdown-menu {
    position: absolute;
    font-family: Playfair Display;
}
.dropdown-item {
    font-weight: 600;
    padding: .65rem 1.5rem;
}
#menuHoverProductShow {
    position: absolute;
}

.multi-line{
    display: none;
}

.bg-light {
    background-color: #ffffff !important;
}

.header-main {
    height: 105px;
}

.navbar {
    padding: 0 1rem;
}

.navbar-nav {
    justify-content: space-around;
}

.navbar-light .navbar-nav .nav-link {
    font-family: Playfair Display;
    font-size: 16px;
    font-weight: 700;
    line-height: 21.33px;
    text-align: center;
    color: #0F2A5Fd9 !important;
}

.navbar-light .navbar-nav .nav-item:hover {
    color: #1e5bb8 !important;
    border-bottom: 2px solid #1e5bb8;
}

.navbar-light .navbar-nav .active {
    color: #1e5bb8 !important;
    border-bottom: 2px solid #1e5bb8;
}

.navbar-light .navbar-nav .nav-item {
    display: flex;
    align-items: center;
    text-transform: uppercase;
}

/* layout utilities */
.section {
    padding: 60px 0;
}
.section--white {
    background: #ffffff;
}
.section--muted {
    background: #f7f7f7;
}
.section-title {
    font-family: Playfair Display;
    font-size: 32px;
    font-weight: 600;
    color: #1e5bb8;
    text-transform: uppercase;
    text-align: center;
    padding-bottom: 20px;
}
.content-narrow {
    max-width: 992px;
    margin: 0 auto;
}

.header-main-logo {
    height: 105.04px;
    padding-right: 50px;
}

.header-main-logo img {
    height: 100%;
}

.header-main-search {
    display: flex;
    align-items: center;
    margin-left: auto;
}

.header-main-search button {
    margin-right: 20px;
}

.header-main-lang {
    display: flex;
    gap: 10px;
    float: right;
}

.carousel-control-prev {
    justify-content: left;
    left: 20px;
}

.carousel-control-next {
    justify-content: right;
    right: 20px;
}

.home-slide .carousel-item {
    height: auto;
    max-height: auto;
    max-width: auto;
    overflow: hidden;
}
.home-slide .carousel-item img{
    width: auto;
    height: auto;
    max-height: 650px;
    max-width: 100%;
    object-fit: contain;
}
.introduce {
    height: 523px;
    background-image: var(--commit-bg-image-introduce);
    background-size: cover;
    background-position: center;
    padding: 80px 0;
}

.introduce-image img {
    width: auto;
    height: auto;
    max-height: 420px;
    object-fit: cover;
    display: block;
}

.picture-image img {
    max-width: 100%;
    height: auto;
    max-height: 420px;
    object-fit: cover;
    display: block;
}

.introduce-text h1 {
    font-family: Playfair Display;
    font-size: 24px;
    font-weight: 400;
    line-height: 30px;
    color: #0F2A5F;
    text-transform: uppercase;
    padding-bottom: 12px;
}

.introduce-text h2 {
    font-family: Playfair Display;
    font-size: 32px;
    font-weight: 600;
    line-height: 30px;
    color: #1e5bb8;
    text-transform: uppercase;
    padding-bottom: 20px;
}

.introduce-text p {
    font-family: Inter;
    font-size: 16px;
    font-weight: 400;
    line-height: 36px;
    text-align: justify;
    color: #0F2A5F;
    padding-bottom: 32px;
}

.introduce-text button {
    padding: 8px 24px 8px 24px;
    text-transform: uppercase;
    border: none;
    color: #ffffff;
    background: #1e5bb8;
    font-family: Playfair Display;
    font-size: 16px;
}

.introduce-text button:hover {
    background: #2a6fd6;
    box-shadow: 0px 1px 6px 4px rgba(30, 91, 184, 0.2);
}
/* introduce-detail  */

.introduce-detail {
    height: 0;
    overflow: hidden;
    transition: height 0.8s ease-out;
}

.introduce-detail-more {
    padding: 0 ;
    display: block;
    height: 470px;
}

.show {
    display: block;
}


.introduce-detail.expanded {
    display: block;
}

.detail-text div{
    padding: 24px 0;
    border: 1px solid #ced2cb;
    position: relative;
    height: 100%;
}


.detail-text h1{
    font-family: Playfair Display;
    font-size: 24px;
    font-weight: 600;
    line-height: 30px;
    text-align: left;
    color: #1e5bb8;
    padding: 0 23px;
    border-left: 1px solid #1e5bb8;
    margin-bottom: 32px;
    text-transform: uppercase;
}

.detail-text p{
    padding: 0 24px;
    font-family: Inter;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    text-align: justify;
    color: #0F2A5F;
}

.detail-text img{
    position: absolute;
    top: 20px;
    right: 20px;
    font-size: 30px;
    color: #1e5bb8;
    width: 48px;
    height: 48px;
}



/* Picture */
.picture {
    padding: 80px 0;
    background: #e6f0ff;
}

/* product */

.product {
    background-image: var(--commit-bg-image-product);
    background-size: cover;
    background-position: center;
    padding: 80px 0;
    height: auto;
}

.title {
    padding-bottom: 40px;
    font-family: Playfair Display;
    text-align: center;
    text-transform: uppercase;
    padding-bottom: 20px;
}

.title h1 {
    font-size: 32px;
    font-weight: 600;
    color: #1e5bb8;
    padding-bottom: 20px;
}

.title h2 {
    font-size: 24px;
    font-weight: 400;
    color: #0F2A5F;
    padding-bottom: 12px;
}

.title p {
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    color: #0F2A5F;
    text-transform: math-auto;
    text-align: justify;
    padding-bottom: 20px;
}

.home .product-list {
    display: flex;
}

.home .product-card {
    height: auto;
    position: relative;
    overflow: hidden;
}

.home .product-card:hover img{
    transform: scale(1.06);
    filter: brightness(90%);
}

.home .product-card:hover {
    box-shadow: 0px 1px 6px 4px rgba(0, 0, 0, 0.2);
}

.home .product-card img {
    height: auto;
    width: 100%;
    transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
}

.home .product-card h1 {
    position: static;
    width: 100%;
    height:100px;
    text-align: center;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    font-size: 20px;
    font-weight: 700;
    text-transform: none;
    letter-spacing: .2px;
    line-height: 28px;
    color: #0F2A5F;
    padding: 12px 0 6px;
}

.home .product-card .price {
    position: static;
    width: 100%;
    text-align: center;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5;
    color: #0F2A5F;
    opacity: 0.95;
    font-variant-numeric: tabular-nums;
    letter-spacing: .1px;
}

.home .product-card .actions {
    position: static;
    width: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    gap: 12px;
    padding-top: 16px;
}

/* generic product card alignment */
.product-card h1{ text-align:center; }
.product-card .price{ text-align:center; }

.home .product-card .btn-primary {
    display: inline-block;
    padding: 6px 14px;
    background: #1e5bb8;
    color: #ffffff;
    text-transform: uppercase;
    font-family: Playfair Display;
    font-size: 14px;
    font-weight: 700;
    border: none;
}

.home .product-card .cta-btn {
    display: inline-block;
    padding: 6px 14px;
    border: 2px solid #1e5bb8;
    color: #1e5bb8;
    text-transform: uppercase;
    font-family: Playfair Display;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

/* customer */

.customer {
    background: #e6f0ff;
    padding: 80px 0;
}

.customer-card {
    background: #ffffff;
    margin: 0px 0px;
    padding: 36px 50px 36px 9px;
    height: 100%;
}

.customer-card-item{
    position: relative;
}

.card-comment{
    position: absolute;
    top: 30px;
    right: 25px;
}

.customer-card-left{

}

.customer-card-left img {
    height: 147px;
    width: 147px;
    max-height: 135px;
    max-width: 135px;
    border-radius: 50%;
    object-fit: cover;
}

.customer-card-left h1 {
    font-family: Inter;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
}

.customer-card-left p {
    font-family: Inter;
    font-size: 14px;
    font-weight: 400;
    line-height: 24px;
    text-align: center;
    color: #000000;
}

.customer-card-right {
    position: relative;
    padding-bottom: 30px;
}

.customer-card-right p{
    font-family: Inter;
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    text-align: justified;
    line-height: 24px;
    color: #0F2A5F;
    text-align: justify;
}

.customer-star{
    position: absolute;
    bottom: 0px;
    display: flex;
    gap: 13px;
    color: #F4B511;
}

.commit{
    background-image: var(--commit-bg-image-commit);
    padding: 80px 0;
    background-size: cover;
    background-position: center;
}

.commit img{
    width: 100%;
    height: auto;
    max-height: 420px;
    object-fit: cover;
    display: block;
}

/* footer  */

.footer{
    padding: 40px 0;
}

.footer-left{
    margin: 0 40px;
}

.footer-logo {
    text-align: center;
    margin-bottom: 35px;
}

.footer-icon{
    display: flex;
    gap: 15px;
    justify-content: space-around;
}

.footer-icon div{
    width: 32px;
    height: 32px;
    border-radius: 50px;
    border: 1px solid #1e5bb8;
    display: flex;
    align-items: center;
    justify-content: center;
}

.footer-icon div:hover{
    display: flex;
    gap: 15px;
    justify-content: space-evenly;
    background: #1e5bb8;
}

.footer-icon i{
    color: #1e5bb8;
}

.footer-icon div:hover i{
    color: #ffffff;
}

.footer-center{
    margin-left: 20px;
}

.footer-text{
    display: block;
}

.footer-text h1{
    font-family: Playfair Display;
    font-size: 16px;
    font-weight: 400;
    color: #0F2A5F;
    padding-bottom: 25px;
    text-transform: uppercase;
}

.footer-text div{
    display: flex;
    flex-direction: column;
}
.footer-text a{
    text-decoration: none;
}

.footer-text .footer-a{
    font-family: Inter;
    font-size: 14px;
    font-weight: 400;
    line-height: 16.94px;
    text-align: left;
    color: #0F2A5F;
    text-decoration: none;
    padding-bottom: 20px;
    display: flex;
    flex-direction: row;
}

.footer-text a:hover{
    color: #1e5bb8;
}

.footer-text-icon{
    color: #1e5bb8;
    width: 25px;
}

/* achievement  */
.achievement{
    background-image: var(--commit-bg-image-achievement);
    padding: 80px 0 148px 0;
    background-size: cover;
    background-position: center;
}

.achievement-detail{
    position: relative;
    padding-bottom: 67.67px;
}
.achievement-detail img{
    height: 602px;
    width: 100%;
    object-fit: cover;
}

.achievement-card{
    padding: 24px;
    position: absolute;
    bottom: 0;
    background: #ffffff;
    border: 1px solid #1e5bb8;
    width: 90%;
    left: 5%;
}

.achievement-card h2{
    font-family: Playfair Display;
    font-size: 24px;
    font-weight: 400;
    color: #0F2A5F;
    text-transform: uppercase;
    padding-bottom: 2px;
}

.achievement-card h1{
    font-family: Playfair Display;
    font-size: 32px;
    font-weight: 600;
    color: #1e5bb8;
    text-transform: uppercase;
    padding-bottom: 10px;
}

.achievement-card p{
    font-family: Inter;
    font-size: 16px;
    font-weight: 400;
    color: #0F2A5F;
}

.achievement .carousel-control-next,.achievement .carousel-control-prev {
    justify-content: center;
    width: 40px;
    height: 40px;
    margin: auto;
    display: flex;
    align-items: center;
    border-radius: 50%;
    background: #0F2A5F;
    font-size: 20px;
}

.url-detail-title{
    padding: 16px 0;
    font-family: Inter;
font-size: 16px;
font-weight: 400;
color: #0F2A5F;
background-color: #ffffff;
}

.form-group {
    margin-bottom: 0;
}

label {
    margin-top: 1rem;
}

.parsley-required{
    color: red;
}
.required{
    color: red;
}

.parsley-error{
    border-color: red;
}

@media (min-width: 992px) {
    .header-main-logo {
        height: 105.04px;
        /* padding: 8px 235px 8px 0px; */
    }

    .navbar-expand-lg .navbar-collapse {
        height: 105px;
    }

    .navbar-expand-lg .navbar-nav {
        height: 100%;
    }
}



@media (max-width: 570px) {
    .navbar-light .navbar-nav .active {
        color: #1e5bb8 !important;
        border-bottom: none;
    }
    .navbar-light .navbar-nav .nav-item {
         display: block;
         align-items: left;
         text-transform: uppercase;
    }
    .navbar-expand-lg .navbar-nav .dropdown-menu {
        border: none;
        text-align: center;
        position: unset;
        left: 118px;
        font-family: Playfair Display;
        text-align: left;
    }
    .navbar-light .navbar-nav .nav-link {
        text-align: left;
    }
    #menuHoverProductShow {
        position: unset;
    }
    .header {
        height: 124px;
    }
    .header-main {
        height: auto;
    }
    .header-top {
        font-size: 12px;
        height: 28px;
    }

    .multi-line{
        display: flex;
        order: 3;
    }

    .header-main-lang{
        display: none;
    }

    .header-main-logo {
        height: 96px;
        padding: 10px 0;
        order: 3;
        display:flex;
        align-items:center;
        justify-content: space-between;
    }

    .header-main-logo img {
        height: 100%;
    }

    .home-slide .carousel-item {
        height: auto;
        max-height: 200px;
        overflow: hidden;
    }

    .navbar-light .navbar-toggler {
        order: 1;
        border: none;
        padding: 0px;
    }

    .navbar-collapse {
        order: 3;
    }

    .header-main-search {
        margin-left: 0px;
    }

    .introduce-image{
        padding-bottom: 40px;
    }

    .picture {
        padding: 40px 0;
    }

    .introduce,.product {
        padding: 40px 0;
        height: auto;
    }

    .introduce-text h1 {
        text-align: center;
    }

    .introduce-text h2 {
        text-align: center;
    }

    .introduce-text div {
        text-align: center;
    }

    .introduce-image img{
        width: 100%;
    }

    .detail-text{
        padding-bottom:30px ;
    }

    .introduce-detail-more {
        height: 1130px;;
    }
    .product-card {
        margin-bottom: 30px;
        padding: 0 15px;
    }

    .picture .introduce-text{
        order: 2;
    }

    .picture-image{
        order: 1;
        padding-bottom: 40px;
    }

    .customer-card {
        padding: 36px 9px 121px 9px;
        margin-top: 15px;
    }

    .customer-card-left {
        text-align: center;
    }

    .customer-star {
        bottom: -54px;
    }

    .achievement {
        padding: 80px 0 0px 0;
    }

    .achievement-detail img {
        height: 242px;
    }

    .achievement .carousel-control-next, .achievement .carousel-control-prev {
        margin: 100px auto 0px;
    }

    .achievement-card {
        position: static;
        margin-top: 58px;
        width: 100%;
    }

    .commit {
        padding: 40px 0;
    }

    .footer-icon {
        gap: 0px;
    }

    .footer-left {
        padding-bottom: 20px;
    }
    .display-mobi{
        display: none;
    }
    .home .product-card img { height: auto; }
    .home .product-card .actions{ justify-content: center; }
    .view-detail-btn{ width: 100%; max-width: 240px; }

    .product-card .info{ text-align: center; }
    .product-card h1{ text-align: center; }
    .product-card .price{ text-align: center; }
    .navbar{ position: relative; }
    .header-main{ position: relative; }
    .header-cart-mobile{ position: static; margin-left: auto; }
    .header-cart-mobile .nav-link{ padding: 0; }
    .header-cart-mobile .badge{ position: absolute; top:-6px; right:-12px; }
    .header-main-cart{ display: none; }
}
/* Reset: remove rounded corners and shadows across frontend */
*, *::before, *::after{
    border-radius: 2 !important;
    box-shadow: none !important;
}
/* Remove image hover transforms/filters globally */
.product-card:hover img,
.product-gallery .main:hover img,
.home .product-card:hover img{ transform: none !important; filter: none !important; }
