@charset "utf-8";
/*
Theme Name: マイルストーン弁護士事務所
Theme URI: 
Description: beReady original wordpress theme
Version: 1.0
*/

/*********************************
	メインビジュアル
*********************************/
.head_logo {
    padding-top: 57px;
}
#main_visual {
    background-image: url(./images/top/mv.jpg);
    position: relative;
}
.mv_wrap {
    position: relative;
    height: 100vh;
}
#main_visual h1 {
    font-weight: bold;
    font-size: 49px;
    text-align: left;
    color: #fff;
    position: absolute;
    top: 46%;
}
#main_visual .online {
    position: absolute;
    bottom: 4.6875%;
    right: 93px;
    width: 205px;
    height: 205px;
}
#main_visual .online div {
    position: relative;
    height: 205px;
}
#main_visual .online div img.text_circle {
    position: absolute;
    width: 205px;
    height: 205px;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
    right: 0;
    animation:10s linear infinite rotation1;
    -webkit-animation:10s linear infinite rotation1;
}
@keyframes rotation1{
    0%{ transform:rotate(0);}
    100%{ transform:rotate(360deg); }
  }
#main_visual .online div img.circle_banner {
    width: 160px;
    height: 160px;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 0;
    right: 0;
}
.scroll {
    position: absolute;
    right: 30px;
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    color: #fff;
    bottom: 0px;
    font-size: 12px;
    letter-spacing: 0.25em;
    -webkit-writing-mode: vertical-rl;
}
.scroll p {
    margin-bottom: 62px;
    animation:3s 1s cubic-bezier(.19, 1, .22, 1) infinite updown;
    -webkit-animation:3s 1s cubic-bezier(.19, 1, .22, 1) infinite updown;
}
@keyframes updown {
    0%{ transform: translateY(0px); -webkit-transform: translateY(0px); -moz-transform: translateY(0px); -ms-transform: translateY(0px); -o-transform: translateY(0px); }
    50%{ transform:translateY(15px) ; -webkit-transform:translateY(15px) ; -moz-transform:translateY(15px) ; -ms-transform:translateY(15px) ; -o-transform:translateY(15px) ; }
    100%{ transform:translateY(0px) ; -webkit-transform:translateY(0px) ; -moz-transform:translateY(0px) ; -ms-transform:translateY(0px) ; -o-transform:translateY(0px) ; }
}
.scroll span {
    display: block;
    height: 40px;
    width: 1px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background-color: #fff;
}
h1.vertical_ttl {
    justify-content: flex-start;
    align-items: flex-start;
}
h1.vertical_ttl span {
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    display: block;
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.4em;
    line-height: 1;
}
h1.vertical_ttl p {
    -ms-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    -webkit-writing-mode: vertical-rl;
    font-size: 60px;
    letter-spacing: 0.2em;
    font-weight: normal;
}

.mv {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 0;
}
.mvWrap {
	width: 100%;
	position: relative;
}
.mv:after {
	    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #fff;
    opacity: 0.04;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}
.mv-block {
	width: 100%;
    padding-top: 100vh;
    overflow: hidden;
    position: relative;
    z-index: 0;
}
.video-block {
	display: block;
	width: 100vw;
    height: 100vh;
    position: relative;
    left: 0;
    top: 0;
}
video.videoTop {
	display: block;
    min-width: 100%;
    min-height: 100%;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translateX(-50%) translateY(-50%);
    -moz-transform: translateX(-50%) translateY(-50%);
    -ms-transform: translateX(-50%) translateY(-50%);
    -o-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}
