@charset "UTF-8";


/* css common 
---------------------------------------------------------- */
#wrapper {
    min-height: 100%;
    margin: 0px auto;
    position: relative;
}

#main,
.box {
    width: 100%;
    max-width: 1370px;
    margin: 0 auto;
}

#footer_box {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

/* main 
---------------------------------------------------------- */
#main {
    display: block;
}

/* pagetop 
---------------------------------------------------------- */
#bk_top {
    text-align: center;
}

#scrollUp {
    width: 70px;
    height: 70px;
    bottom: 5%;
    right: 5%;
    background: url(common/images/pagetop.jpg) no-repeat right bottom;
    background-size: contain;
}


/* footer 
---------------------------------------------------------- */
#footer {
    padding-bottom: 50px;
}

#footer .pc {
    margin: 40px 0 0 70px;
}

#footer .col ul {
    margin-left: 30px;
}

#footer .col li a {
    text-decoration: none;
    color: #000;
}

#footer .col li a:hover {
    color: #df2d32;
}

#footer .footer_r {
    float: right;
    text-align: right;
    margin-top: -55px;
}

#footer .footer_r li {
    float: right;
}

#footer .footer_r li:nth-of-type(2),
#footer .footer_r li:nth-of-type(3) {
    padding-top: 5px;
    padding-left: 5px;
}

#footer .footer_r li.tel_f {
    margin: 5px 0 0 10px;
}

/* margin style
---------------------------------------------------------- */
.section {
    margin-bottom: 80px;
}

.container {
    margin-bottom: 60px;
}

.container.container_reset {
    margin-bottom: 0;
}

.case {
    margin-bottom: 40px;
}

.pack {
    margin-bottom: 30px;
}

.item {
    margin-bottom: 20px;
}

.mb_clear {
    margin-bottom: 0 !important;
}

.section .container:last-child,
.container .case:last-child,
.case .pack:last-child,
.pack .item:last-child {
    margin-bottom: 0px;
}

/* text-align style
---------------------------------------------------------- */
.txt_l {
    text-align: left !important;
}

.txt_c {
    text-align: center !important;
}

.txt_r {
    text-align: right !important;
}

.txt_b {
    font-weight: bold;
}

/* p section 
---------------------------------------------------------- */
main p {
    margin-bottom: 20px;
}

main * p:last-child {
    margin-bottom: 0px;
}


/* tb_style 
---------------------------------------------------------- */
.tb_style {
    width: 100%;
    table-layout: auto;
    border-collapse: collapse;
    background: #FFF;
}

.tb_style td,
.tb_style th {
    padding: 15px !important;
    border-bottom: 2px solid #c3e0ee !important;
    box-sizing: border-box;
}

.tb_style th {
    background: #4cb3e8;
    color: #FFF;
    text-align: left;
}



/* title style 
---------------------------------------------------------- */
.title_sub {
    font-size: 40px;
    color: #8b9267;
    background: url(common/images/bg_title_sub.jpg) no-repeat center top;
    margin-bottom: 50px;
    padding-top: 50px;
    text-align: center;
}



/* container 
---------------------------------------------------------- */

.col2_box,
.col3_box {
    overflow: hidden;
    text-align: center;
    margin: auto;
    display: flex;
}
.col3_box {
    width: 65%;
}
.col2_box .col {
    width: 50%;
    float: left;
}

.col2_box.col_r .col {
    float: right;
}

.col3_box .col {
    width: 100%;
    margin-left: 20px;
}
.col3_box .col:first-child {
    margin-left: 0;
}

.pd_box {
    padding: 70px 0;
    background: #f5f5f5;
}

/* switch pc sp 
---------------------------------------------------------- */
.sp {
    display: none;
}

.pc {
    display: block;
}


/* list_dot 
---------------------------------------------------------- */
.list_dot {
    list-style: disc;
    margin-left: 17px;
}

.list_dot li {
    margin-bottom: 5px;
}

.list_dot li:last-child {
    margin-bottom: 0;
}

