@charset "utf-8";

@media screen and (max-width: 768px) {

    .break {
        display: block;
    }
}

/* =====sec01===== */
@media screen and (max-width: 768px) {

    .sec01 {
        margin: 80px 0 0;
        background: url(../img/naishi01_5.jpg) right 10% center/cover no-repeat;
    }

    .sec01_title {
        padding: 0 20px 20px;
    }

    .sec01_title .break.break01 {
        display: block;
    }

    .sec01_title {
        line-height: 1.5;
    }

    .sec01_text .break {
        display: block;
    }

    .sec01_body {
        background-size: 50%;
    }

    .sec01 .body_text {
        font-size: 18px;
    }

    .sec01 .body_text .break {
        display: block;
    }

    .sec01 .body_text .color {
        font-size: 23px;
    }
}

@media screen and (max-width: 650px) {

    .sec01_title {
        font-size: 28px;
    }
    
    .sec01_title .small {
        font-size: 16px;
    }
}

@media screen and (max-width: 550px) {

    .sec01_title .break.break02 {
        display: block;
    }
}

@media screen and (max-width: 400px) {

    .sec01_title {
        letter-spacing: 0.1em;
    }

    .sec01_item .item_text {
        letter-spacing: 0.1em;
    }

    .sec01 .body_text {
        letter-spacing: 0.1em;
    }
}

/* =====sec02===== */
@media screen and (max-width: 768px) {

    .sec02_title .color {
        font-size: 24px;
        color: #e62520;
        font-weight: bold;
    }

    .kodawaribox {
        display: block;
    }

    .kodawari {
        width: 355px;
        max-width: 100%;
        height: 290px;
        border: 1px solid #1f296e;
        text-align: center;
        margin: 0 auto;
    }

    .kodawari:nth-of-type(1) {
        margin: 0 auto 100px;
    }

    .kodawaribox:before {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        display: inline-block;
        width: 54px;
        height: 54px;
        background: url(../img/home_icon04.png) center/contain no-repeat;
    }

    .kodawari_text {
        font-size: 16px;
        font-weight: bold;
        line-height: 1.7;
    }

    .sec02_text {
        font-size: 18px;
        font-weight: bold;
        text-align: center;
    }

    .sec02_text .color01 {
        font-size: 22px;
        font-weight: bold;
        color: #1f296e;
    }
    
    .sec02_text .color02 {
        font-size: 22px;
        font-weight: bold;
        color: #be9e3a;
    }
    
    .sec02_text .large {
        font-size: 22px;
        font-weight: bold;
    }
}

