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

/*==================
reset
====================*/
/*ベースの要素の設定をリセット*/
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, form, input, p, blockquote, th, td {
    margin: 0;
    padding: 0;
}

h2 {
    font-size: 1em;
}
/*画像の枠線をクリアして位置の初期値の設定*/
img {
    border: 0;
    vertical-align: top;
}

/*リンク時の枠の点線をなしにする*/
a {
    outline: none;
}

/*リスト要素の初期値をリセット*/
ul, ol {
    list-style: none;
}

input[checkbox] {
    display: none;
}

/*==================
共通
====================*/

body {
    background-color: #fff;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
    font-weight: 500;
    font-size: 1em;
    line-height: 1.6;
    font-feature-settings: "palt";
    letter-spacing: .05em;
    color: #373830;
}
@media screen and (min-width:768px) {
    body {
        font-size: 1.4em;
    }
}

#container {
    width: 100%;
    margin: 0 auto;
}
a {
    color: #6bb6bb;
    text-decoration: underline;
}
a:link,
a:visited,
a:active {
    color: #2a6496;
}

a:hover {
    color: #2a6496;
}

img {
    max-width: 100%;
    height: auto;
    width: auto;
}

/*==================
header
====================*/

header {
    width: 100%;
    z-index: 999;
    background: #ffffff;
    box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}
.header-content::before{
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(138.18deg, #09908F 1.08%, #4F9536 102%);
}
.header-main {
    position: relative;
    padding: .5em 10px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    height: 38px;
}

.header-logo {
    font-size: 1em;
    line-height: 1;
    width: 70px;
}
@media screen and (min-width:768px) {
    .header-logo {
        width: 100px;
    }
}
.header-button {
    width: 15em;
}
.header-button a{
    display: block;
    color: #ffffff;
    border-radius: 1em;
    background: #E28500;
    padding: .7em .5em .6em;
    text-align: center;
    font-size: 1em;
    font-weight: bold;
    line-height: 1;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.15);
    text-decoration: none;
}
.header-button a:hover{
    background: #F16500;
}

/*==================
footer
====================*/

footer {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    background: #ffffff;
    box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
}
.footer-content{
    content: "";
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #f8f8f8;
}
.footer-main {
    position: relative;
    padding: .5em 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.footer-button {
    width: 15em;
}
.footer-button a{
    display: block;
    color: #ffffff;
    border-radius: 2em;
    background: #E28500;
    padding: 1em .5em .9em;
    text-align: center;
    font-size: 1em;
    font-weight: bold;
    line-height: 1;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.15);
    text-decoration: none;
}
.footer-button a:hover{
    background: #F16500;
}

/*==================
catch
====================*/

.catch{
    width: 100%;
    overflow-x: hidden;
    padding-bottom: 10px;
}
.catch-content{
    position: relative;
    background: url("/resource/img/keeper/fun/catch-bg_sp.png?b") no-repeat 50% 50%;
    background-size: cover;
    height: 210px;
    width: 100%;
}
@media screen and (min-width:768px) {
    .catch-content{
        height: 374px;
    }
}
.catch-main {
    position: relative;
    width: 100%;
    height: 100%;
}
@media screen and (min-width:768px) {
    .catch-main {
        width: 862px;
        margin: 0 auto;
    }
}
.catch-img1-box {
    width: 220px;
    position: absolute;
    bottom: -9px;
    right: -10px;
}
@media screen and (min-width:768px) {
    .catch-img1-box {
        width: 473px;
        height: 380px;
        background: url(/resource/img/keeper/fun/catch1_pc.png?b) no-repeat;
        background-size: cover;
        bottom: -21px;
        right: -45px;
    }
    .catch-img1-box img {
        display: none;
    }
}
.catch-texts {
    position: absolute;
    left: 20px;
    top: 0;
}
@media screen and (min-width:768px) {
    .catch-texts {
        top: 20px;
        left: 0;
    }
}
.catch-top-text {
    color: #575752;
    padding-top: 20px;
    font-size: 0.8em;
}
@media screen and (min-width:768px) {
    .catch-top-text {
        font-size: 14px;
    }
}

.catch-text {
    color: #575752;
    line-height: 1.4;
    margin-bottom: 5px;
    font-size: 1.5em;
    text-shadow: #fff 1px 1px 0px, #fff -1px 1px 0px,
    #fff 1px -1px 0px, #fff -1px -1px 0px;
}
@media screen and (min-width:768px) {
    .catch-text {
        font-size: 2.4em;
    }
}
.catch-text__item1 {
    color: #4F9536;
}
.catch-text__item2 {
    color: #4F9536;
}
.catch-list {
    width: 200px;
}
@media screen and (min-width:768px) {
    .catch-list {
        width: auto;
        margin-top: .8em;
    }
}
.catch-list__item {
    display: inline-block;
    font-size: .8em;
    background: #EAEAEA;
    border-radius: 3px;
    color: #333;
    line-height: 1;
    padding: .4em .5em;
    margin: 0 .2em .3em 0;
}
@media screen and (min-width:768px) {
    .catch-list__item {
        font-size: 1em;
    }
}
.catch-circle {
    background: url("/resource/img/keeper/fun/catch-circle.png") no-repeat 50% 50%;
    width: 218px;
    height: 191px;
    position: absolute;
    top: 10px;
    right: 120px;
    display: none;
    text-align: center;
}
@media screen and (min-width:768px) {
    .catch-circle {
        display: block;
    }
}
.catch-circle__item1 {
    font-size: 1.2em;
    font-weight: bold;
    line-height: 1;
    margin-top: 2em;
    color: #81712F;
}
.catch-circle__item2 {
    font-size: 2.1em;
    font-weight: bold;
    line-height: 1;
    margin-top: .2em;
    color: #990000;
}
.catch-circle_price_unit {
    font-size: 0.6em;
}
.catch-circle_caption {
    font-size: 12px;
    font-weight: bold;
    color: #81712F;
}
.catch-bottom {
    display: none;
}
@media screen and (min-width:768px) {
    .catch-bottom {
        background: #6BB6BB;
        width: 100%;
        padding: .5em 0;
        font-size: 1.5em;
        color: #ffffff;
        text-align: center;
        font-weight: bold;
        display: block;
    }
}