.video_pc {
    display: block;
}
video.video_sp {
    display: none;
}
/*********************************
	MESSAGE
*********************************/
#message {
    position: relative;
    z-index: 10;
    padding: 138px 0 0 0;
    background-color: #F4F4F4;
    box-sizing: border-box;
    max-height: 900px;
    overflow: hidden;
}
#message::before {
    content: "";
    width: 50%;
    position: absolute;
    height: 810px;
    background-color: #DF6400;
    top: 0;
    left: 0;
    z-index: -1;
}
.message_wrap {
    position: relative;
}
.message_wrap h1 {
    color: #fff;
}
img.message_logo {
    position: absolute;
    top: -53px;
    right: 40px;
    z-index: 10;
}
.message_text_wrap {
    background-color: #fff;
    width: 71.3762%;
    margin-left: 28.6237%;
    box-sizing: border-box;
    padding: 80px 0 120px 80px;
    position: absolute;
    top: 138px;
}
.message_text_wrap b {
    font-weight: bold;
    font-size: 30px;
    letter-spacing: 0.1em;
    line-height: 54px;
    text-align: left;
    color: #2c2c2c;
    position: relative;
}
.message_text_wrap b::after {
    content: "";
    width: 40px;
    height: 1px;
    display: block;
    background-color: #2c2c2c;
    position: absolute;
    bottom: -40px;
}
.message_text_wrap p {
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 44px;
    text-align: left;
    color: #2c2c2c;
    padding-top: 62px;
    font-family: 'notosans';
}
.message_left {
    width: 50%;
    margin-right: auto;
    margin-top: -113px;
}
.message_left img {
    width: 100%;
}
/*********************************
	PROFILE
*********************************/
#profile {
    background-color: #F4F4F4;
    padding-top: 150px;
    position: relative;
    padding-bottom: 244px;
}
h1.right_long_ttl {
    margin-left: calc((100% - 1200px) / 2);
    position: relative;
    padding-bottom: 40px;
}
h1.right_long_ttl::after {
    content: "";
    width: 100%;
    height: 1px;
    display: block;
    position: absolute;
    background-color: #2C2C2C;
    top: -17px;
    bottom: 0;
    margin: auto;
}
h1.right_long_ttl span {
    font-size: 60px;
    letter-spacing: 0.1em;
    color: #2c2c2c;
    font-weight: normal;
    line-height: 1.266666;
    padding-right: 40px;
    background-color: #F4F4F4;
    display: inline-block;
    position: relative;
    z-index: 10;
}
h1.right_long_ttl p {
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.2em;
    line-height: 1;
    color: #2c2c2c;
    padding-top: 2px;
}
#profile .container {
    position: relative;
}
#profile figure.prof_img {
    width: 400px;
    position: absolute;
    left: auto;
    right: calc((100% - 1200px) / 2);
    margin-right: 100px;
}
#profile figure.prof_img img {
    width: 100%;
}
#profile figure.prof_img a {
    position: absolute;
    right: -30px;
    bottom: -30px;
}
.prof_info {
    padding-top: 30px;
}
.prof_info ul li {
    font-family: 'NotoSans';
    margin-bottom: 40px;
}
.prof_info ul li:nth-child(1) {
    margin-bottom: 40px;
}
.prof_info ul li b {
    font-size: 30px;
    letter-spacing: 0.1em;
    line-height: 1;
}
.prof_info ul li p {
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 1;
    padding-top: 17px;
}
.prof_info ul li.hobby p,
.prof_info ul li.milestone p  {
    line-height: 32px;
}
.prof_info ul li.milestone p {
    padding-top: 8px;
}
.prof_info ul li > span {
    background-size: 80px 30px;
    background-image: url(./images/top/arrow_box.svg);
    width: 63px;
    padding-left: 17px;
    display: inline-block;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 30px;
}
.prof_info ul li:last-child p:nth-of-type(2) {
    padding-top: 0px;
}
/*********************************
	OUR BUSINESS
*********************************/