/* =====sec03===== */
@media screen and (max-width: 768px) {

    .sec03 {
        width: 100%;
        letter-spacing: 0.28em;
    }
    
    .sec03_head {
        width: 100%;
        padding: 35px 0;
        box-sizing: border-box;
        background: linear-gradient(to right, #100d3d, #0a2f75, #202663);
    }
    
    .sec03 .head_inner {
        display: block;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        margin: 0 auto;
    }
    
    .sec03_title {
        display: inline-block;
        width: 100%;
        padding: 80px 0 0;
        margin: 0 0 20px;
        background: url(../img/logo05.png) top 13px center/63px no-repeat;
        font-size: 18px;
        font-weight: bold;
        color: #fff;
        text-align: center;
    }
    
    .sec03 .head_text {
        font-size: 18px;
        font-weight: bold;
        color: #fff;
        line-height: 2;
        letter-spacing: 0.04em;
        text-align: center;
    }
    
    .sec03 .head_text .small {
        font-size: 18px;
        font-weight: bold;
    }
    
    .sec03 .head_text .color {
        color: #bd9d3a;
        font-weight: bold;
    }
    
    .sec03_cont01 {
        width: 100%;
        height: 550px;
        padding: 0 20px;
        box-sizing: border-box;
        background: url(../img/naishi04.jpg) top 20% center/cover no-repeat;
    }
    
    .sec03 .cont01_inner {
        position: relative;
        width: 100%;
        height: 100%;
        margin: 0 auto;
    }
    
    .sec03 .cont01_text {
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        display: inline-block;
        width: 70%;
        padding: 20px;
        box-sizing: border-box;
        background: #fff;
        font-size: 16px;
        font-weight: bold;
        line-height: 2;
    }
    
    .sec03 .cont01_text .small {
        display: block;
        margin: 0 0 15px;
        font-size: 16px;
        font-weight: bold;
    }
    
    .sec03 .cont02_03box {
        width: 100%;
        background: #fffdf4;
    }
    
    .sec03_cont02 {
        width: 100%;
        padding: 56px 20px 143px;
        box-sizing: border-box;
        background: url(../img/naishi05.png) center bottom/cover no-repeat;
    }
    
    .sec03 .cont02_text {
        margin: 0 0 35px;
        font-size: 18px;
        font-weight: bold;
        text-align: center;
        line-height: 2;
    }
    
    .sec03 .cont02_text .small {
        font-size: 18px;
        font-weight: bold;
    }
    
    .sec03 .cont02_text .large {
        font-size: 20px;
        font-weight: bold;
    }
    
    .sec03 .cont02_text .grande {
        font-size: 22px;
        font-weight: bold;
    }
    
    .sec03 .cont02_list {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
    }
    
    .sec03 .cont02_item {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 178px;
        height: 178px;
        margin: 0 10px 10px;
        background: url(../img/naishi06.png) center center/cover no-repeat;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.8;
        text-align: center;
    }
    
    .sec03_cont03 {
        width: 100%;
        padding: 135px 20px 75px;
        box-sizing: border-box;
        background: #fffdf4 url(../img/logo03.png) center top 33px /91px no-repeat;
    }
    
    .sec03 .cont03_title {
        margin: 0 0 40px;
        font-size: 18px;
        font-weight: bold;
        text-align: center;
    }
    
    .sec03 .cont03_list {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        margin: 0 0 20px;
    }
    
    .sec03 .cont03_item {
        width: 216px;
        height: 110px;
        border: 1px solid #bd9d3a;
        margin: 0 30px 20px;
        background: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 16px;
        font-weight: bold;
        line-height: 1.7;
        letter-spacing: 0;
        text-align: center;
    }
    
    .sec03 .cont03_text {
        font-size: 20px;
        font-weight: bold;
        color: #1f296e;
        line-height: 1.5;
        text-align: center;
    }
    
    .sec03 .cont03_text .color {
        font-weight: bold;
        color: #e62520;
    }
}


/* =====sec04===== */
@media screen and (max-width: 1000px) {

    .sec04_cont04 .body_wrap {
        width: 700px;
        padding: 0 10px;
    }

    .sec04 .cont04_body {
        width: 70%;
    }

    .step02_06wrap:before {
        height: calc(100% - 206px)
    }

    .sec04 .step_title {
        font-size: 18px;
    }

    .sec04 .step_title span {
        margin: 0 0.5em 0 0;
    }

    .sec04 .step_text01 {
        font-size: 16px;
    }

    .sec04 .step_text02 {
        width: 100%;
        padding: 0 20px;
        box-sizing: border-box;
    }

    .sec04 .step_title.title02 {
        flex-wrap: wrap;
        line-height: 1.5;
    }

}

@media screen and (max-width: 880px) {

    .sec04_cont04 .body_wrap {
        width: 500px;
    }
}

@media screen and (max-width: 856px) {

    .sec04 .cont03_list {
        display: block;
        width: 374px;
        margin: 0 auto;
    }

    .sec04 .cont03_item {
        margin: 0 0 30px;
    }
}

@media screen and (max-width: 800px) {

    .sec04_cont04 .body_wrap {
        width: 90%;
    }

    .sec04 .cont04_body {
        width: 100%;
    }

    .sec04 .step:before {
        display: none;
    }

    .sec04 .step02:after {
        display: none;
    }

    .sec04 .step06:after {
        display: none;
    }

    .sec04 .step_title {
        padding: 100px 0 10px;
    }

    .sec04 .step_title:before {
        top: -20px;
        left: 50%;
        transform: translateX(-50%);
        width: 200px;
        height: 80px;
        font-size: 20px;
        line-height: 80px;
    }

    .sec04 .tate{
        position: static;
        transform: none;
        display: block;
        padding: 0 0 5px;
        margin: 50px 0 0;
        background: none;
        color: #e62520;
        writing-mode: horizontal-tb;
        line-height: 1.5;
        text-align: center;
    }

    .sec04 .cont02_item {
        height: 128px;
        font-size: 16px;
    }
}

@media screen and (max-width: 752px) {

    .sec04 .cont01_inner {
        width: 100%;
    }

    .sec04 .cont01_textbox {
        padding: 30px;
    }
}

@media screen and (max-width: 700px) {

    .sec04 .tate .break01 {
        display: block;
    }
}

@media screen and (max-width: 600px) {

    .sec04 .cont03_title {
        line-height: 1.5;
    }

    .sec04 .cont03_title .break {
        display: block;
    }

    .sec04 .cont04_title {
        line-height: 1.5;
    }

    .sec04 .cont04_title .break {
        display: block;
    }
}

@media screen and (max-width: 550px) {

    .sec04 .cont01_title {
        line-height: 1.5;
    }

    .sec04 .cont01_title .break {
        display: block;
    }

    .sec04 .cont02_title {
        line-height: 1.5;
    }

    .sec04 .cont02_title .break {
        display: block;
    }
}

@media screen and (max-width: 500px) {

    .sec04 .head_text {
        font-size: 22px;
    }

    .sec04 .head_text .small {
        font-size: 18px;
    }

    .sec04 .cont01_title {
        font-size: 20px;
        line-height: 1.5;
    }

    .sec04 .cont01_text01 {
        font-size: 16px;
    }

    .sec04 .cont01_text01 .large {
        font-size: 20px;
    }

    .sec04 .cont02_title {
        font-size: 20px;
    }

    .sec04 .cont03_title {
        font-size: 20px;
    }

    .sec04 .cont04_title {
        margin: 0 0 50px;
        font-size: 20px;
    }

    .sec04 .step02 .step_title .break,
    .sec04 .step03 .step_title .break {
        display: block;
    }

    .step02_05wrap .tate {
        bottom: -500px;
    }
}

@media screen and (max-width: 416px) {

    .sec04 .cont03_list {
        width: 100%;
    }

    .sec04 .cont03_item {
        width: 100%;
        font-size: 20px;
    }
}

@media screen and (max-width: 400px) {

    .sec04 .head_text {
        font-size: 18px;
        letter-spacing: 0;
    }

    .sec04 .head_text .small {
        font-size: 16px;
    }

    .sec04 .cont01_text01 .large {
        letter-spacing: 0.1em;
    }

    .sec04 .cont02_title {
        font-size: 20px;
    }

    .sec04 .cont03_title {
        font-size: 20px;
    }

    .sec04 .cont03_item {
        height: 116px;
        font-size: 16px;
    }

    .sec04 .tate {
        font-size: 18px;
    }

    .sec04 .tate .break02 {
        display: block;
    }
}

@media screen and (max-width: 768px) {
    
    .sec04_head {
        width: 100%;
        padding: 35px 0;
        box-sizing: border-box;
        background: linear-gradient(to right, #100d3d, #0a2f75, #202663);
    }
    
    .sec04 .head_inner {
        display: block;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        margin: 0 auto;
    }
    
    .sec04_title {
        display: inline-block;
        width: 100%;
        padding: 80px 0 0;
        margin: 0 0 20px;
        background: url(../img/logo05.png) top 13px center/63px no-repeat;
        font-size: 18px;
        font-weight: bold;
        color: #fff;
        text-align: center;
    }
    
    .sec04 .head_text {
        font-size: 18px;
        font-weight: bold;
        color: #fff;
        line-height: 2;
        letter-spacing: 0.04em;
        text-align: center;
    }
    
    .sec04 .head_text .small {
        font-size: 20px;
        font-weight: bold;
    }
    
    .sec04 .head_text .color {
        color: #bd9d3a;
        font-weight: bold;
    }
}

/* =====sec05===== */
@media screen and (max-width: 900px) {

    .sec05 {
        display: block;
        height: auto;
    }

    .sec05_img {
        width: 100%;
    }

    .sec05_img img {
        height: 265px;
    }

    .sec05_text {
        width: 100%;
        padding: 20px;
    }
}

@media screen and (max-width: 400px) {

    .sec05_text {
        font-size: 16px;
    }

    .sec05_text .break {
        display: block;
    }
}



/* =====sec06===== */

@media screen and (max-width: 768px) {


.sec06 {
    width: 100%;
    padding: 146px 20px 51px;
    border-top: 1px solid #be9e3a;
    border-bottom: 1px solid #be9e3a;
    box-sizing: border-box;
    background: url(../img/logo04.png) center top 42px no-repeat;
    background-color: #fffef5;
    text-align: center;
}

.sec06_box {
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
}

.sec06_contact {
    width: 469px;
    max-width: 100%;
}

.sec06_contact .title {
    padding: 8px 0;
    margin: 0 0 12px;
    background: #1f296e;
    font-size: 16px;
    font-family: "游ゴシック体";
    color: #fff;
}

.sec06_contact .tel {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    margin: 0 0 22px;
}

.sec06_contact .num {
    padding: 0 0 0 35px;
    margin: 0 20px;
    background: url(../img/home_icon12.png) center left no-repeat;
    font-size: 25px;
    font-weight: bold;
    font-family: "游ゴシック体";
}

.sec06_contact .time {
    padding: 0;
    font-size: 15px;
    font-family: "小塚ゴシック Pro";
    vertical-align: middle;
}

.sec06 .reservebox {
    position: relative;
    display: block;
    justify-content: center;
    width: 100%;
    padding: 25px 0 20px;
    border: 1px solid #be9e3a;
    box-sizing: border-box;
    margin: 0 auto;
    background: #fff;
}

.sec06 .reservebox:before {
    content: "オンライン予約";
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    width: 170px;
    height: 34px;
    padding: 0 0 0 53px;
    box-sizing: border-box;
    background: url(../img/home_icon02.png) top left 12px/25px no-repeat;
    background-color: #fff;
    font-size: 15px;
    font-family: "小塚ゴシック Pro";
    color: #be9e3a;
    line-height: 34px;
}

.sec06 .reserve {
    width: 204px;
    height: 38px;
    margin: 0 auto;
    background: #be9e3a;
    box-shadow: 1.5px 1.5px 1.5px rgba(82, 78, 35, 0.75);
}

.sec06 .reserve01 {
    margin: 0 auto 20px;
}

.sec06 .reserve a {
    display: block;
    box-sizing: border-box;
    font-size: 18px;
    color: #fff;
    font-family: "小塚ゴシック Pro";
    text-shadow: 3px 3px 3px rgba(82, 78, 35, 0.75);
    line-height: 38px;
}

.sec06 .reserve01 a {
    padding: 0 62px 0 30px;
    background: url(../img/home_icon14.png) top 9px right 28px no-repeat;
}

.sec06 .reserve02 a {
    padding: 0 40px 0 20px;
    background: url(../img/home_icon14.png) top 9px right 15px no-repeat;
}

}