.catch-caption {
    display: none;
}
@media screen and (min-width:768px) {
    .catch-caption{
        display: inline;
        position: absolute;
        right: 0;
        bottom:0;
        font-size: 12px;
        line-height: 13px;
        color: #81712F;
        margin-right: 10px;
    }
}

.box {
    padding: 1.6em 20px 2em;
}
@media screen and (min-width:768px) {
    .box {
        padding: 2.4em 0 3em;
    }
}
@media screen and (min-width:768px) {
    .box-pc-864 {
        width: 864px;
        padding-left: 0;
        padding-right: 0;
        margin: 0 auto;
    }
}
.box--no-t-pad {
    padding-top: 0;
}
.box--gray {
    background: #F4F5EC;
}
.box--blue {
    background: #E6F1F1;
}
.box--orange {
    background: #FFFAF3;
}
.box-echo {
    color: #006968;
    font-size: 15.6px;
    text-align: center;
    margin-bottom: .5em;
}

@media screen and (min-width:768px) {
    .box-echo {
        font-size: .8em;
    }
}

.box-echo--black {
    color: #575752;
}
.box-text {
    font-size: 15.6px;
    line-height: 1.5;
    color: #575752;
}
.box-text--center {
    text-align: center;
}
.box-text > p{
    margin-bottom: .8em;
}

.box-text p:last-child{
    margin-bottom: 0;
}

@media screen and (min-width:768px) {
    .box-text {
        font-size: .9em;
    }
}

.box-title {
    text-align: center;
    margin-bottom: .5em;
    font-size: 1.1em;
}

@media screen and (min-width:768px) {
    .box-title {
        font-size: 1.6em;
    }
}
.box-sub-title {
    text-align: center;
    margin-bottom: .5em;
    font-size: 1.1em;
}

