@charset "UTF-8";
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

index

---------------------------------------------------------------------------------------------------------------------------------------- */
/*------------------------------------------------------------mainphoto*/
#mainimage {
    height: calc(100vh - 90px);
    background: url(../img/index_img/mainimage_pc.png) no-repeat right 50%;
    background-size: 140% auto;
    position: relative;
}
#mainimage .container {
    padding-top: 12%;
    text-align: left;
}
#mainimage h2 {
    font-family: "NotoSerifSemiBold";
    font-size: calc(40px * 0.5);
    line-height: 1.5;
    color: #422a11;
    letter-spacing: -0.3pt;
    text-shadow: 0 1px 1px rgba(255, 255, 2550, 0.6), 0 -1px 1px rgba(255, 255, 2550, 0.6), -1px 0 1px rgba(255, 255, 2550, 0.6), 1px 0 1px rgba(255, 255, 2550, 0.6), 0 0 3px rgba(255, 255, 2550, 0.6), 0 0 5px rgba(255, 255, 2550, 1), 0 0 5px rgba(255, 255, 2550, 1);
}
#mainimage h2 span {
    display: inline-block;
    margin-left: -0.5em;
    letter-spacing: -0.3em;
}
#mainimage p.main_tx {
    margin-top: 0.8em;
    margin-left: 0.15em;
    font-family: "NotoSerifMedium";
    font-size: calc(24px * 0.6);
    line-height: 1.4;
    color: #643c21;
    text-shadow: 0 1px 1px rgba(255, 255, 2550, 0.6), 0 -1px 1px rgba(255, 255, 2550, 0.6), -1px 0 1px rgba(255, 255, 2550, 0.6), 1px 0 1px rgba(255, 255, 2550, 0.6), 0 0 3px rgba(255, 255, 2550, 0.6), 0 0 5px rgba(255, 255, 2550, 1), 0 0 5px rgba(255, 255, 2550, 1);
}
@media print, screen and (min-width:340px) {
    #mainimage {}
    #mainimage .container {
        padding-top: 15%;
    }
    #mainimage h2 {
        font-size: calc(40px * 0.6);
    }
    #mainimage p.main_tx {
        font-size: calc(24px * 0.75);
    }
}
@media print, screen and (min-width:768px) {
    #mainimage {
        top: -140px;
        height: 100%;
        background: url(../img/index_img/mainimage_pc.png) no-repeat center top;
        background-size: auto 570px;
    }	
    #mainimage .container {
        padding-top: 9%;
    }
    #mainimage h2 {
        font-size: 40px;
    }
    #mainimage p.main_tx {
        font-size: 24px;
    }
}
@media (orientation: landscape) and (max-width: 767px) {
    #mainimage {
        height: 300px;
        background: url(../img/index_img/mainimage_pc.png) no-repeat right 50%;	
        background-size: auto 100%;
    }
}
/*------------------------------------------------------------content*/
/* greeting */
#greeting {
    padding-top: 50px;
}
#greeting > .container {
    min-height: 495px;
    background: url(../img/index_img/bg_greeting.jpg) no-repeat center bottom;
    background-size: 100% cover;
}
#greeting .tx_area {
    padding-top: 20px;
    padding-bottom: 50px;
    /*
  background: url(../img/index_img/bg_greeting.jpg) no-repeat 34% bottom;
  background-size: 100% cover;*/
}
#greeting .tx_area p.cts_p {
    margin-bottom: 2em;
    text-shadow: 0 1px 1px rgba(255, 255, 255, 0.6), 0 -1px 1px rgba(255, 255, 255, 0.6), -1px 0 1px rgba(255, 255, 255, 0.6), 1px 0 1px rgba(255, 255, 255, 0.6), 0 0 4px rgba(255, 255, 255, 1);
}
@media print, screen and (min-width:768px) {
    #greeting {
        padding-top: 100px;
    }
    #greeting .tx_area {
        box-sizing: border-box;
    }
}
#message {
    position: relative;
    top: -17px;
}
#message .title02 {
    margin-top: 0;
    margin-bottom: 0;
    font-size: calc(40px * 0.75);
    color: #e0909f;
    text-shadow: 0 1px 1px rgba(255, 255, 255, 0.3), 0 -1px 1px rgba(255, 255, 255, 0.3), 1px 0 1px rgba(255, 255, 255, 0.3), 1px 0 1px rgba(255, 255, 255, 0.3), 0 0 3px rgba(255, 255, 255, 1), 0 0 5px rgba(255, 255, 255, 1);
}
#message .flex_container {
    position: relative;
    min-height: 280px;
}
#message .flex_container::after {
    content: "";
    display: block;
    width: 100%;
    height: 640px;
    position: absolute;
    top: 22px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background: #f2f2f2;
    z-index: -1;
}
#message .tx_area {
    padding: 0 10px;
    text-align: left;
}
.sign_tx {
    margin-top: 10px;
    text-align: right;
    font-weight: bold;
    color: #e0909f;
}
#message .top_btn_link {
    margin: 70px auto 40px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#message .top_btn_link li {
    width: 100%;
    margin: 0 15px 15px;
    padding: 1em 0;
    background: #b6a47e;
    font-family: "NotoSerifSemiBold";
    box-shadow: 0 0 0 4px #b6a47e inset, 0 0 0 5px #e9e4d9 inset;
    transition: 0.2s;
}
#message .top_btn_link li a {
    display: block;
    width: 100%;
    height: auto;
    color: #fff;
    text-decoration: none;
}
#message .top_btn_link li:hover {
    opacity: 0.7;
}
@media print, screen and (min-width:340px) {
    #message .flex_container::after {
        height: 590px;
    }
}
@media print, screen and (min-width:768px) {
    #message {
        position: relative;
        top: 0;
    }
    #message .flex_container {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    #message .flex_container figure {
        margin-left: 40px;
        width: 290px;
        height: auto;
    }
    #message .flex_container::after {
        content: "";
        top: 50%;
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        height: 280px;
    }
    #message .tx_area .title02 {
        font-size: 40px;
    }
    #message .tx_area {
        padding: 0 50px;
    }
    #message .tx_area .cts_p {
        padding-left: 30px;
    }
    .sign_tx {
        margin-top: 30px;
    }
    #message .top_btn_link {
        width: 66%;
        margin: 60px auto 120px;
        flex-wrap: nowrap;
    }
    #message .top_btn_link li {
        width: calc(50% - 15px);
        margin: 0 15px;
    }
}
/* #method */
#method {
    padding-bottom: 60px;
}
#method01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #dfd5bf;
}
#method02 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #dfd5bf;
    border-bottom: 1px solid #dfd5bf;
}
article[id^="method"] {
    padding-top: 40px;
    padding-bottom: 40px;
}
article[id^="method"] h4 {
    padding-left: calc(160px * 0.7);
    color: #d2697c;
    font-size: calc(30px * 0.8);
    line-height: 1.5;
    font-family: 'NotoSerifBold';
    letter-spacing: -0.6pt;
    text-align: left;
    position: relative;
}
#method h4 .en_tx {
    color: #e0909f;
    font-size: 18px;
    display: block;
    font-family: madre-script, sans-serif;
}
#method figure {
    width: 100%;
    margin-bottom: 30px;
}
#method figure.tit_sub {
    margin: 0 auto 30px;
    width: auto;
    max-width: 90%;
    border-top: 1px solid #DC8C9A;
    border-bottom: 1px solid #DC8C9A;
    padding: 10px 40px;
}
@media print, screen and (min-width:768px) {
    #method figure.tit_sub {
        width: 70%;
    }
}
#method figure.tit_sub img {
    width: 100%;
    height: auto;
}
.method_num {
    position: absolute;
    top: 60%;
    left: -0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-size: calc(100px * 0.7);
    font-family: madre-script, sans-serif;
    letter-spacing: -0.5pt;
    color: #dfd5bf;
}
article[id^="method"] .tx_area {
    text-align: left;
}
@media print, screen and (min-width:768px) {
    #method01 {
        flex-wrap: nowrap;
    }
    #method02 {
        flex-wrap: nowrap;
    }
    #method figure {
        width: 50%;
        margin: 0 auto;
        text-align: center;
    }
    #method figure img {
        width: 400px;
        margin: 0 auto;
    }
    article[id^="method"] .tx_area {
        width: 50%;
    }
    article[id^="method"] h4 {
        padding-left: 160px;
        font-size: 30px;
    }
    .method_num {
        font-size: 100px;
    }
    #method02 .tx_area {
        order: -1;
    }
    #method02 figure {
        order: 3;
    }
    #method01 .more_btn {
        margin-left: auto;
        float: right;
    }
}
/* support */
#support {
    padding-top: 80px;
    padding-bottom: 80px;
    background: #f4f2ed;
    text-align: left;
}
#support .flex_container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
}
#support .flex_container .tx_area {
    text-align: left;
}
#support .flex_container .tx_area .title01 {
    padding-left: 0;
}
#support .in_ti01::after {
    left: 75%;
}
#support figure {}
.support_course li {
    margin-bottom: 20px;
    background: #fff;
    box-shadow: 0 0 0 1px #b6a47e inset;
}
.support_course li h3 {
    padding: 8px 17px 8px 20px;
    background: #b6a47e;
    font-size: 20px;
    font-family: "NotoSerifSemiBold";
    color: #fff;
    min-height: 1em;
    position: relative;
}
.support_course li h3 .course_target {
    display: block;
    margin-top: 0.5em;
    padding: 0.1em 0.8em;
    color: #877858;
    background: #fff;
    font-size: 14px;
    font-family: 'NotoSansBold';
    border-radius: 7px;
}
.support_course li p {
    padding: 1em 1.3em;
}
#support .more_btn {
    background: rgba(255, 255, 255, 0.5);
}
#support .more_btn:hover {
    background: #ede7db;
}
@media print, screen and (min-width:340px) {
    #support .in_ti01::after {
        left: 63%;
    }
}
@media print, screen and (min-width:768px) {
    #support .flex_container {
        flex-wrap: nowrap;
    }
    #support .in_ti01::after {
        left: 91.4%;
    }
    #support figure {
        margin-left: 60px;
    }
    .support_course li h3 .course_target {
        display: inline-block;
        margin-top: 0;
        position: absolute;
        top: 50%;
        right: 17px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}
