@charset "utf-8";
/* #Mincho */
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho&display=swap');
/* Sacramento */
@import url('https://fonts.googleapis.com/css2?family=Sacramento&display=swap');

#Mincho {
    font-family: 'Shippori Mincho', serif;
}

#YuGothic {
    font-family: "游ゴシック体","Yu Gothic",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
}

#Numbers {
    font-family: 'M PLUS Rounded 1c', sans-serif;
    font-family: 'Open Sans Condensed', sans-serif;
    font-family: 'Quicksand', sans-serif;
}

#Noto {
    font-family: 'Noto Sans JP', sans-serif;
}

.breadcrumb {
    height: 30px;
    width: 74%;
    color: #323232;
    margin: 0 auto;
    padding: 24px 0;
}

.list, .slash {
    font-family: 'M PLUS Rounded 1c', sans-serif;
    font-family: 'Open Sans Condensed', sans-serif;
    font-family: 'Quicksand', sans-serif;
    line-height: 30px;
    font-size: 12px;
}

.list:link, .list:visited, .list:active {
    color: #323232;
    text-decoration: none;
}

.slash {
    margin: 0 6px;
}


/* メインページ */
.order {
    color: #323232;
    margin-top: 20px;
}

.order-header {
    height: 320px;
    width: 100%;
    background-image: url("../image/IMG_1710.jpg");
    background-size: cover;
    background-position: 10% 40%;
    position: relative;
    box-sizing: border-box;   
    /* 複数行テキスト上下中央 */
    display: flex; /* 子要素をflexboxで揃える */
    flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center;  /* 子要素をflexboxにより中央に配置する */
}

.header-textbox {
    color: rgba(0,0,0,0.7);
    width: 40%;
    margin-left: auto;
}

h1.header-title {
    font-size: 2em;
    font-weight: 300;
    margin: 0;
}

h2.header-subtitle {
    font-size: 1.3em;
    margin: 0;
    margin: 0 auto;
    padding-top: 8px;
    padding-left: 4px;
}

.order-contents {
    margin-top: 120px;
}

.content-header1 {
    width: 70%;
    text-align: center;
    background: #f4f4f4;
    margin: 0 auto;
    padding: 30px 40px;
}

span.header-text1 {
    display: block;
    font-weight: 1em;
    line-height: 2.2;
}

.content-main1 {
    width: 80%;
    text-align: center;
    margin: 0 auto;
}

img[src$="image/gift5.jpg"] {
    height: 520px;
    width: 80%;
    box-sizing: border-box;
    object-fit: cover;
}

.content2, .content4, .content5 {
    margin-top: 90px;
}

.content3 {
    margin-top: 90px;
    text-align: center; 
}

.content3-header {
    margin-bottom: 30px;
}

h2.content3-header-text {
    font-size: 1.1em;
    font-weight: 200;
    position: relative;
    padding: 8px;
    text-align: center;
}

h2.content3-header-text:before {
    position: absolute;
    bottom: -10px;
    left: calc(50% - 30px);
    width: 60px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #fa723d;
}

.content3-blocks {
    height: auto;
    width: 80%;
    display: flex;
    margin: 0 auto;
    margin-top: 40px;
}

#block {
    text-align: left;
    flex: 1;
    color: #323232;
    margin: 10px;
    padding: 8px;
}

span.block-number {
    font-size: 1.6em;
    font-family: 'Sacramento', cursive;
    text-align: left;
    display: block;
}

span.block-text {
    font-size: 1em;
    line-height: 2;
    text-align: justify;
}

.content2-flexbox, .contact-mail5, .contact-telnumbers5 {
    display: flex;
}

.content2-flexbox {
    width: 60%;
    box-sizing: border-box;
    margin: 0 auto;
}

.content-leftbox2 {
    height: 360px;
    width: 50%;
    box-sizing: border-box;
}

.leftbox-textbox2 {
    height: 320px;
    display: inline-block;
    text-align: left;
    /* 複数行テキスト上下中央 */
    display: flex; /* 子要素をflexboxで揃える */
    flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: left;  /* 子要素をflexboxにより中央に配置する */
}

.leftbox-header {
    margin-bottom: 30px;
}

h1.leftbox-header-title {
    font-size: 1.1em;
    font-weight: 200;
    position: relative;
    text-align: left;
    margin-top: 0;
    padding-bottom: 8px;
}

h1.leftbox-header-title:before {
    position: absolute;
    bottom: -10px;
    left: 0;
    width: 60px;
    height: 1px;
    content: '';
    border-radius: 3px;
    background: #fa723d;
}

.leftbox-contents {
    margin-bottom: 10px;
}

span.leftbox-text2-1 {
    font-weight: 400;
    font-size: 1.1em;
    margin: 0;
}

p.leftbox-text2-2 {
    font-size: 1em;
    font-weight: 400;
    margin: 0;
}

h1.header-title3 {
    font-family: "游ゴシック体","Yu Gothic",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,sans-serif;
    font-weight: 400;
}

h1.header-title3 {
    font-size: 18px;
}

#leftline:after {
    width: 70px;
    margin-top: 10px;
    height: 1px;
    content: '';
    display: block;
    background-color: #fa723d;
}

#centerline:after {
    width: 70px;
    margin-top: 10px;
    height: 1px;
    content: '';
    display: block;
    margin-right: auto;
    margin-left: auto;
    background-color: #fa723d;
}