@media screen and (min-width:768px) {
    .box-sub-title {
        font-size: 1.2em;
    }
}
.box-button {
    text-align: center;
    margin-bottom: 1em;
}
.box-button .cv-button {
    text-align: center;
    display: inline-block;
    background: linear-gradient(176.68deg, #FBB018 13.81%, #E27A04 86.19%);
    box-shadow: 0px 4px 1px rgba(0, 0, 0, 0.1);
    border-radius: 25px;
    color: #ffffff;
    padding: .8em 1.5em;
    font-weight: bold;
    line-height: 1;
    text-decoration: none;
}

@media screen and (min-width:768px) {
    .box-button .cv-button {
        border-radius: 50px;
        font-size: 1.5em;
    }
}


.box-button .cv-button:hover {
    background: linear-gradient(176.68deg, #FF9900 13.81%, #DB6900 86.19%);
}

.skill {
    padding-top: 1em;
}
.skill-title {
    position: relative;
    color: #006968;
    font-size: 1.3em;
}
.skill-title::before {
    z-index: -999;
    content: "";
    position: absolute;
    background-color: #F4F5EC;
    width: 17em;
    height: .7em;
    left: 50%;
    margin-left: -8.5em;
    bottom: .1em;
}
.skill-text {
    color: #6F706B;
    line-height: 1.6;
    margin-top: 1em;
}
@media screen and (min-width:768px) {
    .skill-text {
        text-align: center;
        font-size: 1.1em;
    }
}

.shigototte-title {
    /*background: url(/resource/img/keeper/fun/shigototte-top-bg.png) no-repeat 50% 100%;*/
    background: #F4F5EC;
    padding-top: 2em;
    /*height: 50px;*/
    text-align: center;
    color: #4F9536;
    background-size: 100% 100%;
    font-size: 15.6px;
}
@media screen and (min-width:768px) {
    .shigototte-title {
        /*height: 120px;*/
        min-width: 864px;
        font-size: 1.4em;
    }
}

.shigototte {
    text-align: center;
    padding-bottom: 1px;
}
.shigototte-img {
    margin-bottom: 2em;
    border-radius: 10px;
    text-align: center;
}
.shigototte-img img{
    border-radius: 10px;
    width: 80%;
}
.shigototte-catch{
    font-size: 1.2em;
    margin-bottom: .8em;
}
@media screen and (min-width:768px) {
    .shigototte-catch{
        font-size: 1.5em;
        margin-bottom: .5em;
    }
}
.shigototte-catch:not(:first-child){
    margin-top: 1.5em;
}

.shigototte-catch::before{
    content: "1";
    display: inline-flex;
    width: 1.5em;
    height: 1.5em;
    border-radius: 1em;
    line-height: 1.5em;
    background: #ADDADD;
    color: #ffffff;
    font-weight: bold;
    align-items: center;
    justify-content: center;
    margin-right: .3em;

}
.shigototte-text__item:nth-of-type(2) .shigototte-catch:before{content: "2";}
.shigototte-text__item:nth-of-type(3) .shigototte-catch:before{content: "3";}
.shigototte-text__item:nth-of-type(4) .shigototte-catch:before{content: "4";}


@media screen and (min-width:768px) {
    .shigototte-catch::before{
        font-size: .9em;

    }
}

.shigototte-catch-text{
    margin-top: 1em;
}

@media screen and (max-width:320px) {
    .shigototte-catch-text{
        font-size: .9em;
    }
}
@media screen and (min-width:768px) {
    .shigototte-catch-text {
        font-size: .8em;
        line-height: 1.8;
    }
}
.shigototte-catch-text strong{
    color: #E28500;
    font-weight: normal;
}
.shigototte-text {

}
@media screen and (min-width:768px) {
    .shigototte-text {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
}
.shigototte-text__item {
    margin-bottom: 2em;
    background: #fff;
    padding: 1em 1.2em;
    box-sizing: border-box;
    border-radius: 10px;
}
@media screen and (min-width:768px) {
    .shigototte-text__item {
        width: 47%;
    }
}

.shigototte-bottom {
    background: url(/resource/img/keeper/fun/shigototte-bottom-bg.png) no-repeat 50% 100%;
    height: 50px;
    background-size: 100% 100%;
}
@media screen and (min-width:768px) {
    .shigototte-bottom {
        height: 100px;
        min-width: 864px;
    }
}



.cv1-echo {
    color: #006968;
}
.cv1-title {
    font-size: .95em;
}

@media screen and (max-width:320px) {
    .cv1-title {
        font-size: .8em;
    }
}

.cv-icons-block {
    background: #F4F5EC;
    border: 1px solid #E4E7CF;
    box-sizing: border-box;
    border-radius: 4px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2em;
}

.cv-icons-sub-title {
    text-align: center;
    padding-top: 10px;
    font-weight: bold;
}

.cv-icons {
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
    padding: 1em 1em 0;
}
@media screen and (min-width:768px) {
    .cv-icons-block {
        width: 740px;
        margin: 2em auto 0;
        border-width: 4px;
        border-radius: 10px;
    }
    .cv-icons {
        padding: 1em 1em .4em
    }
}

.cv-icons--white {
    background: #ffffff;
}

.cv-icons__item {
    font-size: 15.6px;
    margin-bottom: 1em;
    display: flex;
    align-items: center;
    width: 60%;
    text-align: left;
    color: #575752;
}
@media screen and (max-width:320px) {
    .cv-icons__item {
        font-size: .7em;
    }
}
.cv-icons__item:nth-of-type(2){width: 40%;}
.cv-icons__item:nth-of-type(4){width: 40%;}
@media screen and (min-width:768px) {
    .cv-icons__item {
        width: 25%;
        display: block;
        text-align: center;
        font-weight: bold;
    }
    .cv-icons__item:nth-of-type(2){width: 25%;}
    .cv-icons__item:nth-of-type(4){width: 25%;}
}

.cv-icons__item::before {
    content: "";
    display: block;
    width: 34px;
    height: 34px;
    background: url(/resource/img/keeper/fun/cv-icon1.png) no-repeat;
    background-size: 100% 100%;
    margin-right: .5em;
    margin-top: -.5em;
}
@media screen and (min-width:768px) {
    .cv-icons__item::before {
        width: 80px;
        height: 80px;
        margin: 0 auto .4em;
    }
}

.cv-icons__item:nth-of-type(2):before{background-image: url(/resource/img/keeper/fun/cv-icon2.png);}
.cv-icons__item:nth-of-type(3):before{background-image: url(/resource/img/keeper/fun/cv-icon3.png);}
.cv-icons__item:nth-of-type(4):before{background-image: url(/resource/img/keeper/fun/cv-icon4.png);}

.wakaranai-text {
    font-size: .8em;
    text-align: center;
    margin-top: 2em;
}
@media screen and (min-width:768px) {
    .wakaranai-text {
        font-size: .7em;
    }
}

.movie-list {
    margin-top: 2em;
}
@media screen and (min-width:768px) {
    .movie-list {
        display: flex;
        justify-content: center;
    }
}
.movie-list__item {
    border-radius: 5px;
    overflow: hidden;
    z-index: 1;
    height: 180px;
    width: 320px;
    margin: 0 auto 1em;
    position: relative;
}
@media screen and (max-width:320px) {
    .movie-list__item {
        height: 145px;
        width: 280px;
    }
}

.movie-list__item:before {
    content: "";
    width: 1px;
    height: 180px;
    background: #F4F5EC;
    z-index: 2;
    position: absolute;
    top:0;
    left:0;
}
@media screen and (min-width:768px) {

    .movie-list__item:before {
        height: 230px;
    }
}
.movie-list__item:last-child {
    margin-bottom: 0;
}
.movie-list__item iframe{
    height: 180px;
    width: 320px;
}
@media screen and (min-width:768px) {
    .movie-list__item {
        height: 270px;
        width: 480px;
        margin: 0;
    }
    .movie-list__item iframe{
        height: 270px;
        width: 480px;
    }
}
.merit {
    padding-bottom: 1em;
}
.merit-list {
    margin: 1em auto 0;
    text-align: center;
}
@media screen and (min-width:768px) {
    .merit-list {
        margin-top: 2em;
        display: flex;
        justify-content: space-between;
    }
}
@media screen and (min-width:768px) {
    .merit-sub {
        font-size: .9em;
        margin-top: .8em;
    }
}
.merit-list__item {
    margin-bottom: 1.5em;
}
.merit-list__item:last-child {
    margin-bottom: 0;
}
.merit-img {
    width: 50px;
    height: 50px;
    text-align: center;
    margin: 0 auto .5em;
}
@media screen and (min-width:768px) {
    .merit-img {
        width: 90px;
        height: 90px;
    }
}
.merit-text-toggle {
    display: block;
    background: #EDF8E4;
    border-radius: 3px;
    color: #006968;
    margin-top: .5em;
    padding: .4em;
}
.merit-text-toggle-detail {
    display: none;
    border: 2px solid #EDF8E4;
    padding: 1em;
    margin-top: -2px;
}
.merit-text-toggle:hover {
    background: #c5c9a6;
}
.merit-text-caption {
    font-size: .8em;
}
@media screen and (min-width:768px) {
    .merit-text-toggle {
        display: none;
    }
    .merit-text-toggle-detail {
        display: block;
        border: none;
        padding: 0;
        font-size: .75em;
        margin-top: .6em;
    }
}
.sukinakaji {
    background: #F4F5EC;
    border: 1px solid #E5E5E5;
    box-sizing: border-box;
    border-radius: 5px;
    margin: 10px 0 2em;
    padding: 1em;
    text-align: center;
}
@media screen and (min-width:768px) {
    .sukinakaji {
        width: 720px;
        margin: 1em auto 2em;
    }
}
.sukinakaji-title {
    padding-bottom: .8em;
    border-bottom: 1px solid #E5E5E5;
}
.sukinakaji-table {
    margin: 1em auto 0;
}
.sukinakaji-pc-table{
    display: none;
}
@media screen and (min-width:768px) {
    .sukinakaji-pc-table{
        display: table;
    }
    .sukinakaji-sp-table{
        display: none !important;
    }
}
.sukinakaji-table td{
    vertical-align: top;
    text-align: left;
    background: url(/resource/img/keeper/fun/sukinakaji.png) no-repeat left top;
    padding-bottom: 1em;
    white-space: nowrap;
}
.sukinakaji-pc-table td{
    background-size: 27px 27px;
    padding-left: 36px;
    font-size: .8em;
}
.sukinakaji-sp-table td{
    background-size: 20px 20px;
    padding-left: 25px;
    padding-right: 10px;
}
.sukinakaji-pc-table td:nth-child(1){width: 4em;}
.sukinakaji-pc-table td:nth-child(2){width: 6em;}
.sukinakaji-pc-table td:nth-child(3){width: 6em;}
.sukinakaji-pc-table td:nth-child(4){width: 8em;}

.sukinakaji-sp-table td:nth-child(1){width: 6em;}

.sukinakaji-table span{
    display: block;
    font-size: .8em;
}
@media screen and (min-width:768px) {
}
.sarani {
    position: relative;
    background: #F4F5EC;
    border: 1px solid #E5E5E5;
    box-sizing: border-box;
    border-radius: 5px;
    margin: 1.5em 10px 2em;
    padding: 1em;
}
@media screen and (min-width:768px) {
    .sarani {
        width: 720px;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 3em;
    }
}
.sarani-echo {
    position: absolute;
    left: 50%;
    top: -.6em;
    line-height: 1;
    margin-left: -2em;
    font-size: 15.6px;
}

@media screen and (min-width:768px) {
    .sarani-echo {
        font-size: .9em;
    }
}

.sarani-list {
    display: flex;
    justify-content: space-between;
    text-align: center;
}
.sarani-list__item {
    width: 30%;
    font-size: 15.6px;
    font-weight: bold;
    color: #575752;
}
@media screen and (min-width:768px) {
    .sarani-list__item {
        display: flex;
        text-align: left;
        align-items: center;
        font-size: .8em;
    }
}
.sarani-list-img {
    width: 50px;
    margin: 0 auto .5em;
}
@media screen and (min-width:768px) {
    .sarani-list-img {
        width: 70px;
        margin-right: .8em;
    }
}


.yotei {
    padding-left: 0;
    padding-right: 0;
}
.yotei-title {
    text-align: center;
    padding: 0 20px;
    line-height: 1;
}
@media screen and (min-width:768px) {
    .yotei-title {
        padding-bottom: 1em;
    }
}
.yotei-person {
    padding: 2em 0 0;
    border-top: #DADDC5 2px solid;
    margin-top: 20px;
}
@media screen and (min-width:768px) {
    .yotei-person {
        display: flex;
        width: 864px;
        margin: 0 auto 2em;
        justify-content: space-between;
    }
    .yotei-person:last-child {
        margin-bottom: 0 ;
    }
    .yotei-person__item {
        width: 540px;
        margin-right: 1em;
    }
}

.yotei-catch {
    display: flex;
    padding: 0 10px;
    align-items: center;
}
@media screen and (min-width:768px) {
    .yotei-catch {
        padding: 0;
    }
}
.yotei-catch__item:first-child {
    margin-right: 1em;
    width: 90px;
}
.yotei-img {
    text-align: center;
}
.yotei-img img{
    width: 90px;
}
.yotei-list {
    margin-bottom: 1em;
}
@media screen and (min-width:768px) {
    .yotei-list {
        font-size: .9em;
    }
}
.yotei-list__item {
    display: inline-block;
    line-height: 1;
    font-weight: bold;
    font-size: .8em;
    margin-right: .8em;
}
.yotei-list__item:last-child {
    margin-right: 0;
}
.yotei-list__item span{
    border-radius: 3px;
    color: #ffffff;
    padding: .4em .5em;
    display: inline-block;
    font-size: .9em;
    margin-right: .3em;
    font-weight: normal;
}
.yotei-tokui {
    background: #09908F;
}
.yotei-gessyu {
    background: #DD6D0F;
}
.yotei-line {
    font-weight:bold;
    color: #4F9536;
    font-size: 1.15em;
    margin-bottom: .2em;
    line-height: 1.4;
}
@media screen and (min-width:768px) {
    .yotei-line {
        font-size: 1.4em;
    }
}
.yotei-line span{
    font-size: .7em;
}
.yotei-text {
    padding: 0 20px;
    font-size: 15.6px;
    margin-bottom: 1.5em;
}
@media screen and (min-width:768px) {
    .yotei-text {
        padding: 0;
        font-size: .9em;
    }
}
.yotei-text strong {
    color: #E28500;
}


.yotei-toggle {
    background: #DEE1C6;
    border-radius: 3px;
    color: #006968;
    cursor: pointer;
    font-weight: bold;
    text-align: center;
    margin: 0 10px 1em;
    padding: .4em 0 .3em;
}
@media screen and (min-width:768px) {
    .yotei-toggle {
        display: none;
    }
}
.yotei-toggle:hover {
    background: #c5c9a6;
}
.yotei-toggle-detail {
    display: none;
}
@media screen and (min-width:768px) {
    .yotei-toggle-detail {
        display: block;
    }
}
.yotei-table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    border: 1px solid #DEE1C6;
    border-width: 0 0 1px 0;
}
@media screen and (min-width:768px) {
    .yotei-table{
        font-size: .7em;
    }
}
.yotei-table thead{
    background: #EBECE1;
}
.yotei-table th{
    border: 1px solid #DEE1C6;
    border-width: 1px 0 0 1px;
    font-size: .9em;
    line-height: 1.3;
    padding: .4em .2em;
    font-weight: normal;
    color: #6F706B;
}
.yotei-table th:first-child{
    border-left-width: 0;
}
.yotei-table td{
    border: 1px solid #DEE1C6;
    border-width: 1px 0 0 1px;
    text-align: center;
    font-size: .9em;
    line-height: 1.3;
    padding: .4em .2em;
}
.yotei-table td strong{
    background-color: #80BF4B;
    color: #fff;
    padding: .2em .4em;
    border-radius: 4px;
    font-weight: normal;
    display: inline-block;
}

.yotei-table tbody tr:nth-child(odd){
    background-color: #FAFAF4;
}
.three-hour-title {
    color: #DD6D0F;
    text-align: center;
    margin-bottom: 1em;
}
.three-hour-text {
    margin: 0 10px;
    font-size: .9em;
    background: #FAFAF4;
    border-radius: 4px;
    padding: 1em;
}
.three-hour-text p{
    margin-bottom: .4em;
}
.three-hour-text p:last-child{
    margin-bottom: 0;
}
.hachiwari-catch {
    display: flex;
    align-items: center;
    text-align: left;
    margin-bottom: 2em;
    justify-content: start;
}
@media screen and (min-width:768px) {
    .hachiwari-catch {
        justify-content: space-between;
    }
}
.hachiwari-img {
    width: 35%;
    margin-right: 5%;
}
@media screen and (min-width:768px) {
    .hachiwari-img {
        width: 30%;
        margin-top: 1em;
    }
}
.hachiwari-catch-text {
}
@media screen and (min-width:768px) {
    .hachiwari-catch-text {
        width:  65%;
    }
}
.hachiwari-title {
    text-align: left;
    line-height: 1.4;
    color: #09908F;
    font-size: 1.2em;
}
@media screen and (min-width:768px) {
    .hachiwari-title {
        font-size: 1.4em;
        line-height: 1.3;
    }
}
.hachiwari-highlighted__area{
    display: inline-block;
    position: relative;
}
.hachiwari-highlighted__area:before {
    content: "";
    z-index: -999;
    position: absolute;
    background: #FFFB9F;
    width: 7.6em;
    height: .8em;
    top: .5em;
    left: -.2em;
    border-radius: 2px;
}
.hachiwari-highlighted__area--carrier:before {
    width: 8.6em;
}
.hachiwari-highlighted__area--daikatsuyaku:before {
    width: 3.6em;
}
@media screen and (min-width:768px) {
    .hachiwari-highlighted__area--mikeiken:before {
        width: 7.6em;
    }
    .hachiwari-highlighted__area--carrier:before {
        width: 8.6em;
    }
    .hachiwari-highlighted__area--daikatsuyaku:before {
        width: 3.6em;
    }
}
.hachiwari-text strong {
    line-height: 1.6;
}
.hachiwari-text strong {
    color: #E28500;
}
.hachiwari-text-first-sp {
    margin-bottom: 30px;
}

.hachiwari-hachi {
    font-size: 2em;
}
.okigaruni {
}

@media screen and (min-width:768px) {
    .okigaruni {
        background: #ffffff;
        border-top: 4px solid #DADDC5;
    }
}
.okigaruni-title {
    font-size: 1.2em;
}
.step-and-watashitachi {
    padding-top: .5em;
}
@media screen and (min-width:768px) {
    .step-and-watashitachi {
        display: flex;
        justify-content: space-between;
        margin: 0 auto;
        width: 864px;
        padding-top: 2em;
    }
}
@media screen and (min-width:768px) {
    .okigaruni {
        background: #ffffff;
        border-top: 4px solid #DADDC5;
    }
}



@media screen and (min-width:768px) {
    .step {
        background: #F4F5EC;
    }
}
@media screen and (min-width:768px) {
    .step-flow {
        width: 520px;
    }
}
.step-flow-cont {
    border: 4px solid #E3C9BF;
    box-sizing: border-box;
    border-radius: 10px;
    font-weight: bold;
}
.step-flow-title {
    background: #FAE9E3;
    border-radius: 5px 5px 0 0;
    padding: .5em;
    border-bottom: 3px solid #E3C9BF;
    text-align: center;
}
.step-flow-caption {
    font-size: .8em;
    text-align: center;
    margin-top: 1em;
}
.step-text {
    border-bottom: 3px solid #E3C9BF;
    color: #575752;
    font-size: 15px;
    padding: 1em;
    position: relative;
    background: #ffffff;
}
.step-text:last-child {
    border-bottom: none;
    text-align: center;
    font-weight: bold;
    border-radius: 0 0 7px 7px;
    font-size: 1.2em;
    background: #FAE9E3 url(/resource/img/keeper/fun/step-bg_sp.png) no-repeat center bottom;
    background-size: 278px 70px;
    padding-bottom: 2em;
}
@media screen and (min-width:768px) {
    .step-text:last-child {
        background: #FAE9E3 url(/resource/img/keeper/fun/step-bg_sp.png) no-repeat center bottom;
        background-size: 510px 122px;
        padding-bottom: 2.5em;
    }
}
.step-text:after, .step-text:before {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}

.step-text:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-color: #ffffff;
    border-width: 10px;
    margin-left: -10px;
    z-index: 501;
}
.step-text:before {
    border-color: rgba(227, 201, 191, 0);
    border-top-color: #E3C9BF;
    border-width: 14px;
    margin-left: -14px;
    z-index: 500;
}

.step-text:last-child:after, .step-text:last-child:before {
    display: none;
}
.step-text p {
}
@media screen and (min-width:768px) {
    .step-text p {
        width: 21em;
        margin: 0 auto;
    }
}
.step-text p span{
    padding-left: 3em;
    font-size: .8em;
    font-weight: normal;
}
.step-text p::before {
    content: "1";
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 2em;
    height: 2em;
    border-radius: 1em;
    background: #E2A291;
    font-weight: bold;
    color: #ffffff;
    line-height: 1;
    margin-right: .5em;
}

.step-text:nth-of-type(2) p::before{content: "2";}
.step-text:nth-of-type(3) p::before{content: "3";}
.step-text:nth-of-type(4) p::before{content: "4";}

.step-text:last-child:before {
    display: none;
}
.step-text-strong {
    display: inline-block;
    text-indent: 1em;
    margin-left: -1em;
}

.watashitachi {
    margin-top: 2em;
}
@media screen and (min-width:768px) {
    .watashitachi {
        width: 300px;
    }
}
.watashitachi__title {
    text-align: center;
}
.watashitachi__img {
    margin-top: 1em;
}
.watashitachi__overview {
    margin-top: 1em;
    text-align: center;
    font-size: 15.6px;
}
@media screen and (min-width:768px) {
    .watashitachi__overview {
        font-size: 0.9em;
    }
}

.watashitachi__text {
    margin-top: 1em;
    font-size: 15.6px;
}

@media screen and (min-width:768px) {
    .watashitachi__text {
        font-size: 0.9em;
    }
}


@media screen and (min-width:768px) {
    .wada {
        background: #ffffff;
    }
    .wada-img-and-text {
        display: flex;
        flex-flow: row-reverse;
    }
}
.wada-toggle {
    background: #DEE1C6;
    border-radius: 3px;
    color: #006968;
    margin-top: .5em;
    padding: .4em;
    text-align: center;
    cursor: pointer;
}
@media screen and (min-width:768px) {
    .wada-toggle {
        margin-right: 250px;
    }
}
.wada-toggle:hover {
    background: #c5c9a6;
}
.wada-toggle-detail {
    display: none;
    margin-top: 1em;
}
.wada-toggle-detail h3{
    margin-bottom: 1em;
}
.wada-toggle-detail p{
    margin-bottom: .5em;
}
.wada-img {
    width: 120px;
    margin: 0 auto 1em;
}
@media screen and (min-width:768px) {
    .wada-img {
        min-width: 220px;
        margin-left: 1em;
    }
}

.wada-text {
    text-align: center;
    font-size: .9em;
}

.commu-and-kosei {
}
.community {
    padding: 0;
}

@media screen and (min-width:768px) {
    .community {
        padding-bottom: 1em;
    }
}
.community-cont {
    background: #ffffff;
    padding: 2em 20px;
}
@media screen and (min-width:768px) {
    .community-cont {
        width: 864px;
        margin: 0 auto 2em;
        border-radius: 5px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 1.5em 40px;
        box-sizing: border-box;
    }
}
.community-title {
    margin-bottom: 1em;
}
@media screen and (min-width:768px) {
    .community-title {
        font-size: 1em;
        margin-bottom: 0;
    }
}
.community-title span{
    font-size: 1.3em;
    color: #E28500;
}
.community-text {
    display: flex;
    align-items: center;
}
.community-text__img {
    flex-basis: 140px;
    min-width: 140px;
    margin-right: 1em;
}
@media screen and (min-width:768px) {
    .community-text {
        flex-grow: 1;
        margin-left: 1em;
        flex-direction: row-reverse;
        width: 300px;
        justify-content: space-between;
    }
    .community-text__text {
        font-size: .9em;
    }
    .community-text__img {
        margin-left: 1em;
        margin-right: 0;
    }
}
.kosei {
    order: 2;
    overflow: hidden;
    position: relative;
    padding-bottom: 1em;
}
.kosei-texts {
    height: 450px;
}
@media screen and (min-width:768px) {
    .kosei-texts {
        width: 864px;
        margin-left: auto;
        margin-right: auto;
        margin-top: 2em;
        position: relative;
        height: 322px;
        font-size: .8em;
    }
}
.kosei-item1 {
    position: absolute;
    top: 314px;
    left: 50%;
    margin-left: -218px;
    width: 320px;
    height: 162px;
    background: url(/resource/img/keeper/fun/kosei1.png) no-repeat center bottom;
    background-size: 320px 162px;
}
@media screen and (min-width:768px) {
    .kosei-item1 {
        left: 32px;
        top: 101px;
        margin-left: 0;
        width: 320px;
        height: 162px;
        background-size: 320px 162px;
    }
}
.kosei-item2 {
    position: absolute;
    top: 88px;
    left: 50%;
    margin-left: -224px;
    width: 447px;
    height: 209px;
    background: url(/resource/img/keeper/fun/kosei2.png) no-repeat left top;
    background-size: 447px 209px;
}
@media screen and (min-width:768px) {
    .kosei-item2 {
        right: 0;
        top: 8px;
        margin-left: -114px;
        width: 492px;
        height: 235px;
        background-size: 492px 235px;
        background-position-x: 0;
    }
}
.kosei-text {
    position: absolute;
}
.kosei-text-name {
    font-size: .8em;
}
.kosei-text-sub {
    font-size: 15.6px;
    left: 100px;
    top: -25px;
    line-height: 1.2;
    color: #575752;
}

@media screen and (min-width:768px) {
    .kosei-text-sub {
        font-size: .9em;
    }
}

.kosei-text-title {
    font-weight: bold;
    text-align: center;
    line-height: 1.2;
}
.kosei-text1 {
    left: 92px;
    top: 168px;
}
.kosei-text2 {
    left: 173px;
    top: 21px;
}
.kosei-text3 {
    color: #CD5638;
    left: 193px;
    top: 80px;
}


@media screen and (min-width:768px) {
    .kosei-text1 {
        left: 83px;
        top: 167px;
    }
    .kosei-text2 {
        left: 155px;
        top: 16px;
    }
    .kosei-text3 {
        top: 77px;
        left: 186px;
    }
}



.kosei-text7 {
    left: 74px;
    top: 144px;
}
.kosei-text8 {
    left: 121px;
    top: -22px;
}
.kosei-text9 {
    color: #09908F;
    top: 19px;
    left: 138px;
}


@media screen and (min-width:768px) {
    .kosei-text7 {
        left: 79px;
        top: 158px;
    }
    .kosei-text8 {
        left: 140px;
        top: -20px;
    }
    .kosei-text9 {
        left: 152px;
        top: 21px;
    }
}

.kosei-text10 {
    left: 312px;
    top: 207px;
}
.kosei-text11 {
    left: 184px;
    top: 94px;
    text-align: right;
}
.kosei-text12 {
    color: #B62822;
    left: 185px;
    top: 154px;
}
@media screen and (min-width:768px) {
    .kosei-text10 {
        left: 344px;
        top: 223px;
    }
    .kosei-text11 {
        left: 199px;
        top: 107px;
    }
    .kosei-text12 {
        left: 203px;
        top: 173px;
    }
}

.profile {
    font-size: 1rem;
}
@media screen and (min-width:768px) {
    .profile {
        font-size: 1.15rem;
    }
}
.profile-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 864px;
    margin: 2em auto 0;
    font-size: 1.2em;

}
@media screen and (min-width:768px) {
    .profile-title {
        margin-bottom: 1em;
        margin-top: 0;
    }
}

