*,
::after,
::before {
    box-sizing: border-box
}

.preload {
    position: fixed;
    top: 0;
    width: 100%;
    height: 100vh;
    background: #000;
    z-index: 9999;
    transition: opacity .5s ease;
}

#LogoLoader {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: loadercolor 1s ease forwards 2s
}

#LogoLoader path:nth-child(1) {
    stroke-dasharray: 357px;
    stroke-dashoffset: 357px;
    animation: loaderline 2s ease infinite
}

#LogoLoader path:nth-child(2) {
    stroke-dasharray: 357px;
    stroke-dashoffset: 357px;
    animation: loaderline 2s ease infinite
}

#LogoLoader path:nth-child(3) {
    stroke-dasharray: 340px;
    stroke-dashoffset: 340px;
    animation: loaderlineiso 2s ease infinite
}

#LogoLoader path:nth-child(4) {
    stroke-dasharray: 340px;
    stroke-dashoffset: 340px;
    animation: loadercoloriso 1s ease forwards 2s
}

@keyframes loaderline {
    to {
        stroke-dashoffset: 0
    }
}

@keyframes loadercolor {
    from {
        fill: transparent
    }

    to {
        fill: #fff
    }
}

@keyframes loaderlineiso {
    to {
        stroke-dashoffset: 0
    }
}

@keyframes loadercoloriso {
    from {
        fill: transparent
    }

    to {
        fill: #0071d7;
    }
}

.preload-end {
    opacity: 0;
    pointer-events: none
}

:root {
    --primary: #0071d7;
}

.site-wrapper,
body,
html {
    height: 100%
}

body::-webkit-scrollbar {
    width: 7px;
    background-color: #212121
}

body::-webkit-scrollbar-thumb {
    background-color: var(--primary)
}

body {
    font-family: Poppins, sans-serif;
    font-size: 16px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.74;
    position: relative;
    visibility: visible;
    overflow-x: hidden;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    color: #212121
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Poppins, sans-serif;
    font-weight: 700;
    line-height: 1.3;
    margin-top: 0;
    color: #000
}

a,
button {
    line-height: inherit;
    display: inline-block;
    cursor: pointer;
    text-decoration: none;
    color: inherit
}

a,
button,
img,
input {
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

:focus {
    outline: 0 !important
}

a:focus {
    text-decoration: none;
    color: inherit;
    outline: 0
}

a:hover {
    text-decoration: none;
    color: var(--primary)
}

button,
input[type=submit] {
    cursor: pointer
}

img {
    max-width: 100%
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    opacity: 1
}

input:-moz-placeholder,
textarea:-moz-placeholder {
    opacity: 1
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    opacity: 1
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    opacity: 1
}

ul:last-child {
    margin-bottom: 0
}

hr {
    border-top: 1px solid var(--primary) !important
}

svg:not(:root) {
    overflow: hidden
}



.py-10 {
    padding-top: 10rem;
    padding-bottom: 10rem
}

.pt-10 {
    padding-top: 10rem
}

.pb-10 {
    padding-bottom: 10rem
}

.number {
    font-family: Montserrat, sans-serif
}

.fix {
    overflow: hidden
}

.before-zindex-9 {
    position: relative
}

.before-zindex-9::before {
    z-index: 9 !important
}

.box-shadow {
    box-shadow: 0 0 40px rgba(51, 51, 51, .1)
}

.bg-primary {
    background-color: var(--primary) !important
}

.text-primary {
    color: var(--primary) !important
}

.bg-secondary {
    background-color: #000 !important
}

.text-secondary {
    color: #000 !important
}

.bg-dark {
    background-color: #000 !important
}

.text-dark {
    color: #000 !important
}

.bg-white-gray {
    background-color: #f2f2f2 !important
}

.text-white-gray {
    color: #f2f2f2 !important
}

.bg-white-opacity-50 {
    background-color: rgba(255, 255, 255, .5) !important
}

.text-white-opacity-50 {
    color: rgba(255, 255, 255, .5) !important
}

.bg-white {
    background-color: #fff !important
}

.text-white {
    color: #fff !important
}

.bg-overlay-black {
    background-color: #000 !important
}

.text-overlay-black {
    color: #000 !important
}

.fw-100 {
    font-weight: 100
}

.fw-200 {
    font-weight: 200
}

.fw-300 {
    font-weight: 300
}

.fw-400 {
    font-weight: 400
}

.fw-700 {
    font-weight: 700
}

.fw-900 {
    font-weight: 900
}

[data-overlay] {
    position: relative;
    z-index: 1
}

[data-overlay]::before {
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    background-color: #000
}

.overlay {
    position: relative
}

.overlay::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: linear-gradient(to right, rgba(3, 15, 39, .7) 0, rgba(3, 15, 39, 0) 100%)
}

[data-overlay="0.7"]::before {
    opacity: .7
}

[data-bg-image] {
    background-repeat: repeat;
    background-position: top center
}

[data-bg-image]:not(.bg-pattern) {
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    overflow: hidden
}

input {
    border-radius: 0
}

input[type=date],
input[type=time],
input[type=email],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=url],
select,
textarea {
    -webkit-appearance: caret;
    width: 100%;
    min-height: 56px;
    padding: 3px 20px;
    color: #212121;
    border: 1px solid #f5f5f5;
    border-radius: 5px;
    outline: 0;
    background-color: #f5f5f5
}

input[type=date]::-webkit-input-placeholder,
input[type=time]::-webkit-input-placeholder,
input[type=email]::-webkit-input-placeholder,
input[type=number]::-webkit-input-placeholder,
input[type=password]::-webkit-input-placeholder,
input[type=search]::-webkit-input-placeholder,
input[type=tel]::-webkit-input-placeholder,
input[type=text]::-webkit-input-placeholder,
input[type=url]::-webkit-input-placeholder {
    color: #9f9f9f
}

input[type=date]:-moz-placeholder,
input[type=time]:-moz-placeholder,
input[type=email]:-moz-placeholder,
input[type=number]:-moz-placeholder,
input[type=password]:-moz-placeholder,
input[type=search]:-moz-placeholder,
input[type=tel]:-moz-placeholder,
input[type=text]:-moz-placeholder,
input[type=url]:-moz-placeholder {
    color: #9f9f9f
}

input[type=date]::-moz-placeholder,
input[type=time]::-moz-placeholder,
input[type=email]::-moz-placeholder,
input[type=number]::-moz-placeholder,
input[type=password]::-moz-placeholder,
input[type=search]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
input[type=text]::-moz-placeholder,
input[type=url]::-moz-placeholder {
    color: #9f9f9f
}

input[type=date]:-ms-input-placeholder,
input[type=time]:-ms-input-placeholder,
input[type=email]:-ms-input-placeholder,
input[type=number]:-ms-input-placeholder,
input[type=password]:-ms-input-placeholder,
input[type=search]:-ms-input-placeholder,
input[type=tel]:-ms-input-placeholder,
input[type=text]:-ms-input-placeholder,
input[type=url]:-ms-input-placeholder {
    color: #9f9f9f
}

input[type=date]:focus,
input[type=time]:focus,
input[type=email]:focus,
input[type=number]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=tel]:focus,
input[type=text]:focus,
input[type=url]:focus,
select:focus,
textarea:focus {
    border-color: var(--primary);
    background-color: #fff
}

textarea {
    width: 100%;
    min-height: 130px;
    padding: 10px 20px;
    color: #212121;
    border: 1px solid #f5f5f5;
    border-radius: 5px;
    outline: 0;
    background-color: #f5f5f5
}

textarea::-webkit-input-placeholder {
    color: #9f9f9f
}

textarea:-moz-placeholder {
    color: #9f9f9f
}

textarea::-moz-placeholder {
    color: #9f9f9f
}

textarea:-ms-input-placeholder {
    color: #9f9f9f
}

textarea:focus {
    border-color: var(--primary);
    background-color: #fff
}

.single-input label {
    color: #000
}

.single-input .description {
    font-style: italic;
    margin-top: 10px;
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 0
}

.btn {
    font-size: 16px;
    padding: 1rem 2.5rem;
    border-radius: 2rem;
    
}

.btn-primary {
    background-color: var(--primary);
    color: #fff;
    transition: .2s ease-in-out all !important;



}

.btn-primary:hover {
    background-color: #000
}

.btn-white {
    background-color: #fff;
    color: #000
}

.btn-white:hover {
    background-color: #000;
    color: #fff
}

.btn-white-primary{
    background-color: white;
    border: 2px solid white;
    transition: .5s ease all;
}
.btn-white-primary:hover{
    color: white;
    box-shadow: inset 300px 0 0 0 var(--primary);

}
.btn-anlcle  {
    margin-left: 20px;
}

.btn-ancle::after {
    position: relative;
    font-family: "Font Awesome 5 Free"; 
    font-weight: 900; 
    content: "\f105";
    color: rgb(0, 0, 0);
    opacity: 0;
    transition: .3s ease all;
    
}
.btn-ancle:hover::after {
    font-family: "Font Awesome 5 Free"; 
    font-weight: 900; 
    content: "\f105";
    color: #fff;
    margin-left: 5px;
    opacity: 100%;

}




.btn-black {

    background-color: var(--primary);
    color: #fff
}





.btn-black:hover {
    background-color: var(--primary)
}

.link {
    font-size: 16px;
    font-weight: 400;
    line-height: 1
}

.link-lg {
    font-size: 18px
}

.link .mark,
.link mark {
    font-weight: 400;
    line-height: 1;
    position: relative;
    padding: 3px 0;
    color: var(--primary);
    background-color: transparent
}

.link .mark::after,
.link .mark::before,
.link mark::after,
.link mark::before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    content: "";
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .3s;
    transform: scaleX(1) translateZ(0);
    transform-origin: right;
    background: #e0e0e0
}

.link .mark::after,
.link mark::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0);
    transform-origin: left;
    background-color: var(--primary)
}

.link:hover {
    color: #8c89a2
}

.link:hover .mark::before,
.link:hover mark::before {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0)
}

.link:hover .mark::after,
.link:hover mark::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .3s;
    transform: scaleX(1) translateZ(0)
}

.breadcrumb {
    padding: 40px 0;
    background-color: transparent
}

@media only screen and (max-width:767px) {
    .breadcrumb {
        padding: 25px 0
    }
}

.breadcrumb li {
    font-size: 16px;
    line-height: 1.5;
    display: flex;
    color: #fff
}

.breadcrumb li+li::before {
    margin: 0 15px;
    font-size: 16px;
    content: "";
    font-family: "Font Awesome 5 Pro";
    color: #fff;
    margin-top: 2px
}

.breadcrumb li a {
    position: relative;
    display: block;
    color: #fff
}

.breadcrumb li a::before {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 0;
    height: 1px;
    content: "";
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    background-color: var(--primary)
}

.breadcrumb li a:hover {
    color: var(--primary)
}

.breadcrumb li a:hover::before {
    left: 0;
    width: 100%
}

.icon-box {
    position: relative;
    display: block;
    padding: 50px 60px;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    border-radius: 5px;
    z-index: 99;
    background-color: #fff
}

.icon-box.box-border {
    border: 1px solid #e7e7e7
}

