@charset 'UTF-8';
/* ------------------------------ */
/* サンプル表示用 */
/* ------------------------------ */
.sample {
  padding: 300px 0;
  background: #fcc;
  text-align: center;
}
/* ------------------------------ */
/* 汎用スタイル */
/* ------------------------------ */
.sp-hide {
    display: block;
}

@media screen and (max-width: 767px) {
    .sp-hide {
        display: none;
    }
}

.pc-hide {
    display: none;
}

@media screen and (max-width: 767px) {
    .pc-hide {
        display: block;
    }
}

/* ------------------------------ */
/* パンくず周り調整 */
/* ------------------------------ */
.hirayaWrap__hd {
  padding: 0;
}

.hirayaBc {
    background-color: #F6F6F6;
}

@media screen and (max-width: 767px) {
    .hirayaBc {
        background-color: #fff;
    }
}

/* ------------------------------ */
/* 背景色 */
/* ------------------------------ */
.hirayaWrap__bd {
    background-color: #F6F6F6;
    overflow: hidden;
}

/* ------------------------------ */
/* コラムコンテンツ */
/* ------------------------------ */
.p-column-section {
    max-width: 750px;
    margin-inline: auto;
    padding-top: 45px;
    font-family: YakuHanJPs, 'Zen Kaku Gothic New', sans-serif;
}

@media screen and (max-width: 767px) {
    .p-column-section {
        padding-top: 40px;
    }
}

@media screen and (max-width: 767px) {
    .p-column-section {
        width: calc(100% - 40px);
        padding-inline: 20px;
    }
}

.p-column-section__lead {
    margin-block: 70px 100px;
}

@media screen and (max-width: 767px) {
    .p-column-section__lead {
        margin-block: 24px 60px;
    }
}

.p-column-section .cmnRecomCatalogBnr__bt {
    margin-top: 60px !important;
}

@media screen and (max-width: 767px) {
    .p-column-section .cmnRecomCatalogBnr__bt {
        margin-top: 30px !important;
    }
}

/* ------------------------------ */
/* 画像 */
/* ------------------------------ */
.c-img-01 {
    width: 100%;
}

@media screen and (max-width: 767px) {
    .c-img-01 {
        margin-inline: -20px;
        width: calc(100% + 40px);
    }
}

.c-img-01--mt-28 {
    margin-top: 28px;
}

@media screen and (max-width: 767px) {
    .c-img--mt-28 {
        margin-top: 24px;
    }
}

.c-img-01 img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.c-img-02 {
    margin-inline: -125px;
    width: calc(1000 / 750 * 100%);
}

@media screen and (max-width: 767px) {
    .c-img-02 {
        margin-inline: -20px;
        width: calc(100% + 40px);
    }
}

.c-img-02 img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.c-img-03 {
    margin-inline: auto;
    width: calc(446 / 750 * 100%);
}

.c-img-03 img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.c-img-04 {
    margin-inline: auto;
    width: calc(400 / 750 * 100%);
}

.c-img-04 img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.c-img-05 {
    margin-inline: auto;
    width: calc(517 / 750 * 100%);
}

.c-img-05 img {
    width: 100%;
    height: auto;
    vertical-align: middle;
}

/* ------------------------------ */
/* キャプション */
/* ------------------------------ */
.c-caption-01 {
    font-size: 14px;
    font-weight: normal;
    line-height: calc(24 / 14);
}

/* ------------------------------ */
/* テキスト */
/* ------------------------------ */
.c-txt-01 {
    font-size: 16px;
    font-weight: normal;
    line-height: calc(28 / 16);
    letter-spacing: 0;
}

.c-txt-01--mt-28 {
    margin-top: 28px;
}

@media screen and (max-width: 767px) {
    .c-txt-01--mt-28 {
        margin-top: 24px;
    }
}

.c-txt-01--desc {
    font-size: 14px;
    line-height: calc(24 / 14);
}

.c-txt-01 + .c-txt-01 {
    margin-top: 10px;
}

.c-txt-01 a {
    text-decoration: underline;
    color: #3073bb;
}

@media screen and (min-width: 768px) {
    .c-txt-01 a:hover {
        text-decoration: none;
    }
}

/* ------------------------------ */
/* ラベル */
/* ------------------------------ */
.c-label-01 {
    font-size: 12px;
    font-weight: bold;
    line-height: calc(20 / 12);
    letter-spacing: 0.1em;
    color: #000;
}

@media screen and (max-width: 767px) {
    .c-label-01 {
        line-height: calc(24 / 12);
    }
}