.profile-title span {
    min-width: 13em;
}
@media screen and (min-width:768px) {
    .profile-title span {
        min-width: 13em;
    }
}
.profile-title:before,.profile-title:after {
    content: "";
    background: rgba(0,0,0,.1);
    height: 2px;
    width: 100%;
}
.profile-box1 {
    justify-content: space-between;
    max-width: 864px;
    margin: 1em auto;
    display: block;
}
@media screen and (min-width:768px) {
    .profile-box1 {
        display: flex;
        margin-top: 2em;
        justify-content: space-between;
    }
}
.profile-item {
    background: #fff;
    padding: 1em 1.2em;
    box-sizing: border-box;
    border-radius: 10px;
}
@media screen and (min-width:768px) {
    .profile-item {
        padding: 1.2em 1.5em;
    }
}
.profile-item1 {
    margin-bottom: 1em;
}
@media screen and (min-width:768px) {
    .profile-item1 {
        margin-bottom: 0;
        flex-grow: 1;
        margin-right: 2em;
    }
}
.profile-item1 div{
    display: flex;
    flex-flow: column-reverse;
}
@media screen and (min-width:768px) {
    .profile-item1 div{
        flex-flow: row;
        justify-content: space-between;
    }
    .profile-item1 .profile-sub-title {
        margin-top: 0;
    }
}
.profile-item1 p {
    margin-top: .5em;
}
@media screen and (min-width:768px) {
    .profile-item1 p{
        margin-top: 2em;
        margin-right: 1em;
    }
}

