@charset "utf-8";

/*==========================
common
==========================*/

:root {
    --black: #32393A;
    --lightbrown: #F7EEE7;
    --white: #FDFDFD;
    --red: #A02D2D;
    --brown: #EEE0D5;
    --green: #527E5B;
}

html {
    font-size: 62.5%;
}

body {
    font-family:
        'Klee One',
        'Kaisei Opti',
        sans-serif;
    font-style: normal;
    color: var(--black);
    background-color: var(--lightbrown);
    line-height: 1.5;
}

img {
    max-width: 100%;
    height: auto;
}




/*==========================
header
==========================*/
.header {
    padding: 4px 7px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--white)
}

.logo {
    display: flex;
    gap: 0px 8px;
    align-items: center;
}

.header__logo {
    width: 60px;
}

.header__txt {
    color: var(--red);
    font-size: 0.8rem;
    font-weight: 600;
}

.header_btn {
    display: none;
}

.btn_pc_lesson {
    display: none;
}

.btn_pc {
    display: none;
}

.logo_pc {
    display: none;
}

.header_nami {
    width: 100vw;
}

/* .nav初期表示 */
.nav {
    background: var(--red);
    width: 80%;
    height: 100vh;
    position: fixed;
    top: 0;
    z-index: 100;
    transform: translateX(100%);
    transition: transform 0.4s;
    left:  20%;
}

.nav__list {
    text-align: center;
    margin-top: 91px;
}

.nav__item__maru {
    background-color: var(--white);
    width: 80px;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    filter:drop-shadow(2px 2px 4px #32393A);
    margin: 0 auto;
    font-size: 1.4rem;
    margin-top: 41px;
    color: var(--red);
}

.nav__header{
    display: flex;
    justify-content: end;
    padding: 8px 16px;
}

.nav__btn {
    padding: 19px;
    border-radius: 50%;
    background-color: var(--red);
}

.nav__item {
    color: var(--lightbrown);
    font-size: 2rem;
    font-weight: 400;
    margin-top: 14px;
}

.nav__item:hover {
    color: var(--white);
}



.nav__item__maru_pc{
    display: none;
}


/*=============================
.btn-trigger
=============================*/
.btn02 {
    padding: 16px 17px;
    border-radius: 50%;
    background-color: var(--white);
    position: fixed;
    right: 4%;
    top: 6px;
    z-index: 1000;
}

.header__btn {
    position: relative;
    width: 24px;
    height: 24px;
    cursor: pointer;
    z-index: 1000;
  }
  .header__btn span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: var(--red);
    border-radius: 4px;
  }
  .header__btn, .header__btn span {
    display: inline-block;
    transition: all .5s;
    box-sizing: border-box;
  }
  .header__btn span:nth-of-type(1) {
    top: 0;
  }
  .header__btn span:nth-of-type(2) {
    top: 11px;
  }
  .header__btn span:nth-of-type(3) {
    bottom: 0;
  }
  
  
  /*=============================
  #btn01
  =============================*/
  .btn02.active {
    background-color: var(--red);
    padding: 19px;
    border-radius: 50%;
    position: fixed;
    z-index: 1000;
}
  #btn01.active span:nth-of-type(1) {
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(1px) rotate(-45deg);
    background-color: var(--white);
  }
  #btn01.active span:nth-of-type(2) {
    opacity: 0;
  }
  #btn01.active span:nth-of-type(3) {
    -webkit-transform: translateY(-20px) rotate(45deg);
    transform: translateY(-20px) rotate(45deg);
    background-color: var(--white);
  }
  
  


/* .nav.active表示 */
.nav.active {
    transform: translateX(0);
}

