@charset "UTF-8";
/* ==============================================================================================
 Sprite
================================================================================================= */
.mod-listCaution > li::before, .mod-listIdx a::before, .mod-listIdx a::after, .mod-lytIdx2 a .title::before, .mod-lytIdx3 a .title::before, .mod-listIdx4 a::before, .mod-btn::before {
    background-image: url();
}

/* ==============================================================================================
 Stracture
================================================================================================= */
/*
 * .str-main
** ------------------------------------------------------ */
.str-main {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #223;
}
.str-main input, .str-main button {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.str-main :placeholder-shown {
    color: #78787d;
}
.str-main ::-webkit-input-placeholder {
    color: #78787d;
    opacity: 1;
}
.str-main ::-moz-placeholder {
    color: #78787d;
    opacity: 1;
}
.str-main :-ms-input-placeholder {
    color: #78787d;
}
.str-main *, .str-main *::before, .str-main *::after {
    box-sizing: border-box;
}
.str-main p {
    margin-bottom: 24px;
}
.str-main > :last-child {
    border-bottom: 0;
}

/*
 * .str-content
** ------------------------------------------------------ */
.str-content {
    padding: 65px 0 74px;
    border-bottom: 1px solid #dedede;
}
@media only screen and (max-width: 960px) {
    .str-content {
        padding: 65px 16px 74px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content {
        padding: 36px 16px 40px;
    }
}
.str-content.type-bg {
    padding: 32px 0;
    background: #f7f7f2;
    border: 0;
}
@media only screen and (max-width: 960px) {
    .str-content.type-bg {
        padding: 32px 16px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-bg {
        padding: 22px 16px;
    }
}
.str-content.type-bg2 {
    padding: 26px 0;
    background: #edede4;
    border: 0;
}
@media only screen and (max-width: 960px) {
    .str-content.type-bg2 {
        padding: 26px 16px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-bg2 {
        padding: 21px 16px;
    }
}
.str-content.type-bg2 .lead {
    margin-bottom: 16px;
    font-size: .9375rem;
    text-align: center;
    line-height: 1.6;
}
.str-content.type-important {
    padding: 12px 0 11px;
    background: #ffebeb;
    border-color: #d9dadb;
}
@media only screen and (max-width: 960px) {
    .str-content.type-important {
        padding: 12px 16px 11px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-important {
        border-bottom: 0;
    }
}
.str-content.type-kv {
    position: relative;
    z-index: 0;
    overflow: hidden;
    min-height: 192px;
    padding: 31px 0;
    background: linear-gradient(to right, #f9faf6, #f9faf6 50%, #e8e8e2 50%, #e8e8e2);
    border-bottom: 1px solid #d9dadb;
}
@media only screen and (max-width: 960px) {
    .str-content.type-kv {
        padding: 31px 16px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv {
        min-height: inherit;
        padding: 0 0 calc(40vw * 100 / 767);
        background: #f9faf6;
    }
	.str-content.type-kv form {
        margin: 0;
		width: 100%;
    }
}
.str-content.type-kv .breadcrumb {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 0 -8px -28px;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .breadcrumb {
        display: none;
    }
}
.str-content.type-kv .breadcrumb > li {
    position: relative;
    margin: 0 0 8px 28px;
    font-size: .6875rem;
    color: #8e8e96;
    line-height: 1.2;
}
.str-content.type-kv .breadcrumb > li::before, .str-content.type-kv .breadcrumb > li::after {
    position: absolute;
    top: 50%;
    right: -17px;
    display: block;
    width: 5px;
    height: 1px;
    background: #6c6c75;
    content: "";
}
.str-content.type-kv .breadcrumb > li::before {
    margin-top: -3px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.str-content.type-kv .breadcrumb > li::after {
    margin-top: 0;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}
.str-content.type-kv .breadcrumb > li:last-child::before, .str-content.type-kv .breadcrumb > li:last-child::after {
    display: none;
}
.str-content.type-kv .hdg {
    margin-bottom: 3px;
    font-weight: bold;
    font-size: 1.25rem;
    text-align: center;
    line-height: 1.4;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .hdg {
        margin-bottom: 5px;
        font-size: calc(28vw * 100 / 700);
        line-height: 1.3;
    }
}
.str-content.type-kv .hdg br {
    display: none;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .hdg br {
        display: block;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .panel {
        position: relative;
        min-height: calc(186vw * 100 / 700);
        padding: calc(48vw * 100 / 700) 0 0 calc(170vw * 100 / 700);
    }
}
.str-content.type-kv .panel img {
    position: absolute;
    top: 0;
    left: 16px;
    z-index: -1;
    width: auto;
    max-width: inherit;
    height: 100% !important;
}
@media only screen and (min-width: 768px) {
    .str-content.type-kv .panel img {
        display: none;
    }
}
.str-content.type-kv .lead {
    margin-bottom: 14px;
    font-weight: bold;
    font-size: 1.375rem;
    color: #5ca122;
    text-align: center;
    line-height: 1.6;
}
@media only screen and (max-width: 960px) {
    .str-content.type-kv .lead {
        font-size: 1.1875rem;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .lead {
        margin-bottom: 0;
        font-size: calc(30vw * 100 / 767);
    }
}
.str-content.type-kv .question-area {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    overflow: hidden;
    max-width: 540px;
    margin: 0 auto;
    border: 2px solid #5ca122;
    border-radius: 4px;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .question-area {
        max-width: 100%;
        margin: 0 16px;
    }
}
.str-content.type-kv .question-area .input-area {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: 100%;
    background: #fff;
}
.str-content.type-kv .question-area .btn-area {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    white-space: nowrap;
    background: #d9d9d4;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .question-area .btn-area {
        background: #edede4;
    }
}
.str-content.type-kv .question-area input, .str-content.type-kv .question-area button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
.str-content.type-kv .question-area input[type="text"] {
    width: 100%;
    padding: 9px 12px 8px;
    font-size: 1rem;
    line-height: 1.5;
    background: #fff;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .question-area input[type="text"] {
        padding: 3px 12px;
        font-size: .875rem;
        line-height: 1.5;
    }
}
.str-content.type-kv .question-area [type="button"], .str-content.type-kv .question-area [type="submit"] {
    width: 100%;
    margin: 0;
    padding: 9px 29px 8px 31px;
    font-size: 1rem;
    color: #fff;
    line-height: 1.5;
    background: #5ca122;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    cursor: pointer;
    -webkit-animation: none;
    animation: none;
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .question-area [type="button"], .str-content.type-kv .question-area [type="submit"] {
        width: auto;
        padding: 9px 16px 9px;
        font-weight: normal;
        font-size: .875rem;
    }
}
.str-content.type-kv .visual {
    position: absolute;
    top: 0;
    left: 50%;
    z-index: -1;
    width: 100%;
    max-width: 1280px;
    min-height: 192px;
    text-align: center;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media only screen and (max-width: 1280px) {
    .str-content.type-kv .visual {
        max-width: 960px;
    }
}
@media only screen and (max-width: 767px) {
    .str-content.type-kv .visual {
        display: none;
    }
}
.str-content.type-kv .visual img {
    display: block;
    max-width: inherit;
}
.str-content.type-kv .visual img:first-child {
    position: absolute;
    top: 0;
    left: 0;
}
@media only screen and (max-width: 1280px) {
    .str-content.type-kv .visual img:first-child {
        left: -160px;
    }
}
.str-content.type-kv .visual img:first-child + img {
    position: absolute;
    top: 0;
    right: 0;
}
@media only screen and (max-width: 1280px) {
    .str-content.type-kv .visual img:first-child + img {
        right: -160px;
    }
}

/*
 * .str-contentInner
** ------------------------------------------------------ */
.str-contentInner {
    max-width: 960px;
    margin: 0 auto;
}
.str-contentInner > *:last-child {
    margin-bottom: 0;
}

/*
 * .str-infoContent
** ------------------------------------------------------ */
.str-infoContent {
    position: relative;
    margin-bottom: 55px;
}
@media only screen and (max-width: 767px) {
    .str-infoContent {
        margin-bottom: 42px;
    }
}
.str-infoContent > *:last-child {
    margin-bottom: 0 !important;
}

/* ==============================================================================================
 Modules
================================================================================================= */
/*
 * .mod-hdg2
** ------------------------------------------------------ */
.mod-hdg2 {
    position: relative;
    margin-bottom: 32px;
    padding-bottom: 8px;
    font-weight: bold;
    font-size: 2rem;
    text-align: center;
    line-height: 1.3;
}
@media only screen and (max-width: 767px) {
    .mod-hdg2 {
        margin-bottom: 27px;
        font-size: 1.375rem;
    }
}
.mod-hdg2::before {
    position: absolute;
    bottom: 0;
    left: 50%;
    display: block;
    width: 224px;
    height: 2px;
    background: linear-gradient(to right, #5ca122, #fff630);
    content: "";
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
    .mod-hdg2::before {
        width: 171px;
    }
}
.mod-hdg2 + .mod-hdg3 {
    margin-top: 24px;
}

/*
 * .mod-hdg2-2
** ------------------------------------------------------ */
.mod-hdg2-2-wrapper {
    position: relative;
    padding: 20px 0;
    border-top: 1px solid #e3e4e6;
}
@media only screen and (max-width: 767px) {
    .mod-hdg2-2-wrapper {
        padding: 15px 0 14px;
        border-top: 0;
    }
}
.mod-hdg2-2-wrapper::before {
    position: absolute;
    top: -1px;
    left: 0;
    display: block;
    width: 64px;
    height: 1px;
    background: linear-gradient(to right, #5ca122, #fff630);
    content: "";
}
@media only screen and (max-width: 767px) {
    .mod-hdg2-2-wrapper::before {
        left: -16px;
        width: calc(100% + 32px);
    }
}

.mod-hdg2-2 {
    font-weight: bold;
    font-size: 1.375rem;
    line-height: 1.4;
}
@media only screen and (max-width: 767px) {
    .mod-hdg2-2 {
        font-size: 1.125rem;
    }
}

/*
 * .mod-hdg3
** ------------------------------------------------------ */
.mod-hdg3 {
    margin-top: 40px;
    margin-bottom: 25px;
    padding: 9px 12px;
    font-weight: bold;
    font-size: 1.0625rem;
    line-height: 1.4;
    background: #f7f7f2;
    border-left: 4px solid #d9d9d4;
}
@media only screen and (max-width: 767px) {
    .mod-hdg3 {
        margin-top: 24px;
        margin-bottom: 11px;
        padding: 3px 9px;
        font-size: .9375rem;
        background: none;
    }
}

/*
 * .mod-listCaution
** ------------------------------------------------------ */
.mod-listCaution > li {
    position: relative;
    padding-left: 37px;
    font-size: .9375rem;
    color: #e00000;
    line-height: 1.5;
}
.mod-listCaution > li::before {
    display: inline-block;
    width: 24px;
    height: 22px;
    margin: -2px 13px 0 -37px;
    vertical-align: middle;
    background-position: -95px -57.5px;
    background-size: 121px 110px;
    content: "";
}
@media only screen and (max-width: 767px) {
    .mod-listCaution > li::before {
        position: absolute;
        top: 50%;
        left: 0;
        display: block;
        margin: -12px 0 0;
        border-bottom: 0;
    }
}

/*
 * .mod-listIdx
** ------------------------------------------------------ */
.mod-listIdx {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: -16px 0 30px -24px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx {
        margin: -10px 0 16px -12px;
    }
}
.mod-listIdx.type-col2 > li {
    width: 50%;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx.type-col2 > li {
        width: 100%;
    }
}
.mod-listIdx.type-col3 > li {
    width: 33.33333%;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx.type-col3 > li {
        width: 100%;
    }
}
.mod-listIdx.type-col4 > li {
    width: 25%;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx.type-col4 > li {
        width: 100%;
    }
}
.mod-listIdx > li {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 16px 0 0 24px;
    text-align: center;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li {
        padding: 10px 0 0 12px;
        text-align: left;
    }
}

.mod-listIdx > li.icon a::before {
    width: 62px;
    height: 52px;
    background-position: 0 -63px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon a::before {
        width: 43.02568px;
        height: 36.08605px;
        background-position: 0 -43.71964px;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon2 a::before {
    width: 59px;
    height: 58px;
    background-position: 0 0;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon2 a::before {
        width: 40.94379px;
        height: 40.24983px;
        background-position: 0 0;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon3 a::before {
    top: 24px;
    width: 60px;
    height: 48px;
    background-position: 0 -172px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon3 a::before {
        width: 41.63775px;
        height: 33.3102px;
        background-position: 0 -119.36155px;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon4 a::before {
    width: 61px;
    height: 56px;
	top: 18px;
    background-position: -64px 0;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon4 a::before {
        left: 22px;
        width: 42.33171px;
        height: 38.8619px;
        background-position: -44.4136px 0;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon5 a::before {
    top: 26px;
    width: 64px;
    height: 47px;
    background-position: 0 -120px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon5 a::before {
        left: 18px;
        width: 44.4136px;
        height: 32.61624px;
        background-position: 0 -83.2755px;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon6 a::before {
        top: 25px;
        width: 78px;
        height: 44px;
        background-position: -60px -172px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon6 a::before {
        left: 17px;
        width: 49.92228px;
        height: 33.3102px;
        background-position: -43.85288px -117.02568px;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon7 a::before {
        top: 16px;
        width: 58px;
        height: 58px;
        background-position: -64px -57px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon7 a::before {
        left: 23px;
        width: 41.16794px;
        height: 47.24983px;
        background-position: -43.21513px -39px;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx > li.icon8 a::before {
    width: 52px;
    height: 57px;
    background-position: -190px 0;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx > li.icon8 a::before {
        left: 25px;
        width: 36.08605px;
        height: 39.55586px;
        background-position: -131.85288px 0;
        background-size: 167.93893px 152.67176px;
    }
}
.mod-listIdx a {
    position: relative;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: 100%;
    min-height: 140px;
    padding: 85px 34px 15px;
    background: #fff;
    border: 1px solid #d9dadb;
    border-radius: 4px;
    box-shadow: 0 2px 0 #eeefeb;
}
@media only screen and (max-width: 960px) {
    .mod-listIdx a {
        padding: 96px 24px 20px;
    }
}
@media only screen and (max-width: 767px) {
    .mod-listIdx a {
        -ms-flex-pack: start;
        -webkit-justify-content: flex-start;
        justify-content: flex-start;
        min-height: 78px;
        padding: 20px 36px 20px 80px;
    }
}
.mod-listIdx a::before {
    position: absolute;
    top: 20px;
    left: 50%;
    display: block;
    content: "";
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
    .mod-listIdx a::before {
        top: 50% !important;
        left: 17px;
        -webkit-transform: translateX(0%);
        -webkit-transform: translateY(-50%);
        transform: translateX(0%);
        transform: translateY(-50%);
    }
}
.mod-listIdx a::after {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 9px;
    height: 18px;
    background-position: -166px -63px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
    .mod-listIdx a::after {
        right: 16px;
        width: 7px;
        height: 12px;
        background-position: -65px -31.5px;
        background-size: 121px 110px;
    }
}
@media only screen and (max-width: 960px) {
    .mod-listIdx a br {
        display: none;
    }
}
.mod-listIdx a[target="_blank"] img {
    display: none;
    width: 13px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx a[target="_blank"] img {
        position: absolute;
        top: 50%;
        right: 16px;
        display: block;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}
.mod-listIdx a[target="_blank"]::after {
    display: none;
}
.mod-listIdx .title {
    font-size: .9375rem;
    line-height: 1.4;
}

/*
 * .mod-listIdx2
** ------------------------------------------------------ */
.mod-lytIdx2 .idx-inner {
    min-height: 142px;
    padding: 16px;
    border: 1px solid #d9dadb;
    border-radius: 4px;
    box-shadow: 0 2px 0 #edeff0;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx2 .idx-inner {
        min-height: inherit;
        text-align: center;
    }
}
.mod-lytIdx2 a {
    position: relative;
    display: block;
    padding-left: 298px;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx2 a {
        padding-left: 0;
    }
}
.mod-lytIdx2 a .title {
    position: relative;
}
.mod-lytIdx2 a .title::before {
    position: absolute;
    top: 50%;
    right: 0;
    display: block;
    width: 6.5px;
    height: 12px;
    background-position: -65px -31.5px;
    background-size: 121px 110px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.mod-lytIdx2 .visual {
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid #e8e9eb;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx2 .visual {
        position: static;
    }
}
.mod-lytIdx2 .item {
    margin-left: 298px;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx2 .item {
        margin-left: 0;
    }
}
.mod-lytIdx2 .desc {
    padding-right: 16px;
    font-weight: bold;
    font-size: .8125rem;
    text-align: left;
    line-height: 1.5;
}
.mod-lytIdx2 .title {
    margin-bottom: 12px;
    padding-right: 16px;
    font-weight: bold;
    font-size: .9375rem;
    text-align: left;
    line-height: 1.4;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx2 .title {
        margin-top: 12px;
        margin-bottom: 16px;
    }
}

/*
 * .mod-listIdx3
** ------------------------------------------------------ */
.mod-lytIdx3 {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: -16px 0 20px -24px;
}
.mod-lytIdx3.type-col2 > .idx {
    width: 50%;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3.type-col2 > .idx {
        width: 100%;
    }
}
.mod-lytIdx3.type-col3 > .idx {
    width: 33.33333%;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3.type-col3 > .idx {
        width: 100%;
    }
}
.mod-lytIdx3.type-col4 > .idx {
    width: 25%;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3.type-col4 > .idx {
        width: 100%;
    }
}
.mod-lytIdx3 > .idx {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 16px 0 0 24px;
}
.mod-lytIdx3 .idx-inner {
    width: 100%;
    padding: 15px 16px;
    text-align: center;
    border: 1px solid #d9dadb;
    border-radius: 4px;
    box-shadow: 0 2px 0 #edeff0;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3 .idx-inner {
        padding: 12px 16px;
        text-align: center;
    }
}
.mod-lytIdx3 .hdg {
    margin-bottom: 14px;
    font-weight: bold;
    font-size: .9375rem;
    line-height: 1.4;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3 .hdg {
        margin: 0 -16px 14px;
        padding-bottom: 12px;
        border-bottom: 1px solid #e8e9eb;
    }
}
.mod-lytIdx3 a {
    position: relative;
    display: block;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3 a {
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
        height: 51px;
        margin-bottom: 16px;
        padding-left: 145px;
    }
}
.mod-lytIdx3 a .title {
    position: relative;
}
.mod-lytIdx3 a .title::before {
    position: absolute;
    top: 50%;
    right: 0;
    display: block;
    width: 6.5px;
    height: 12px;
    background-position: -65px -31.5px;
    background-size: 121px 110px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.mod-lytIdx3 .visual {
    vertical-align: bottom;
    border: 1px solid #e8e9eb;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3 .visual {
        position: absolute;
        top: 0;
        left: 0;
        width: 126px;
    }
}
.mod-lytIdx3 .desc {
    font-size: .8125rem;
    text-align: left;
    line-height: 1.5;
}
.mod-lytIdx3 .title {
    margin-top: 16px;
    margin-bottom: 12px;
    padding-right: 16px;
    font-size: .9375rem;
    text-align: left;
    line-height: 1.4;
}
@media only screen and (max-width: 767px) {
    .mod-lytIdx3 .title {
        width: 100%;
        margin-top: 0;
        margin-bottom: 0;
    }
}

/*
 * .mod-listIdx4
** ------------------------------------------------------ */
.mod-listIdx4 {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: -16px 0 30px -24px;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4 {
        margin: -8px 0 16px -8px;
    }
}
.mod-listIdx4.type-col2 > li {
    width: 50%;
}
.mod-listIdx4.type-col3 > li {
    width: 33.33333%;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4.type-col3 > li {
        width: 50%;
    }
}
.mod-listIdx4.type-col4 > li {
    width: 25%;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4.type-col4 > li {
        width: 50%;
    }
}
.mod-listIdx4 > li {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 16px 0 0 24px;
    text-align: center;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4 > li {
        padding: 8px 0 0 8px;
        text-align: left;
    }
}
.mod-listIdx4 a {
    position: relative;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: 100%;
    min-height: 125px;
    padding: 20px 34px;
    background: #fff;
    border: 1px solid #d9dadb;
    border-radius: 4px;
    box-shadow: 0 2px 0 #eeefeb;
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4 a {
        min-height: 90px;
    }
}
.mod-listIdx4 a::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 6.5px;
    height: 12px;
    background-position: -65px -31.5px;
    background-size: 121px 110px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
    .mod-listIdx4 a::before {
        right: 16px;
    }
}
.mod-listIdx4 a img {
    min-width: calc(0%);
}

/*
 * .mod-btn
** ------------------------------------------------------ */
.mod-btn {
    position: relative;
    display: block;
    padding: 16px 24px 16px 16px;
    font-size: .9375rem;
    text-align: left;
    line-height: 1.4;
    letter-spacing: -.05em;
    background: #fff;
    border: 1px solid #d9dadb;
    border-radius: 4px;
    box-shadow: 0 2px 0 #edeff0;
}
.mod-btn::before {
    position: absolute;
    top: 50%;
    right: 13px;
    display: block;
    width: 6.5px;
    height: 12px;
    background-position: -65px -31.5px;
    background-size: 121px 110px;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.mod-btn.type-2 {
    color: #223;
    background: #fcdb00;
    border-color: #fcdb00;
    box-shadow: 0 2px 0 #e1e2db;
}
.mod-btn.type-2::before {
    width: 6.5px;
    height: 12px;
    background-position: -74px -31.5px;
    background-size: 121px 110px;
}

/*
 * .mod-btnMore
** ------------------------------------------------------ */
.mod-btnMore {
    display: inline-block;
    padding: 10px 48px;
    font-size: .9375rem;
    text-align: center;
    line-height: 1.4;
    background: #fff;
    border: 1px solid #d9dadb;
    border-radius: 4px;
}
@media only screen and (max-width: 767px) {
    .mod-btnMore {
        display: block;
        padding: 14px 24px;
    }
}

/*
 * .mod-lytBtn
** ------------------------------------------------------ */
.mod-lytBtn {
    margin: 0 auto 20px;
    text-align: center;
}
.mod-lytBtn.type-2 {
    max-width: 320px;
}
@media only screen and (max-width: 767px) {
    .mod-lytBtn.type-2 {
        max-width: 280px;
    }
}
.mod-lytBtn .mod-btn {
    padding: 13px 24px 13px 24px;
    text-align: center;
}
@media only screen and (max-width: 767px) {
    .mod-lytBtn .mod-btn {
        padding: 16px 24px 16px 24px;
    }
}

/*
 * .mod-listBtn
** ------------------------------------------------------ */
.mod-listBtn {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: -16px 0 24px -24px;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn {
        overflow: hidden;
        margin: 0 0 18px 0;
        border: 1px solid #d9dadb;
        border-radius: 4px;
        box-shadow: 0 2px 0 #edeff0;
    }
}
.mod-listBtn.type-col2 > li {
    width: 50%;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn.type-col2 > li {
        width: 100%;
    }
}
.mod-listBtn.type-col3 > li {
    width: 33.33333%;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn.type-col3 > li {
        width: 100%;
    }
}
.mod-listBtn.type-col4 > li {
    width: 25%;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn.type-col4 > li {
        width: 100%;
    }
}
.mod-listBtn > li {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 16px 0 0 24px;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn > li {
        padding: 0;
    }
    .mod-listBtn > li + li {
        margin-top: -1px;
    }
    .mod-listBtn > li:first-child [class*="mod-btn"] {
        border-top: 0;
    }
    .mod-listBtn > li:last-child [class*="mod-btn"] {
        border-bottom: 0;
    }
}
.mod-listBtn [class*="mod-btn"] {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    width: 100%;
}
@media only screen and (max-width: 767px) {
    .mod-listBtn [class*="mod-btn"] {
        border-right: 0;
        border-left: 0;
        border-radius: 0;
        box-shadow: none;
    }
}

/*
 * .mod-listLink
** ------------------------------------------------------ */
.mod-listLink.type-inline {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: -6px 0 20px -44px;
}
@media only screen and (max-width: 767px) {
    .mod-listLink.type-inline {
        margin: 0 0 20px 0;
    }
}
.mod-listLink.type-inline > li {
    margin: 6px 0 0 44px;
}
@media only screen and (max-width: 767px) {
    .mod-listLink.type-inline > li {
        width: 100%;
        margin: 0 0 6px 0;
    }
    .mod-listLink.type-inline > li:last-child {
        margin-bottom: 0;
    }
}
.str-infoContent .mod-listLink {
    position: absolute;
    top: 24px;
    right: 0;
}
@media only screen and (max-width: 960px) {
    .str-infoContent .mod-listLink {
        position: static;
        display: block;
        margin: 0 0 20px 0;
    }
}
@media only screen and (max-width: 960px) {
    .str-infoContent .mod-listLink > li {
        margin: 0 0 13px 0;
    }
    .str-infoContent .mod-listLink > li:last-child {
        margin-bottom: 0;
    }
}
@media only screen and (max-width: 960px) {
    .str-infoContent .mod-listLink a {
        display: block;
        padding: 14px 24px;
        text-align: center;
        background: #fff;
        border: 1px solid #d9dadb;
        border-radius: 4px;
    }
    .str-infoContent .mod-listLink a::before {
        display: none;
    }
}
.mod-listLink > li {
    font-size: .9375rem;
    line-height: 1.5;
}
.mod-listLink a {
    display: inline-block;
    padding-left: 15px;
}
.mod-listLink a::before {
    display: inline-block;
    width: 12px;
    height: 6px;
    margin: -3px 3px 0 -15px;
    vertical-align: middle;
    border-width: 3px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #223;
    content: "";
}

/*
 * .mod-listNews
** ------------------------------------------------------ */
.mod-listNews {
    margin-bottom: 26px;
}
.mod-listNews > li {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 13px 6px 12px;
    font-size: .9375rem;
    line-height: 1.6;
    border-bottom: 1px dashed #c0c1c2;
}
@media only screen and (max-width: 767px) {
    .mod-listNews > li {
        display: block;
        padding: 13px 0;
    }
}
.mod-listNews > li:first-child {
    border-top: 1px dashed #c0c1c2;
}
.mod-listNews > li .date {
    width: 8em;
    margin-right: 20px;
    white-space: nowrap;

    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}
.mod-listNews > li .news {
    width: 100%;
}
.mod-listNews > li .news li {
    line-height: 1.6;
    max-height: calc(0%);
}
.mod-listNews a {
    display: block;
}
.mod-listNews a img {
    width: 13px;
    margin-top: -1px;
    margin-left: 4px;
    vertical-align: middle;
}

/*
 * オサ追記分
** ------------------------------------------------------ */
/* mod-colbox（type-col2を付けることで2カラムにする。SP時は1カラム） */
.mod-colbox {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 30px;
}
.mod-colbox::after {
  clear: both;
  content: "";
  display: block;
}
.mod-colbox.type-col2 .mod-colitem {
  width: calc(50% - 5px);
  padding: 15px;
  margin-right: 10px;
  margin-bottom: 10px;

}
.mod-colbox.type-col2 .mod-colitem:nth-child(even) {
  margin-right: 0;
}
.mod-colbox.type-col2 .mod-colitem .mod-hdg3 {
  margin-top: 0;
}
@media only screen and (max-width: 767px) {
.mod-colbox.type-col2 .mod-colitem {
  width: 100%;
  border: 1px solid #ccc;
  border-radius: 4px;
  margin-right: 0;
}
}
/* リスト使用時のマージンをガイドラインに準じ14px取る（ひとまずmod-listLink配下に限定） */
.mod-listLink > li + li {
  margin-top: 14px;
}

/* ----------------------------------------------------------------------------
 * .mod-list-alert
 * ------------------------------------------------------------------------- */
.mod-list-alert {
  color: #d9dadb;
  margin: 0;
  padding: 0 12px;
  border: solid;
  border-width: 1px 0;
}

.mod-list-alert strong {
  font-weight: normal;
  color: #223;
}

.mod-list-alert .list {
  max-width: 950px;
  margin: 0 auto;
  padding: 12px 0 8px;
}

.mod-list-alert li {
  position: relative;
}

.mod-list-alert li strong {
  display: block;
}

.mod-list-alert li a {
  text-decoration: underline;
  color: inherit;
}

.mod-list-alert li:not(:last-child) {
  margin: 0 0 4px;
}

.mod-list-alert[data-level="1"] {
  background: #fff8eb;
}

/* ----------------------------------------------------------------------------
 * .emergency-box
 * ------------------------------------------------------------------------- */

.emergency-box {
    display: table;
    max-width: 956px;
    width: 99%;
    margin: 20px auto;
    border: solid 2px #e00000;
}
.emergency-box > * {
	display: table-cell;
}
.emergency-box > .title {
	width: 195px;
	background: #ffebeb;
	text-align: center;
	vertical-align: middle;
	color: #e00000;
	font-size: 1rem;
	font-weight: bold;
}
.emergency-box > .inner {
	vertical-align: middle;
	color: #e00000;
	padding: 10px 30px;
}
.emergency-box > .inner > p {
	margin-bottom: 5px;
}
.emergency-box > .inner > p:last-child {
	margin-bottom: 0;
}
@media only screen and (max-width: 767px) {
.emergency-box {
	display: block;
	width: 96%;
}
.emergency-box > * {
	display: block;
}
.emergency-box > .title {
	width: 100%;
	padding: 10px;
}
.emergency-box > .inner {
	vertical-align: middle;
	color: #e00000;
	padding: 10px 15px;
}
}
.sp-only {
	display: none;
}
@media only screen and (max-width: 767px) {
.pc-only {
	display: none;
}
.sp-only {
	display: block;
}
}
@media only screen and (max-width: 767px) {
#d-page-top {
	bottom: 100px;
}
}