.profile-item1 img{
    max-width: 210px;
    margin: .2em auto 0;
}
@media screen and (min-width:768px) {
    .profile-item1 img{
        max-width: 220px;
        margin: -1em 0 0 0;
    }
}
.profile-item2 span{
    font-size: .9em;
    text-indent: -2em;
    margin-left: 2em;
    display: block;
}
.profile-item2 img{
    max-width: 222px;
    display: block;
    margin: .5em auto 1em;
}
@media screen and (min-width:768px) {
    .profile-item2 img{
        max-width: 242px;
    }
}
.profile-box2 {
    background: #fff;
    padding: 1em 1.2em;
    box-sizing: border-box;
    border-radius: 10px;
    max-width: 864px;
}
@media screen and (min-width:768px) {
    .profile-box2 {
        margin: 2em auto 1em;
        padding: 1.2em 1.5em;
    }
}
.profile-box2-cont {
    margin-top: 1em;
}
.profile-box2 .profile-sub-title {
    margin-bottom: .2em;
}
@media screen and (min-width:768px) {
    .profile-box2-cont {
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
    }
}
.profile-box2 ul{
    list-style: disc;
    margin-left: 1.5em;
}

.profile-box2-cont img{
    margin-top: 1em;
}
@media screen and (min-width:768px) {
    .profile-box2-cont img{
        max-width: 282px;
        margin-top: -2em;
    }
}
.profile-sub-title2 {
    border-bottom: 2px solid rgba(0,0,0,.1);
    margin-bottom: .7em;
    padding-bottom: .2em;
}
@media screen and (min-width:768px) {
    .profile-sub-title2 {
        border: none;
        display: flex;
        align-items: center;
        margin-bottom: .2em;
        font-size: 1.3em;
    }
}
.profile-sub-title2 span {
    min-width: 14em;
    text-align: center;
    display: block;
}
@media screen and (min-width:768px) {
    .profile-sub-title2 span {
    }
    .profile-sub-title2:before,.profile-sub-title2:after {
        content: "";
        background: rgba(0,0,0,.05);
        height: 2px;
        width: 100%;
    }
}
.naritai {
    text-align: center;
}
.naritai-tarinai {
    background: rgba(255, 246, 40, 0.45);
    border: 1px solid #FFF628;
    box-sizing: border-box;
    border-radius: 6px;
    padding: .5em;
    font-weight: bold;
    margin: 0 auto 1em;
}
@media screen and (min-width:768px) {
    .naritai-tarinai {
        font-size: 1.6em;
        width: 864px;
    }
}
.naritai-sukoshidemo {
    font-weight: bold;
    margin-bottom: 2em;
    padding-bottom: 1em;
    border-bottom: 3px solid #E4E7CF;
    position: relative;
    background: #ffffff;
}
.naritai-sukoshidemo:after, .naritai-sukoshidemo:before {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}