.icon-box.box-border:hover {
    border-color: #fff;
    box-shadow: 0 0 40px rgba(51, 51, 51, .1)
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-box {
        padding: 30px 35px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .icon-box {
        padding: 30px 35px
    }
}

@media only screen and (max-width:767px) {
    .icon-box {
        padding: 20px 25px
    }
}

.icon-box .icon {
    margin-bottom: 35px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-box .icon {
        margin-bottom: 20px
    }
}

@media only screen and (max-width:767px) {
    .icon-box .icon {
        margin-bottom: 20px
    }
}

.icon-box .icon svg {
    width: 50px;
    height: 50px
}

.icon-box .icon svg path {
    stroke: var(--primary)
}

.icon-box .content .title {
    font-size: 20px;
    line-height: 1;
    margin: 0;
    color: #000
}

.icon-box .content .desc {
    margin-top: 25px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-box .content .desc {
        margin-top: 20px
    }
}

@media only screen and (max-width:767px) {
    .icon-box .content .desc {
        margin-top: 20px
    }
}

.icon-box .content .desc p {
    line-height: 1.6;
    color: #212121
}

.icon-box .content .link {
    font-size: 16px;
    font-weight: 400;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    margin-top: 35px;
    color: var(--primary)
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-box .content .link {
        margin-top: 20px
    }
}

@media only screen and (max-width:767px) {
    .icon-box .content .link {
        margin-top: 20px
    }
}

.icon-box:hover {
    box-shadow: 0 0 40px rgba(51, 51, 51, .1);
    transform: translateY(-5px);
    z-index: 1
}

.icon-box:hover .content .link {
    color: var(--primary)
}

.icon-box-shape-animation {
    position: relative
}

.icon-box-shape-animation .shape {
    position: absolute;
    z-index: 1
}

.icon-box-shape-animation .shape-1 {
    top: -40px;
    left: -50px;
    z-index: -1
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .icon-box-shape-animation .shape-1 {
        top: -40px;
        left: 0;
        z-index: -1
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-box-shape-animation .shape-1 {
        top: -20px;
        left: 0;
        z-index: -1
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .icon-box-shape-animation .shape-1 {
        top: -20px;
        left: 0;
        z-index: -1
    }
}

@media only screen and (max-width:767px) {
    .icon-box-shape-animation .shape-1 {
        top: -20px;
        left: 0;
        z-index: -1
    }
}

.funfact {
    text-align: center
}

.funfact .number {
    font-size: 52px;
    font-weight: 400;
    line-height: 1;
    display: block;
    color: var(--primary);
    margin-bottom: 25px
}

.funfact .text {
    font-size: 20px;
    font-weight: 400;
    line-height: 1;
    margin-bottom: 0;
    color: #000
}

.pagination {
    flex-wrap: wrap;
    margin: 0 -7px
}

@media only screen and (max-width:479px) {
    .pagination {
        margin: 0 -8px
    }
}

.pagination.center {
    justify-content: center;
    align-items: flex-end
}

.pagination li {
    padding: 0 7px
}

@media only screen and (max-width:479px) {
    .pagination li {
        margin: 0 -3px
    }
}

.pagination li a {
    font-size: 16px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 45px;
    padding: 10px 15px;
    border: 1px solid #e7e7e7;
    text-transform: uppercase;
    color: #212121;
    border-radius: 5px
}

@media only screen and (max-width:479px) {
    .pagination li a {
        width: 40px;
        height: 40px;
        padding: 10px 10px
    }
}

.pagination li a:hover {
    background-color: var(--primary);
    color: #fff
}

.pagination li a.active {
    cursor: default;
    pointer-events: none;
    color: #fff;
    background-color: var(--primary)
}

.faq-section {
    padding-bottom: 120px
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .faq-section {
        padding-bottom: 280px
    }
}

@media only screen and (max-width:767px) {
    .faq-section {
        padding-bottom: 260px
    }
}

.agency-accordion .card {
    border: 1px solid #e7e7e7;
    margin-bottom: 30px;
    transition: all .3s cubic-bezier(.645, .045, .355, 1)
}

.agency-accordion .card:last-child {
    margin-bottom: 0
}

.agency-accordion .card-header {
    position: relative;
    background: 0 0;
    padding: 0;
    border: 1px solid #e7e7e7;
    border-bottom: 0 none
}

.agency-accordion .card-header .h5 a.acc-btn,
.agency-accordion .card-header h5 a.acc-btn {
    color: #000;
    font-size: 16px;
    line-height: 24px;
    padding: 0;
    font-weight: 400;
    border: 0 none;
    -webkit-appearance: none;
    display: block;
    background: #fff;
    border: 1px solid #eee;
    padding: 20px 26px;
    margin: -1px -1px 0;
    position: relative;
    border-radius: 5px
}

.agency-accordion .card-header .h5 a.acc-btn::before,
.agency-accordion .card-header h5 a.acc-btn::before {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    content: "";
    right: 16px;
    font-size: 20px;
    color: #000
}

.agency-accordion .card-header .h5 a.acc-btn[aria-expanded=true],
.agency-accordion .card-header h5 a.acc-btn[aria-expanded=true] {
    background: #fff;
    color: #000
}

.agency-accordion .card-header .h5 a.acc-btn[aria-expanded=true]::before,
.agency-accordion .card-header h5 a.acc-btn[aria-expanded=true]::before {
    content: "";
    color: #000
}

.agency-accordion .card-header .h5 a.border-0,
.agency-accordion .card-header h5 a.border-0 {
    border: 0;
    border-radius: 5px
}

.agency-accordion .card-body {
    padding: 10px 25px 39px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.74;
    font-size: 15px;
    font-family: Poppins, sans-serif;
    border: 0 none;
    box-shadow: 0 20px 40px rgba(0, 0, 0, .07);
    transition: all .3s cubic-bezier(.645, .045, .355, 1);
    border-radius: 0 0 5px 5px
}

.faq-image-area {
    position: relative;
    z-index: 9;
    height: 100%;
    margin-right: 0 !important
}

.faq-image-area .shape {
    position: absolute;
    z-index: 1
}

.faq-image-area .shape-1 {
    top: auto;
    bottom: 145px !important;
    right: -128px !important;
    z-index: -1
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .faq-image-area .shape-1 {
        top: auto;
        bottom: 145px !important;
        right: 0 !important
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .faq-image-area .shape-1 {
        top: auto;
        bottom: 145px !important;
        right: 0 !important
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .faq-image-area .shape-1 {
        top: auto;
        bottom: 145px !important;
        right: 0 !important
    }
}

@media only screen and (max-width:767px) {
    .faq-image-area .shape-1 {
        top: auto;
        bottom: 145px !important;
        right: 0 !important
    }
}

.brand-list {
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.brand-list:hover .brand a {
    display: block
}

.brand-list:hover .brand a img {
    opacity: .5
}

.brand-list .brand {
    display: flex;
    justify-content: center;
    align-self: center
}

.brand-list .brand a {
    display: block
}

.brand-list .brand a img {
    opacity: 1
}

.brand-list .brand:hover a img {
    opacity: 1
}

.newsletter-section {
    position: relative
}

.newsletter-section .shape {
    position: absolute;
    z-index: -1
}

.newsletter-section .shape-1 {
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    margin: 0 auto
}

@media only screen and (max-width:767px) {
    .newsletter-section .shape-1 {
        width: 250px
    }
}

.newsletter-form {
    max-width: 570px;
    margin: 0 auto;
    margin-top: 50px
}

@media only screen and (max-width:767px) {
    .newsletter-form {
        max-width: 100%;
        margin-top: 30px
    }
}

.newsletter-form.form-border form input {
    border-color: var(--primary)
}

.newsletter-form form {
    display: flex
}

@media only screen and (max-width:767px) {
    .newsletter-form form {
        flex-wrap: wrap
    }
}

.newsletter-form form input {
    border-width: 1px 0 1px 1px;
    border-radius: 5px 0 0 5px;
    min-height: 52px;
    padding: 3px 20px
}

@media only screen and (max-width:767px) {
    .newsletter-form form input {
        border-width: 1px;
        border-radius: 5px;
        margin-bottom: 15px
    }
}

.newsletter-form form button {
    border-radius: 0 5px 5px 0;
    width: 160px
}

@media only screen and (max-width:767px) {
    .newsletter-form form button {
        border-radius: 5px
    }
}

.icon-up-down-animation {
    position: relative;
    z-index: 9
}

.icon-up-down-animation .shape {
    position: absolute;
    display: inline-block;
    width: 96px;
    height: 96px;
    z-index: -1
}

.icon-up-down-animation .shape img {
    box-shadow: 0 0 40px 0 rgba(51, 51, 51, .1);
    border-radius: 3rem;
}

.icon-up-down-animation .shape-1 {
    top: -170px;
    left: 300px;
    animation: up-down infinite 4s ease-in-out
}

.icon-up-down-animation .shape-2 {
    top: -150px;
    right: 400px;
    animation: up-down infinite 5s ease-in-out
}

.icon-up-down-animation .shape-3 {
    top: -55px;
    left: 15px;
    animation: up-down infinite 6s ease-in-out
}

.icon-up-down-animation .shape-4 {
    top: -55px;
    right: 15px;
    width: 130px;
    height: 130px;
    animation: up-down infinite 4s ease-in-out
}



.icon-up-down-animation .shape-5 {
    bottom: -80px;
    left: 80px;
    width: 130px;
    height: 130px;
    animation: up-down infinite 5s ease-in-out
}


.icon-up-down-animation .shape-6 {
    bottom: -30px;
    right: 300px;
    animation: up-down infinite 6s ease-in-out
}

.icon-up-down-animation .shape-7 {
    bottom: -40px;
    left: 300px;
    animation: up-down infinite 4s ease-in-out
}

.icon-up-down-animation .shape-8 {
    bottom: -155px;
    right: 80px;
    animation: up-down infinite 5s ease-in-out
}

.icon-up-down-animation .shape-9 {
    bottom: 0;
    right: 15px;
    animation: up-down infinite 6s ease-in-out
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .icon-up-down-animation .shape-1 {
        top: -170px;
        left: 300px
    }

    .icon-up-down-animation .shape-2 {
        top: -150px;
        right: 150px
    }

    .icon-up-down-animation .shape-3 {
        top: -55px;
        left: 15px
    }

    .icon-up-down-animation .shape-4 {
        top: -55px;
        right: 0;
        width: 100px;
        height: 100px
    }


    .icon-up-down-animation .shape-5 {
        bottom: -80px;
        left: 20px;
        width: 100px;
        height: 100px
    }


    .icon-up-down-animation .shape-6 {
        bottom: -30px;
        right: 230px
    }

    .icon-up-down-animation .shape-7 {
        bottom: -40px;
        left: 180px
    }

    .icon-up-down-animation .shape-8 {
        bottom: -125px;
        right: 60px
    }

    .icon-up-down-animation .shape-9 {
        bottom: 0;
        right: 15px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .icon-up-down-animation .shape {
        width: 60px;
        height: 60px
    }


    .icon-up-down-animation .shape-1 {
        top: -115px;
        left: 150px
    }

    .icon-up-down-animation .shape-2 {
        top: -115px;
        right: 150px
    }

    .icon-up-down-animation .shape-3 {
        top: -80px;
        left: 15px
    }

    .icon-up-down-animation .shape-4 {
        top: -100px;
        right: 0;
        width: 90px;
        height: 90px
    }


    .icon-up-down-animation .shape-5 {
        bottom: 0;
        left: 10px;
        width: 90px;
        height: 90px
    }



    .icon-up-down-animation .shape-6 {
        bottom: 30px;
        right: 150px
    }

    .icon-up-down-animation .shape-7 {
        bottom: 40px;
        left: 160px
    }

    .icon-up-down-animation .shape-8 {
        bottom: -70px;
        right: 70px
    }

    .icon-up-down-animation .shape-9 {
        bottom: 10px;
        right: 15px
    }
}

@media only screen and (max-width:767px) {
    .icon-up-down-animation .shape {
        width: 50px;
        height: 50px
    }


    .icon-up-down-animation .shape-1 {
        top: -115px;
        left: 150px
    }

    .icon-up-down-animation .shape-2 {
        top: -115px;
        right: 150px
    }

    .icon-up-down-animation .shape-3 {
        top: -80px;
        left: 15px
    }

    .icon-up-down-animation .shape-4 {
        top: -100px;
        right: 0;
        width: 60px;
        height: 60px
    }


    .icon-up-down-animation .shape-5 {
        bottom: 0;
        left: 10px;
        width: 60px;
        height: 60px
    }



    .icon-up-down-animation .shape-6 {
        bottom: 0;
        right: 120px
    }

    .icon-up-down-animation .shape-7 {
        bottom: 10px;
        left: 100px
    }

    .icon-up-down-animation .shape-8 {
        bottom: -70px;
        right: 45px
    }

    .icon-up-down-animation .shape-9 {
        bottom: 10px;
        right: 15px
    }
}

@media only screen and (max-width:575px) {
    .icon-up-down-animation .shape-6 {
        bottom: 0;
        right: 90px
    }
}

@media only screen and (max-width:767px) {
    .icon-up-down-animation .shape-1 {
        top: -110px;
        left: 90px
    }

    .icon-up-down-animation .shape-2 {
        top: -110px;
        right: 90px
    }

    .icon-up-down-animation .shape-3 {
        top: -80px;
        left: 15px
    }

    .icon-up-down-animation .shape-4 {
        top: -100px;
        right: 10px
    }

    .icon-up-down-animation .shape-5 {
        bottom: 0;
        left: 10px;
        width: 60px;
        height: 60px
    }


    .icon-up-down-animation .shape-6 {
        display: none
    }

    .icon-up-down-animation .shape-7 {
        display: none
    }

    .icon-up-down-animation .shape-8 {
        bottom: -70px;
        right: 45px
    }

    .icon-up-down-animation .shape-9 {
        bottom: 10px;
        right: 15px
    }
}

.up-down {
    animation: up-down infinite 2s ease-in-out
}

@keyframes up-down {
    50% {
        transform: translateY(30px)
    }
}

.team .thumb {
    position: relative;
    margin-bottom: 20px
}

.team .thumb img {
    width: 100%
}

.team .thumb .overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: inherit;
    padding: 30px;
    opacity: 0;
    visibility: hidden;
    background-blend-mode: multiply;
    background-size: cover;
    background-color: var(--primary);
    transition: all .3s cubic-bezier(.645, .045, .355, 1)
}

.team .thumb .social-icon {
    position: absolute;
    bottom: 33px;
    left: 0;
    padding: 0 30px;
    font-size: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-5px);
    transition: all .3s cubic-bezier(.645, .045, .355, 1);
    right: 0;
    margin: 0 -15px
}

.team .thumb .social-icon li {
    margin: 0;
    display: inline-block
}

.team .thumb .social-icon li a {
    transition: all .3s cubic-bezier(.645, .045, .355, 1);
    display: inline-block;
    font-size: 18px;
    color: #222;
    width: 40px;
    height: 40px;
    line-height: 40px;
    border-radius: 50%;
    background: #fff;
    margin: 7px
}

.team .thumb .social-icon li a:hover {
    background-color: var(--primary);
    color: #fff
}

.team .team-info .info .h5,
.team .team-info .info h5 {
    font-size: 18px;
    line-height: 1.388;
    margin-bottom: 6px
}

.team .team-info .info span {
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.58;
    font-size: 14px;
    color: #212121
}

.team:hover .thumb .overlay {
    opacity: .5;
    visibility: visible
}

.team:hover .thumb .social-icon {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.page-title-section {
    position: relative;
    height: 530px;
    display: flex;
    align-items: center;
    z-index: 9;
    flex-direction: column;
    justify-content: center
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .page-title-section {
        height: 400px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .page-title-section {
        height: 400px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .page-title-section {
        height: 400px
    }
}

@media only screen and (max-width:767px) {
    .page-title-section {
        height: 350px
    }
}

.page-title .title {
    font-size: 28px;
    line-height: 1.2;
    color: #fff;
    margin: 0;
    text-align: center
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .page-title .title {
        font-size: 42px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .page-title .title {
        font-size: 34px
    }
}

@media only screen and (max-width:767px) {
    .page-title .title {
        font-size: 23px;
        line-height: 1.5
    }
}

.sub-title {
    font-size: 18px;
    line-height: 24px;
    font-weight: 500;
    display: block;
    max-width: 530px;
    margin: 0 auto;
    margin-top: 20px;
    color: #212121
}

.sub-h::before {
    content: "— ";
    font-weight: 700;
    color: var(--primary)
}

.h::before {
    content: "| ";
    color: var(--primary)
}
.h-h {
    border-bottom: 3px solid var(--primary);
    width: 30px;
}

[data-aos=fade-up] {
    transform: translate3d(0, 30px, 0)
}

.header-section {
    z-index: 999;
    min-height: 80px;
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .header-section {
        min-height: 80px
    }
}

@media only screen and (max-width:767px) {
    .header-section {
        min-height: 80px
    }
}

.header-section .header-inner {
    z-index: 999;
    display: flex;
    align-items: center;
    min-height: 80px;
    background-color: #000
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .header-section .header-inner {
        min-height: 80px
    }
}

@media only screen and (max-width:767px) {
    .header-section .header-inner {
        min-height: 80px
    }
}

.header-section.is-sticky .header-inner {
    position: fixed;
    top: 0;
    left: 0;
    background-color: #000 !important;
    width: 100%;
    height: 80px;
    animation: headerSlideDown .95s ease forwards;
    box-shadow: 0 8px 20px 0 rgba(0, 0, 0, .1);
}

.header-section.header-fluid .container {
    max-width: 100%
}

@media only screen and (min-width:1600px) {
    .header-section.header-fluid .container {
        padding-right: 150px;
        padding-left: 150px
    }
}

.header-section.header-fluid-two .container {
    max-width: 100%
}

@media only screen and (min-width:1600px) {
    .header-section.header-fluid-two .container {
        padding-right: 240px;
        padding-left: 240px
    }
}

.header-section.header-shadow .header-inner {
    box-shadow: 0 3px 9px rgba(0, 0, 0, .05)
}

.header-section.header-transparent {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

.header-section.header-transparent .header-inner {
    background-color: transparent
}

.header-section.header-light .header-login a {
    color: #fff
}

.header-section.header-light .header-login a:hover {
    color: #fff
}

@keyframes headerSlideDown {
    0% {
        transform: translateY(-100%)
    }

    100% {
        transform: translateY(0)
    }
}

.header-logo a {
    position: relative;
    max-width: 225px
}

.header-logo a img {
    width: 100%;
    padding: 15px 0
}

.header-logo a img.light-logo {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0
}

@media only screen and (max-width:479px) {
    .header-logo a {
        max-width: 170px
    }
}

.header-light .header-logo a img.light-logo {
    opacity: 1
}

.header-light .header-logo a img.dark-logo {
    opacity: 0
}

.header-search-area {
    display: flex;
    align-items: center
}

.header-search a {
    line-height: 1;
    display: flex;
    padding: 6px 5px;
    color: #fff
}

.header-search a i {
    font-size: 26px
}

.header-search a:hover {
    color: var(--primary)
}

@media only screen and (max-width:479px) {
    .header-search a {
        padding-right: 7px;
        padding-left: 7px
    }
}

.main-search-active {
    background: rgba(0, 0, 0, .92) none repeat scroll 0 0;
    width: 100%;
    min-height: 100vh;
    padding: 32px 46px 39px;
    position: fixed;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    display: flex;
    justify-content: center;
    z-index: 9999;
    transition: all .5s ease-in-out
}

@media only screen and (max-width:767px) {
    .main-search-active {
        padding: 32px 20px 39px
    }
}

.sidebar-search-icon {
    position: absolute;
    top: 50px;
    right: 70px;
    color: #fff;
    font-size: 60px;
    cursor: pointer
}

@media only screen and (max-width:767px) {
    .sidebar-search-icon {
        right: 0
    }
}

.swal2-html-container {
    color: white !important;
}

.sidebar-search-icon button {
    background: transparent none repeat scroll 0 0;
    border: medium none;
    color: #fff;
    cursor: pointer;
    font-size: 50px;
    line-height: 1;
    padding: 0;
    transition: all .2s ease 0s
}

.sidebar-search-input {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(.8);
    display: inline-block;
    padding: 0 50px;
    width: 75%;
    text-align: center;
    font-size: 18px;
    opacity: 0;
    visibility: hidden;
    transition: all ease-in-out .3s
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .sidebar-search-input {
        padding: 0 10px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .sidebar-search-input {
        padding: 0 10px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .sidebar-search-input {
        padding: 0 10px
    }
}

@media only screen and (max-width:767px) {
    .sidebar-search-input {
        padding: 0 10px;
        width: 100%
    }
}

.sidebar-search-input form .form-search {
    position: relative
}

.sidebar-search-input form .form-search input {
    padding: 10px 0;
    border: 0;
    border-radius: 0;
    border-bottom: 5px solid transparent;
    background-color: transparent;
    font-size: 200px;
    width: 100%;
    height: auto;
    color: #fff;
    transform: scale3d(0, 1, 1);
    transform-origin: 0 50%;
    transition: transform .3s
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .sidebar-search-input form .form-search input {
        font-size: 150px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .sidebar-search-input form .form-search input {
        font-size: 120px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .sidebar-search-input form .form-search input {
        font-size: 80px
    }
}

@media only screen and (max-width:767px) {
    .sidebar-search-input form .form-search input {
        font-size: 50px
    }
}

.sidebar-search-input form .form-search input:-ms-input-placeholder,
.sidebar-search-input form .form-search input::-moz-placeholder,
.sidebar-search-input form .form-search input::-webkit-input-placeholder,
.sidebar-search-input form .form-search input::placeholder {
    color: #fff
}

.sidebar-search-input form .form-search button {
    background-color: transparent;
    border: medium none;
    color: #fff;
    font-size: 30px;
    padding: 0;
    position: absolute;
    right: 0;
    bottom: 10px;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: all .2s ease 0s
}

.sidebar-search-input p {
    font-size: 90%;
    font-weight: 700;
    display: block;
    padding: 11px 0;
    text-align: right;
    opacity: 0;
    line-height: 1.6;
    color: #fff;
    transform: translate3d(0, 50px, 0);
    transition: opacity .4s, transform .4s
}

@media only screen and (max-width:767px) {
    .sidebar-search-input p {
        font-size: 14px
    }
}

.main-search-active.inside {
    opacity: 1;
    visibility: visible;
    z-index: 999
}

.main-search-active.inside .sidebar-search-input {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%) scale(1)
}

.main-search-active.inside .sidebar-search-input input {
    transform: scale3d(1, 1, 1);
    transition: .5s ease-out .3s;
    border-bottom-color: #fff
}

.main-search-active.inside .sidebar-search-input p {
    opacity: 1;
    transform: translate3d(0, 0, 0)
}

.site-main-menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: center
}

.site-main-menu>ul {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding-left: 0;
    list-style: none
}

.site-main-menu>ul>li {
    position: relative
}

.site-main-menu>ul>li>a {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.375;
    display: block;
    padding: 20px 15px;
    color: #fff
}

.site-main-menu>ul>li>a .menu-text {
    display: flex;
    align-items: center;
}

.site-main-menu>ul>li .menu-toggle {
    display: none
}
.menu-text  {
    color: white;

}
.menu-text i {
    font-size: .5rem;
    padding-left: .5rem;

}

.link_item:after{ 
    content: "";
    width: 0;
    height: 2px;
    background-color: rgb(0, 0, 0);
    position: absolute;
    bottom: 0;
    left: 0;
    transition: all .2s ease-in-out;
    will-change: width;
    
}

.link_item:hover:after{
    background-color: var(--primary);
    width: 100%;
    right: 0;
}
.sub-link_item{
    border: 1px solid black;
}
.sub-link_item:hover{
    border: 1px solid #3f5054
}
.sub-link_item:before{ 
    content: "";
    height: 0;
    width: 5px;
    background-color: rgb(0, 0, 0);
    position: absolute;
    top: 0;
    left: 0;
    transition: all .1s ease-in-out;
    will-change: height;
    
}

.sub-link_item:hover:before{
    background-color: var(--primary);
    height: 100%;
    bottom: 0;
}
.site-main-menu>ul>li:hover>a {
    color: var(--primary)
}

.site-main-menu>ul>li:hover .mega-menu,
.site-main-menu>ul>li:hover>.sub-menu {
    visibility: visible;
    margin-top: 2rem;
    opacity: 1
}

.site-main-menu .mega-menu,
.site-main-menu .sub-menu {
    position: absolute;
    z-index: 999;
    top: 100%;
    left: 0;
    visibility: hidden;
    width: 240px;
    margin-top: 20px;
    margin-bottom: 0;
    padding: 18px 0;
    list-style: none;
    transition: all .4s ease .2s;
    opacity: 0;
    border-radius: 10px;
    background-color: black;
}

.site-main-menu .mega-menu::before,
.site-main-menu .sub-menu::before {
    content: "";
    position: absolute;
    top: -10px;
    left: 40px;
    text-align: center;
    margin: 0 auto;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 7.5px 10px 7.5px;
    border-color: transparent transparent #fff transparent
}

.site-main-menu .mega-menu li,
.site-main-menu .sub-menu li {
    position: relative
}

.site-main-menu .mega-menu li a,
.site-main-menu .sub-menu li a {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.375;
    display: block;
    padding: 8px 30px;
    white-space: nowrap;
    color: #212121
}

.site-main-menu .mega-menu li a .menu-text,
.site-main-menu .sub-menu li a .menu-text {
    display: flex;
    align-items: center
}

.site-main-menu .mega-menu li .menu-toggle,
.site-main-menu .sub-menu li .menu-toggle {
    display: none
}

.site-main-menu .mega-menu li.has-children>a .menu-text::after,
.site-main-menu .sub-menu li.has-children>a .menu-text::after {
    font-family: "Font Awesome 5 Pro";
    font-size: 8px;
    font-weight: 900;
    margin-left: auto;
    content: ""
}

.site-main-menu .mega-menu li.active>a,
.site-main-menu .mega-menu li:hover>a,
.site-main-menu .sub-menu li.active>a,
.site-main-menu .sub-menu li:hover>a {
    color: #111
}

.site-main-menu .mega-menu li:hover>.sub-menu,
.site-main-menu .sub-menu li:hover>.sub-menu {
    visibility: visible;
    margin-top: 0;
    opacity: 1
}

.site-main-menu .mega-menu .sub-menu,
.site-main-menu .sub-menu .sub-menu {
    top: -18px;
    left: 100%
}

.site-main-menu .mega-menu .sub-menu::before,
.site-main-menu .sub-menu .sub-menu::before {
    display: none
}

.site-main-menu .mega-menu {
    left: 0;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    padding: 30px 15px 34px;
    list-style: none
}

.site-main-menu .mega-menu>li {
    flex: 0 0 25%;
    width: 25%;
    padding: 0 15px
}

.site-main-menu .mega-menu>li.menu-item-50 {
    flex: 0 0 50%;
    width: 50%;
    padding: 0 15px
}

.site-main-menu .mega-menu>li>ul {
    padding-left: 0;
    list-style: none;
    margin: 0
}

.site-main-menu .mega-menu>li>ul>li>a {
    font-size: 15px;
    line-height: 1.78;
    font-weight: 500;
    padding: 8px 0
}

.site-main-menu .mega-menu>li>ul>li>a .badge {
    background-color: transparent;
    background-image: linear-gradient(45deg, #fe378c 0, #fe5b34 100%);
    display: inline-block;
    border-radius: 2px;
    padding: 4px 8px 3px;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin: 0 0 0 7px
}

.site-main-menu .mega-menu>li>ul>li>a .badge.primary {
    background-image: none;
    background-color: var(--primary) !important
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .site-main-menu.laptop-space>ul>li>a {
        padding-right: 9px;
        padding-left: 9px
    }
}

.site-main-menu.menu-hover-1>ul>li>a .menu-text {
    position: relative
}

.site-main-menu.menu-hover-1>ul>li>a .menu-text::before {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 0;
    height: 1px;
    content: "";
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    background-color: var(--primary)
}

.site-main-menu.menu-hover-1>ul>li:hover>a .menu-text::before {
    left: 0;
    width: 100%
}

.header-light .site-main-menu>ul>li>a {
    color: #fff
}

.header-light .site-main-menu>ul>li:hover>a {
    color: #fff
}

.header-light .site-main-menu.menu-hover-1>ul>li>a .menu-text::before {
    background-color: #fff
}

.header-orange .site-main-menu>ul>li>a {
    color: #212121
}

.header-orange .site-main-menu>ul>li:hover>a {
    color: #ef6f31
}

.header-orange .site-main-menu .sub-menu {
    border-bottom: 4px solid #ef6f31
}

.header-orange .site-main-menu .sub-menu li.active>a,
.header-orange .site-main-menu .sub-menu li:hover>a {
    color: #ef6f31
}

.header-orange .site-main-menu .mega-menu {
    border-bottom: 4px solid #ef6f31
}

.header-orange .site-main-menu .mega-menu li.active>a,
.header-orange .site-main-menu .mega-menu li:hover>a {
    color: #ef6f31
}

.header-orange .site-main-menu.menu-hover-1>ul>li>a .menu-text::before {
    background-color: #ef6f31
}

.header-fluid .site-main-menu .mega-menu,
.header-fluid-two .site-main-menu .mega-menu {
    width: 1170px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center
}

.header-left .site-main-menu .mega-menu {
    left: 150px;
    transform: translateX(0);
    text-align: center
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .header-left .site-main-menu .mega-menu {
        left: 20px
    }
}

.header-mobile-menu-toggle,
.mobile-menu-close {
    display: flex;
    padding: 0 10px
}

.header-mobile-menu-toggle .toggle,
.mobile-menu-close .toggle {
    display: flex;
    flex-direction: column;
    padding: 0;
    border: none;
    background-color: transparent
}

.header-mobile-menu-toggle .toggle i,
.mobile-menu-close .toggle i {
    position: relative;
    display: block;
    overflow: hidden;
    width: 24px;
    height: 2px
}

.header-mobile-menu-toggle .toggle i+i,
.mobile-menu-close .toggle i+i {
    margin-top: 6px
}

.header-mobile-menu-toggle .toggle i::after,
.header-mobile-menu-toggle .toggle i::before,
.mobile-menu-close .toggle i::after,
.mobile-menu-close .toggle i::before {
    position: absolute;
    top: 0;
    left: 0;
    flex: 1 0 100%;
    width: 100%;
    height: 100%;
    content: "";
    background-color: #fff
}

.header-mobile-menu-toggle .toggle i.icon-bottom::before,
.header-mobile-menu-toggle .toggle i.icon-top::before,
.mobile-menu-close .toggle i.icon-bottom::before,
.mobile-menu-close .toggle i.icon-top::before {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .2s;
    transform: scaleX(1) translateZ(0);
    transform-origin: right
}

.header-mobile-menu-toggle .toggle i.icon-bottom::after,
.header-mobile-menu-toggle .toggle i.icon-top::after,
.mobile-menu-close .toggle i.icon-bottom::after,
.mobile-menu-close .toggle i.icon-top::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0);
    transform-origin: left
}

.header-mobile-menu-toggle .toggle i.icon-middle::before,
.mobile-menu-close .toggle i.icon-middle::before {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .2s;
    transform: scaleX(1) translateZ(0);
    transform-origin: left;
    background-color: var(--primary)
}

.header-mobile-menu-toggle .toggle i.icon-middle::after,
.mobile-menu-close .toggle i.icon-middle::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0);
    transform-origin: right;
    background-color: var(--primary)
}

.header-mobile-menu-toggle .toggle:hover i::after,
.header-mobile-menu-toggle .toggle:hover i::before,
.mobile-menu-close .toggle:hover i::after,
.mobile-menu-close .toggle:hover i::before {
    background-color: #fff
}

.header-mobile-menu-toggle .toggle:hover i.icon-bottom::before,
.header-mobile-menu-toggle .toggle:hover i.icon-top::before,
.mobile-menu-close .toggle:hover i.icon-bottom::before,
.mobile-menu-close .toggle:hover i.icon-top::before {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0)
}

.header-mobile-menu-toggle .toggle:hover i.icon-bottom::after,
.header-mobile-menu-toggle .toggle:hover i.icon-top::after,
.mobile-menu-close .toggle:hover i.icon-bottom::after,
.mobile-menu-close .toggle:hover i.icon-top::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .2s;
    transform: scaleX(1) translateZ(0)
}

.header-mobile-menu-toggle .toggle:hover i.icon-middle::before,
.mobile-menu-close .toggle:hover i.icon-middle::before {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1);
    transform: scaleX(0) translateZ(0);
    background-color: var(--primary)
}

.header-mobile-menu-toggle .toggle:hover i.icon-middle::after,
.mobile-menu-close .toggle:hover i.icon-middle::after {
    transition: transform .6s cubic-bezier(.165, .84, .44, 1) .2s;
    transform: scaleX(1) translateZ(0);
    background-color: var(--primary)
}

@media only screen and (max-width:479px) {

    .header-mobile-menu-toggle,
    .mobile-menu-close {
        padding-right: 8px;
        padding-left: 8px
    }
}

.header-light .header-mobile-menu-toggle .toggle i::after,
.header-light .header-mobile-menu-toggle .toggle i::before,
.header-light .mobile-menu-close .toggle i::after,
.header-light .mobile-menu-close .toggle i::before {
    background-color: #fff
}

.header-light .header-mobile-menu-toggle .toggle:hover i::after,
.header-light .header-mobile-menu-toggle .toggle:hover i::before,
.header-light .mobile-menu-close .toggle:hover i::after,
.header-light .mobile-menu-close .toggle:hover i::before {
    background-color: #fff
}

.site-main-mobile-menu {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    visibility: hidden;
    width: 100%;
    height: 100%;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    opacity: 0;
    background: rgba(0, 0, 0, .7)
}

.site-main-mobile-menu-inner {
    position: relative;
    z-index: 9;
    float: right;
    width: 360px;
    height: 100%;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    transform: translateX(100%);
    background-repeat: no-repeat;
    background-attachment: scroll;
    background-position: top center;
    background-size: cover
}

@media only screen and (max-width:479px) {
    .site-main-mobile-menu-inner {
        width: 300px
    }
}

.site-main-mobile-menu-inner::before {
    position: absolute;
    z-index: -1;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    content: "";
    background-color: #000
}

#page {
    position: relative;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.mobile-menu-open {
    overflow: hidden
}

.mobile-menu-open #page {
    transform: translateX(-360px)
}

.mobile-menu-open .site-main-mobile-menu {
    visibility: visible;
    opacity: 1
}

.mobile-menu-open .site-main-mobile-menu-inner {
    transform: translateX(0)
}

.mobile-menu-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
    height: 80px;
    padding: 0 15px 0 30px;
    background-color: #000
}

.mobile-menu-logo a {
    width: 150px
}

.mobile-menu-close {
    padding: 0
}

.mobile-menu-close .toggle {
    position: relative;
    width: 40px;
    height: 40px
}

.mobile-menu-close .toggle i {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 29px;
    height: 2px;
    margin: 0 !important;
    transform-origin: center
}

.mobile-menu-close .toggle i.icon-top {
    transform: translate(-50%, -50%) rotate(45deg)
}

.mobile-menu-close .toggle i.icon-bottom {
    transform: translate(-50%, -50%) rotate(-45deg)
}

.mobile-menu-close .toggle:hover i::after,
.mobile-menu-close .toggle:hover i::before {
    background-color: #fff
}

.mobile-menu-content {
    overflow-y: auto;
    height: calc(100% - 80px);
    padding: 20px 30px 100px
}

.site-mobile-menu>ul {
    margin: 0;
    padding-left: 0;
    list-style: none
}

.site-mobile-menu>ul>li {
    position: relative !important
}

.site-mobile-menu>ul>li+li>a {
    border-top: 1px solid rgba(255, 255, 255, .15)
}

.site-mobile-menu>ul>li>a {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    display: block;
    padding-top: 19px;
    padding-right: 0;
    padding-bottom: 19px;
    padding-left: 0;
    color: #fff;
    border-bottom: 1px solid transparent
}

.site-mobile-menu>ul>li .menu-toggle {
    position: absolute;
    top: 11px;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    cursor: pointer;
    color: #fff;
    border-radius: 50%;
    background-color: transparent
}

.site-mobile-menu>ul>li .menu-toggle i {
    font-size: 18px;
    line-height: 1;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.site-mobile-menu>ul>li .menu-toggle:hover {
    background-color: rgba(255, 255, 255, .2)
}

.site-mobile-menu>ul>li.open>a {
    border-bottom-color: rgba(255, 255, 255, .15)
}

.site-mobile-menu>ul>li.open>.menu-toggle {
    background-color: rgba(255, 255, 255, .2)
}

.site-mobile-menu>ul>li.open>.menu-toggle i {
    transform: rotateX(180deg)
}

.site-mobile-menu .mega-menu,
.site-mobile-menu .sub-menu {
    display: none;
    margin: 14px 0;
    padding-left: 0;
    list-style: none
}

.site-mobile-menu .mega-menu li,
.site-mobile-menu .sub-menu li {
    position: relative
}

.site-mobile-menu .mega-menu li>a,
.site-mobile-menu .sub-menu li>a {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.5;
    padding-top: 10px;
    padding-right: 0;
    padding-bottom: 10px;
    padding-left: 0;
    color: rgba(255, 255, 255, .7)
}

.site-mobile-menu .mega-menu li>a:hover,
.site-mobile-menu .sub-menu li>a:hover {
    color: #fff
}

.site-mobile-menu .mega-menu li .menu-toggle,
.site-mobile-menu .sub-menu li .menu-toggle {
    top: 1px
}

.site-mobile-menu .mega-menu li.open>a,
.site-mobile-menu .sub-menu li.open>a {
    color: #fff
}

.site-mobile-menu .mega-menu li.open>.menu-toggle,
.site-mobile-menu .sub-menu li.open>.menu-toggle {
    background-color: rgba(255, 255, 255, .2)
}

.site-mobile-menu .mega-menu li.open>.menu-toggle i,
.site-mobile-menu .sub-menu li.open>.menu-toggle i {
    transform: rotateX(180deg)
}

.site-mobile-menu .mega-menu ul,
.site-mobile-menu .sub-menu ul {
    list-style: none;
    margin: 0;
    padding-left: 0;
    list-style: none
}

.site-mobile-menu .mega-menu ul li a .badge,
.site-mobile-menu .sub-menu ul li a .badge {
    background-color: transparent;
    background-image: linear-gradient(45deg, #fe378c 0, #fe5b34 100%);
    display: inline-block;
    border-radius: 2px;
    padding: 4px 8px 3px;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin: 0 0 0 7px
}

.site-mobile-menu .mega-menu ul li a .badge.primary,
.site-mobile-menu .sub-menu ul li a .badge.primary {
    background-image: none;
    background-color: var(--primary) !important
}

.site-mobile-menu .mega-menu .sub-menu,
.site-mobile-menu .sub-menu .sub-menu {
    padding-left: 15px
}

.intro-section {
    position: relative;
    z-index: 9;
    display: flex;
    align-items: center;
    height: 100vh;
    padding: 50px 0
}

.intro-section .container {
    z-index: 9
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .intro-section {
        height: 550px
    }
}

@media only screen and (max-width:767px) {
    .intro-section {
        height: 500px
    }
}

.intro-content {
    max-width: 760px
}

.intro-content .title {
    font-size: 72px;
    line-height: 1.2;
    color: #fff;
    margin-bottom: 40px
}

.intro-content .desc {
    max-width: 700px
}

.intro-content .desc p {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.67;
    color: #fff
}

.intro-content .btn {
    margin: 0 5px;
    margin-top: 60px
}

@media only screen and (min-width:768px) and (max-width:991px),
only screen and (max-width:767px) {
    .intro-content .title {
        font-size: 36px;
        margin-bottom: 20px
    }

    .intro-content .desc p {
        font-size: 16px
    }

    .intro-content .btn {
        margin-top: 30px
    }
}

@media only screen and (max-width:479px) {
    .intro-content .title {
        font-size: 30px
    }

    .intro-content .desc p {
        font-size: 14px
    }
}

.intro-content>* {
    animation-duration: 1s;
    animation-fill-mode: both;
    animation-name: fadeOutUp
}

.intro-slider .main-slider-nav {
    cursor: pointer;
    background: rgba(0, 0, 0, .25);
    width: 100px;
    height: 100px;
    line-height: 100px;
    display: block;
    text-align: center;
    color: #fff;
    opacity: 0;
    visibility: hidden;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.intro-slider .main-slider-nav::after {
    display: none
}

.intro-slider .main-slider-nav i {
    font-size: 40px;
    line-height: 1;
    vertical-align: middle
}

.intro-slider .main-slider-nav:hover {
    color: var(--primary)
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .intro-slider .main-slider-nav {
        width: 80px;
        height: 80px;
        line-height: 80px
    }

    .intro-slider .main-slider-nav i {
        font-size: 30px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .intro-slider .main-slider-nav {
        width: 60px;
        height: 60px;
        line-height: 60px
    }

    .intro-slider .main-slider-nav i {
        font-size: 24px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .intro-slider .main-slider-nav {
        width: 60px;
        height: 60px;
        line-height: 60px
    }

    .intro-slider .main-slider-nav i {
        font-size: 24px
    }
}

@media only screen and (max-width:767px) {
    .intro-slider .main-slider-nav {
        width: 50px;
        height: 50px;
        line-height: 50px
    }

    .intro-slider .main-slider-nav i {
        font-size: 24px
    }
}

.intro-slider .home-slider-prev {
    left: 30px
}

.intro-slider .home-slider-next {
    right: 30px
}

.intro-slider .home-slider-next::after {
    display: none
}

.intro-slider:hover .main-slider-nav {
    opacity: 1;
    visibility: visible
}

.swiper-slide-active .intro-content>* {
    animation-name: fadeInUp
}

.swiper-slide-active .intro-content>:nth-child(1) {
    animation-delay: .5s
}

.swiper-slide-active .intro-content>:nth-child(2) {
    animation-delay: 1s
}

.swiper-slide-active .intro-content>:nth-child(3) {
    animation-delay: 1.5s
}

.swiper-slide-active .intro-content>:nth-child(4) {
    animation-delay: 2s
}

.swiper-slide-active .intro-content>:nth-child(5) {
    animation-delay: 2.5s
}

.swiper-slide-active .intro-content>:nth-child(6) {
    animation-delay: 3s
}

.intro-content-two {
    max-width: 760px;
    margin: 0 auto
}

.intro-content-two .title {
    font-size: 72px;
    line-height: 1.2;
    color: #fff;
    margin-bottom: 40px
}

.intro-content-two .desc {
    max-width: 700px;
    margin: 0 auto
}

.intro-content-two .desc p {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.67;
    color: #fff
}

.intro-content-two .btn {
    margin: 0 5px;
    margin-top: 60px
}

@media only screen and (min-width:768px) and (max-width:991px),
only screen and (max-width:767px) {
    .intro-content-two .title {
        font-size: 36px;
        margin-bottom: 20px
    }

    .intro-content-two .desc p {
        font-size: 16px
    }

    .intro-content-two .btn {
        margin-top: 30px
    }
}

@media only screen and (max-width:479px) {
    .intro-content-two .title {
        font-size: 30px
    }

    .intro-content-two .desc p {
        font-size: 14px
    }
}

.ah-headline.rotate-3 i {
    font-style: normal !important
}

.testimonial {
    height: auto;
    background: #fff
}

.owl-stage {
    display: flex;
    align-items: center;
    vertical-align: center;
    height: 100%
}

.about-image-area {
    position: relative;
    z-index: 9;
    height: 100%;
    margin-right: 45px
}

.about-image-area.right-0 .about-image {
    right: 0
}

.about-image-area .about-image {
    position: relative;
    top: 0;
    right: 45px;
    float: right;
    z-index: 9
}

.about-image-area .about-image.right-n50 {
    right: -50px !important
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .about-image-area .about-image.right-n50 {
        right: 0 !important
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .about-image-area .about-image.right-n50 {
        right: 0 !important
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-image-area .about-image.right-n50 {
        right: 0 !important
    }
}

@media only screen and (max-width:767px) {
    .about-image-area .about-image.right-n50 {
        right: 0 !important
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .about-image-area .about-image {
        right: 0
    }
}

@media only screen and (max-width:767px) {
    .about-image-area .about-image {
        right: 0
    }
}

@media only screen and (max-width:479px) {
    .about-image-area .about-image {
        right: 0;
        width: 250px
    }
}

.about-image-area .about-image:nth-child(2) {
    position: absolute;
    top: 70px;
    left: 0;
    z-index: 8;
    float: left;
    text-align: left
}

.about-image-area .about-image img {
    border-radius: 5px;
    box-shadow: 0 .25rem .5rem rgba(0, 0, 0, .05), 0 1.5rem 2.2rem rgba(0, 0, 0, .1);
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.about-image-area .about-image:hover img {
    box-shadow: 0 .5rem 1.2rem rgba(0, 0, 0, .1), 0 2rem 3rem rgba(0, 0, 0, .15)
}

.about-image-area .shape {
    position: absolute;
    z-index: 1
}

.about-image-area .shape-1 {
    right: 0;
    top: 50px;
    z-index: -1
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .about-image-area {
        margin-right: 0
    }

    .about-image-area .shape {
        position: absolute;
        z-index: -1
    }

    .about-image-area .shape-1 {
        right: 0;
        top: 50px;
        z-index: -1
    }

    .about-image-area .shape-1 span {
        width: 200px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-image-area {
        margin-right: 0
    }

    .about-image-area .shape {
        position: absolute;
        z-index: -1
    }

    .about-image-area .shape-1 {
        right: 0;
        top: 50px;
        z-index: -1
    }

    .about-image-area .shape-1 span {
        width: 200px
    }
}

@media only screen and (max-width:767px) {
    .about-image-area {
        margin-right: 0
    }

    .about-image-area .shape {
        position: absolute;
        z-index: -1
    }

    .about-image-area .shape-1 {
        right: 0;
        top: 50px;
        z-index: -1
    }

    .about-image-area .shape-1 span {
        width: 200px
    }
}

.about-content-area p {
    max-width: 420px;
    margin-bottom: 0
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-content-area p {
        max-width: 100%
    }
}

@media only screen and (max-width:767px) {
    .about-content-area p {
        max-width: 100%
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-content-area {
        margin-top: 150px
    }
}

@media only screen and (max-width:767px) {
    .about-content-area {
        margin-top: 150px
    }
}

.about-funfact .number {
    font-size: 41px;
    line-height: 1;
    color: var(--primary);
    margin-bottom: 15px
}

.about-funfact .text {
    font-size: 20px;
    line-height: 1.5;
    margin-bottom: 15px
}

.about-shape-animation {
    position: relative
}

.about-shape-animation .shape {
    position: absolute;
    z-index: 1
}

.about-shape-animation .shape-1 {
    top: auto;
    bottom: 0;
    right: -35px;
    z-index: -1
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .about-shape-animation .shape-1 {
        bottom: -60px;
        right: 0;
        z-index: -1
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .about-shape-animation .shape-1 {
        bottom: -60px;
        right: 0;
        z-index: -1
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-shape-animation .shape-1 {
        bottom: -60px;
        right: 0;
        z-index: -1
    }
}

@media only screen and (max-width:767px) {
    .about-shape-animation .shape-1 {
        bottom: -60px;
        right: 0;
        z-index: -1
    }
}

.about-content-full .title {
    font-size: 42px;
    font-weight: 600;
    margin-bottom: 25px
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .about-content-full .title {
        font-size: 26px;
        line-height: 32px
    }
}

@media only screen and (max-width:767px) {
    .about-content-full .title {
        font-size: 24px;
        line-height: 30px
    }
}

.about-content-full p {
    margin-bottom: 20px
}

.skill- {
    padding-bottom: 190px
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .skill- {
        padding-bottom: 150px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .skill- {
        padding-bottom: 200px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .skill- {
        padding-bottom: 50px
    }
}

@media only screen and (max-width:767px) {
    .skill- {
        padding-bottom: 30px
    }
}

.video-section {
    position: relative;
    z-index: 9
}

.video-section .shape {
    position: absolute;
    z-index: -1
}

.video-section .shape-1 {
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    margin: 0 auto
}

@media only screen and (max-width:767px) {
    .video-section .shape-1 {
        width: 250px
    }
}

.agency-list {
    list-style: none;
    padding-left: 0;
    margin-bottom: 35px
}

.agency-list li {
    display: flex;
    align-items: center
}

.agency-list li+li {
    margin-top: 10px
}

.agency-list li .icon {
    margin-right: 19px;
    font-size: 15px;
    color: var(--primary)
}

.video-popup-area {
    position: relative;
    z-index: 9
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .video-popup-area {
        margin-top: 50px
    }
}

@media only screen and (max-width:767px) {
    .video-popup-area {
        margin-top: 50px
    }
}

.video-popup-area img {
    border-radius: 5px
}

.video-popup-area .shape {
    position: absolute;
    z-index: 1
}

.video-popup-area .shape-1 {
    left: -40px;
    bottom: -60px;
    z-index: -1
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .video-popup-area .shape-1 {
        left: 0;
        bottom: -20px;
        z-index: -1
    }
}

@media only screen and (max-width:767px) {
    .video-popup-area .shape-1 {
        left: 0;
        bottom: -20px;
        z-index: -1
    }
}

.skill-video {
    position: relative;
    z-index: 9;
    display: block;
    overflow: hidden;
    width: 100%;
    margin: auto;
    border-radius: 5px
}

.skill-video .image {
    width: 100%;
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.skill-video .icon {
    position: absolute;
    z-index: 9;
    top: 50%;
    left: 50%;
    width: 90px;
    height: 90px;
    line-height: 90px;
    background-color: rgba(255, 255, 255, .8);
    transform: translate(-50%, -50%);
    text-align: center;
    border-radius: 50%
}

.skill-video .icon i {
    font-size: 24px;
    color: var(--primary)
}

.skill-video:hover .image {
    transform: scale(1.1)
}

.play-btn {
    width: 90px;
    height: 90px;
    line-height: 90px;
    background-color: rgba(255, 255, 255, .8);
    text-align: center;
    border-radius: 50%;
    margin: auto;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.play-btn i {
    font-size: 24px;
    color: var(--primary)
}

.play-btn:hover {
    transform: scale(1.04)
}

.skill-image-area {
    margin-right: 0
}

.skill-image-area .shape {
    position: absolute;
    z-index: 1
}

.skill-image-area .shape-1 {
    top: auto;
    bottom: 60px;
    right: -35px;
    z-index: -1
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .skill-image-area .shape-1 {
        top: auto;
        bottom: 60px;
        right: 0
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .skill-image-area .shape-1 {
        top: auto;
        bottom: 40px;
        right: 0
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .skill-image-area .shape-1 {
        top: auto;
        bottom: 30px;
        right: 0
    }
}

@media only screen and (max-width:767px) {
    .skill-image-area .shape-1 {
        top: auto;
        bottom: 30px;
        right: 0
    }
}

.progress-bar--one .progress-charts {
    margin-bottom: 20px;
    padding-bottom: 20px;
    overflow: hidden
}

.progress-charts .heading {
    font-size: 16px;
    line-height: 23px;
    color: #000;
    margin-bottom: 12px;
    font-weight: 400
}

.progress-charts .progress {
    height: 4px;
    overflow: visible;
    font-size: 14px;
    background-color: #212121;
    border-radius: 0
}

.progress-charts .progress .progress-bar {
    overflow: visible;
    position: relative;
    background: var(--primary);
    color: var(--primary)
}

.progress-charts .progress .progress-bar::after,
.progress-charts .progress .progress-bar::before {
    content: "";
    position: absolute;
    right: -4px;
    top: 50%;
    border-radius: 50%;
    transform: translate(50%, -50%)
}

.progress-charts .progress .progress-bar::after {
    height: 13px;
    width: 13px;
    border: 3px solid currentColor;
    background-color: #fff
}

.progress-charts .progress .progress-bar::before {
    height: 28px;
    width: 28px;
    border: 1px solid currentColor;
    opacity: .3
}

.progress-charts .progress .progress-bar span.percent-label {
    position: absolute;
    right: -45px;
    font-size: 14px;
    font-weight: 500;
    top: -40px;
    color: #2e3280;
    line-height: 2
}

.progress-charts .progress .progress-bar.gradient-1 {
    color: #61fded;
    background-color: #0d8abc;
    background-image: linear-gradient(-224deg, #0d8abc 0, #61fded 100%)
}

.progress-charts .progress .progress-bar.gradient-2 {
    color: #eece90;
    background-color: #d45529;
    background-image: linear-gradient(-224deg, #d45529 0, #eece90 100%)
}

.progress-charts .progress .progress-bar.gradient-3 {
    color: #5c51ff;
    background-color: #f646a9;
    background-image: linear-gradient(-224deg, #f646a9 0, #5c51ff 100%)
}

.progress-charts .progress .progress-bar.gradient-4 {
    color: #e5529a;
    background-color: #e77654;
    background-image: linear-gradient(-224deg, #e77654 0, #e5529a 100%)
}

.success- {
    padding-bottom: 180px
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .success- {
        padding-bottom: 140px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .success- {
        padding-bottom: 140px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .success- {
        padding-bottom: 50px
    }
}

@media only screen and (max-width:767px) {
    .success- {
        padding-bottom: 30px
    }
}

.success-image-wrap {
    position: relative;
    z-index: 9;
    height: 100%
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .success-image-wrap {
        margin-top: 50px
    }
}

@media only screen and (max-width:767px) {
    .success-image-wrap {
        margin-top: 50px
    }
}

.success-image-wrap .success-image {
    position: relative;
    top: 0;
    left: 0;
    float: left;
    z-index: 9
}

@media only screen and (max-width:479px) {
    .success-image-wrap .success-image {
        width: 250px
    }
}

.success-image-wrap .success-image:nth-child(2) {
    position: absolute;
    top: 70px;
    left: auto;
    right: 0;
    z-index: 8;
    float: right;
    text-align: right
}

.success-image-wrap .success-image img {
    border-radius: 5px;
    box-shadow: 0 .25rem .5rem rgba(0, 0, 0, .05), 0 1.5rem 2.2rem rgba(0, 0, 0, .1);
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.success-image-wrap .success-image:hover img {
    box-shadow: 0 .5rem 1.2rem rgba(0, 0, 0, .1), 0 2rem 3rem rgba(0, 0, 0, .15)
}

.success-image-wrap .shape {
    position: absolute;
    z-index: 1
}

.success-image-wrap .shape-1 {
    left: -40px;
    bottom: -60px;
    z-index: -1
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .success-image-wrap .shape-1 {
        left: 0;
        bottom: -30px;
        z-index: -1
    }
}

@media only screen and (max-width:767px) {
    .success-image-wrap .shape-1 {
        left: 0;
        bottom: -20px;
        z-index: -1
    }
}

.messonry-button button {
    padding: 0;
    border: 0 none;
    position: relative;
    background-color: transparent;
    font-family: Poppins, sans-serif
}

.messonry-button button span {
    position: relative;
    display: inline-block;
    padding: 5px 15px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .messonry-button button span {
        padding: 5px 10px
    }
}

@media only screen and (max-width:767px) {
    .messonry-button button span {
        padding: 5px 10px
    }
}

@media only screen and (max-width:479px) {
    .messonry-button button span {
        padding: 10px 10px
    }
}

.messonry-button button span.filter-text {
    font-weight: 400;
    line-height: 1;
    font-size: 16px;
    transition: all .3s cubic-bezier(.645, .045, .355, 1)
}

.messonry-button button::before {
    content: "";
    position: absolute;
    bottom: -15px;
    left: 0;
    right: 0;
    width: 7px;
    height: 7px;
    background: var(--primary);
    text-align: center;
    margin: auto;
    border-radius: 50%;
    opacity: 0;
    visibility: hidden;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

@media only screen and (max-width:479px) {
    .messonry-button button::before {
        bottom: -8px
    }
}

.messonry-button button:hover span.filter-text {
    color: var(--primary)
}

.messonry-button button:hover::before {
    opacity: 1;
    visibility: visible
}

.messonry-button button.is-checked span.filter-text {
    color: var(--primary)
}

.messonry-button button.is-checked::before {
    opacity: 1;
    visibility: visible
}

.single-portfolio {
    display: block;
    position: relative;
    overflow: hidden
}

.single-portfolio .thumbnail {
    position: relative
}

.single-portfolio .thumbnail::before {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    transition: all .5s ease 0s;
    opacity: 0;
    background-color: rgba(18, 146, 238, .5)
}

.single-portfolio .thumbnail img {
    width: 100%
}

.single-portfolio .content {
    position: absolute;
    z-index: 9;
    top: 70%;
    left: 0;
    width: 100%;
    padding: 20px;
    transition: all .5s ease 0s;
    text-align: center;
    opacity: 0
}

.single-portfolio .content .title {
    font-size: 20px;
    line-height: 1;
    color: #fff;
    font-weight: 400;
    margin-bottom: 0
}

.single-portfolio .content .title a {
    font-family: Poppins, sans-serif
}

.single-portfolio .content .title a img {
    margin-left: 10px;
    vertical-align: baseline
}

.single-portfolio .content .title a:hover {
    color: #fff
}

.single-portfolio:hover .thumbnail::before {
    opacity: 1
}

.single-portfolio:hover .content {
    transform: translateY(-70%);
    opacity: 1
}

.work {
    overflow: hidden;
    height: 100%;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.work .thumbnail {
    position: relative;
    overflow: hidden;
    border-radius: 5px 5px 0 0
}

.work .thumbnail .image {
    display: block
}

.work .thumbnail .image img {
    width: 100%;
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.work .info {
    position: relative;
    padding: 35px 30px;
    border: 1px solid #e7e7e7;
    border-top: 0;
    border-radius: 0 0 5px 5px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .work .info {
        padding: 25px 20px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .work .info {
        padding: 25px 22px
    }
}

@media only screen and (max-width:479px) {
    .work .info {
        padding: 25px 20px
    }
}

.work .info .title {
    font-size: 20px;
    line-height: 30px;
    margin: 0
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .work .info .title {
        font-size: 16px;
        line-height: 24px
    }
}

@media only screen and (max-width:479px) {
    .work .info .title {
        font-size: 17px;
        line-height: 24px
    }
}

.work .info .desc {
    margin-top: 15px
}

.work .info>a {
    font-family: Poppins, sans-serif;
    color: #212121;
    position: relative;
    display: inline-block
}

.work .info>a:hover {
    color: var(--primary)
}

.work:hover .thumbnail .image img {
    transform: scale(1.1)
}

.info-contacto {
    padding-left: 1.5rem
}

.contact-section {
    position: relative
}

.contact-section .shape {
    position: absolute;
    z-index: -1
}

.contact-section .shape-1 {
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    margin: 0 auto
}

@media only screen and (max-width:767px) {
    .contact-section .shape-1 {
        width: 250px
    }
}

.contact-info {
    display: flex;
    align-items: flex-start;
    padding: 45px 30px 50px;
    border-radius: 5px;
    background-color: #fff;
    box-shadow: 0 0 40px rgba(51, 51, 51, .1);
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

@media only screen and (max-width:767px) {
    .contact-info {
        padding: 25px 30px 30px;
        flex-wrap: wrap
    }
}

.contact-info.info-light {
    padding: 25px 0;
    background-color: transparent;
    box-shadow: none;
    border-radius: 0;
    border-bottom: 1px solid #fff
}

.contact-info.info-light:last-child {
    border-bottom: 0 none;
    padding-bottom: 0
}

.contact-info.info-light .icon svg path {
    stroke: #fff
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-info.info-light .icon {
        margin-right: 20px
    }
}

@media only screen and (max-width:767px) {
    .contact-info.info-light .icon {
        margin-right: 15px
    }
}

@media only screen and (max-width:479px) {
    .contact-info.info-light .icon {
        margin-right: 0;
        margin-bottom: 15px
    }
}

.contact-info.info-light .info .title {
    color: #fff
}

.contact-info.info-light .info .info-text {
    color: #fff
}

.contact-info.info-light .info .info-text strong {
    color: #fff
}

.contact-info.ct-info-two {
    padding: 25px 0;
    background-color: transparent;
    box-shadow: none;
    border-radius: 0;
    border-bottom: 1px solid #e7e7e7
}

.contact-info.ct-info-two:last-child {
    border-bottom: 0 none;
    padding-bottom: 0
}

.contact-info.ct-info-two .icon svg path {
    stroke: var(--primary)
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-info.ct-info-two .icon {
        margin-right: 20px
    }
}

@media only screen and (max-width:767px) {
    .contact-info.ct-info-two .icon {
        margin-right: 15px
    }
}

@media only screen and (max-width:479px) {
    .contact-info.ct-info-two .icon {
        margin-right: 0;
        margin-bottom: 15px
    }
}

.contact-info .icon {
    margin-right: 40px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-info .icon {
        margin-right: 20px
    }
}

@media only screen and (max-width:767px) {
    .contact-info .icon {
        margin-right: 20px;
        margin-bottom: 20px
    }
}

@media only screen and (max-width:479px) {
    .contact-info .icon {
        margin-right: 30px;
        margin-bottom: 0
    }
}

.contact-info .icon svg {
    width: 50px
}

.contact-info .icon svg path {
    stroke: var(--primary)
}

.icon svg path {
    stroke: var(--primary)
}

.contact-info .info .title {
    font-size: 20px;
    line-height: 1;
    font-weight: 400;
    margin-bottom: 15px
}

.contact-info .info .info-text {
    font-size: 16px;
    display: block;
    line-height: 27px
}

.contact-info .info .info-text strong {
    color: #000
}

.contact-map-area iframe {
    width: 100%;
    height: 500px;
    border: 0 none
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-map-area iframe {
        height: 400px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .contact-map-area iframe {
        height: 350px
    }
}

@media only screen and (max-width:767px) {
    .contact-map-area iframe {
        height: 300px
    }
}

.contact-form-area {
    padding: 70px 90px;
    border-radius: 10px;
    background-color: #fff;
    position: relative
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-form-area {
        padding: 50px 30px
    }
}

@media only screen and (max-width:767px) {
    .contact-form-area {
        padding: 50px 40px
    }
}

@media only screen and (max-width:479px) {
    .contact-form-area {
        padding: 30px 20px
    }
}

.contact-form-area .shape {
    position: absolute;
    z-index: -1
}

.contact-form-area .shape-1 {
    top: auto;
    left: auto;
    bottom: -45px;
    right: -60px
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .contact-form-area .shape-1 {
        right: -5px
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .contact-form-area .shape-1 {
        right: -5px
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .contact-form-area .shape-1 {
        right: -5px
    }
}

@media only screen and (max-width:767px) {
    .contact-form-area .shape-1 {
        right: -5px
    }
}

.shape-animate {
    position: relative
}

.shape-animate .shape {
    position: absolute;
    z-index: -1
}

.shape-animate .shape-1 {
    bottom: -45px;
    right: -40px;
    text-align: center;
    margin: 0 auto
}

@media only screen and (min-width:1200px) and (max-width:1599px) {
    .shape-animate .shape-1 {
        bottom: -20px;
        right: 0
    }
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .shape-animate .shape-1 {
        bottom: -20px;
        right: 0
    }
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .shape-animate .shape-1 {
        display: none
    }
}

@media only screen and (max-width:767px) {
    .shape-animate .shape-1 {
        display: none
    }
}

.digital-marketing .title,
.portfolio-main-info .title {
    font-size: 42px;
    line-height: 1.3;
    margin-bottom: 0
}

@media only screen and (min-width:768px) and (max-width:991px) {

    .digital-marketing .title,
    .portfolio-main-info .title {
        font-size: 36px
    }
}

@media only screen and (max-width:767px) {

    .digital-marketing .title,
    .portfolio-main-info .title {
        font-size: 32px
    }
}

.work-details-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 62px 30px
}

.work-details-list .details-list label {
    color: #000;
    text-transform: capitalize;
    font-weight: 600;
    font-size: 18px;
    margin-bottom: 12px
}

.work-details-list .details-list span {
    color: #212121;
    font-weight: 500;
    line-height: 1.5;
    font-size: 16px;
    display: block
}

.work-details-list .details-list span a {
    color: #212121;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.work-details-list .details-list span a:hover {
    color: var(--primary)
}

.blog {
    overflow: hidden;
    height: 100%;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

.blog .thumbnail {
    position: relative;
    overflow: hidden
}

.blog .thumbnail .image {
    display: block
}

.blog .thumbnail .image img {
    width: 100%;
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.blog .info {
    position: relative;
    padding: 30px 0
}

.blog .info .title {
    font-size: 24px;
    line-height: 1.3;
    margin-bottom: 15px
}

@media only screen and (max-width:767px) {
    .blog .info .title {
        font-size: 18px;
        line-height: 1.3
    }
}

.blog .info .desc {
    margin-top: 10px
}

.blog .info .meta {
    font-size: 14px;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10px;
    padding-left: 0;
    list-style: none
}

.blog .info .meta li {
    margin-right: 28px
}

.blog .info .meta li:last-child {
    margin-right: 0
}

.blog .info .meta li i {
    margin-right: 10px
}

.blog:hover .thumbnail .image img {
    transform: scale(1.1)
}

.blog-3 {
    height: 100%;
    margin-bottom: 50px;
    padding-bottom: 50px;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    border-bottom: 1px solid #f3f3f3
}

.blog-3 .thumbnail {
    position: relative;
    overflow: hidden;
    border-radius: 5px
}

.blog-3 .thumbnail .image {
    display: block
}

.blog-3 .thumbnail .image img {
    width: 100%;
    transition: all 1.5s cubic-bezier(0, 0, .2, 1)
}

.blog-3 .info {
    position: relative;
    padding: 30px 0 0
}

.blog-3 .info .meta {
    font-size: 14px;
    line-height: 27px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-right: -28px;
    margin-bottom: 30px;
    padding-left: 0;
    list-style: none
}

.blog-3 .info .meta li {
    margin-right: 28px
}

.blog-3 .info .meta li i {
    color: var(--primary);
    margin-right: 10px
}

.blog-3 .info .meta li .avatar {
    width: 32px;
    height: 32px;
    margin-right: 8px;
    border-radius: 50%
}

.blog-3 .info .meta li a {
    display: flex;
    align-items: center
}

.blog-3 .info .title {
    font-size: 32px;
    line-height: 44px;
    font-weight: 600;
    margin: 0
}

.blog-3 .info .desc {
    margin-top: 30px
}

.blog-3 .info .desc strong {
    color: #000;
    font-family: 400
}

.blog-3 .info .desc .block-quote {
    border-left: 4px solid var(--primary);
    padding-left: 20px;
    margin: 50px 0 44px 48px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.78;
    max-width: 660px
}

@media only screen and (max-width:767px) {
    .blog-3 .info .desc .block-quote {
        margin: 25px 0 20px 0
    }
}

.blog-3 .info .entry-post-tags {
    display: flex
}

.blog-3 .info .entry-post-tags .tag-label {
    margin: 0 7px 0 0
}

.blog-3:hover .thumbnail .image img {
    transform: scale(1.1)
}

@media only screen and (max-width:767px) {
    .blog-3 .info .meta {
        margin-bottom: 15px
    }

    .blog-3 .info .title {
        font-size: 24px;
        line-height: 32px
    }

    .blog-3 .info .desc {
        margin-top: 15px
    }
}

@media only screen and (max-width:479px) {
    .blog-3 .post-share .label {
        display: none
    }
}

.media {
    position: relative
}

.media .list {
    position: absolute;
    z-index: 999;
    left: 0;
    bottom: 100%;
    display: flex;
    visibility: hidden;
    width: auto;
    padding: 0 4px;
    -webkit-user-select: none;
    user-select: none;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    transform: translateY(0);
    white-space: nowrap;
    opacity: 0;
    border-radius: 5px;
    background: #fff;
    box-shadow: 0 2px 20px rgba(0, 0, 0, .06);
    filter: drop-shadow(0 2px 20px rgba(0, 0, 0, .06))
}

.media .list::before {
    position: absolute;
    top: 100%;
    left: 20px;
    content: "";
    border-top: 8px solid #fff;
    border-right: 9px solid transparent;
    border-left: 9px solid transparent
}

.media .list a {
    display: flex;
    padding: 10px 8px
}

.media .list a:hover {
    color: var(--primary)
}

.media:hover .icon {
    color: #fff;
    border-color: transparent;
    background-color: var(--primary)
}

.media:hover .list {
    visibility: visible;
    transform: translateY(-10px);
    opacity: 1
}

.entry-author .author-info {
    display: flex
}

@media only screen and (max-width:767px) {
    .entry-author .author-info {
        flex-wrap: wrap
    }
}

.entry-author .author-avatar {
    flex-shrink: 0;
    width: 170px;
    text-align: center
}

@media only screen and (max-width:767px) {
    .entry-author .author-avatar {
        margin: 0 auto
    }
}

.entry-author .author-avatar img {
    border-radius: 50%
}

@media only screen and (max-width:575px) {
    .entry-author .author-avatar {
        width: 120px
    }
}

.entry-author .author-name {
    font-size: 17px;
    line-height: 24px;
    color: var(--primary);
    font-weight: 400;
    margin-bottom: 0
}

.entry-author .designation {
    font-size: 15px;
    line-height: 24px
}

.entry-author .author-biographical-info {
    margin-top: 15px;
    font-size: 15px;
    color: #212121
}

.blog-nav-links {
    margin-top: 35px
}

.blog-nav-links .title {
    display: block;
    font-size: 24px;
    line-height: 1.3;
    font-weight: 700;
    margin-bottom: 40px
}

.blog-nav-links .nav-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 30px
}

@media only screen and (max-width:767px) {
    .blog-nav-links .nav-list {
        grid-template-columns: auto
    }
}

.blog-nav-links .nav-list .nav-item .inner a {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    padding-top: 50px;
    border-radius: 5px;
    overflow: hidden;
    background: #fff;
    padding: 50px 30px 25px;
    border: 1px solid #e7e7e7;
    transition: all .25s cubic-bezier(.645, .045, .355, 1)
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .blog-nav-links .nav-list .nav-item .inner a {
        padding: 35px 20px 25px
    }
}

.blog-nav-links .nav-list .nav-item .inner a .hover-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #333;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    transition: all .25s cubic-bezier(.645, .045, .355, 1);
    opacity: 0
}

.blog-nav-links .nav-list .nav-item .inner a .hover-bg::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: .5;
    background-image: linear-gradient(-180deg, rgba(51, 51, 51, 0) 0, #000 80%);
    border-radius: 5px
}

.blog-nav-links .nav-list .nav-item .inner a .cate {
    position: relative;
    display: block;
    word-wrap: break-word;
    width: 100%
}

.blog-nav-links .nav-list .nav-item .inner a .h6,
.blog-nav-links .nav-list .nav-item .inner a h6 {
    position: relative;
    display: block;
    word-wrap: break-word;
    width: 100%;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.56;
    margin: 0
}

.blog-nav-links .nav-list .nav-item .inner a:hover .hover-bg {
    opacity: 1
}

.blog-nav-links .nav-list .nav-item .inner a:hover .cate {
    color: #fff
}

.blog-nav-links .nav-list .nav-item .inner a:hover .h6,
.blog-nav-links .nav-list .nav-item .inner a:hover h6 {
    color: #fff
}

.comment-list-wrapper {
    padding-top: 30px;
    margin-top: 45px
}

.comment-list-wrapper .title {
    display: block;
    font-size: 24px;
    line-height: 1.3;
    font-weight: 700;
    margin-bottom: 40px
}

.comment-list {
    margin: 0;
    padding: 0
}

.comment-list .comment {
    list-style-type: none;
    padding: 30px 30px;
    border: 1px solid #e7e7e7;
    margin-bottom: 30px;
    border-radius: 5px
}

@media only screen and (max-width:479px) {
    .comment-list .comment {
        padding: 15px 15px
    }
}

.comment-list .comment:last-child {
    margin-bottom: 0
}

.comment-list .comment-author {
    float: left
}

.comment-list .comment-author img {
    border-radius: 50px
}

@media only screen and (max-width:479px) {
    .comment-list .comment-author {
        float: none
    }
}

.comment-list .comment-content {
    position: relative;
    overflow: hidden;
    margin-left: 100px
}

@media only screen and (max-width:479px) {
    .comment-list .comment-content {
        margin-left: 0;
        margin-top: 15px
    }
}

.comment-list .meta {
    margin-bottom: 12px
}

.comment-list .meta .fn {
    font-size: 15px;
    text-transform: uppercase;
    color: var(--primary);
    display: inline-block;
    margin-bottom: 0
}

.comment-list .meta .comment-datetime {
    position: relative;
    display: block;
    font-size: 14px;
    color: #ababab
}

.comment-list .comment-actions a {
    margin-right: 20px;
    font-size: 14px;
    font-weight: 400;
    font-family: Poppins, sans-serif;
    color: #000
}

.comment-list .comment-actions a:hover {
    color: var(--primary)
}

.comment-list .children {
    margin: 20px 0 20px 50px;
    border: 0;
    background-color: #f8faff
}

@media only screen and (max-width:767px) {
    .comment-list .children {
        margin: 20px 0 20px 25px
    }
}

.comment-list .children li+li {
    margin-top: 35px
}

.comment-list .comment-actions {
    margin-top: 16px;
    color: #212121;
    text-align: right
}

.comment-list .comment-actions .comment-reply-link {
    display: inline-block;
    margin-left: 10px;
    font-family: Poppins, sans-serif;
    margin-right: 10px;
    font-weight: 400
}

.comment-form-wrap {
    margin-top: 60px
}

.comment-form-wrap .comment-respond .title {
    display: block;
    font-size: 24px;
    line-height: 1.3;
    font-weight: 700;
    margin-bottom: 20px
}
.grecaptcha-badge {
    visibility: hidden
}
.whats-float {
    position: fixed;
    width: 50px;
    height: 50px;
    line-height: 50px;
    bottom: 20px;
    right: 20px;
    background-color: #13a94a;
    color: #fff;
    border-radius: 50%;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px rgba(44, 44, 44, .39);
    z-index: 999;
    transition: all .2s ease;
    display: block
}

.whats-float:hover {
    color: #13a94a;
    background-color: #fff
}

.my-float {
    margin-top: 16px
}

.sidebar-widget-wrapper {
    float: left;
    width: 100%;
    padding-left: 30px
}

@media only screen and (min-width:992px) and (max-width:1199px),
only screen and (min-width:768px) and (max-width:991px),
only screen and (max-width:767px) {
    .sidebar-widget-wrapper {
        padding-left: 0
    }
}

.sidebar-widget {
    float: left;
    width: 100%
}

.sidebar-widget+.sidebar-widget {
    margin-top: 45px
}

.sidebar-widget-title {
    font-size: 20px;
    line-height: 1;
    font-weight: 400;
    margin-bottom: 30px
}

.sidebar-widget-search form {
    position: relative;
    overflow: hidden;
    border-radius: 4px
}

.sidebar-widget-search form input {
    padding-right: 50px
}

.sidebar-widget-search form button {
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    color: var(--primary);
    border: none;
    border-radius: 4px;
    background-color: transparent
}

.sidebar-widget-search form button:hover {
    color: #fff;
    background-color: var(--primary)
}

.sidebar-widget-cate-list {
    margin: 0;
    padding: 0;
    list-style: none
}

.sidebar-widget-cate-list li+li {
    border-top: 1px solid #eee
}

.sidebar-widget-cate-list li a {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.78;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 0 15px 0
}

.sidebar-widget-list-post {
    margin: 0;
    padding: 0;
    list-style: none
}

.sidebar-widget-list-post li {
    padding: 16px 0 15px 0
}

.sidebar-widget-list-post li+li {
    border-top: 1px solid #eee
}

.sidebar-widget-list-post li a {
    font-size: 20px;
    font-weight: 400;
    line-height: 30px;
    color: #000;
    position: relative;
    display: block
}

@media only screen and (max-width:479px) {
    .sidebar-widget-list-post li a {
        font-size: 16px;
        line-height: 22px
    }
}

.sidebar-widget-list-post li a:hover {
    color: var(--primary)
}

.tagcloud {
    margin: -5px
}

.tagcloud a {
    font-size: 14px !important;
    font-weight: 400;
    line-height: 22px;
    font-family: Poppins, sans-serif;
    display: block;
    float: left;
    overflow: hidden;
    margin: 5px;
    padding: 7px 8px 6px;
    color: var(--primary);
    border: 0;
    border-radius: 3px;
    background: #f5f5f5
}

.tagcloud a:hover {
    color: #fff;
    background-color: var(--primary)
}

.sidebar-widget-banner {
    position: relative;
    z-index: 9;
    padding: 90px 35px;
    text-align: center;
    border-radius: 5px
}

.sidebar-widget-banner .title {
    font-size: 20px;
    line-height: 30px;
    margin-bottom: 35px;
    color: #fff
}

.sidebar-widget-banner p {
    font-size: 16px;
    line-height: 24px;
    color: #fff;
    margin-bottom: 35px
}

.sidebar-widget-banner a {
    color: #fff
}

.sidebar-widget-banner a:hover {
    color: var(--primary)
}

.footer-logo {
    margin-bottom: 30px
}

.footer-widget-title {
    font-size: 18px;
    color: #fff;
    margin-bottom: 17px
}

.footer-widget-content {
    font-size: 18px;
    font-weight: 500;
    color: #adb5bd
}

.footer-widget-content p {
    margin-bottom: 5px;
    color: #adb5bd;
    font-family: Poppins, sans-serif
}

.footer-widget-content p:last-child {
    margin-bottom: 0
}

.footer-widget-content ul {
    margin-right: -20px;
    margin-bottom: -5px;
    padding-left: 0;
    list-style: none
}

.footer-widget-content ul li {
    margin-bottom: 5px;
    padding-right: 20px
}

.footer-widget-content ul li a {
    font-size: 16px;
    line-height: 30px
}

@media only screen and (min-width:992px) and (max-width:1199px) {
    .footer-widget-content ul li a {
        font-size: 15px
    }
}

@media only screen and (max-width:479px) {
    .footer-widget-content ul li a {
        font-size: 15px
    }
}

.ft-badge {
    background-color: var(--primary);
    display: inline-block;
    border-radius: 2px;
    padding: 4px 8px 3px;
    color: #fff;
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin: 0 0 0 7px
}

.footer-social-inline {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
    margin-right: -10px;
    margin-bottom: -10px;
    top: 50%
}

.footer-social-inline a {
    margin-right: 10px;
    margin-bottom: 10px;
    color: #dfdfdf
}

.footer-social-inline a i {
    font-size: 24px;
    line-height: 1;
    display: block
}

.footer-social-inline a:hover {
    color: var(--primary)
}

.footer-section {
    padding: 100px 0 0;
    overflow: hidden
}

@media only screen and (min-width:768px) and (max-width:991px) {
    .footer-section {
        padding: 80px 0 0
    }
}

@media only screen and (max-width:767px) {
    .footer-section {
        padding: 60px 0 0
    }
}

.copyright {
    font-size: 14px;
    line-height: 25px;
    text-align: center;
    padding: 20px 15px;
    border-top: 1px solid #3f5054;
    color: #fff;
    margin-bottom: 0
}

#particles-js {
    height: 100vh;
    width: 100%;
    background: #000;
    position: relative;
    z-index: -3
}

.info-hero {
    position: absolute;
    z-index: 99;
    padding-top: 20px;
    padding-bottom: 20px;
    color: #fff
}

.iconos-footer {
    font-size: 1.7em;
    text-align: center
}

.accordion-button:not(.collapsed) {
    color: #ffffff;
    background-color: #000000;
}

.accordion-button:focus {
    border: none !important;
    box-shadow: none;
}

.logo-cliente {
    max-width: 11rem;
    max-height: 7rem;
    margin-bottom: 2rem;
}



/*--------------------------------------------------------------
# DESARROLLO WEB
--------------------------------------------------------------*/


#desarrolloWeb #hero {
    height: 75vh;
}