.content-rightbox2 {
    height: 360px;
    width: 50%;
    background-color: #fff;
    box-sizing: border-box;
    margin-left: auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

img[src$="image/gift4.jpg"] {
    height: 330px;
    box-sizing: border-box;
}

.content-flows {
    margin-top: 50px;
}

#flow-block {
    color: #fff;
    height: auto;
    width: 60%;
    display: flex;
    margin: 0 auto;
    margin-bottom: 30px;
}

#left-block {
    border-right: solid 1px #fff;
    width: 8%;
    text-align: center;
}

#left-block, #right-block {
    font-size: 1em;
    padding: 0 40px;
}

.flow1, .flow2, .flow3, .flow4, .flow5, .flow6, .flow7 {
    background: #8fa1b3;
}

#numbers-text {
    font-family: 'M PLUS Rounded 1c', sans-serif;
    font-family: 'Open Sans Condensed', sans-serif;
    font-family: 'Quicksand', sans-serif;
    font-size: 1em;
    line-height: 1.4;
}

#texts-text {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 300;
    font-size: 1em;
    line-height: 1.4;
}

.content5 {
    margin-bottom: 60px;
}

.content-contact5 {
    margin: 0 auto;
    width: 30%;
}

.contact-mail5 {
    border: solid 1px #073061;
    color: #073061;
    justify-content: center;
}

.contact-mail5:hover {
    background-color: #073061;
    color: #fff;
}

i.fa-envelope {
    font-size: 18px;
    line-height: 62px;
    margin: 0;
    padding-right: 8px;
}

p.mail-text5 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-size: 1em;
    line-height: 60px;
    margin: 0;
}

a.contact-mail5:visited, a.contact-mail5:link, a.contact-mail5:active {
    text-decoration: none;
}

.contact-telnumbers5 {
    margin-top: 24px;
}

.telnumbers-tel5, .telnumbers-fax5 {
    flex: 1;
    text-align: center;
    border: solid 1px #b5c1de;
}

.telnumbers-tel5 {
    margin-right: 6px;
}

.telnumbers-fax5 {
    margin-left: 6px;
}

p.tel-text5, p.fax-text5 {
    font-family: 'M PLUS Rounded 1c', sans-serif;
    font-family: 'Open Sans Condensed', sans-serif;
    font-family: 'Quicksand', sans-serif;
    font-size: 1em;
    color: #073061;
}


/* 大きいディスプレイに対応 */
@media screen and (min-width: 1680px)  {
}


/* スマートフォン */
@media screen and (max-width: 600px) {

    .breadcrumb {
        width: 100%;
        margin: 0;
        padding: 0;
        padding-left: 16px;
        box-sizing: border-box;
    }

    .list, .slash {
        font-size: 10px;
    }

    .order-header {
        height: 220px;
        width: 100%;
        background-position: 100% 40%;
        background-size: 110%;
    }

    .header-textbox {
        width: 50%;
    }

    h1.header-title {
        font-size: 1.6em;
    }

    h2.header-subtitle {
        font-size: 1.2em;
    }

    img[src$="image/gift5.jpg"] {
        height: 240px;
        width: 100%;
        box-sizing: border-box;
        object-fit: cover;
    }
    
    .order-contents {
        margin-top: 60px;
    }
    
    .content-header1 {
        width: 100%;
        box-sizing: border-box;
        font-size: 0.9em;
        margin: 0 auto;
        padding: 20px;
    }
    
    .content2-flexbox {
        width: 100%;
        display: block;
    }
    
    .content-leftbox2 {
        height: auto;
        width: 100%;
    }
    
    .leftbox-textbox2 {
        height: auto;
        text-align: center;
    }
    
    h1.leftbox-header-title {
        text-align: center;
    }
    
    h1.leftbox-header-title:before {
        left: calc(50% - 30px);
    }
    
    .content-rightbox2 {
        height: auto;
        width: 100%;
        box-sizing: border-box;
        margin: 0 auto;
        padding-top: 20px;
    }

    img[src$="image/gift4.jpg"] {
        height: 280px;
        width: 100%;
        object-fit: cover;
        box-sizing: border-box;
        margin: 0 auto;
    }
    
    .content3-blocks {
        width: 88%;
        display: block;
    }

    #block.home3-block2, #block.home3-block3, #block.home3-block4 {
        margin-top: 16px;
    }

    #flow-block {
        width: 100%;
    }

    #left-block {
        width: 30%;
        box-sizing: border-box;
    }

    #right-block {
        width: 70%;
    }

    .content-flows {
        width: 90%;
        margin: 0 auto;
        padding-top: 20px;
    }

    #left-block, #right-block {
        font-size: 1em;
        padding: 0 10px;
    }

    #numbers-text, #texts-text {
        font-size: 0.8em;
    }

    .content-contact5 {
        font-size: 0.8em;
        width: 80%;
    }
}


/* タブレット */
@media screen and (min-width: 601px) and (max-width: 1024px) {
        
    .breadcrumb {
        width: 84%;
    }
    
    .order-header {
        height: 330px;
    }

    .content2-flexbox {
        width: 80%;
        box-sizing: border-box;
    }

    .content-rightbox2 {
        height: auto;
        width: 100%;
        box-sizing: border-box;
        margin: 0 auto;
        padding-top: 20px;
    }

    img[src$="image/gift4.jpg"] {
        height: 280px;
        width: 100%;
        object-fit: cover;
        box-sizing: border-box;
        margin: 0 auto;
    }

    #flow-block {
        width: 80%;
    }

    .content-contact5 {
        width: 50%;
    }
}

/* 小さめのタブレット */
@media screen and (min-width: 601px) and (max-width: 768px) {

    .content-main1 {
        width: 100%;
    }
    
    span.leftbox-text2-1 {
        display: block;
    }
}