/* .header pc */
@media screen and (min-width:769px) {

    .header {
        justify-content: center;
        height: 5.2vw;
        position: fixed;
        width: 100%;
        z-index: 100;
    }


    .header__logo {
        /* width: 120px;
        position: absolute;
        top: 10px;
        left: 8.3%;
        text-align: center; */
        display: none;
    }

    .logo_pc {
        display: block;
        width: 13vw;
        position: absolute;
        right: 80.5%;
        transform: translateY(45px);
    }

    .header__logo::before {
        content: '栃木市・佐野市の出張着付け';
        display: block;
        width: 156px;
        color: #A02D2D;
        font-size: 1.2rem;
        font-weight: 400;
        margin-bottom: 5px;
    }
    
    .header__txt {
        display: none;
    }

    .nav__header {
        display: none;
    }

    .nav {
        background: transparent;
        width: auto;
        height: auto;
        padding: 0;
        position: static;
        transform: translate(0);
        margin-top: -10px;
    }

    .nav__list {
        margin-top: 0;
        display: flex;
        align-items: center;
        gap: 0px 2.9vw;

    }

    .nav__item {
        color: #32393A;
        font-size: 1.011vw;
        font-weight: 600;
    }

    .nav__item:hover {
        color: #A02D2D;
    }

    .header__btn {
        display: none;
    }


    .nav__item__maru {

        display: none;
    }
    
    
    .nav__item__maru_pc {
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: 50%;
        filter:drop-shadow(2px 2px 4px #32393A);
        font-size: 1.4rem;
        width: 8.68vw;
        height: 8.68vw;
        background-color: #A02D2D;
        color: var(--white);
        position: fixed ;
        left: 82.7%;
        transform: translateY(50px);
        z-index: 100;
        transition: all .4s;
    }
    
    .nav__item__maru_pc:hover {
        opacity: 0.7;

    }

    .btn_pc {
        display: inline;
    }

    .nav__txt {
        text-align: center;
        font-size: 1.25vw;
    }

    .btn02  {
        display: none;
    }

}

/* pc 769px */


/*==========================
footer
==========================*/

.nav__list_f {
    padding: 38px 26px 34px 26px
}


.nav__item_f {
    color: #32393A;
    text-align: left;
    font-size: 1.4rem;
    font-weight: 400;
    margin: 24px 0 0 72px;
    position: relative;
}

.nav__item_f:hover {
    color: #A02D2D;
}

.nav__item--iroha {
    margin: 24px 0 0 64px;
}

.nav__item_f::after {
    content: '';
    display: block;
    width: 50px;
    height: 2px;
    background-color: var(--red);
    position: absolute;
    bottom: 7px;
    left: -70px;
}

.nav__item--iroha::after {
    left: -61px;
}

.footer__logo {
    text-align: center;
    background-image: url(../images/footer.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    height: 169px;
}

.logo_F {
    width: 55px;
    margin-top: 35px;
}

.footer__txt {
    color: #FDFDFD;
    font-size: 1.2rem;
    font-weight: 600;
    margin-top: 10px;
}

.copy {
    color: #FDFDFD;
    margin-top: 34px;
}


/* .footer pc */
@media screen and (min-width:769px) {
    
    .nav__list_f {
        padding: 2.361vw 9.8%;
        display: flex;
        justify-content: center;
    }

    .nav__item_f::after {
        /* width: 2px;
        height: 27px; */
        display: none;
    }

    .nav__item_f {
        display: flex;
        text-align: center;
        font-size: 1.05vw;
        margin: 0;
    }

    .sp_nav {
        display: none;
    }
    
    .nav__item--iroha {
        margin: 0;
    }

    .line {
        width: 0.14vw;
        height: 1.875vw;
        background-color: var(--red);
        margin: 0 2.9vw;
    }
    
    .logo_F {
        width: 7.5vw;
        margin-top: 3.54vw;
    }

    .footer__txt {
        font-size: 1.11vw;
        margin-top: 1.319vw;
    }

    .copy {
        margin-top: 2.36vw;
    }

    .footer__logo {
        height: 17.36vw;
    }


}
/* pc 769px */

/*==========================
fadeIn
==========================*/
.fadeIn {
    transform: translate(0, 50px);
    opacity: 0;
    transition: 0.8s;
}

.fadeIn.animated {
    transform: translate(0, 0);
    opacity: 1;
}