/* ------------------------------ */
/* ページタイトル */
/* ------------------------------ */
.c-ttl-01 {
    margin-block: 22px 52px;
    font-size: 36px;
    font-weight: bold;
    line-height: calc(56 / 36);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-ttl-01 {
        margin-block: 10px 24px;
        font-size: 24px;
        line-height: calc(34 / 24);
    }
}

/* ------------------------------ */
/* 目次 */
/* ------------------------------ */
.c-box-index {
    padding: 35px 40px 40px;
    background-color: #fff !important;
}

@media screen and (max-width: 767px) {
    .c-box-index {
        padding: 23px 20px 20px;
    }
}

.c-box-index__ttl {
    font-size: 18px;
    font-weight: 500;
    line-height: calc(30 / 18);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-box-index__ttl {
        font-size: 16px;
        line-height: calc(30 / 16);
    }
}

.c-list-main {
    margin-top: 35px;
    font-size: 16px;
    font-weight: 500;
    line-height: calc(23 / 16);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-list-main {
        margin-top: 13px;
        font-size: 15px;
        line-height: calc(23 / 15);
    }
}

.c-list-main__item:not(:first-child) {
    margin-top: 32px;
}

@media screen and (max-width: 767px) {
    .c-list-main__item:not(:first-child) {
        margin-top: 18px;
    }
}

.c-list-main__link {
    color: #222;
    transition: opacity 0.3s;
}

@media screen and (min-width: 768px) {
    .c-list-main__link:hover {
        opacity: 0.8;
    }
}

.c-list-secondary {
    margin-top: 10px;
    margin-left: 22px;
}

@media screen and (max-width: 767px) {
    .c-list-secondary {
        margin-left: 20px;
        font-size: 13px;
        line-height: calc(20 / 13);
    }
}

.c-list-secondary__item:not(:first-child) {
    margin-top: 10px;
}

@media screen and (max-width: 767px) {
    .c-list-secondary__item:not(:first-child) {
        margin-top: 5px;
    }
}

.c-list-secondary__link {
    color: #444444;
    transition: opacity 0.3s;
}

@media screen and (min-width: 768px) {
    .c-list-secondary__link:hover {
        opacity: 0.8;
    }
}

.c-list-tertiary {
    margin-top: 10px;
    margin-left: 22px;
}

@media screen and (max-width: 767px) {
    .c-list-tertiary {
        display: none;
    }
}

.c-list-tertiary__item:not(:first-child) {
    margin-top: 10px;
}

.c-list-tertiary__link {
    color: #444444;
    transition: opacity 0.3s;
}

@media screen and (min-width: 768px) {
    .c-list-tertiary__link:hover {
        opacity: 0.8;
    }
}

/* ------------------------------ */
/* 各セクション */
/* ------------------------------ */
/* ------------------------------ */
/* c-cassette-01 */
/* ------------------------------ */
.c-cassette-01 {
    margin-top: 200px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01 {
        margin-top: 60px;
    }
}

.c-cassette-01:first-of-type {
    margin-top: 160px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01:first-of-type {
        margin-top: 60px;
    }
}

.c-cassette-01--last {
    padding-bottom: 160px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01--last {
        padding-bottom: 60px;
    }
}

.c-cassette-01__ttl {
    margin-bottom: 52px;
    text-align: center;
    font-size: 36px;
    font-weight: bold;
    line-height: calc(56 / 36);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-cassette-01__ttl {
        margin-bottom: 20px;
        font-size: 24px;
        line-height: calc(34 / 24);
    }
}

.c-cassette-01__lead-01 {
    margin-block: 60px 80px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01__lead-01 {
        margin-block: 32px 40px;
    }
}

.c-cassette-01__lead-02 {
    margin-bottom: 80px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01__lead-02 {
        margin-bottom: 40px;
    }
}

.c-cassette-01__lead-03 {
    margin-block: 60px 32px;
}

@media screen and (max-width: 767px) {
    .c-cassette-01__lead-03 {
        margin-block: 32px;
    }
}

/* ------------------------------ */
/* c-cassette-02 */
/* ------------------------------ */
.c-cassette-02 + .c-cassette-02 {
    margin-top: 80px;
}

@media screen and (max-width: 767px) {
    .c-cassette-02 + .c-cassette-02 {
        margin-top: 40px;
    }
}

.c-cassette-02__ttl {
    margin-bottom: 28px;
    font-size: 20px;
    font-weight: bold;
    line-height: calc(24 / 20);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-cassette-02__ttl {
        margin-bottom: 24px;
        font-size: 16px;
        line-height: calc(24 / 16);
    }
}

.c-cassette-02__lead {
    margin-top: 28px;
}