/* moniter */
#moniter {
    padding-top: 80px;
    padding-bottom: 80px;
}
#moniter h2 {
    display: inline-block;
    margin-top: -1.5em;
    padding: 0.6em;
    color: #0d0803;
    background: #fff;
    font-size: calc(30px * 0.7);
    font-family: "NotoSerifSemiBold";
    letter-spacing: -1pt;
}
#moniter h2 span.en_tx {
    display: block;
    color: #e0909f;
    font-size: 20px;
    letter-spacing: normal;
    font-family: madre-script, sans-serif;
}
.moniter_box {
    padding: 10px;
    border: 3px solid #ccc4b2;
    box-shadow: 0 0 0 3px #fff inset, 0 0 0 4px #ccc4b2 inset;
    background: url(../img/common_img/po_corner.png) no-repeat 0 0, url(../img/common_img/po_corner_r.png) no-repeat right 0, url(../img/common_img/po_corner_lb.png) no-repeat left bottom, url(../img/common_img/po_corner_rb.png) no-repeat right bottom;
}
.moniter_info {
    margin: 0 10px;
    padding: 10px;
    background: #f4f2ed;
}
.moniter_info li {
    margin-bottom: 1em;
    padding-left: 1.3em;
    color: #0d0803;
    font-size: 14px;
    line-height: 1.5;
    text-align: left;
    font-family: "NotoSansMedium";
    letter-spacing: -0.5pt;
}
.cir_po {
    margin-left: -1.3em;
    margin-right: 0.3em;
    color: #b6a47e;
}
.moniter_attention {
    margin-top: 2em;
}
.moniter_attention dt {
    color: #d2697c;
    text-align: left;
    font-family: 'NotoSansBold';
}
.moniter_attention dd ul {
    text-align: left;
}
.moniter_attention dd li {
    margin-bottom: 0;
    margin-right: 1em;
    padding-left: 0;
    display: inline-block;
    font-family: 'NotoSansRegular';
}
.go_contact {
    margin: 20px auto;
}
.go_contact.more_btn2 {
    display: inline-block;
    padding: 0.6em 1.5em;
}
.go_contact.more_btn2 img {
    vertical-align: -2px;
    margin-right: 0.5em;
}
.moniter_box .attention_ul {
    margin-bottom: 50px;
}
.moniter_box .attention_ul li {
    font-size: 14px;
    line-height: 1.3;
}
@media print, screen and (min-width:768px) {
    #moniter h2 {
        font-size: 30px;
        padding: 0.6em 1.5em;
        letter-spacing: -1.2pt;
    }
    #moniter h2 br {
        display: none;
    }
    .moniter_info {
        margin: 0 68px;
        padding: 30px;
    }
    .moniter_info li {
        font-size: 16px;
    }
    .moniter_attention dd ul {
        width: 80%;
    }
    .go_contact.more_btn2 {
        width: 360px;
        padding: 0.7em 0;
    }
}
/* news */
#news_area {
    padding-top: 80px;
    padding-bottom: 80px;
    background: #f2f2f2;
}
#news_container .container {}
#news {
    margin-bottom: 30px;
}
#news_area .title01 {
    font-size: calc(40px * 0.75);
    font-family: 'NotoSerifRegular';
    color: #aa9873;
    padding: 10px 15px;
    margin-bottom: 10px;
    border-radius: 4px;
    text-align: left;
    position: relative;
}
#news_area .title01 span.in_ti01 {
    display: inline-block;
    font-family: madre-script, sans-serif;
    font-weight: normal;
    line-height: 0.75;
    color: rgba(180, 61, 83, 0.8);
    /*透過必須*/
    text-shadow: 1px 1px 1px #f2f2f2, 2px 2px 2px #f2f2f2/*背景色に合わせる*/
    , 0 0 0 #832133, 0 0 1px #ce5a70;
    font-feature-settings: 'palt';
    position: relative;
}
#news_area .title01 span.in_ti01::after {
    content: "";
    display: block;
    width: calc(113px * 0.6);
    height: calc(98px * 0.6);
    position: absolute;
    top: calc(-98px * 0.49);
    left: calc(100% - 113px * 0.26);
    background: url(../img/common_img/ti_po_butterfly_pi.png) no-repeat 0 0;
    background-size: auto;
    background-size: calc(113px * 0.6) calc(98px * 0.6);
}
.news_more {
    display: block;
    width: 166px;
    height: 34px;
    line-height: 34px;
    background: #e0909f;
    font-size: 16px;
    font-family: 'NotoSansRegular';
    border-radius: 30px;
    text-align: center;
    margin-left: auto;
    transition: 0.2s;
}
.news_more a {
    color: #fff;
    text-decoration: none;
}
.news_more:hover {
    opacity: 0.7;
}
@media print, screen and (min-width:768px) {
    #news {
        width: 50%;
        float: left;
    }
    #news_container .container {
        flex-wrap: nowrap;
    }
    #news_area .title01 {
        font-size: 40px;
        margin-bottom: 30px;
    }
    #news_area .title01 span.in_ti01::after {
        content: "";
        display: block;
        width: 113px;
        height: 98px;
        position: absolute;
        top: calc(-98px * 0.81);
        left: calc(100% - 113px * 0.43);
        background: url(../img/common_img/ti_po_butterfly_pi.png) no-repeat 0 0;
        background-size: 113px 98px;
    }
    #news_area .title01 .ti01_jp_tx {
        font-size: 24px;
    }
    .news_more {
        display: inline-block;
        position: absolute;
        right: 0;
        bottom: 20px;
    }
    #fb_area {
        width: 458px;
        float: right;
    }
}
/*更新プログラム(連動)フォーマット*/
#news01 {
    overflow: hidden;
    text-align: left;
}
#news01 dl {
    padding: 0 0 10px 0;
}
#news01 dl dt {
    color: #9b8559;
}
#news01 dl dd div.rendo_title {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
#news01 dl dd a {
    color: #0d0803;
    text-decoration: underline;
    transition: 0.2s;
}
#news01 dl dd a:hover {
    color: #baac8e;
}
@media print, screen and (min-width:768px) {
    #news01 dl dt {
        float: left;
    }
    #news01 dl dd {
        padding: 0 0 0 100px;
    }
}
/* #products , #link*/
#products {
    padding-top: 100px;
}
.in_bd_box {
    margin-bottom: 60px;
    border: 1px solid #b8a98b;
    border-radius: 7px;
}
.in_bd_box .title03 {
    display: inline-block;
    padding: 0 30px;
    margin-top: -0.7em;
    background: #fff;
}
.bnr_link_ul {
    margin: 40px auto 0;
    padding: 0 10px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}
