/* ===================================
    Crafto - It business
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@200;300;400;500;600;700;800&display=swap');
/* variable */
:root {     
    --base-color: #074eb9; 
    --dark-gray:#252840;
    --black:#05060a;
    --medium-gray:#7d8087;
    --very-light-gray: #f0f2f8;
    --gradient-purple-pink: linear-gradient(to right, #7638fa, #ff0069);
    --primary-font: 'Plus Jakarta Sans', sans-serif;
}
/* reset */
body{
    line-height: 29px;
}
/* header */
header .navbar-brand img {
    max-height: 64px;
} 
.navbar .navbar-nav .nav-link {
    font-size: 17px;
}
header .header-button {
    padding: 0 1rem;
}
header .btn.btn-rounded.btn-large {
    padding:10px 26px;
    font-size: 13px;
    font-weight: 500;
}
.sticky .header-transparent .header-button .btn {
    color: var(--dark-gray);
    border-color: var(--extra-medium-gray);
}
.sticky .header-transparent .header-button .btn:hover {
    border-color: var(--dark-gray);
    color: var(--white);
    background:  var(--dark-gray);
}
header.sticky.sticky-active [data-header-hover="light"] .widget-text i {
    color: var(--white);
}
/* accordion style 02 */
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
    background-color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover a,
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active a{
    opacity: .5;
}
/* btn */
[class*=btn-transparent], [class*=" btn-transparent"] {
    font-weight: 500;
}
.btn {
    text-transform: none;
    font-family: var(--primary-font);
}
.btn.btn-switch-text.btn-extra-large > span {
    padding: 19px 40px;
}
.btn-gradient-purple-pink {
    background-image: linear-gradient(70deg, rgba(225, 0, 50, 1) 15%, rgb(225, 0, 200) 35%, rgb(153, 0, 184) 65%, rgba(123, 0, 186, 1) 85%);
    background-size: 200% auto;
    color: var(--white);
    border: none;
}
.btn-gradient-youtube {
    background-image: linear-gradient(70deg, rgba(255, 0, 0, 1) 15%, rgba(255, 70, 70, 1) 85%);
    background-size: 200% auto;
    color: var(--white);
    border: none;
}
.button .btn {
    color: #252840;
    border: 1px solid #e4e4e4;
    font-weight: bold;
}
.button .btn:hover {
    color: #FFF;
    background-color: #252840;
    border: 1px solid #252840;
}
.label {
    font-style: normal;
    font-size: 14px;
    font-weight: 700;
    text-align: center;
    width: 6rem;
    border-radius: 1rem;
    -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    padding: 0.4rem 0 0.5rem;
}
.label.label-black {
    background-color: var(--dark-gray);
    color: var(--white);
}
.label.label-gradient-purple-pink {
    background: var(--gradient-purple-pink);
    color: var(--white);
}
.label.label-base-color {
    background-color: var(--base-color);
    color: var(--white);
}

/* bg gradient color */
.bg-gradient-dark-gray-transparent { 
    background: -webkit-linear-gradient(right, rgba(24, 25, 28, .5), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(24, 25, 28, .5), rgba(255, 255, 255, 0.0));
}
.bg-gradient-very-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(240, 244, 253, 1.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(240, 244, 253, 1.0), rgba(255, 255, 255, 0.0));
}
.bg-gradient-flamingo-red-transparent {
    background: -webkit-linear-gradient(right, rgba(241, 70, 70, 0.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(241, 70, 70, 0.32) 10%, rgba(255, 255, 255, 0.0) 95%);
}
.bg-gradient-base-color-transparent {
    background: -webkit-linear-gradient(right, rgba(15, 89, 201, 0.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(15, 89, 201, 0.32) 10%, rgba(255, 255, 255, 0.0) 95%);
}
.bg-gradient-light-gray-transparent {
    background: -webkit-linear-gradient(right, rgba(222, 230, 244, 0.0), rgba(255, 255, 255, 0.0));
    background: linear-gradient(to right, rgba(222, 230, 244, 0.32), rgba(255, 255, 255, 0.0));
}
.bg-midnight-blue {
    background-color: #1e2033;
}
.bg-khaki {
    background-color: #3f4f19;
}
.bg-gradient-purple-pink {
    background-image: linear-gradient(60deg, rgba(225, 0, 50, 1) 15%, rgb(225, 0, 200) 35%, rgb(153, 0, 184) 65%, rgba(123, 0, 186, 1) 85%);
}
.height-10rem {
    height: 10rem;
}
.bg-sns {
    background-color: #252840;
}
.bg-sns a span,
.bg-youtube a span {
    color: var(--white);
    font-size: 1rem;
}
/* Background for shiranuka section (right half image) */
.bg-black.bg-shiranuka {
  position: relative;
  overflow: hidden;
}
.bg-black.bg-shiranuka::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 50%;
  background-image: url("../images/bg-shiranuka.jpg");
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
  z-index: 1;
}

@media (max-width: 1420px) {
    .bg-black.bg-shiranuka::after {
    width: 42%;
    }
}

@media (max-width: 991px) {
    .bg-black.bg-shiranuka::after {
    width: 100%;
    opacity: 0.5;
    }
}


.bg-black.bg-shiranuka .container,
.bg-black.bg-shiranuka .row,
.bg-black.bg-shiranuka .col-xl-6,
.bg-black.bg-shiranuka .col-lg-6 {
  position: relative;
  z-index: 2;
}
.bg-sea {
    background-image: url(../images/bg-sea.png);
    background-size: cover;
    padding-bottom: 0;
}
.bg-tech {
    background: url(../images/bg-tech.png) top right no-repeat;
    background-size: cover;
    background-position-x: center;
    background-position-y: 0;
}

.bg-last {
    background-image: url(../images/bg-last.jpg);
    background-size: cover;
    background-position-x: center;
}

/* text */
.text-flamingo {
    color: #e55b53;
}
.text-gradient-orange-sky-blue {
    background-image: linear-gradient(to right, #5e70f3, #6170f1, #8074dc, #b87bb6, #ec8192);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
    margin-bottom: 25px;
}
/* portfolio filter */
.portfolio-filter li {
    padding: 0 18px;
    line-height: 24px;
}
/* blog */ 
.categories-btn {
    font-size: 11px;
}
/* page title */

.content-title {
    width: 20rem;
}

.small-title {
    font-size: 1.75rem;
    font-weight: 700;
    font-style: italic;
    line-height: 2rem;
}

.small-title span {
    font-size: 1.25rem;
    font-style: normal;
    margin-left: 1rem;
}

.middle-title {
    color: #252840;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2.5rem;   
}

.text-purple {
    color: #b963a4;
}

.text-yellow {
    color: #f1bb46;
}

.contact-title {
    width: 20rem;
    position: absolute;
    left: 1rem;
    top: -3.5rem;
}
.page-title-extra-large h2 {
    font-size: 17px;
    line-height: 28px;
    margin: 0 auto;
}
.process-step-style-05 .progress-step-separator {
    bottom: -10px;
    height: 100%;
    z-index: -1;
}
/* height */
.h-72px {
    height: 72px !important;
}
#map {
    height: 650px;
    border-radius: 6px 0 0 6px;
}
/* margin top */
.mt-minus-50px {
    margin-top: -50px;
}
/* line-height */
.lh-200 {
    line-height: 12.5rem;
}
/* bottom */
.bottom-auto {
    bottom: auto;
}
/* footer */
footer .footer-logo img {
    max-height: 100%;
    width: 320px;
}
footer .sns-icon img {
    height: 3rem;
}
footer .sns-icon:hover {
    opacity: 0.7;
}
.footer-light a:hover, .footer-navbar li a:hover {
    color: var(--dark-gray);
}


/* other */
.shop-banner img {
    width: 6rem;
    height: fit-content;
}
.shop-banner p {
    font-size: 20px;
    font-weight: 900;
    margin-top: -5px;
}
.shop-banner p small {
    font-size: 14px;
    font-weight: 500;
}
.shop-banner {
    display: flex;
    justify-content: center;
}

.shop-banner a:hover {
    opacity: 0.7;
}
.box-shadow-tech {
    width: 20%;
    border-radius: 20rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Icon with white circle border */
.icon-circle-border-white {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5em;
  height: 2.5em;
  border: 1px solid white;
  border-radius: 50%;
}

/* Company info list: align label and value horizontally */
.list-style-01 li {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.list-style-01 li > .text-dark-gray {
  flex: 0 0 25%;
  max-width: 25%;
}
.list-style-01 .list-value {
  flex: 1 1 75%;
  text-align: left;
}


@media (max-width: 1299px) {
    .navbar .navbar-nav .nav-link {
        font-size: 16px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 15px;
        font-size: 12px; 
    }
    .sp-none {
        display: none;
    } 
}
@media (max-width: 1199px) {
    .navbar .navbar-nav .nav-link {
        font-size: 15px;
    }
    header .btn.btn-rounded.btn-large {
        padding: 10px 10px;
        font-size: 11px; 
    }
}
@media (max-width: 991px) {
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu {
        width: calc(100% + 30px) !important;
        margin-left: -15px;
        padding: 10px 45px;
        margin-bottom: 0;
        margin-right: -15px;
    }
    @media (max-width: 991px) {
      .list-style-01 li {
        flex-direction: column;
        align-items: flex-start;
      }
      .list-style-01 li > .text-dark-gray {
        flex: none;
        max-width: none;
        width: auto;
        margin-bottom: .25rem;
      }
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:last-child a {
        padding-bottom: 17px;
    }
    [data-mobile-nav-style=full-screen-menu] .navbar-full-screen-menu-inner .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a i {
        font-size: 19px;
    }
    header .btn.btn-rounded.btn-large {
        color: var(--dark-gray);
        border-color: var(--extra-medium-gray);
        padding: 10px 15px;
        font-size: 13px;
    }
    .content-title {
        width: 74%;
    }
    .contact-title {
        width: 74%;
    }
    .footer-logo {
        justify-content: center;
    }
    .box-shadow-tech {
        width: 50%;
         margin-bottom: 2rem;
    }

    .bg-sea {
        background-image: linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.25)), url(../images/bg-sea.png);
        background-size: cover;
        background-position: center;
        background-repeat: no-repeat;
    }

}

@media (max-width: 767px) {
    .portfolio-filter li {
        padding: 0;
    }

    .main-title {
        font-size: 3.5rem;
    }

    .btn.btn-switch-text.btn-extra-large > span {
        padding: 19px 32px;
    }

    .shop-banner img {
        display: flex;
        margin: 0 auto;
        margin-bottom: 1rem;
    }

     .jc-sm-btw {
        justify-content: space-around;
     }

    .shop-banner p {
    font-size: 18px;
    }

    .shop-banner p small {
        font-size: 11px;
    }

}
@media (max-width: 575px) {

    footer .footer-logo p {
    margin-top: 1rem;
    margin-left: 1rem;
}


}