@media screen and (max-width: 767px) {
    .c-cassette-02__lead {
        margin-top: 24px;
    }
}

@media screen and (max-width: 767px) {
    .c-cassette-02 .c-img-01 {
        margin-inline: 0;
        width: 100%;
    }
}

/* ------------------------------ */
/* c-box-01 */
/* ------------------------------ */
.c-box-01:not(:first-of-type) {
    margin-top: 80px;
}

@media screen and (max-width: 767px) {
    .c-box-01:not(:first-of-type) {
        margin-top: 40px;
    }
}

.c-box-01__head {
    padding-bottom: 15px;
    border-bottom: 1px solid #5C5C5C;
}

@media screen and (max-width: 767px) {
    .c-box-01__head {
        padding-bottom: 12px;
    }
}

.c-box-01__ttl {
    font-size: 24px;
    font-weight: bold;
    line-height: calc(36 / 24);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-box-01__ttl {
        font-size: 20px;
        line-height: calc(30 / 20);
    }

    .c-box-01__ttl--ls-1 {
        letter-spacing: -1px;
    }
}

.c-box-01__body {
    margin-top: 28px;
}

@media screen and (max-width: 767px) {
    .c-box-01__body {
        margin-top: 24px;
    }
}

.c-box-01__list {
    margin-block: 28px 10px;
}

@media screen and (max-width: 767px) {
    .c-box-01__list {
        margin-block: 24px 10px;
    }
}

.c-box-01__list-item {
    position: relative;
    padding-left: 1.5em;
    font-size: 16px;
    font-weight: normal;
    line-height: calc(28 / 16);
    letter-spacing: 0;
}

.c-box-01__list-item:before {
    position: absolute;
    top: 0;
    left: 0;
    content: '●';
}

.c-box-01 .c-img-01 {
    margin-top: 60px;
}

@media screen and (max-width: 767px) {
    .c-box-01 .c-img-01 {
        margin-top: 30px;
        margin-inline: auto;
        width: 100%;
    }
}

.c-box-01 .c-img-04 {
    margin-block: 60px 28px;
}

@media screen and (max-width: 767px) {
    .c-box-01 .c-img-04 {
        margin-block: 30px 24px;
    }
}

/* ------------------------------ */
/* c-box-02 */
/* ------------------------------ */
.c-box-02 {
    margin-top: 60px;
}

@media screen and (max-width: 767px) {
    .c-box-02 {
        margin-top: 30px;
    }
}

.c-box-02__ttl {
    margin-bottom: 28px;
    font-size: 20px;
    font-weight: bold;
    line-height: calc(24 / 20);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-box-02__ttl {
        margin-bottom: 12px;
        font-size: 16px;
        line-height: calc(24 / 16);
    }
}

.c-box-02 .c-img-01 {
    margin-top: 0;
    margin-bottom: 28px;
}

@media screen and (max-width: 767px) {
    .c-box-02 .c-img-01 {
        margin-top: 24px;
        margin-bottom: 24px;
        margin-inline: auto;
        width: 100%;
    }
}
/* ------------------------------ */
/* c-box-table */
/* ------------------------------ */
.c-box-table {
    margin-block: 40px;
}

@media screen and (max-width: 767px) {
    .c-box-table {
        margin-block: 20px;
    }
}

.c-box-table__ttl {
    font-size: 18px;
    font-weight: 500;
    line-height: calc(30 / 18);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-box-table__ttl {
        font-size: 16px;
        line-height: calc(30 / 16);
    }
}

.c-box-table__desc {
    display: block;
    font-size: 14px;
    font-weight: normal;
    line-height: calc(22 / 14);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-box-table__desc {
        line-height: calc(18 / 14);
    }
}

.c-box-table__desc a {
    text-decoration: underline;
    color: #3073bb;
}

@media screen and (min-width: 768px) {
    .c-box-table__desc a:hover {
        text-decoration: none;
    }
}

/* ------------------------------ */
/* c-box-column */
/* ------------------------------ */
.c-box-column {
    margin-top: 60px;
    padding: 20px;
    border: 1px solid #000;
}

@media screen and (max-width: 767px) {
    .c-box-column {
        margin-top: 30px;
    }
}

.c-box-column .c-img-01 {
    margin-top: 28px;
}

@media screen and (max-width: 767px) {
    .c-box-column .c-img-01 {
        margin-top: 24px;
    }
}

/* ------------------------------ */
/* c-table-01 */
/* ------------------------------ */
.c-table-01,
.c-table-01 th,
.c-table-01 td {
    border: 2px solid #F6F6F6;
	border-collapse: collapse;
}