.bnr_link_ul li {
    margin: 0 auto 15px;
}
@media print, screen and (min-width:768px) {
    .bnr_link_ul li {
        margin: 0 25px 30px;
    }
    #link .in_bd_box {
        padding-bottom: 30px;
    }
}
/* map_area */
#map_area {
    padding-bottom: 40px;
}
#map_area iframe {
    margin-bottom: 40px;
}
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

blog 

---------------------------------------------------------------------------------------------------------------------------------------- */
/*category_link*/
.category_link {
    font-size: 0;
    margin-bottom: 30px;
}
.category_link li {
    display: inline-block;
    margin: 0 5px 10px;
}
.category_link li a {
    display: block;
    text-decoration: none;
    transition: 0.5s all;
    background: #F7F7F7;
    color: #D44C65;
    padding: 7px 0;
    font-family: 'NotoSansRegular';
    font-size: 14px;
}
.category_link li a:hover {
    background: #D44C65;
    color: #fff;
}
.category_link li a span {
    border-left: 3px solid #D44C65;
    padding: 0 15px;
}
/*inside_title01*/
#blog_sec01 .inside_title01 {
    font-size: calc(40px * 0.6);
    margin-top: 0;
}
#blog_sec01 .inside_title01 span.in_ti01 {
    font-family: 'NotoSerifRegular';
}
@media print, screen and (min-width:768px) {
    #blog_sec01 .inside_title01 {
        margin-bottom: 40px;
        font-size: 40px;
    }
}
/*NewsBox*/
.newsbox {
    overflow: hidden;
    /* for modern browser */
}
.newsbox .news_text {
    overflow: hidden;
    /* for modern browser */
    zoom: 1;
    /*ie6*/
    line-height: 1.5;
    text-align: left;
}
.newsbox img {
    margin-bottom: 10px;
}
.newsbox a:hover img {
    opacity: 0.6;
    filter: alpha(opacity=60);
    -ms-filter: "alpha( opacity=60 )";
}
.newstitle {
    font-family: 'NotoSerifRegular';
    color: #d2697c;
    font-size: 18px;
    padding: 30px 0;
    line-height: 140%;
    margin-bottom: 20px;
    background: url(../img/common_img/it02_top.png) no-repeat top center, url(../img/common_img/it02_bottom.png) no-repeat bottom center;
}
.newstitle span {
    font-size: 12px;
}
.newsbox .more-link {
    float: right;
    margin: 10px 0;
}
.postinfo {
    margin-top: 10px;
    text-align: right;
    clear: both;
    padding: 5px 20px;
    background: #EEEEEE;
    /* CSS3 */
    border-radius: 20px;
}
.news_text div {
    clear: both;
    margin: 30px 0;
}
.news_text hr {
    clear: both;
    border: none;
    padding: 10px 0;
    margin: 0;
}
img.alignleft {
    display: block;
    margin: 0 auto 10px;
}
img.alignright {
    display: block;
    margin: 0 auto 10px;
}
img.aligncenter {
    display: block;
    margin: 0 auto 10px;
}
@media print, screen and (min-width:768px) {
    img.alignleft {
        float: left;
        clear: both;
        margin-right: 20px;
    }
    img.alignright {
        float: right;
        clear: both;
        margin-left: 20px;
    }
    img.aligncenter {
        float: center;
        clear: both;
    }
    .newstitle {
        font-size: 26px;
        margin-bottom: 25px;
    }
    .newstitle br {
        display: none;
    }
}
/*WP-PageNavi*/
.wp-pagenavi {
    clear: both;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 20px;
    font-size: 12px;
}
.wp-pagenavi a, .wp-pagenavi span {
    text-decoration: none;
    padding: 5px 10px;
    margin: 3px;
    /* CSS3 */
    -webkit-border-radius: 2px;
    -moz-border-radius: 2px;
    border-radius: 2px;
}
.wp-pagenavi span.pages {
    border: 1px solid #EBE2D0;
    color: #b6a47e;
    background: #EBE2D0;
}
.wp-pagenavi span.current {
    border: 1px solid #b6a47e;
    background: #b6a47e;
    color: #fff;
    zoom: 1;
}
.wp-pagenavi a {
    border: 1px solid #b6a47e;
    color: #b6a47e;
    background: none;
}
.wp-pagenavi a:hover {
    opacity: 0.7;
}
/*Program*/
.pagelink .oldpage {
    float: left;
    width: 45%;
    text-align: left;
}
.pagelink .newpage {
    float: right;
    width: 45%;
    text-align: right;
}
.listlink {
    clear: both;
    margin: 20px 0;
    text-align: center;
}
.listlink a {
    color: #fff;
    text-decoration: none;
    padding: 5px 10px;
    margin: 3px;
    border: 1px solid #b6a47e;
    background: #b6a47e;
    /* CSS3 */
    border-radius: 3px;
}
.listlink a:hover {
    opacity: 0.7;
}
/*search*/
#news_search div {
    margin-bottom: 20px;
    text-align: center;
}
@media print, screen and (min-width:768px) {
    #news_search div {
        text-align: left
    }
}
input#searchsubmit:hover {
    cursor: pointer;
}
#news_search_title {
    font-weight: bold;
}
.screen-reader-text {
    display: none;
}
#news_search #s {
    width: 70%;
    margin: 0;
    border: 1px solid #BFBFBF;
    padding: 3px;
    background: #fff;
    /* CSS3 */
    border-radius: 3px;
    /* Webkit */
    -webkit-border-radius: 3px;
    background: -webkit-gradient(linear, left top, left bottom, from(#F1F1F1), to(#fff));
    /* Firefox */
    -moz-border-radius: 3px;
    background: -moz-linear-gradient(top, #F1F1F1, #fff);
}
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

contact 

---------------------------------------------------------------------------------------------------------------------------------------- */
/*contact_sec01*/
.p_btn a {
    display: inline-block;
    color: #fff;
    background: #A79051;
    border-radius: 2px;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    padding: 10px 30px;
    text-decoration: none;
}
.p_btn a:hover {
    opacity: 0.7;
}
/*contact_sec02*/
table#contact {
    width: 100%;
    margin: 20px 0;
    border-left: 1px solid #E9A8B5;
    border-top: 1px solid #E9A8B5;
}
table#contact tr th {
    display: block;
    padding: 10px;
    border-right: 1px solid #E9A8B5;
    border-bottom: 1px solid #E9A8B5;
    background: #FFE6EB;
    color: #BB3B53;
    line-height: 150%;
    text-align: left;
    vertical-align: middle;
}
table#contact tr td {
    display: block;
    padding: 10px;
    background: #fff;
    border-right: 1px solid #E9A8B5;
    border-bottom: 1px solid #E9A8B5;
    text-align: left;
    vertical-align: middle;
}
table#contact tr td.td_child {
    border-bottom: 1px dotted #E9A8B5;
}
table#contact p {
    margin-bottom: 5px;
}
table#contact tr th span.form_title {
    display: block;
    overflow: hidden;
}
/*必須アイコン*/
table#contact tr th span.txt_required {
    float: left;
    font-size: 11px;
    font-weight: normal;
    text-align: center;
    border-radius: 2px;
    color: #fff;
    background: #cc1414;
    padding: 6px 0;
    margin-right: 10px;
    line-height: 70%;
    width: 40px;
    display: block;
}
/*任意アイコン*/
table#contact tr th span.txt_optional {
    float: left;
    font-size: 11px;
    text-align: center;
    font-weight: normal;
    border-radius: 2px;
    color: #fff;
    background: #847C66;
    padding: 6px 0;
    margin-right: 10px;
    line-height: 70%;
    width: 40px;
    display: block;
}
/*入力エリア装飾*/
input, select, textarea {
    padding: 10px;
    background: #e8e8e8;
    border: 1px solid #e8e8e8;
    font-size: 1.6rem;
}
input:focus, select:focus, textarea:focus {
    background: #E2EBF4;
    border: 1px solid #E2EBF4;
}
/*入力エリアサイズ*/
.input_10 {
    width: 10%;
}
.input_30 {
    width: 30%;
}
.input_50 {
    width: 50%;
}
.input_70 {
    width: 70%;
}
.input_100 {
    width: 100%;
}
/*入力例の文字装飾*/
::-webkit-input-placeholder {
    color: #bbb;
}
::-moz-placeholder {
    color: #bbb;
}
:-ms-input-placeholder {
    color: #bbb;
}
input:focus::-webkit-input-placeholder {
    color: transparent;
}
input:focus:-moz-placeholder {
    color: transparent;
}
input:focus::-moz-placeholder {
    color: transparent;
}
textarea:focus::-webkit-input-placeholder {
    color: transparent;
}
textarea:focus:-moz-placeholder {
    color: transparent;
}
textarea:focus::-moz-placeholder {
    color: transparent;
}
/*ラジオボタン余白調整*/
input[type=radio] {
    margin-right: 5px;
    margin-left: 15px;
}
/*チェックボックス余白調整*/
input[type=checkbox] {
    margin-right: 5px;
    margin-left: 15px;
}
/*送信・戻るボタン*/
ul.submit_btn {
    font-size: 0;
    text-align: center;
    margin-bottom: 20px;
}
ul.submit_btn li {
    display: inline-block;
    cursor: pointer
}
ul.submit_btn li.inp_submit01 input {
    color: #fff;
    background: #CB3B58;
    border: none;
    border-radius: 4px;
    padding: 10px 15px;
    margin: 0 5px;
    cursor: pointer;
}
ul.submit_btn li.inp_submit02 input {
    color: #fff;
    background: #73633C;
    border: none;
    border-radius: 4px;
    padding: 10px 15px;
    margin: 0 5px;
    cursor: pointer;
}
ul.submit_btn li:hover {
    opacity: 0.7;
}
@media print, screen and (min-width:768px) {
    table#contact {
        border-collapse: separate;
    }
    table#contact tr th {
        display: table-cell;
        border-right: 1px dotted #E9A8B5;
        width: 28%;
    }
    table#contact tr td {
        display: table-cell;
    }
    table#contact tr td.td_child {
        border-right: 1px dotted #E9A8B5;
        border-bottom: 1px solid #E9A8B5;
    }
    /*入力例の文字装飾*/
    ::-webkit-input-placeholder {
        color: #666;
    }
    ::-moz-placeholder {
        color: #666;
    }
    :-ms-input-placeholder {
        color: #666;
    }
}
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