#business {
    background-color: #F4F4F4;
    position: relative;
    padding-bottom: 150px;
}
#business .container {
    position: relative;
    z-index: 10;
}
#business h1 {
    font-size: 82px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #df6400;
    justify-content: flex-start;
    font-weight: normal;
}
#business h1 span {
    font-weight: bold;
    font-size: 20px;
    line-height: 30px;
    letter-spacing: 0;
    padding-left: 7px;
}
#business::before {
    content: "";
    width: 100%;
    height: 613px;
    background-size: 100%;
    background-repeat: no-repeat;
    background-image: url(./images/top/business_bg.svg);
    position: absolute;
    z-index: 0;
    top: 92px;
}
.business_text {
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: flex-start;
    padding-top: 60px;
}
.business_text b {
    font-weight: bold;
    font-size: 30px;
    letter-spacing: 0.1em;
    color: #fff;
    display: block;
}
.business_text p {
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 32px;
    color: #fff;
    width: 693px;
    font-weight: normal;
}
ul.business_list {
    width: 1200px;
    margin: 152px auto 0 auto;
    position: relative;
    z-index: 10;
}
ul.business_list li {
    position: relative;
    z-index: 10;
    align-items: flex-start;
    margin-bottom: 221px;
}
ul.business_list li::before {
    content: "";
    width: 91.6666%;
    background-color: #fff;
    height: 411px;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 0;
}
ul.business_list li:nth-child(2)::before {
    left: 0;
    right: auto;
}
ul.business_list li div {
    width: calc(100% - 590px);
    position: relative;
    box-sizing: border-box;
    padding: 70px 60px 0 70px;
}
ul.business_list li figure {
    width: 590px;
    position: relative;
    margin-top: -60px;
}
ul.business_list li figure.order_2 {
    order: 2;
}
ul.business_list li figure figcaption {
    position: absolute;
    top: 20px;
}
ul.business_list li:nth-child(2) figure figcaption {
    bottom: 10px;
    right: 0;
    top: auto;
}
ul.business_list li figure img {
    width: 100%;
}
ul.business_list li div h2 {
    font-weight: bold;
    font-size: 34px;
    letter-spacing: 0.1em;
    text-align: left;
    color: #df6400;
    line-height: 1;
    position: relative;
}
ul.business_list li div h2::before {
    content: "";
    width: 46px;
    height: 1px;
    background-color: #DF6400;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    left: -70px;
}
ul.business_list li div p {
    font-size: 14px;
    letter-spacing: 0.06em;
    line-height: 32px;
    color: #2c2c2c;
    padding-top: 20px;
}
ul.business_list li figure figcaption span {
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
    line-height: 58px;
    text-align: left;
    color: #2c2c2c;
    display: inline-block;
    background-color: #fff;
    line-height: 1;
    padding: 14px 0 14px 23px;
    margin-bottom: 10px;
    position: relative;
}
ul.business_list li figure figcaption span::after {
    content: "";
    position: absolute;
    right: -20px;
    top: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 26px 0 26px 20px;
    border-color: transparent transparent transparent #ffffff;
}
ul.business_list li:nth-child(2) figure figcaption span {
    padding: 14px 1px 14px 10px;
}
ul.business_list li:nth-child(2) figure figcaption span::after {
    width: 0;
    right: auto;
    left: -20px;
    height: 0;
    border-style: solid;
    border-width: 26px 20px 26px 0;
    border-color: transparent #ffffff transparent transparent;
}
ul.business_list li:nth-child(2) figure figcaption p:nth-child(1) {
    position: relative;
    right: -2px;
}
#business a.btn {
    margin: 0 auto;
}
ul.business_list li:nth-child(3) {
    margin-bottom: 140px;
}
/*********************************
	price
*********************************/
#price {
    background-color: #2C2C2C;
    padding-top: 113px;
}
.price_wrap {
    position: relative;
}
#price h1 {
    color: #fff;
    position: absolute;
}
.price_info {
    width: 900px;
    margin-left: 236px;
    background-color: #fff;
    margin-bottom: 60px;
}
.price_info .main_price {
    padding: 60px 0;
    justify-content: flex-start;
}
.price_info .main_price span {
    font-weight: bold;
    font-size: 30px;
    letter-spacing: 0.1em;
    color: #2c2c2c;
    padding-left: 80px;
}
.price_info .main_price p {
    font-weight: bold;
    font-family: 'NotoSans';
    font-size: 30px;
    letter-spacing: 0.1em;
    color: #2c2c2c;
    padding-left: 140px;
    position: relative;
}
.price_info .main_price p::after {
    content: "";
    width: 46px;
    height: 1px;
    background-color: #2C2C2C;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 46px;
}
.price_info .main_price p small.pc {
    font-size: 14px;
    font-weight: normal;
}
.price_detail {
    width: 900px;
    margin-left: 236px;
    color: #fff;
    margin-bottom: 100px;
}
.price_detail dl {
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 60px;
}
.price_detail dl dt {
    width: 200px;
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.1em;
}
.price_detail dl dd {
    width: 700px;
    letter-spacing: 0.2em;
}
.price_detail dl dd b {
    font-size: 20px;
    line-height: 36px;
}
.price_detail dl dd ul li {
    justify-content: space-between;
    font-size: 16px;
    letter-spacing: 0.06em;
    padding-bottom: 20px;
    padding-top: 20px;
    border-bottom: 1px solid #fff;
    font-family: 'NotoSans';
}
.price_detail dl dd ul li:nth-child(1) {
    padding-top: 0;
}
#price a.btn {
    background-color: #fff;
    color: #2C2C2C;
    margin: 0px auto;
    position: relative;
    top: 30px;
}
#price a.btn span {
    color: #2C2C2C;
}
#price .btn::after {
    background-color: #2C2C2C;
}
#price .btn:hover {
    background-color: #DF6400;
}
#price .btn:hover span {
    color: #fff;
}
#price .btn:hover::after {
    background-color: #fff;
}