.naritai-sukoshidemo:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-color: #ffffff;
    border-width: 10px;
    margin-left: -10px;
}
.naritai-sukoshidemo:before {
    border-color: rgba(228, 231, 207, 0);
    border-top-color: #e4e7cf;
    border-width: 14px;
    margin-left: -14px;
}

.qa-texts {
    font-size: 15.6px;
}
@media screen and (min-width:768px) {
    .qa-texts {
        margin-top: 2em;
        font-size: .9em;
    }
}

.qa-texts dt{
    font-weight: bold;
    position: relative;
    padding-left: 30px;
    margin-bottom: .4em;
}
@media screen and (min-width:768px) {
    .qa-texts dt {
        padding-left: 40px;
    }
}
.qa-texts dt:before {
    content: "";
    background: url(/resource/img/keeper/fun/qa-q.png) no-repeat 0 0;
    background-size: 23px 23px;
    width: 23px;
    height: 23px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}
@media screen and (min-width:768px) {
    .qa-texts dt:before {
        background-size: 30px 30px;
        width: 30px;
        height: 30px;
    }
}
.qa-texts dd {
    position: relative;
    padding-left: 30px;
    margin-bottom: 2em;
    color: #575752;
}
@media screen and (min-width:768px) {
    .qa-texts dd {
        padding-left: 40px;
    }
}
.qa-texts dd:before {
    content: "";
    background: url(/resource/img/keeper/fun/qa-a.png) no-repeat 0 0;
    background-size: 23px 23px;
    width: 23px;
    height: 23px;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}