school

---------------------------------------------------------------------------------------------------------------------------------------- */
/*common*/
p.inside_title03 {
    color: #fff;
    background: #826A37;
}
.sheet_school {
    width: 100%;
    border: 2px solid #d2697c;
}
.sheet_school tr th {
    text-align: left;
    vertical-align: top;
    padding: 10px;
    background: #FFEDF0;
    display: block;
    font-weight: normal;
}
.sheet_school tr td {
    text-align: right;
    vertical-align: top;
    padding: 10px;
    background: #fff;
    color: #9F1931;
    display: block;
}
.sheet_school tr:last-child th, .sheet_school tr:last-child td {
    font-weight: bold;
}
.sheet_school tr:last-child th {
    border-top: 1px dotted #d2697c;
}
@media print, screen and (min-width:768px) {
    .sheet_school {
        width: 600px;
        margin: 0 auto 40px;
    }
    .sheet_school tr th {
        background: #fff;
        display: table-cell;
    }
    .sheet_school tr td {
        background: #fff;
        display: table-cell;
    }
    .sheet_school tr:nth-child(odd) th, .sheet_school tr:nth-child(odd) td {
        background: #FFEDF0;
    }
    .sheet_school tr:last-child th, .sheet_school tr:last-child td {
        border-top: 1px dotted #d2697c;
    }
}
/*school_sec01*/
#school_sec01 ul:nth-of-type(1) {
    margin: 0 auto;
    display: inline-block;
}
#school_sec01 ul:nth-of-type(1) li {
    text-align: left;
    color: #d2697c;
    margin-bottom: 15px;
    padding-left: 10px;
    border-left: 2px solid #d2697c;
    line-height: 100%;
}
#school_sec01 ul:nth-of-type(2) {
    text-align: left;
}
#school_sec01 ul:nth-of-type(2) li {
    display: inline-block;
    background: #FFEDF0;
    color: #d2697c;
    padding: 2px 10px;
    border-radius: 2px;
    margin: 0 5px 8px 0;
}
#school_sec03 h6 {
    font-size: 18px;
    font-weight: bold;
    background: rgba(255, 237, 240, 1.00);
    padding: 10px;
    color: rgba(86, 50, 28, 1.00);
    width: 80%;
    margin: 20px auto;
}
#school_sec03 h6 span {
    font-size: 16px;
    font-weight: normal;
}
.sheet_school tr td span {
    font-size: 12px;
}
.mt_m30 {
    margin-top: 0;
}
@media print, screen and (min-width:768px) {
    .mt_m30 {
        margin-top: -30px;
    }
}
.bn_sisso {
    display: block;
}
.bn_sisso a {
    font-family: 'NotoSerifRegular';
    display: block;
    color: #fff;
    background: #4f9ad2;
    padding: 20px 10px;
    font-size: 20px;
    text-decoration: none;
    line-height: 1em;
    width: 100%;
    margin: 10px auto;
    border-radius: 6px;
}
.bn_sisso a span {
    display: block;
    font-size: 14px;
    margin-top: 10px;
}
.bn_sisso a:hover {
    opacity: 0.7;
    transition: 0.3s;
}
@media print, screen and (min-width:768px) {
    .bn_sisso a {
        width: 60%;
    }
}
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