/*********************************
	COMPANY
*********************************/
#company {
    background-color: #F4F4F4;
    padding-top: 180px;
    padding-bottom: 90px;
}
#company h1.right_long_ttl::after {
    top: -60px;
}
.company_info_wrap {
    justify-content: flex-start!important;
    align-items: flex-start;
}
.company_info_wrap .company_img {
    width: 43.85%;
    height: 416px;
    background-image: url(./images/top/company.jpg);
}
.company_info_wrap ul {
    margin-left: 64px;
}
.company_info_wrap ul li {
    justify-content: flex-start;
    margin-bottom: 29px;
    font-family: 'NotoSans';
}
.company_info_wrap ul li span {
    display: block;
    width: 80px;
    background-size: 80px 30px;
    background-image: url(./images/top/arrow_box.svg);
    width: 80px;
    display: inline-block;
    text-align: center;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 30px;
    margin-right: 27px;
}
.company_info_wrap ul li p {
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 32px;
}
.company_info_wrap ul li:nth-child(6) {
    align-items: flex-start;
    margin-bottom: 16px;
}
.company_map {
    overflow: hidden;
}
.company_map figure  {
    margin-top: 70px;
}
.company_map figure img {
    width: 100%;
}
.company_map figure img.map_pc {
    display: block;
}
.company_map figure img.map_sp {
    display: none;
}
.company_map a {
    float: right;
    display: block;
    text-decoration: underline;
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 32px;
    text-align: left;
    color: #df6421;
    padding-top: 10px;
}

/*********************************
    news
*********************************/
#news {
    background-color: #F4F4F4;
    padding-top: 0px;
    padding-bottom: 150px;
}
#news h1 {
    position: absolute;
}
.news_wrap {
    width: 900px;
    margin-left: auto;
}
.page_news .news_wrap {
    padding: 150px 0;
    margin: 0 auto;
}
.news_wrap ul li dl {
    justify-content: flex-start;
    padding-bottom: 30px;
    padding-top: 30px;
    border-bottom: 1px solid #2C2C2C;
    position: relative;
}
.news_wrap ul li dl dt {
    width: 200px;
    font-family: 'NotoSans';
    font-size: 16px;
    letter-spacing: 0.06em;
}
.news_wrap ul li dl dd {
    font-size: 16px;
    letter-spacing: 0.06em;
    line-height: 1em;
    position: relative;
}
.news_wrap ul li dl dd a {
    color: #2C2C2C;
}
.news_wrap ul li dl::after {
    content: "";
    display: block;
    width: 20px;
    height: 1px;
    background-color: #2C2C2C;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
}
#news a.btn {
    margin: 80px auto 0 auto;
}
.page_news {
    background-color: #F4F4F4;
}