@media screen and (min-width:768px) {
    .qa-texts dd:before {
        background-size: 30px 30px;
        width: 30px;
        height: 30px;
    }
}
.qa-texts dd p {
    margin-bottom: .5em;
}
.qa-texts dd ul {
    list-style: disc;
    margin-left: 1.2em;
    margin-bottom: .5em;
}
.support {
    position: relative;
    border-bottom: 3px solid #e4e7cf;
}
.support:after, .support:before {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}

.support:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-color: #ffffff;
    border-width: 10px;
    margin-left: -10px;
}
.support:before {
    border-color: rgba(228, 231, 207, 0);
    border-top-color: #e4e7cf;
    border-width: 14px;
    margin-left: -14px;
}
.support-title {
    margin-bottom: 1em;
}
@media screen and (min-width:768px) {
    .support-title {
        margin-bottom: 1.5em;
    }
}
.support-texts {
    justify-content: space-between;
    flex-wrap: wrap;
    display: flex;
    text-align: center;
    font-size: 15.6px;
    line-height: 1.4;
}

@media screen and (min-width:768px) {
    .support-texts {
        font-size: .9em;
    }
}

.support-text {
    width: 50%;
    margin-bottom: 1em;
}
@media screen and (min-width:768px) {
    .support-text {
        width: 25%;
        margin-bottom: 0;
    }
}
.support-text__img img {
    width: 43px;
    margin-bottom: .5em;
}
@media screen and (min-width:768px) {
    .support-text__img img {
        width: 74px;
    }
}
.media {
    text-align: center;
    padding-top: 0;
}
.media-title {
    color: #E2A291;
    font-size: 1.1em;
    font-weight: bold;
}
.media-img {
    width: 80%;
    margin: 1em auto 2em;
}
@media screen and (min-width:768px) {
    .media-img {
        width: 492px;
    }
}
.media-sns {
    display: flex;
    align-items: center;
    justify-content: center;
}
.media-facebook,.media-instagram,.media-twitter {
    margin-top: 1em;
}
.media-facebook,.media-instagram {
    margin-right: 1em;
}
.media-facebook img,.media-twitter img,.media-instagram img {
    width: 60px;
}