.c-table-01 th,
.c-table-01 td {
    text-align: center;
    vertical-align: middle;
    padding: 0.5em 1em;
}

.c-table-01 {
    margin-block: 10px;
    width: 100%;
}

.c-table-01--2 td {
    text-align: left;
}

.c-table-01--2 td:first-of-type {
    white-space: nowrap;
    text-align: center;
}

.c-table-01 th {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0;
    background-color: #E3E9EB;
}

.c-table-01 td {
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0;
    background-color: #F2F2F2;
}

.c-table-01 td.text-left {
    text-align: left;
}

.c-table-01 td.nowrap {
    white-space: nowrap;
}

.c-table-01 tr {
    height: 48px;
}

/* ------------------------------ */
/* c-list-link */
/* ------------------------------ */
.c-list-link {
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0;
}

.c-list-link__item:not(:first-of-type) {
    margin-top: 14px;
}

.c-list-link__link {
    position: relative;
    display: inline-block;
    padding-right: 25px;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0;
    transition: opacity 0.3s;
}

.c-list-link__link:after {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    content: '';
    display: block;
    mask: url(../images/column/ico_arrow.svg) 0 0 no-repeat;
    mask-size: 100% 100%;
    background-color: #156082;
    width: 15px;
    height: 14px;
}

@media screen and (min-width: 768px) {
    .c-list-link__link:hover {
        opacity: 0.8;
    }
}

/* ------------------------------ */
/* 関連コラム */
/* ------------------------------ */
/* ------------------------------ */
/* c-cassette-relate */
/* ------------------------------ */
.c-cassette-relate {
    margin-inline: calc(50% - 50vw);
    padding-block: 100px;
    background-color: #F2F2F2;
}

@media screen and (max-width: 1140px) {
    .c-cassette-relate {
        margin-inline: calc(50% - 570px);
    }
}

@media screen and (max-width: 767px) {
    .c-cassette-relate {
        margin-inline: calc(50% - 50vw);
        padding-block: 60px;
    }
}

.c-cassette-relate__inner {
    /* max-width: 1140px; */
    /* margin-inline: auto; */
    padding-inline: 20px;
}

@media screen and (max-width: 767px) {
    .c-cassette-relate__inner {
        padding-inline: 20px;
    }
}

.c-cassette-relate__ttl {
    display: block;
    text-align: center;
    font-size: 36px;
    font-weight: bold;
    line-height: calc(56 / 36);
    letter-spacing: 0;
}

@media screen and (max-width: 767px) {
    .c-cassette-relate__ttl {
        font-size: 28px;
        line-height: calc(56 / 28);
    }
}

@media screen and (max-width: 767px) {
    .c-cassette-relate__btn {
        position: relative;
        margin-top: 40px;
        margin-inline: auto;
        display: grid;
        place-items: center;
        border: 1px solid currentColor;
        font-size: 16px;
        font-weight: normal;
        letter-spacing: 0;
        color: #156082;
        width: 260px;
        height: 60px;
    }

    .c-cassette-relate__btn::before,
    .c-cassette-relate__btn::after {
        position: absolute;
        top: 50%;
        right: 21px;
        transform: translateY(-50%);
        content: '';
        display: block;
        width: 13px;
        height: 1px;
        background-color: currentColor;
    }

    .c-cassette-relate__btn::after {
        transform: translateY(-50%) rotate(90deg);
    }
}

/* ------------------------------ */
/* c-list-relate */
/* ------------------------------ */
.c-list-relate {
    margin-top: 40px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    /* gap: 32px; */
    gap: 20px;
}

@media screen and (max-width: 767px) {
    .c-list-relate {
        flex-wrap: wrap;
        gap: 20px;
    }
}

.c-list-relate__item {
    width: 226px;
    /* flex-shrink: 0; */
}

@media screen and (max-width: 767px) {
    .c-list-relate__item {
        width: calc(50% - 10px);
    }
}

.c-list-relate__link {
    display: block;
    transition: opacity 0.3s;
}

@media screen and (min-width: 768px) {
    .c-list-relate__link:hover {
        opacity: 0.8;
    }
}

.c-list-relate__img {
    width: 100%;
}

.c-list-relate__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    vertical-align: middle;
    aspect-ratio: 226 / 140;
}

.c-list-relate__txt {
    margin-top: 10px;
    font-size: 14px;
    font-weight: 500;
    line-height: calc(22 / 14);
    letter-spacing: 0;
    color: #222222;
}

@media screen and (max-width: 767px) {
    .c-list-relate__txt {
        line-height: calc(18 / 14);
    }
}