/*********************************
	CONTACT
*********************************/
#contact {
    padding-top: 255px;
    position: relative;
}
#contact::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 300px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    background-image: url(./images/top/top_contact.jpg);
}
#contact a {
    width: 990px;
    margin: 0 auto;
    background-color: #DF6400;
    color: #fff;
    padding: 58px 107px 58px 60px;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    transition: all 0.25s;
    -webkit-transition: all 0.25s;
    -moz-transition: all 0.25s;
    -ms-transition: all 0.25s;
    -o-transition: all 0.25s;
}
#contact a span {
    display: block;
    font-size: 50px;
    letter-spacing: 0.1em;
    display: inline-block;
    line-height: 1;
}
#contact a p {
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.2em;
    line-height: 36px;
    display: inline-block;
    line-height: 1;
    position: relative;
}
#contact a p::after {
    content: "";
    background-color: #fff;
    width: 20px;
    height: 1px;
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: -44px;
    transition: all 0.25s;
    -webkit-transition: all 0.25s;
    -moz-transition: all 0.25s;
    -ms-transition: all 0.25s;
    -o-transition: all 0.25s;
}
#contact a:hover {
    background-color: #2C2C2C;
}
#contact a:hover p::after {
    right: -54px;
}
footer {
    padding-top: 80px;
}
footer figure {
    text-align: center;
    margin-bottom: 50px;
}
#footer_nav ul {
    width: 814px;
    margin: 0 auto;
    justify-content: space-between;
}
#footer_nav ul li a {
    font-size: 14px;
    letter-spacing: 0.06em;
    color: #2c2c2c;
}
footer small.copy {
    display: block;
    text-align: center;
    font-size: 12px;
    letter-spacing: 0.1em;
    padding-top: 40px;
    padding-bottom: 50px;
}
/*********************************
	SP
*********************************/
@media screen and (max-width: 768px) {
    #main_visual {
        background-position: center left 40%;
    }
    video.video_pc {
        display: none;
    }
    video.video_sp {
        display: block;
    }
    #main_visual h1 {
        font-size: 41px;
        letter-spacing: 0.1em;
        top: 34%;
    }
    #main_visual .online {
        left: 4%;
    }
    #main_visual .online div img.text_circle {
        width: 168px;
        height: 168px;
    }
    #main_visual .online div img.circle_banner {
        width: 130px;
        height: 130px;
    }

    .message_text_wrap {
        margin-left: 8%;
        width: 92%;
        box-sizing: border-box;
        padding: 40px;
        top: 373px;
    }
    .message_text_wrap b {
        font-size: 24px;
        letter-spacing: 0.1em;
        line-height: 36px;
    }
    img.message_logo {
        width: 140px;
        right: -10px;
        top: 62px;
    }
    .message_left {
        width: 100%;
        position: absolute;
        left: 0;
        top: 323px;
        z-index: -1;;
    }
    h1.vertical_ttl p {
        font-size: 46px;
        letter-spacing: 0.2em;
    }
    #message {
        padding: 50px 0 0 0;
        min-height: 1040px;
    }
    .message_text_wrap p {
        letter-spacing: 0.06em;
        line-height: 32px;
    }
    h1.right_long_ttl {
        margin-left: 8%;
        
    }
    h1.right_long_ttl span {
        font-size: 46px;
        letter-spacing: 0.1em;
    }
    h1.right_long_ttl::after {
        top: -70px;
    }
    #profile {
        padding-top: 83px;
        padding-bottom: 41px;
    }
    #profile figure.prof_img {
        position: relative;
        right: auto;
        width: 92%;
        margin-left: 8%;
    }
    #profile figure.prof_img a {
        position: absolute;
        right: 8%;
    }
    .prof_info {
        padding-top: 78px;
    }
    .prof_info ul li p {
        font-size: 14px;
        letter-spacing: 0.06em;
        line-height: 32px;
        padding-top: 31px;
    }
    .prof_info ul li:nth-child(3) p:nth-of-type(1) {
        padding-top: 10px;
    }
    .prof_info ul li:nth-child(1) p {
        padding-top: 17px;
    }
    .prof_info ul li.milestone p {
        padding-top: 0;
    }
    .prof_info ul li.hobby p {
        padding-top: 12px;
    }
    .prof_info ul li.milestone p span {
        display: block;
        padding-top: 30px;
    }
    #business h1 {
        font-size: 46px;
        letter-spacing: 0.1em;
        line-height: 50px;
        flex-wrap: wrap;
    }
    #business h1 p {
        width: 100%;
    }
    #business::before {
        top: 172px;
        background-size: cover;
        background-position: center top;
        height: 680px;
    }
    #business h1 span {
        padding-left: 0;
        padding-top: 18px;
    }
    .business_text {
        flex-wrap: wrap;
        padding-top: 55px;
    }
    .business_text p {
        padding-top: 17px;
    }
    ul.business_list {
        width: 100%;
        margin-top: 93px;
    }
    ul.business_list li::before {
        display: none;
    }
    ul.business_list li div {
        width: 92%;
        margin-left: 8%;
        background-color: #fff;
        padding: 36px 30px;
    }
    ul.business_list li {
        margin-bottom: 40px;
    }
    ul.business_list li figure figcaption span {
        font-size: 18px;
        letter-spacing: 0.1em;
        line-height: 40px;
        padding: 0 0 0 23px;
    }
    ul.business_list li figure figcaption span::after {
        border-width: 20px 0 20px 20px;
    }
    ul.business_list li:nth-child(2) figure figcaption span::after {
        border-width: 21px 21px 20px 0;
    }
    ul.business_list li div h2 {
        font-size: 24px;
    }
    ul.business_list li div h2::before {
        width: 22px;
        left: -30px;
    }
    ul.business_list li figure.order_2 {
        order: 1;
    }
    .order_1 {
        order: 2;
    }
    ul.business_list li figure {
        margin-top: 0;
    }
    ul.business_list li:nth-child(2) figure figcaption span {
        padding: 0 0 0 23px;
    }
    ul.business_list li figure {
        height: 262px;
    }
    ul.business_list li:nth-child(3) {
        margin-bottom: 60px;
    }
    #business {
        padding-bottom: 80px;
    }
    #price {
        padding-top: 52px;
    }
    #price h1 {
        flex-wrap: wrap;
        width: 145px;
        position: static;
    }
    #price h1.vertical_ttl p{
        writing-mode: horizontal-tb;
    }
    #price h1.vertical_ttl span {
        writing-mode: horizontal-tb;
    }
    .price_info,
    .price_detail {
        width: 100%;
        margin: 0 auto;
    }
    .price_info .main_price {
        padding: 22px 0 25px 0;
        margin: 52px 0 70px 0;
    }
    .price_info .main_price span {
        padding-left: 20px;
    }
    .price_info .main_price p {
        padding-left: 20px;
        font-size: 26px;
        padding-top: 11px;
    }
    .price_info .main_price p small.sp {
        font-size: 18px;
        letter-spacing: 0;
    }
    .price_info .main_price p small.pc {
        display: block;
        text-align: right;
    }
    .price_info .main_price p::after {
        left: 50%;
        top: -120px;
    }
    .price_detail dl:nth-of-type(1) dd {
        padding-left: 25px;
        padding-top: 13px;
    }
    .price_detail dl:nth-of-type(1) dd small {
        font-size: 14px;
        letter-spacing: 0.1em;
    }
    .price_detail dl dd ul li:nth-child(1) {
        padding-top: 17px;
    }
    .price_detail dl dd ul li span {
        display: block;
        width: 100%;
    }
    .price_detail dl dd ul li span:nth-of-type(2) {
        display: block;
        text-align: right;
        padding-top: 10px;
    }
    .price_detail dl:nth-of-type(3) {
        margin-bottom: 40px;
    }
    /*********************************
    news
    *********************************/

    #news h1 {
        position: relative;
        writing-mode: inherit;
        flex-wrap: wrap;
        width: calc(100vw - 10%);
        box-sizing: border-box;
        margin-bottom: 20px;
    }
    #news h1::after {
        content: "";
        width: 100%;
        height: 1px;
        display: block;
        background-color: #2c2c2c;
        position: absolute;
        top: -30px;
        bottom: 0;
        margin: auto;
    }
    #news h1 span,
    #news h1 p {
        writing-mode: inherit;
        display: block;
        background-color: #F4F4F4;
        position: relative;
        z-index: 10;
    }
    #news h1 span {
        width: 100%;
        letter-spacing: 0.2em;
    }
    #news h1 p {
        letter-spacing: 0.1em;
        padding-right: 27px;
    }
    .news_wrap {
        width: 100%;
    }
    .news_wrap ul li dl::after {
        display: none;
    }
    .news_wrap ul li dl {
        padding-bottom: 20px;
    }
    .news_wrap ul li dl dt {
        width: 100%;
        padding-bottom: 9px;
    }
    .news_wrap ul li dl dd {
        width: 100%;
        font-size: 14px;
        letter-spacing: 0.06em;
        line-height: 32px;
    }
    #news a.btn {
        margin: 60px auto 0 auto;
    }
    #news {
        padding-bottom: 80px;
    }
    .page_news {
        padding-bottom: 60px;
    }
    .page_news .news_wrap {
        margin: 0 auto;
        width: 84%;
        padding: 30px 0 0 0;
    }
    
    /*********************************
    company
    *********************************/
    #company {
        padding-top: 106px;
    }
    .company_info_wrap {
        width: 84%;
        margin: 0 auto;
    }
    .company_info_wrap .company_img {
        width: 100%;
        height: 219px;
        margin-top: 20px;
        margin-bottom: 30px;
    }
    .company_info_wrap ul {
        margin-left: 0;
    }
    .company_info_wrap ul li {
        flex-wrap: wrap;
        margin-bottom: 23px;
    }
    .company_info_wrap ul li p {
        width: 100%;
    }
    .company_map figure img.map_pc {
        display: none;
    }
    .company_map figure img.map_sp {
        display: block;
    }
    .company_map figure {
        margin-top: 40px;
    }
    #contact::before {
        background-image: url(./images/top/top_contact_sp.jpg);
        height: 340px;
    }
    #contact a span {
        font-size: 40px;
    }
    #contact a {
        width: 92%;
        margin-left: 8%;
        padding: 35px 28px 40px 34px;
    }
    #contact a p {
        margin-top: 40px;
    }
    
}