.hide-sp{
    display: none;
}
@media screen and (min-width:768px) {
    .hide-sp{
        display: block;
    }
}
@media screen and (min-width:768px) {
    .hide-ipad{
        display: none;
    }
}

.top-interview-reservation-button {
    margin-bottom: 40px;
}

.campaign-information {
    text-align: center;
    font-size: 15.6px;
    margin-bottom: 20px;
}

@media screen and (min-width:768px) {
    .campaign-information {
        font-size: .8em;
    }
}

.campaign-information-bold {
    color: #CD5638;
    font-weight: bold;
}

.hide-sp-inline-block {
    display: none;
}
@media screen and (min-width:768px) {
    .hide-sp-inline-block {
        display: inline-block;
    }
}

.hard-reservation-information {
    background-color: #fbe5d6;
    border: 1px solid #dcdada;
    font-size: 15px;
    max-width: 500px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 30px;
    padding-left: 5px;
    padding-right: 5px;
}

@media screen and (min-width:768px) {
    .hard-reservation-information {
        font-size: 17px;
    }
}

.yotei-footer {
    font-weight:bold;
    font-size: 1.15em;
    margin-bottom: .2em;
    line-height: 1.4;
    text-align: center;
}

.yotei-footer-green-text {
    color: #4F9536;
}

.footer {
    background: #F4F5EC;
    padding: 20px;
    margin-bottom: 50px;
}

@media screen and (max-width:768px) {
    .footer {
        margin-bottom: 35px;
    }
}

.footer-row {
    display: flex;
    font-size: 15px;
}

.footer-row div {
    min-width: 150px;
}

.corporate-name {
    font-size: 17px;
    font-weight: bold;
}

.footer-link {
    margin-top: 30px;
    font-size: 15px;

    .contact-link {
        margin-top: 10px;
    }
}

.footer-copyright {
    text-align: center;
    font-size: 12px;
    margin-top: 20px;
}
