body{ width: 100%; height: 100%; padding: 0; margin: 0; color: #111; background: #fff; font-family: 'Roboto'; font-size: 15px; font-weight: 400; overflow: auto; overflow-x: hidden;}
html { scroll-behavior: smooth; }
::selection{ background: #89060d; color: #fff;}
.loading{ position: fixed; width: 100%; height: 100vh; background: #fff; top: 0; left: 0; z-index: 9999999999999999;}
.container{ max-width: 1500px !important; }
.main-section::after { content: ""; display: block; clear: both; }

/* Top Brand */

.top-brand { padding: 15px 0; }
.top-brand span { letter-spacing: 2px; margin-right: 5px; }

/* Top Links */

.top-links a { text-decoration: none; color: currentColor; display: inline-block; }
.top-links a:hover { text-decoration: underline; }
.top-links .col-6:nth-child(1) { background: #fcdffa; }
.top-links .col-6:nth-child(2) { background: #fed3d3; }

/* Header Section */

.header-section { position: fixed; z-index: 99999; background: white; width: 100%; }

.whatsapp-icon { color: #25D366; font-size: 18px; text-decoration: none; font-weight: bold; }

    .whatsapp-icon i { font-size: 24px; margin-right: 5px; }

/* Search Section */

.search-section { width: 100%; position: absolute; left: 0; bottom: -59px; background: #f5f5f5; z-index: 2; display: none; }
    .search-section .inputs { width: 100%; display: flex; padding: 15px 0; }
        .search-section .inputs input[type=text] { width: 100%; outline: none; background: transparent; border: 0; font-size: 18px; }
        .search-section .inputs input[type=submit] { outline: none; background: transparent; border: 0; }

/* Detail Gallery */

.detail-gallery { margin-bottom: 15px; }
    .detail-gallery a { text-decoration: none; color: currentColor; display: block; }
        .detail-gallery a img { width: 100%; }

    .detail-gallery .swiper-button-prev::after, .detail-gallery .swiper-button-next::after { font-size: 24px; color: #111; }

/* Detail Thumbs */

.detail-thumbs img { width: 100%; opacity: 0.3; }
.detail-thumbs .swiper-slide-thumb-active img { opacity: 1; }

/* Logo */

.logo { width: auto; margin-right: 15px; }
.logo a { text-decoration: none; color: currentColor; display: block; }
    .logo a img { max-width: 252px; width: 100%; }

/* Right Links */

.right-links { width: auto; display: inline-flex; align-items: center; }
.right-links a { position: relative; width: 31px; height: 31px; text-decoration: none; color: currentColor; display: block; margin-left: 15px; }
.right-links a.search { background: url(../images/search.png) no-repeat center; background-size: 31px; }
.right-links a.account { background: url(../images/user.png) no-repeat center; background-size: 31px; }
.right-links a.fav { background: url(../images/fav.png) no-repeat center; background-size: 31px; }
.right-links a.basket { background: url(../images/bag.png) no-repeat center; background-size: 31px; }
.right-links a.basket span { width: 18px; height: 18px; right: -4px; top: -4px; font-size: 12px; font-weight: 600; position: absolute; background: #fff; color: #111; border-radius: 100%; display: flex; align-items: center; justify-content: center; }

/* Top Menu */

.top-menu{ width: auto;}
.top-menu ul{ list-style: none; padding: 0; margin: 0; display: flex; align-items: center; justify-content: center;}
.top-menu ul li{ position: relative; width: auto;}
    .top-menu ul li a { text-decoration: none; color: #000000; display: flex; align-items: center; padding: 15px 25px; font-size: 17px; letter-spacing: 1px; position: relative; font-weight: 400; }
.top-menu ul li a i{ color: #fff; font-size: 15px; margin-left: 3px; position: relative; top: -1px; }
.top-menu ul li:hover a{ opacity: 0.5;}
.top-menu > ul{ list-style: none; padding: 0; margin: 0; display: flex;}
.top-menu > ul ul{ list-style: none; padding: 15px 0; margin: 0; position: absolute; width: 180px; background: #ffe7e7; display: none; z-index: 2;}
    .top-menu > ul ul li a { font-weight: 400; padding: 5px 25px; letter-spacing: 0 !important; opacity: 1 !important; color: #111 !important; font-size: 15px; }
.top-menu > ul ul li a:hover{ opacity: 0.5 !important; }
.top-menu > ul ul.opened{ display: block;}
.top-menu > ul ul ul{ left: 100%; top: 0; display: none;}
.top-menu > ul ul ul.opened{ display: block;}

/* Mobile Menu */

.mobile-menu{ width: 100%; height: 100%; position: fixed; left: -100%; top: 0; z-index: 9; transition: 0.3s; background: #fff; overflow: auto;}
.mobile-menu.opened{ left: 0;}
.mobile-menu ul{ width: 100%; height: 100%; top: 0; z-index: 3; padding: 30px 0; padding-top: 60px; margin: 0; list-style: none;}
.mobile-menu ul li{ position: relative; border-top: 1px solid #eee;}
.mobile-menu ul li:last-child{ border-bottom: 1px solid #eee;}
.mobile-menu ul li a{ text-decoration: none; color: #111; font-size: 14px; font-weight: 500; display: block; letter-spacing: 1px; padding: 10px 15px; text-align: center;}
.mobile-menu > ul{ display: block; left: 0;}
.mobile-menu > ul ul{ position: fixed; background: #fff; left: -100%; opacity: 0; visibility: hidden; transition: 0.3s;}
.mobile-menu > ul ul.opened{ left: 0; opacity: 1; visibility: visible;}
.mobile-menu > ul ul ul{ position: fixed; left: 0; top: 0; left: -100%; opacity: 0; visibility: hidden; transition: 0.3s;}
.mobile-menu > ul ul ul.opened{ left: 0; opacity: 1; visibility: visible;}
.mobile-menu .back-icon{ width: 40px; height: 40px; position: absolute; left: 15px; top: 10px; display: flex; align-items: center; justify-content: center; z-index: 2; border: 1px solid #ddd;}
.mobile-menu .sub-icon{ width: 40px; height: 40px; position: absolute; right: 0; top: 0; display: flex; align-items: center; justify-content: center; z-index: 2;}

.mobile-menu .close-btn { width: 40px; height: 40px; position: absolute; right: 15px; top: 10px; display: flex; align-items: center; justify-content: center; z-index: 9; border: 1px solid #ddd; }

/* Slider */

.slider{ width: 100%;}
.slider a{ text-decoration: none; color: currentColor; display: block;}
    .slider img { width: 100%; height: 857px; }

.slider .swiper-pagination span { width: 12px; height: 12px; background: #fff; opacity: 0.4; }
.slider .swiper-pagination .swiper-pagination-bullet-active { opacity: 1; }

/* Banner */

.banner{ width: 100%;}
.banner a{ text-decoration: none; color: currentColor; display: inline-block;}
.banner img{ width: 100%; height: 240px; object-fit: cover;}

/* Breadcrumb */

.breadcrumb{ background: transparent; padding: 0; margin: 0; }
.breadcrumb a{ text-decoration: none; font-size: 13px; color: currentColor; opacity: 0.7;}
.breadcrumb a::after{ content: ">"; position: relative; margin: 0 10px;}
.breadcrumb a:last-child{ opacity: 1; text-decoration: underline; }
.breadcrumb a:last-child::after{ display: none;}

/* Product Gallery */

.product-gallery a { text-decoration: none; color: currentColor; display: block; }
.product-gallery a img { width: 100%; }

/* Product Detail */

.product-detail > h1 { font-size: 24px; margin-bottom: 30px; }
.product-detail > p { font-style: italic; margin-bottom: 30px; }
.product-detail > span { opacity: 0.7; margin-bottom: 30px; display: block; }
.product-detail > .price { font-size: 28px; font-weight: 600; margin-bottom: 30px; }
.product-detail > a.add-basket { filter: invert(1) brightness(0); background: url(../images/bag.png) no-repeat center left 20px; background-size: 31px; text-decoration: none; color: currentColor; display: inline-block; border: 1px solid rgba(0,0,0,0.3); padding: 10px 30px 10px 60px; font-size: 13px; letter-spacing: 2px; }

/* Product Single */

.product-single img { width: 100%; }
.product-single .content > h2 { font-size: 24px; margin-bottom: 30px; }
.product-single .content > p { font-style: italic; margin-bottom: 30px; }
.product-single .content > span { opacity: 0.7; margin-bottom: 30px; display: block; }
.product-single .content > a.add-basket { filter: invert(1) brightness(0); background: url(../images/bag.png) no-repeat center left 20px; background-size: 31px; text-decoration: none; color: currentColor; display: inline-block; border: 1px solid rgba(0,0,0,0.3); padding: 10px 30px 10px 60px; font-size: 13px; letter-spacing: 2px; }

/* Accordion List */

.accordion-list ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; }
.accordion-list ul li { width: 100%; display: block; }
.accordion-list ul li .title { background: #eee; border-radius: 5px; padding: 15px 20px; margin-bottom: 15px; display: flex; justify-content: space-between; cursor: pointer; }
.accordion-list ul li .title i { transition: 0.2s; }
.accordion-list ul li.active .title i { transform: rotate(90deg); }
.accordion-list ul li .title i { font-size: 24px; margin-left: 15px; }
.accordion-list ul li .title h4 { margin: 0; font-size: 16px; }
.accordion-list ul li .content { padding: 0 20px; display: none; margin-bottom: 20px; }

.certifications { display: flex; gap: 15px; margin-top: 20px; }
    .certifications img { width: 50px; height: auto; }

/* Mid Banner */

.mid-banner { position: relative; display: flex; align-items: center; }
    .mid-banner::after { content: ""; position: absolute; width: 100vw; height: 100%; left: -50vw; margin-left: 50%; top: 0; z-index: -1; background: url(../images/tech-bg.jpg) no-repeat center; background-size: cover; background-attachment: fixed; z-index: -1; opacity: 0.1; }
    
    .mid-banner .image img { max-width: 663px; /* width: 100%;  transform: scale(1.15);*/ }
.mid-banner .content { min-width: 380px; /*text-align: center; padding-left: 60px;*/ }
    .mid-banner .content h2 { font-size: 54px; margin-bottom: 30px; font-family: math; }
.mid-banner .content ul { list-style: none; padding: 0; margin: 0; margin-bottom: 30px; }
.mid-banner .content ul li { padding: 5px 0; }
.mid-banner .content ul li::before { content: ""; width: 20px; height: 20px; display: inline-block; background: url(../images/tick.png) no-repeat center; background-size: 20px; position: relative; top: 3px; margin-right: 5px; }
.mid-banner .content a.detail-btn { text-decoration: none; color: #fff; background: #000; padding: 15px 30px; display: inline-block; font-weight: 300; letter-spacing: 2px; font-size: 13px; }

.mid-banner2 { position: relative; display: flex; align-items: center; }
    .mid-banner2::after { content: ""; position: absolute; width: 100vw; height: 100%; left: -50vw; margin-left: 50%; top: 0; z-index: -1; background: linear-gradient(to right, #e3edf7, #7a46a1) no-repeat center; background-size: cover; background-attachment: fixed; z-index: -1; opacity: 0.1; }

    .mid-banner2 .image img { max-width: 663px; /* width: 100%;  transform: scale(1.15);*/ }
    .mid-banner2 .content { min-width: 56%; /*text-align: center; padding-left: 60px;*/ }
        .mid-banner2 .content h2 { font-size: 54px; margin-bottom: 30px; font-family: math; }
        .mid-banner2 .content ul { list-style: none; padding: 0; margin: 0; margin-bottom: 30px; }
            .mid-banner2 .content ul li { padding: 5px 0; }
                .mid-banner2 .content ul li::before { content: ""; width: 20px; height: 20px; display: inline-block; background: url(../images/tick.png) no-repeat center; background-size: 20px; position: relative; top: 3px; margin-right: 5px; }
        .mid-banner2 .content a.detail-btn { text-decoration: none; color: #fff; background: #000; padding: 15px 30px; display: inline-block; font-weight: 300; letter-spacing: 2px; font-size: 13px; }

.mid-banner3 { position: relative; display: flex; align-items: center; }
    .mid-banner3::after { content: ""; position: absolute; width: 100vw; height: 100%; left: -50vw; margin-left: 50%; top: 0; z-index: -1; background: linear-gradient(to right, #fff, #fff) no-repeat center; background-size: cover; background-attachment: fixed; z-index: -1; opacity: 0.1; }

    .mid-banner3 .image img { max-width: 663px; /* width: 100%;  transform: scale(1.15);*/ }
    .mid-banner3 .content { min-width: 33%; /*text-align: center; padding-left: 60px;*/ margin-left: 11%; }
        .mid-banner3 .content h2 { font-size: 54px; margin-bottom: 30px; font-family: math; }
        .mid-banner3 .content ul { list-style: none; padding: 0; margin: 0; margin-bottom: 30px; }
            .mid-banner3 .content ul li { padding: 5px 0; }
                .mid-banner3 .content ul li::before { content: ""; width: 20px; height: 20px; display: inline-block; background: url(../images/tick.png) no-repeat center; background-size: 20px; position: relative; top: 3px; margin-right: 5px; }
        .mid-banner3 .content a.detail-btn { text-decoration: none; color: #fff; background: #000; padding: 15px 30px; display: inline-block; font-weight: 300; letter-spacing: 2px; font-size: 13px; }

.contact-info { max-width: 400px; }
    .contact-info h2 { font-size: 24px; letter-spacing: 2px; }
.phone { font-size: 43px; font-weight: 100; color: #333; }
.description { font-size: 23px; color: #666; }
.brand { font-size: 22px; font-weight: bold; color: #7a5ea6; }



/* About */

.about img { width: 100%; }
.about small { font-size: 13px; letter-spacing: 1px; }
.about h1 { font-size: 32px; letter-spacing: 6px; margin-bottom: 30px; }

/* Icons */

.icons { display: flex; justify-content: center; }
.icons a { text-decoration: none; color: currentColor; display: block; max-width: 200px; width: 100%; padding: 0 15px; }
.icons a .image { position: relative; width: 115px; height: 115px; margin: auto; margin-bottom: 10px; border: 1px solid #000; border-radius: 100%; }
.icons a .image img { position: absolute; width: 80px; height: 80px; object-fit: contain; left: 50%; top: 50%; transform: translate(-50%,-50%); }
.icons a h3 { font-size: 13px; }

/* Doc List */

.doc-list.carou a { text-decoration: none; color: currentColor; display: block; position: relative; width: 100%; padding-bottom: 85%; }
.doc-list.carou a::after { content: ""; position: absolute; width: 100%; height: 100%; left: 0; top: 0; background: linear-gradient(to bottom, transparent, rgba(0,0,0,0.5)) }
.doc-list.carou a img { position: absolute; width: 100%; height: 100%; object-fit: cover; left: 0; top: 0; }

.doc-list.carou a .content { position: absolute; width: 100%; left: 0; bottom: 0; padding: 15px 25px; text-align: left; color: #fff; z-index: 2; }
.doc-list.carou a .content h6 { font-weight: 400; letter-spacing: 3px; }

.doc-list.carou .swiper-button-prev { background: #fff; border: 1px solid #ccc; padding: 0 15px; }
.doc-list.carou .swiper-button-prev::after { font-size: 18px; font-weight: bold; color: #000; }
.doc-list.carou .swiper-button-next { background: #fff; border: 1px solid #ccc; padding: 0 15px; }
.doc-list.carou .swiper-button-next::after { font-size: 18px; font-weight: bold; color: #000; }

/* Side Nav */

.side-nav{ width: 100%;}
.side-nav ul{ list-style: none; padding: 0; margin: 0;}
.side-nav ul li{ width: 100%; position: relative;}
.side-nav ul li:last-child a{ border: 0;}
.side-nav ul li a{ text-decoration: none; color: currentColor; display: block; padding: 10px 0; padding-right: 44px; font-size: 18px; font-weight: 600;}
.side-nav ul li a:hover{ color: #ff0000;}
.side-nav ul li .arrow{ position: absolute; color: #14ab37; right: 0; width: 42px; height: 42px; top: 0; display: flex; align-items: center; justify-content: center; font-size: 20px; cursor: pointer; z-index: 2;}
.side-nav ul li .arrow.active{ transform: rotate(90deg);}
.side-nav ul li.has-sub ul{ padding: 0; height: 0; overflow: hidden;}
.side-nav ul li.has-sub ul.opened{ padding: 10px 0; height: auto;}
.side-nav ul ul{ border: 0;}
.side-nav ul ul li a{ border: 0; font-size: 14px;}
.side-nav ul ul li a{ font-weight: 400;}

/* Contact Map */

.contact-map { width: 100%; min-height: 300px; height: 100%; position: relative; margin-bottom: 15px; }
.contact-map iframe { position: absolute; width: 100%; height: 100%; left: 0; top: 0; }

/* Contact Info */

.contact-info { margin-bottom: 30px; }
.contact-info h2 { font-size: 24px; margin-bottom: 15px; }
.contact-info ul { list-style: none; padding: 0; margin: 0; }
.contact-info ul li { width: 100%; margin-bottom: 10px; }
.contact-info ul li a { text-decoration: none; display: block; color: currentColor; }

/* Contact Form */

.contact-form h2 { font-size: 24px; margin-bottom: 15px; }
.contact-form ul { list-style: none; padding: 0; margin: 0; }
.contact-form ul li { width: 100%; margin-bottom: 10px; }
.contact-form ul li label { display: block; margin-bottom: 3px; }
.contact-form ul li input[type=text] { width: 100%; outline: none; border: 1px solid #ddd; padding: 10px; }
.contact-form ul li textarea { width: 100%; height: 120px; outline: none; border: 1px solid #ddd; padding: 10px; }
.contact-form input[type=submit] { outline: none; border: 0; background: #111; color: #fff; font-weight: 500; padding: 10px 30px; }

/* Newsletter Section */

.newsletter-section { background: #48265e; color: #fff; }

.newsletter-section .inputs { display: flex; align-items: flex-end; justify-content: space-between; }
.newsletter-section .inputs input[type=text] { width: 46%; outline: none; border: 0; color: currentColor; border-bottom: 1px solid #fff; padding: 10px 0; background: transparent; font-size: 13px; letter-spacing: 1px; }
.newsletter-section .inputs input[type=submit] { min-width: 24px; width: 24px; height: 24px; outline: none; border: 0; background: url(../images/arrow.png) transparent no-repeat center; background-size: 24px; }

/* Social Media */

.social-media { display: flex; align-items: center; justify-content: center; }
    .social-media img { width: 25%; height: 60px; object-fit: contain; }
.social-media span { margin: 0 15px; letter-spacing: 3px; }
.social-media a { width: 32px; height: 32px; text-decoration: none; color: currentColor; display: block; margin: 0 5px; }
.social-media a.instagram { background: url(../images/social/instagram.png) no-repeat center; background-size: 32px; }
.social-media a.facebook { width: 14px; background: url(../images/social/facebook.png) no-repeat center; background-size: 32px; }
.social-media a.youtube { background: url(../images/social/youtube.png) no-repeat center; background-size: 32px; }

/* Footer Section */

.footer-section { background: #48265e; }

/* Footer Description */

.f-description { color: #fff; }
.f-description h3 { color: currentColor; font-size: 12px; font-weight: 500; letter-spacing: 2px; margin-bottom: 20px; }
.f-description p { font-size: 13px; font-weight: 300; letter-spacing: 1px; opacity: 0.7; margin: 0; padding: 7px 0; }

/* Footer Menu */

.f-menu { color: #fff; }
.f-menu h3 { color: currentColor; font-size: 12px; font-weight: 500; letter-spacing: 2px; margin-bottom: 20px; }
.f-menu ul { list-style: none; padding: 0; margin: 0; }
.f-menu ul li { padding: 7px 0; }
.f-menu ul li a { text-decoration: none; color: currentColor; display: block; font-size: 12px; font-weight: 300; letter-spacing: 2px; opacity: 0.7; }

/* Copyright */

.copyright { background: #48265e; color: #fff; font-size: 13px; font-weight: 300; letter-spacing: 2px; }
.copyright span { opacity: 0.3; }
.copyright a { text-decoration: none; color: currentColor; }

/* Helpers */

.page-title h2 { font-size: 26px; }
.page-title h2::after { content: ""; display: block; clear: both; }
.page-title h2 span { display: block; }
.page-title h2 strong { display: inline-block; font-family: 'Chantal'; font-size: 54px; transform: rotate(-10deg); font-weight: 400; float: right; margin-top: -15px; }

.page-content ul { list-style: none; padding: 0; margin: 0; margin-bottom: 30px; }
.page-content ul li { padding: 10px 0; display: flex; }
.page-content ul li::before { content: ""; min-width: 20px; width: 20px; height: 20px; display: inline-block; background: url(../images/tick.png) no-repeat center; background-size: 20px; position: relative; top: 3px; margin-right: 10px; }

.w-500 { max-width: 500px; }
.w-320 { max-width: 320px; }
.w-240 { max-width: 240px; }

.h4 { font-weight: 400; letter-spacing: 1px; display: flex; align-items: center; }
.h4 i { width: 28px; height: 50px; background: url(../images/and.png) no-repeat center; background-size: 28px 50px; margin: 0 10px; }

a.read-more { text-decoration: none; color: currentColor; display: inline-block; padding: 15px 30px; border: 1px solid #ccc; font-size: 13px; letter-spacing: 2px; }

.menu-btn{ position: relative; width: 36px; height: 36px; background: #fff; color: #000; font-size: 24px; margin-left: 15px; display: none; align-items: center; justify-content: center;}

@media(max-width: 991px)
{
    .menu-btn{ display: flex;}
    .top-menu{ display: none;}
    .side-nav{ margin-bottom: 30px;}
    .side-nav > ul > li{ border-bottom: 1px solid #ddd;}
    .side-nav > ul > li:last-child{ border: 0;}
    .logo a img { max-width: 100px; }
    .doc-list.carou a .content h5 { font-size: 16px; }
    .doc-list.carou a .content h6 { font-size: 14px; }
}

@media(max-width: 768px)
{
    .mid-banner { flex-wrap: wrap; }
    .mid-banner .image { width: 100%; }
    .mid-banner .image img { transform: unset; }
    .mid-banner .content { padding: 30px 0; margin: auto; }
        .mid-banner .image img { max-width: 364px; /* width: 100%;  transform: scale(1.15);*/ }

    .mid-banner2 { flex-wrap: wrap; }
        .mid-banner2 .image { width: 100%; }
            .mid-banner2 .image img { transform: unset; }
        .mid-banner2 .content { padding: 30px 0; margin: auto; }
    .mid-banner2 .image img { max-width: 364px; /* width: 100%;  transform: scale(1.15);*/ }

    .mid-banner3 { flex-wrap: wrap; }
        .mid-banner3 .image { width: 100%; }
            .mid-banner3 .image img { transform: unset; }
        .mid-banner3 .content { padding: 30px 0; margin: auto; }

    #map{ width: 100%; height: 500px; }
}

@media(max-width: 640px)
{
    .right-links a { margin-left: 5px; }
}

@media(max-width: 576px)
{
    .top-links a { font-size: 13px; }
    .icons { flex-wrap: wrap; }
    .icons a { margin-bottom: 10px; max-width: 170px; }
}

@media(max-width: 480px)
{
    .mid-banner .content { min-width: unset; width: 100%; }
    .mid-banner2 .content { min-width: unset; width: 100%; }
    .mid-banner3 .content { min-width: unset; width: 100%; }
}

@media(max-width: 440px)
{

}












