@charset "utf-8";
/* =======================
common
=======================*/
.selector {
    font-feature-settings: "palt";
  }

:root{
    --primary-white: #FDFDFD;
    --primary-black: #10170A;
    --primary-green: #72BB2B;
    --primary-lightGreen: #98CA63;
    --primary-gray: #DCDCDC;
    --primary-lightGray: #F1F1F1;
    --primary-beige: #F2EDE6;
    --primary-lineGray: #F5F5F5;
}

html{
    font-size: 62.5%;
}

body{
    font-family:
        'Noto Sans JP',
        Arial, 
        sans-serif;
    font-style: normal;
    color:  var(--primary-black, #10170A);
    background-color:  var(--primary-white, #FDFDFD);
    line-height: 1.5;
}

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




/*＝＝＝＝＝
 トップページのセクションタイトル
 ＝＝＝＝＝*/

.section__title__en{
    text-align: center;
    font-family: Inter;
    color: var(--primary-green);
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 1px;
	display: block;
}


.section__title__jp{
    margin-top: 8px;
    text-align: center;
    font-size: 2.8rem;
    line-height: 1;
    letter-spacing: 1.4px;
	display: block;
}

/*  トップページのセクションタイトル common PC */
@media screen and (min-width: 769px){
    .section__title__en{
        font-size: 2.0rem;
    }
    
    
    .section__title__jp{
        font-size: 3.6rem;
        margin-top: 14px;
    }

} /* PC769px*/





/*＝＝＝＝＝
 下層ページのヘッダータイトル
 ＝＝＝＝＝*/

 .page__title__en{
    text-align: center;
    font-family: Inter;
    color: var(--primary-green);
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 1px;
	display: block;
}


.page__title__jp{
    margin-top: 14px;
    text-align: center;
    color: var(--primary-black);
    font-size: 3.0rem;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 1.5px;
    margin: 4px auto 0;
	display: block;
}

.page__title{
    padding: 1rem 0;
    margin-bottom: 0.2rem;
    margin-top: 94px;
    background-image: linear-gradient(90deg, var(--primary-lightGray) 0 40%, var(--primary-green) 40% 60%, var(--primary-lightGray) 60%);
    background-repeat: no-repeat;
    background-size: 100% 0.2rem;
    background-position: bottom;
    font-weight: bold;
    font-size: 26px;
    text-align: center;
}

/* 下層ページのヘッダータイトル　800px */
@media screen and (min-width: 800px) {
.page__title{
    margin-top: 148px;
}
}/* 800px */



/*＝＝＝＝＝
 下層ページのセクションのタイトル
 ＝＝＝＝＝*/

.page__section__title{
    font-size: 2.4rem;
    font-weight: 600;
    line-height: 1; 
    letter-spacing: 1.2px;
    padding: 16px 0;
    background-image: linear-gradient(90deg, var(--primary-green) 0 20%, var(--primary-gray) 20%);
    background-repeat: no-repeat;
    background-size: 100% 0.2rem;
    background-position: bottom;
    margin: 64px 5% 0;
}

/* 下層ページのセクションタイトル　769px */
@media screen and (min-width: 769px) {
    .page__section__title{
        margin: 80px 5% 0;
    }
    }/* 769px */

/*＝＝＝＝＝
 下層ページの小タイトル
 ＝＝＝＝＝*/

 .smallTitle{
    font-size: 2.0rem;
    font-weight: 600;
    line-height: 1.3;
}



/* ================
　トップボタン
================*/

.back-to-top {
    position: fixed;
    right: 5%;
    bottom: 5%;
    text-align: center;
    padding-top: 16px;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    font-size:1.2rem;
    font-family: Inter;
    letter-spacing: 1px;
    background-color: var(--primary-green);
    color:var(--primary-white);
    display: inline-block;
    z-index: 100;
    transition: 0.4s; /* ボタンには絶対入れる*/
  }

  .btn_top:hover{
    opacity: 0.5;
}
 

/* =======================
header
=======================*/
.header{
    display: block;
    background-color: var(--primary-white);
    position: fixed;
    z-index: 101;
    width: 100%;
    height: auto;
    left: 0;
    top: 0;
}

.pc__2{
    display: none;
}

.sp__3{
    display: flex;
    margin-left: auto; /* ボタン群を右端に寄せる */
}

.header__box{
    display: flex;
    justify-content: space-between;
    align-items: center; /* 縦方向の中央揃え */
}


/* TELボタン始*/
.sp__header__tel{
	width: 64px;
    height: 64px;
    display: inline-block;
    text-align: center;
    background-color: var(--primary-beige);
}

.sp__header__tel p{
	font-size: 1.2rem;
    margin-top: 3px;
}

.tel__btn::after{
    content: '';
        display: inline-block;
        background-image: url(../images/tel2.svg);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: bottom;
        width: 30px;
        height: 30px;
        margin-top: 5px;
}
/* TELボタン終*/

/* アクセスボタン始*/
.sp__header__access{
	width: 64px;
    height: 64px;
    display: inline-block;
    text-align: center;
    background-color: var(--primary-gray);
}

.sp__header__access p{
	font-size: 1.2rem;
    margin-top: 3px;
}

.access__btn::after{
    content: '';
        display: inline-block;
        background-image: url(../images/access.svg);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: bottom;
        width: 30px;
        height: 30px;
        margin-top: 5px;
}
/* アクセスボタン終*/


/* メニューボタン始*/
.sp__header__menu{
	width: 64px;
    height: 64px;
    display: inline-block;
    text-align: center;
    background-color: var(--primary-white);
}

.sp__header__menu p{
	font-size: 1.2rem;
    margin-top: 3px;
}

.sp__header__tel p{
	font-family: Inter;
}

.header__btn{
    margin-top: 8px;
    width: 36px;
    height: 25px;
}
/* メニューボタン終*/

.nav__btn{
	width: 26px;
    display: inline-block;
}

.logo span{
    display: none;
}

.logo img{
    width:139.17px;
    height: 64px;
}



/* .nav初期表示 */
.nav{
    background-color: var(--primary-beige);
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    transform: translateX(-100%); /* 左に隠れる*/
    transition: transform 0.4s;  
}

.nav__header{
    display: flex; /* 横並び*/
    justify-content: space-between;
    height: 64px;
    align-items: center;/* 水平中央*/
}

.nav__btn{
    margin-right: 24px;
}

.nav__topic{
    color: var(--primary-black);
}

.nav__list{
    margin-top: 56px;
}

.nav__item{
    color: var(--primary-black);
    font-size: 2.4rem;
    line-height: 1;
    display: flex;
    align-items: center;
	margin-top: 40px;
	margin-left: 6%;
    transition: 0.4s; /* ボタンには絶対入れる*/
}

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

.nav__item::before{
    content:  "";     /* 空の要素作成 */
    width:  32px;               /* 幅指定 */
    height:  2px;              /* 高さ指定 */
    background-color: var(--primary-green);
    display:  inline-block;     /* インラインブロックにする */
    position:  relative;        /* 位置調整 */
    top: 1px;                  /* 位置調整 */
    margin-right: 10px;          /* 余白指定 */
}



/*  .nav.active表示 */
.nav.active {
    transform: translateX(0);
}/* 半角スペースは開けない*/


/*  800px*/
@media screen and (min-width: 800px){    

    .header__box{
        margin: 8px auto 16px;
        height: 94px;
        width: 90%;
        max-width: 1180px;
        display: flex;
        align-items: center;/* 水平中央に揃う */
        justify-content: space-between;
    }

    .logo span{
        display: block;
        font-size: 1.3rem;
        letter-spacing: 0.8px;
        margin-bottom: 6px;
        margin-left: 1.5px;
    }

    .sp__3{
        display: none;
    }

    .access__btn::after{
        display: none;
    }

    .pc__2{
        display: flex;
        align-items: center;
        margin-left: 270px;
        
    }

    /* パソコン版のTEL　設定始*/
    
    /* .pc__header__tel__number{
        width: 152.62px;
    }*/
    .pc__header__tel a{
        font-size: 2.3rem;
        font-family: Inter;
        font-weight: 700;
        line-height: 1;
        display: inline-block;
    }

    .header__hyphen1{
        margin-left: -1px;
        margin-right: 1.5px;
    }

    .header__hyphen2{
        margin-right: 1px;
    }

    .pc__header__tel a::before{
        content: '';
        display: inline-block;
        background-image: url(../images/tel1.svg);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: bottom;
        width: 25px;
        height: 25px;
        margin-right: 3px;
    }

    .pc__header__tel__open{
        font-size: 1.3rem;
        letter-spacing: 0.5px;
        margin-left: 3.5px;
    }

    .pc__header__time{
        font-family: Inter;
        font-size: 1.35rem;
        margin-left: 10px;
        display: inline-block;
    }


    /* パソコン版のTEL　設定終*/



     /* パソコン版のアクセス　設定始*/
    .pc__header__access{
        font-size: 1.6rem;
        margin-top: -24px;
        transition: 0.4s; /* ボタンには絶対入れる*/
    }


    .pc__header__access:hover{
    color: var(--primary-green);
    }

    .pc__header__access::before{
        content: '';
        display: inline-block;
        background-image: url(../images/access.svg);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: bottom;
        width: 18px;
        height: 25px;
        margin-right: 3px;
        margin-left: 10px;
        position: relative;
        top:5px;
    }
      /* パソコン版のアクセス　設定終*/

    .nav__list{
        margin-top: 64px;
    }
    

    .header__width{
        max-width:  1180px;
    }


    .nav__header{
         display: none; /*メニューボタンを消す*/
    }


   .nav{
       background: transparent; /* 色がついていたものを消す*/
       width: auto;/* 元の状態に戻す*/
       height: auto;/* 元の状態に戻す*/
       padding: 0;/* 元の状態に戻す*/
       position: static;/* 元の状態に戻す*/
       transform: translateX(0);/* 元の状態に戻す*/
       text-align: right;
   }


    .nav__list{
        margin: 0;
        display: flex; /* 横並び*/
        align-items: center;/* flexとセットで使う*/
    }


    .nav__item{
        margin: 0 0 0 32px;
        text-align: center;
        font-size: 1.6rem;
        margin-top: 16px;
    }

    .page__office,.page__lawyer,.page__service,.page__legalfee{
        letter-spacing: 1px;
    }

    .page__contact{
        letter-spacing: 0.1px;
    }

    
    .nav__item::before{
        display: none;
    }
    
    
    .header__btn{
        display: none;
    }
		
} /* PC800px*/

	


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

.footer{
    margin-top: 80px;
    border-top: solid 1px var(--primary-beige);
}

.footer__group{
    padding: 48px 5% 0px;/* 上は文字の高さの影響を受ける */
}

.footer__group h2{
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 1px;
	margin-top: 0px; 
}

.footer__group p{
	margin-top: 24px;
    font-size: 1.6rem;
}

.footer__group a{
	margin-top: 16px;
    font-size: 1.6rem;
    display: block;
}

.footer__group address{
	margin-top: 16px;
    font-size: 1.6rem;
}

.map{
    display: none;
}

.footerNav__list{
    display: flex;
    flex-wrap: wrap;
    gap: 10px 32px;
    width: 90%;
    margin: 64px auto 32px;
}

.footerNav{
	font-size: 1.6rem;
}

.footerNav__item{
    transition: 0.4s; /* ボタンには絶対入れる*/
    }

    .footerNav__item:hover{
    color: var(--primary-green);
    }

.copy{
    text-align: center; 
    padding: 8px 0;
    align-items: center;
    background-color: var(--primary-green);
}

.copy small{
    font-size: 1.2rem;
    color: var(--primary-white);
    line-height: 1.5;
}



/*  .artcle__footer pc988px */
@media screen and (min-width:988px) {
    .footer__box{
        max-width: 1180px;
        width: 100%;
        margin: 0 auto;
    }


    .footer{
        margin-top: 120px;   
    }

    .footer__group{
        padding: 72px 5% 0px;/* 上は文字の高さの影響を受ける */
    }
    
    .footerNav__item{
        font-size: 1.6rem;
        line-height: 1;
        margin-top: 24px; 
    }

    .footerNav__list{
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
        width: 100%;
        max-width: 1000px;
    }

    .footerNav__box{
    width: 90%;
    margin: 0 auto 24px;
    }
    
}/* PC 988px */