.list_dot.txt_b li {
    font-weight: bold;
}

/* main_img_wrap 
---------------------------------------------------------- */
#main_img_wrap {
    background: url(common/images/bg_main.jpg) no-repeat center;
    background-size: cover;
    max-height: 870px;
    height: 70vw;
    position: relative;
    margin-bottom: 120px;
}

#main_img {
    max-width: 450px;
    width: 35vw;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
}

/* intro 
---------------------------------------------------------- */
#intro .box {
    max-width: 1000px;
}

#intro h2 {
    font-size: 39px;
    text-indent: -230px;
    padding-left: 230px;
    margin-bottom: 130px;
    letter-spacing: -0.1vw;
}

#intro h2 span {
    color: #8c9267;
    font-size: 60px;
    margin: 0 -15px;
}

#intro h2:after {
    content: '';
    background: url(common/images/bg_tit_intro.png) no-repeat left top;
    background-size: contain;
    display: inline-block;
    width: 34px;
    height: 36px;
    margin-left: -20px;
}

#intro .col2_box .col h3 {
    font-size: 30px;
    margin-bottom: 30px;
}

#intro .col2_box .col .txt_box {
    margin: 0 50px 30px;
}

#intro .sup_tit h3 {
    font-size: 26px;
    text-align: center;
    margin-bottom: 110px;
}

#intro .col3_box {
    margin-bottom: 150px;
}

#intro .col3_box .col {
    text-align: center;
    color: #8b9267;
}

#intro .col3_box .col img {
    margin-bottom: 20px;
}


/* sleepmaster 
---------------------------------------------------------- */
#sleepmaster .pd_box {
    margin-bottom: 120px;
}

#sleepmaster .box {
    max-width: 1000px;
}

#sleepmaster .col2_box .col .txt_name {
    display: block;
    text-align: center;
    margin-top: 15px;
}

#sleepmaster .col2_box .col h3 {
    font-size: 30px;
    margin-bottom: 35px;
    color: #8b9267;
}

#sleepmaster .col2_box .col .txt_box {
    margin: 150px 0 0 70px;
}


/* serviceflow 
---------------------------------------------------------- */
#serviceflow .img_txt span {
    color: #8b9267;
    display: block;
    margin-top: 10px;
}

#serviceflow .col2_box {
    margin-bottom: 110px;
}

#serviceflow .col2_box .col .txt_box {
    margin: 0 40px 0 180px;
}

#serviceflow .col2_box.col_r .col .txt_box {
    margin: 0 180px 0 40px;
}

#serviceflow .col2_box .col .txt_box .num_img {
    text-align: center;
    margin-bottom: 50px;
}

#serviceflow h3 {
    font-size: 30px;
    margin-bottom: 25px;
    color: #8b9267;
}

#serviceflow h3 span {
    font-size: 18px;
    display: block;
}

#serviceflow .txt_att {
    font-size: 90%;
    color: #7a7a7a;
}

#serviceflow .col2_box .col table td {
    font-weight: bold;
    vertical-align: top;
}

#serviceflow .col2_box .col_img {
    padding-top: 70px;
}

#serviceflow .check_system {
    max-width: 1000px;
    background: #f5f5f5;
    border-radius: 10px;
    margin: 0 auto 200px;
    box-sizing: border-box;
    padding: 100px 80px 50px;
    position: relative;
}

#serviceflow .check_system img {
    position: absolute;
}

#serviceflow .check_system img.img_tit {
    top: -60px;
    left: 0;
    right: 0;
    margin: 0 auto;
}

#serviceflow .check_system img.img_ico {
    top: 0;
    right: -120px;
    bottom: 0;
    margin: auto 0;
}

#serviceflow .check_system img.img_btn {
    left: 0;
    right: 0;
    bottom: -40px;
    margin: 0 auto;
}

#serviceflow .link_btn {
    margin-bottom: 180px;
}


/* linkarea 
---------------------------------------------------------- */
#linkarea .box {
    max-width: 1000px;
}

#linkarea .col3_box .col {
    text-align: center;
}