salon

---------------------------------------------------------------------------------------------------------------------------------------- */
/*common*/
.wax_btn a {
    display: inline-block;
    color: #fff;
    background: #A79051;
    border-radius: 2px;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    padding: 10px 30px;
    text-decoration: none;
}
.wax_btn.buy_btn a {
    background: #D5697C;
}
.wax_btn a:hover {
    opacity: 0.7;
}
.wax_box {
    margin-bottom: 20px;
    padding: 25px;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    border-radius: 2px;
    background: #fff;
}
.wax_box figure {
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    max-width: 300px;
    margin: 0 auto 20px;
}
.wax_box figure img {
    width: 100%;
    height: auto;
}
@media print, screen and (min-width:768px) {
    .wax_box {
        text-align: left;
        padding: 35px;
    }
    .wax_box figure {
        max-width: 400px;
        margin: 0 0 0 30px;
        ;
        float: right;
    }
}
/*salon_sec01*/
#salon_sec01 .brazil_btn a {
    display: inline-block;
    color: #fff;
    background: #A79051;
    border-radius: 2px;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    padding: 10px 30px;
    text-decoration: none;
}
#salon_sec01 .brazil_btn a:hover {
    opacity: 0.7;
}
/*salon_sec02*/
#salon_sec02 table {
    width: 100%;
    margin: 0 auto 20px;
    border: 2px solid #d2697c;
}
#salon_sec02 table tr th {
    text-align: left;
    vertical-align: top;
    padding: 10px;
    background: #FFEDF0;
    display: block;
    font-weight: normal;
}
#salon_sec02 table tr td {
    text-align: left;
    vertical-align: top;
    padding: 10px;
    background: #fff;
    color: #9F1931;
    display: block;
}
#salon_sec02 table tr:last-child th, #salon_sec02 table tr:last-child td {
    font-weight: bold;
}
#salon_sec02 figure {
    max-width: 400px;
    margin: 0 auto 20px;
}
#salon_sec02 figure img {
    width: 100%;
    height: auto;
}
@media print, screen and (min-width:768px) {
    #salon_sec02 table {
        width: 870px;
    }
    #salon_sec02 table tr th {
        background: #fff;
        display: table-cell;
        width: 20%;
    }
    #salon_sec02 table tr td {
        background: #fff;
        display: table-cell;
    }
    #salon_sec02 table tr:nth-child(odd) th, #salon_sec02 table tr:nth-child(odd) td {
        background: #FFEDF0;
    }
    #salon_sec02 figure {
        max-width: 870px;
    }
}
/*salon_sec03*/
#salon_sec03 .wax_box {
    background: #f4f2ed;
}
/*salon_sec05*/
#salon_sec05 ul {
    text-align: left;
}
#salon_sec05 ul li {
    margin-bottom: 20px;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    border-radius: 2px;
    background: #f4f2ed;
}
#salon_sec05 ul li h4 {
    background: #d5697c;
    padding: 10px 20px;
    color: #fff;
    font-family: 'NotoSerifRegular';
    font-size: 18px;
    border-radius: 2px 2px 0 0;
}
#salon_sec05 ul li .qa_a {
    padding: 20px;
}
/* ---------------------------------------------------------------------------------------------------------------------------------------- 

price

---------------------------------------------------------------------------------------------------------------------------------------- */
.price_dl {
    width: 100%;
    margin: 0 auto 40px;
}
.price_dl div {
    min-height: 54px;
    margin-bottom: 4px;
    padding: 0.2em 1em;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    background: #fae4e9;
}
.price_dl dd {
    margin-left: auto;
    min-width: 100px;
    padding: 0.2em 1em;
    background: #fff;
    border-radius: 5px;
    text-align: right;
    color: #e64a37;
    font-family: "NotoSerifSemiBold";
}
.price_dl dd .price_en_tx {
    font-size: 16px;
}
#price_sec02 figure {
    margin: 0 auto 40px;
}
#price_sec02 figure img {
    border-radius: 10px;
}
#price_sec02 .ladys_menu_dl {
    margin-bottom: 40px;
}
#price_sec02 .ladys_menu_dl div {
    background: #fff;
    border-radius: 7px;
    margin-bottom: 10px;
}
#price_sec02 .ladys_menu_dl dt {
    padding: 0.5em 0;
    border-radius: 7px 7px 0 0;
    background: #ffdde4;
    color: #0d0803;
    background-image: linear-gradient(to right, #e0909f, #e0909f 2px, transparent 2px, transparent 3px);
    background-size: 4px 2px;
    background-position: bottom;
    background-repeat: repeat-x;
}
#price_sec02 .ladys_menu_dl.monthly_plan dt {
    background: #dfd5bf;
}
#price_sec02 .ladys_menu_dl dt .tx_l {
    display: inline-block;
    margin-right: 0.2em;
    font-size: 1.3em;
    color: #f05678;
}
#price_sec02 .ladys_menu_dl dd {
    padding: 1em 2em;
}
#price_sec02 .ladys_menu_dl .price_tx {
    display: block;
    margin: 0.5em auto 0;
    text-align: center;
    color: #e64a37;
    font-family: "NotoSerifSemiBold";
}
#price_sec02 .attention_ul {
    margin-bottom: 30px;
    text-align: left;
}
#price_sec02 .attention_ul li {
    margin-bottom: 0.5em;
    margin-right: 0.2em;
    padding-left: 1em;
    line-height: 1.4;
}
#price_sec02 .attention_ul li span.kome {
    margin-left: -0.7em;
}
#price_sec02 .wax_box .price_tx {
    display: block;
    margin: 0.5em auto 0;
    text-align: center;
    color: #e64a37;
    font-family: "NotoSerifSemiBold";
}
@media print, screen and (min-width:768px) {
    .price_dl {
        width: 83%;
    }
    .price_dl div {
        padding: 0 2em;
        flex-wrap: nowrap;
        justify-content: space-between;
    }
    .price_dl dd {
        min-width: 160px;
        font-size: 18px;
    }
    #price_sec02 figure {
        position: relative;
        width: 551px;
    }
    #price_sec02 figure::before {
        content: "";
        width: 170px;
        height: 385px;
        position: absolute;
        top: 50%;
        left: -170px;
        -webkit-transform: translateY(-50%) rotateY(180deg);
        transform: translateY(-50%) rotateY(180deg);
        background: url(../img/price_img/illust_bg.png) no-repeat left center;
    }
    #price_sec02 figure::after {
        content: "";
        width: 170px;
        height: 385px;
        position: absolute;
        top: 50%;
        right: -170px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        background: url(../img/price_img/illust_bg.png) no-repeat left center;
    }
    #price_sec02 .wax_box figure::before {
        background: none;
    }
    #price_sec02 .wax_box figure::after {
        background: none;
    }
    #price_sec02 .wax_box .price_tx {
        text-align: left;
    }
}
