@charset "utf-8";
/* GoogleFonts読み込み 下記のライセンス記述は削除禁止 */
/*
* "Noto Sans JP" licensed under the SIL Open Font License 1.1
* by https://fonts.google.com/specimen/Noto+Sans+JP
*/
@font-face {
    font-family: "Noto Sans JP";
    font-style: normal;
    font-weight: 500;
    src: url("fonts/NS-500.woff2") format("woff2"), url("fonts/NS-500.woff") format("woff");
    font-display: swap;
}
@font-face {
    font-family: "Noto Sans JP";
    font-style: normal;
    font-weight: 700;
    src: url("fonts/NS-700.woff2") format("woff2"), url("fonts/NS-700.woff") format("woff");
    font-display: swap;
}
@font-face {
  font-family: "Noto Serif JP";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/NSerif-700.woff2") format("woff2"), url("fonts/NSerif-700.woff") format("woff");
  font-display: swap;
}

/* CSS Document */


/*--------------------------------------------------------------------------
 reset
---------------------------------------------------------------------------*/

h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
small,
dl,
dt,
dd,
ol,
ul,
li {
    margin: 0;
    /* font-size: 100%; */
}

ul {
    margin: 0;
    padding: 0;
    vertical-align: baseline;
}

img {
    vertical-align: top;
}

li {
    list-style-type: none;
    vertical-align: baseline;
}

input,
button,
textarea,
select {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

html {
    font-size: 62.5%;
}

h1,
h2,
h3,
h4,
h5,
h6,
.catch,
h1:not([class]) a,
h2 a,
h3:not([class]) a,
h4:not([class]) a,
h5:not([class]) a,
h6:not([class]) a,
.catch a {
    font-weight: bold;
    font-family: "Noto Serif JP", serif;
}


/*--------------------------------------
 Base
---------------------------------------*/

body {
    color: #3d424b;
    font-family: "Noto Sans JP", "Noto Serif JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.8em;
    min-width: 1000px;
}

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

a {
    color: #3d424b;
    text-decoration: none;
}

.fl {
    float: left;
}

.fr {
    float: right;
}

.strong {
    font-weight: bold;
}

.wi1000 {
    width: 1000px;
    margin: 0 auto;
}

.sp {
    display: none;
}

.sp_br {
    display: none;
}
.btn-tel{
    display: none;
}

a:hover {
    opacity: 0.6;
}

.bgTxt {
    font-size: 9.1rem;
    margin: 0 0 0 -6rem;
    /* line-height: 1em; */
}

.addCont01 .four-selection img{
    margin-top: -7.5rem;
    opacity: 0.8;
}

.addCont02 .bgTxt,
.addCont03 .bgTxt {
    position: relative;
    margin: 0 0 2rem -5rem;
}


/* ================== */

/*header　*/

/* ================== */

header {
    position: relative;
}

header .rightTxt {
    background: #3d424b;
    padding: .2rem 1rem;
    color: #fff;
    font-size: 1.2rem;
    text-align: right;
    font-family: 'Noto Sans JP', 'M PLUS 1p', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'メイリオ', 'Meiryo', 'sans-serif';
}
header .rightTxt a{
    color:#fff;
}
header .rightTxt:before {
    content: "PR";
    display: inline-block;
    background: #fff;
    color: #3d424b;
    text-align: center;
    line-height: 1.6;
    width: 2.3rem;
    margin-right: 1rem;
    font-size: 1rem;
}

#headNoteArea {
    width: 100%;
    padding: 1.5rem 0 1rem;
    font-size: 1.2rem;
    margin-bottom: 10px;
}

#headNoteArea .areaInner {
    width: 1000px;
    padding: 0;
    margin: 0 auto;
}

#headNoteArea .sitename,
#headNoteArea .sitename a {
    font-size: 1.8rem;
    text-align: center;
    display: table;
    margin: auto;
    line-height: 1.4;
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
}

#headNoteArea .sitename a {
    background: none;
    padding: 0;
}
#headNoteArea .sitelogo{
    width: 240px;
    max-width: 100%;
    margin: 0 auto .5rem;
}


/* ================== */

/*g-nav　*/

/* ================== */

#g-nav {
    width: 100%;
    position: relative;
    margin: 0;
    /* border-bottom: 1px solid #ddd; */
    z-index: 10;
}

#g-nav ul:not([class]) {
    width: 1000px;
    margin: 0 auto;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    align-items: center;
}

#g-nav ul:not([class]) li {
    -webkit-flex-grow: 1;
    flex-grow: 1;
    width: 20%;
    position: relative;
    background-size: 104px, auto;
}

#g-nav ul:not([class]) li::after {
    content: "";
    width: 1px;
    height: 20px;
    display: inline-block;
    border-left: 1px solid #3d424b;
    position: absolute;
    top: calc(50% - 10px);
    left: 0;
}

#g-nav ul:not([class]) li:last-child::before {
    content: "";
    width: 1px;
    height: 20px;
    display: inline-block;
    border-right: 1px solid #3d424b;
    position: absolute;
    top: calc(50% - 10px);
    right: 0;
}

#g-nav li a {
    display: block;
    text-align: center;
    font-size: 1.4rem;
    padding: 16px 20px;
    box-sizing: border-box;
    line-height: 1.8rem;
}

#g-nav li a:hover {
    color: #e50012;
    position: relative;
    opacity: 100;
}

#g-nav li a:hover::after {
    content: "";
    width: 95px;
    height: 4px;
    background: #e50012;
    display: inline-block;
    position: absolute;
    bottom: 0;
    left: 0;
    margin: auto;
    right: 0;
}


/*--------------------------------------
 Pankuzu
---------------------------------------*/

#pankuzu {
    font-size: 12px;
    font-size: 1.2rem;
    margin: 0 auto;
    padding: 14px 0 40px;
    width: 1000px;
    overflow: hidden;
    white-space: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    word-wrap: break-word;
}

#pankuzu a:hover {
    text-decoration: underline;
}


/*--------------------------------------
 Main Contents
---------------------------------------*/

.contents {
    margin: 0 auto;
    padding: 0;
}

.index,
.category,
.page {
    margin: 0;
    padding: 0;
}

.category,
.page {
    width: 1000px;
    margin: 0 auto;
}

.category .baseBox,
.page .baseBox {
    width: 760px;
    float: left;
}


/*--------------------------------------
 PageTop
---------------------------------------*/

#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 2;
    width: 60px;
}

#page-top:hover {
    opacity: 0.6;
}


/*--------------------------------------
 Side
---------------------------------------*/

#side {
    box-sizing: border-box;
    width: 20rem;
    float: right;
    margin: 10px 0 60px;
}

#side .sideBox {
    box-sizing: border-box;
    margin: 0 0 30px;
    overflow: hidden;
    box-shadow: 9px 9px #e8e9ee;
}

#side .sideBox a {
    line-height: 1.6;
}

#side .sideBox .sttl {
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

#side .sideBox .sttl a {
    background: #3d424b;
    display: block;
    height: 100%;
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.4;
    text-decoration: none;
    padding: 20px 10px 18px;
    position: relative;
    z-index: 2;
}

#side .sideBox .sttl a:hover {
    opacity: 0.6;
}

#side .sideBox ul:not([class]) {
    padding: 0 !important;
    margin: 0;
    background: #fff;
}

#side .sideBox li {
    border-top: dashed 1px #3d424b;
    background: none;
    padding: 0;
}

#side .sideBox li::before {
    content: none;
}

#side .sideBox li:first-child {
    border-top: none;
}

#side .sideBox li ul.subList li {
    border-top: dashed 1px #d4d4d4;
}

#side .sideBox li a {
    display: block;
    padding: 20px 25px 18px 10px;
    text-decoration: none;
    font-size: 1.3rem;
    background: url(img/arrow_bk_other.png) right 10px center no-repeat;
    background-size: 15px auto;
}

#side .sideBox .subList {
    margin: 0;
}

#side .sideBox .subList li {
    background: none;
    margin: 0;
}

#side .sideBox .subList li:last-child {
    background: none;
}

#side .sideBox .subList li a {
    background: url(img/arrow_side_sub.png) no-repeat left 15px top 10px, url(img/arrow_bk_other.png) right 10px center no-repeat;
    background-size: auto, 15px auto;
    display: block;
    padding: 13px 25px 13px 32px;
}

#side .sideBox ul:not([class]) li span:hover {
    opacity: 1;
    border-bottom: solid 2px #f6e847;
}

#side .sideBox ul:not([class]) li a:hover {
    opacity: 0.6;
}


/*--------------------------------------
Footer
---------------------------------------*/

footer {
    margin: 0;
    padding: 0;
    background: #3d424b;
}

footer .areaInner {
    width: 1000px;
    margin: 0 auto;
    padding: 40px 0 0 0;
}

footer a {
    color: #3d424b;
    text-decoration: none;
}

footer a:hover {
    text-decoration: underline;
}

footer .areaInner .footBox {
    margin: 0 0 30px 0;
}

footer .areaInner .footBox .sttl {
    border-bottom: 1px solid #fff;
    padding: 0 0 6px 0;
    margin: 0 0 14px 0;
}

footer .areaInner .footBox .sttl a {
    background: url("img/arrow_white.png") 0px 50% no-repeat;
    background-size: 27px auto;
    display: inline-block;
    font-size: 1.6rem;
    font-weight: 500;
    color: #fff;
    padding: 3px 0 3px 34px;
    font-family: 'Noto Sans JP', sans-serif;
}

footer .footBox ul:not([class]) {
    padding: 0 20px;
}

footer .areaInner .footBox .accChild {
    padding: 0 0 0 12px;
    box-sizing: border-box;
}

footer .areaInner .footBox .accChild li {
    background: none;
}

footer .areaInner .footBox .accChild li.subCat {
    margin: 0 30px 0 0;
    padding: 0;
}

footer .areaInner .footBox .accChild .sp+li::before {
    letter-spacing: 0;
    color: #a3b9b7;
}

footer .areaInner .footBox .accChild .sp+li::before {
    letter-spacing: 0;
    color: #a3b9b7;
}

footer .areaInner .footBox .accChild .sp+li.subCat::before {
    content: "";
}

footer .areaInner .footBox .accChild .subList li::after {
    content: "　/　";
    letter-spacing: 0;
    color: #444;
}

footer .areaInner .footBox .accChild .subList li:last-child::after {
    content: none;
}

footer .areaInner .footBox .accChild li {
    display: inline-block;
    margin: 0 20px 0 0;
}

footer .areaInner .footBox .accChild li a {
    background: url("img/arrow_wt_small.png") 0 37% no-repeat;
    background-size: auto 7px;
    font-size: 1.3rem;
    font-weight: normal;
    color: #fff;
    padding: 0 0 0 29px;
}

footer .areaInner .footBox .accChild .subList li:first-child::before {
    content: "　/　";
    letter-spacing: 0;
    color: #444;
}

footer .areaInner .footBox .accChild .subList {
    display: inline-block;
    padding: 0;
    margin: 0 0 0 20px;
}

footer .areaInner .footBox .accChild .subList li {
    padding: 0;
    display: inline-block;
    margin: 0;
}

footer .areaInner .footBox .accChild .subList li a {
    padding: 0 8px;
    font-size: 13px;
    font-size: 1.3rem;
    background: none;
}

footer .areaInner .noticeArea {
    box-sizing: border-box;
    width: 71%;
    color: #444;
    margin: 60px auto 35px;
}

footer .areaInner .noticeArea p {
    padding: 20px 30px;
    font-size: 1.2rem;
    margin: 0;
    color: #fff;
    border: 1px solid #fff;
}

footer .areaInner .noticeArea .botPrg {
    font-size: 1.2rem;
    text-align: center;
    padding: 10px 0 0;
    border: none;
}

footer .botArea {
    background: #fff;
    padding: 13px 0;
}

footer .botArea .botInner {
    width: 1000px;
    margin: 0 auto;
    position: relative;
}

footer .botArea .botInner .smap {
    float: right;
}

footer .botArea .botInner .smap a {
    font-size: 1.2rem;
}

footer .botArea .botInner .smap a:hover {
    text-decoration: underline;
}

footer p.copy {
    font-size: 1.2rem;
    float: left;
    margin: 0;
}

footer .areaInner .footBox .accChild .sp {
    display: none;
}


/* ================== */

/*メインコンテンツ　*/

/* ================== */

.category .titLArea,
.page .titLArea {
    text-align: center;
    margin: 0 auto 50px;
    position: relative;
}

.category .titLArea,
.page .titLArea {
    background: url(img/low_h1.png) no-repeat center;
    background-size: 70%;
}

.category h1:not([class]),
.page h1:not([class]) {
    text-align: center;
    position: relative;
    box-sizing: border-box;
    font-size: 3rem;
    line-height: 4.4rem;
    padding: 3rem;
}

.category h1::before,
.page h1::before {
    content: "";
    width: 64px;
    height: 5px;
    background: #e50012;
    display: inline-block;
    position: absolute;
    bottom: 0;
    left: 0;
    margin: auto;
    right: 0;
}

.category h2:not([class]),
.page h2 {
    position: relative;
    margin: 35px 0 20px;
    padding: 23px 20px 23px;
    font-size: 2.6rem;
    line-height: 4rem;
    background: #ccd1ed;
}

.category h2:not([class]) a,
.page h2 a,
.category h3:not([class]) a,
.page h3 a,
.category h4:not([class]) a,
.page h4 a,
.contents .noCount .check a{
    background: url("img/arrow_link.png") right top 50% no-repeat;
    background-size: 22px auto;
    padding-right: 30px;
    display: block;
}


.sitemap h2 a {
    color: #444;
}

.category h2 a:hover,
.page h2 a:hover {
    opacity: 0.6;
}

.category h3:not([class]),
.page h3:not([class]) {
    position: relative;
    border-bottom: solid 1px #ddd;
    margin: 35px 0 20px;
    padding: 18px 20px 17px 50px;
    font-size: 2.2rem;
    line-height: 3.5rem;
    background: url(img/low_h4.png) left 5px center no-repeat;
}

.category h3:not([class]) a:hover,
.page h3:not([class]) a:hover {
    opacity: 0.6;
}

.category h6,
.category h4:not([class]),
.category h5:not([class]),
.category h6:not([class]),
.page h4:not([class]),
.page h5:not([class]),
.page h6:not([class]) {
    margin: 35px 0 20px;
    padding: 3px 15px;
    font-size: 2rem;
    border-left: 4px solid #e50012;
}

.category h6::before,
.category h4::before,
.category h5::before,
.category h6::before,
.category h6:not([class]) a:hover,
.category h4:not([class]) a:hover,
.category h5:not([class]) a:hover,
.category h6:not([class]) a:hover,
.page h4:not([class]) a:hover,
.page h5:not([class]) a:hover,
.page h6:not([class]) a:hover {
    opacity: 0.6;
}

.contents ul:not([class]) {
    margin: 20px 0 20px;
    padding: 10px 10px 0;
}

.contents ul:not([class]) li {
    padding: 0 0 6px 22px;
    position: relative;
}

.contents ul:not([class]) li::before {
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #e50012;
    left: 2px;
    top: 6px;
}
.four-selection__lists li span,
p:not([class]) span:not([class]) {
    font-weight: 700;
    color: #a91f29;
}
.addCont01 .addTxt span {
    font-weight: 700;
    color: #5cf5fb;
}
.contents table:not([class]) td span {
    font-weight: 700;
    color: #a91f29;
}
.contents .noCount .check,
.contents .noCount .point,
.contents .rank_wrap3 .check,
.contents .rank_wrap4 .point,
.addCont03 .point {
    display: block;
    position: relative;
    margin: 3.5rem 0 2.5rem 1%;
    padding: 15px 15px 15px 55px;
    font-size: 2.5rem;
    font-weight: bold;
    font-family: "Noto Serif JP", serif;
    line-height: 1.4;
    background: #f5f5f5;
    box-shadow: 7px 7px #e8e9ee;
}

.contents .rank::before {
    counter-increment: number;
    content: counter(number, decimal-leading-zero);
    border: 1px solid #444;
    padding: 9px 0 0 12px;
    line-height: 1.1;
    font-size: 3rem;
    color: #000000;
    border-radius: 50%;
    margin: auto 0;
    height: 55px;
    bottom: 0;
    top: 0;
    left: -21px;
    position: absolute;
    background: #fff;
    width: 55px;
    box-sizing: border-box;
    display: block;
}

.contents .noCount .check::before,
.contents .noCount .point::before,
.contents .rank_wrap3 .check::before,
.contents .rank_wrap4 .point::before,
.addCont03 .point::before {
    margin: auto 0;
    content: "";
    width: 56px;
    height: 56px;
    left: -15px;
    top: 0;
    bottom: 0;
    display: block;
    position: absolute;
}

.contents .noCount .check::before {
    background: url(img/check_ico.png) no-repeat left center;
    background-size: 56px;
}

.contents .noCount .point::before,
.addCont03 .point::before {
    background: url(img/point_ico.png) no-repeat left center;
    background-size: 56px;
}


/*--------------------------------------
 table
---------------------------------------*/

.contents table:not([class]) {
    width: 100%;
    table-layout: fixed;
    margin: 30px auto 30px;
    font-size: 1.4rem;
}

.contents table:not([class]) th {
    width: 20%;
    padding: 14px 16px;
    background: #3d424b;
    border-bottom: 1px solid #fff;
    border-top: 1px solid #3d424b;
    border-right: none;
    line-height: 2.2rem;
    text-align: center;
    color: #FFF;
    word-break: break-all;
}
.contents table tr:last-child:not([class]) th{
    border: 1px solid #3d424b;
}

.contents table:not([class]) td {
    line-height: 2.2rem;
    padding: 14px 20px;
    border: 1px solid #3d424b;
    background: #ffffff;
    text-align: left;
    word-break: break-all;
}

.contents table:not([class]) td:first-of-type {
    border-left: none;
}


/*--------------------------------------
 float img
---------------------------------------*/

.contents .float-wrap {
    margin: 30px 0;
    box-sizing: border-box;
}

.contents .float-wrap img {
    width: 100%;
}

.contents .float-wrap .fl {
    width: 340px;
    padding: 0 40px 10px 0;
    text-align: center;
}

.contents .category .float-wrap .fl,
.contents .page .float-wrap .fl {
    width: 280px;
}

.contents .float-wrap .fr {
    width: 340px;
    padding: 0 0 10px 40px;
    text-align: center;
}

.contents .category .float-wrap .fr,
.contents .page .float-wrap .fr {
    width: 280px;
}
.contents .float-wrap.ct .float-img{
    width: 650px;
    margin: 0 auto;
}
.contents .float-wrap.ct .float-img .caption{
    text-align:center;
}
.caption {
    margin: 8px 0 0;
    font-size: 1.0rem;
    line-height: 1.3;
    word-break: break-all;
    color: #999;
    text-align: right;
    white-space: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
}

.caption a {
    color: #999;
    text-decoration: underline;
}


/*chrome safari*/
.caption::-webkit-scrollbar {
    height: 5px;
}

.caption::-webkit-scrollbar-track {
    border-radius: 5px;
    background: #eee;
}

.caption::-webkit-scrollbar-thumb {
    border-radius: 2px;
    background: #ddd;
}


/*--------------------------------------
 btn
---------------------------------------*/

.btn-internal a,
.btn-web a,
.btn-scroll a {
    box-sizing: border-box;
}

.btn-internal,
.btn-web,
.btn-scroll {
    width: 450px;
    margin: 3rem auto;
    position: relative;
    box-sizing: border-box;
}

.btn-internal a,
.btn-web a,
.btn-tel a,
.btn-scroll a {
    color: #fff;
    font-size: 1.6rem;
    padding: 25px 50px;
    display: block;
    text-align: center;
    position: relative;
    transition: 0.2s;
}

.btn-internal a {
    background: #1e2c5b url(img/arrow_wt.png) right 2rem top 50% no-repeat;
    border-radius: 100px;
    font-size: 1.8rem;
}

.btn-internal a:hover {
    background: #101730 url("img/arrow_wt.png") right 4rem top 50% no-repeat;
    opacity: 1;
}

.btn-tel::before,
.btn-internal::before,
.btn-web::before,
.btn-scroll::before {
    content: '';
    width: 100%;
    height: 100%;
    background: #c2c2c2;
    border-radius: 100px;
    position: absolute;
    top: 4px;
    left: 4px;
    pointer-events: none;
    transition: 0.2s;
}

.btn-web a {
    background: #e50012 url("img/arrow_wt.png") right 2rem top 50% no-repeat;
    border-radius: 100px;
    font-size: 1.8rem;
}

.btn-web a:hover {
    background: #ad1610 url("img/arrow_wt.png") right 4rem top 50% no-repeat;
    opacity: 1;
}

.btn-scroll a:hover {
    background: #000000 url("img/arrow_up.png") right 4rem top 50% no-repeat;
    opacity: 1;
}

.btn-internal:hover a,
.btn-web:hover a,
.btn-scroll:hover a {
    transform: translate(4px, 4px) translateZ(0);
    border-width: 0 10px 6px 0;
    transition: 0.2s;
}

.btn-link {
    margin: 20px 0;
    text-align: right;
}

.btn-link a {
    background: url("img/top_h2.png") 0% 50% no-repeat;
    background-size: 28px auto;
    padding: 7px 0 7px 45px;
    line-height: 1.3;
    font-size: 1.4rem;
    text-decoration: underline;
}

.btn-link a:hover {
    opacity: 1;
    text-decoration: none;
}

p {
    margin: 15px 0 15px 0;
}

.page.sitemap {
    width: 1000px;
    margin: 0 auto;
}

.page.sitemap h2 a {
    color: #444;
}

.page.sitemap li a:hover {
    text-decoration: underline;
}

.index .headArea {
    padding: 0 25px;
    text-align: left;
    position: relative;
}

.index .headArea.gray::before {
    position: absolute;
    content: "";
    width: 20px;
    height: 414px;
    left: -35px;
    top: 10px;
    background: url(img/Pick-ups--gray.png) no-repeat left top;
    background-size: auto;
    z-index: 20;
}

.index .headArea.back::before {
    position: absolute;
    content: "";
    width: 20px;
    height: 414px;
    left: -35px;
    top: 10px;
    background: url(img/Pick-ups_white.png) no-repeat left top;
    background-size: auto;
    z-index: -1;
}

.index .wi1000 .titL {
    margin: 0 auto 2rem;
    padding: 7px 20px 7px 20px;
    font-size: 3.6rem;
    line-height: 4.4rem;
}

.index .wi1000 .titL span.red {
    color: #e7211a;
}

.index .wi1000 .titL a {
    background: url(img/top_h2.png) no-repeat right 50%;
    background-size: 52px auto;
    padding: 10px 70px 6px 0px;
    display: block;
}

.frame-body p {
    margin: 1rem 0 0;
}


/*addCont01*/

.addCont01 {
    padding: 12rem 0;
    position: relative;
    margin: 0;
    width: 100%;
}

.addCont01::before {
    position: absolute;
    content: "";
    width: 100%;
    height: calc(100% - 8rem);
    background: url(./img/top-bg1.jpg) no-repeat center top;
    background-size: cover;
    pointer-events: none;
    z-index: -1;
    top: 8rem;
}
.addCont01 .wi1000{
    position: relative;
}
.addCont01 .wi1000::after{
    position: absolute;
    width: 981px;
    height: 91px;
    content: '';
    background: url(./img/company-info.png) no-repeat center top;
    background-size: 80% auto;
    bottom: -180px;
    left: 0rem;
    z-index: 10;
    opacity: 0.8;
}
.lower .addCont01 .wi1000::after{
    content: none;
}


.addCont01 .headArea {
    margin: 0 0 50px 0;
}

.addCont01 .headArea::before {
    background: url(img/Pick-ups_white.png) no-repeat left top;
}
.addCont01 .titL{
    font-size: 3.6rem;
    line-height: 1.2;
    margin-bottom: 2rem;
    font-family: "Noto Serif JP", serif;
}
.addCont01 .titL,
.addCont01 .addTxt {
    color: #fff;
}
.addCont01 .titL span{
    color: #5cf5fb;
}
.addCont01 .addTxt {
    font-family: 'Noto Sans JP', sans-serif;
}

.addCont01 .thBoxArea {
    margin: 40px 0 20px;
}

.addCont01 .thBoxArea .sBox {
    width: 320px;
    padding: 0;
    float: left;
    margin: 0 20px 0 0;
    background: transparent;
    position: relative;
    box-sizing: border-box;
}

.addCont01 .thBoxArea .sBox:nth-child(3n) {
    margin: 0;
}

.addCont01 .thBoxArea .sBox .comName {
    font-size: 1.8rem;
    text-align: center;
    background: #3D424B;
    color: #fff;
    padding: 20px;
    margin: 0;
    line-height: 1.3;
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
}

.addCont01 .thBoxArea .sBox .comName span {
    font-size: 2.8rem;
    line-height: 1.4;
    background: linear-gradient(transparent 70%, #B47F81 40%);
}

.addCont01 .thBoxArea .sBox .com-catch {
    text-align: center;
    margin: 0 0 2rem;
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
}

.four-selection__inner {
    background-color: #fff;
    padding: 30px 15px 40px;
}

.four-selection__table {
    width: 100%;
    border: none;
    margin: 15px 0 15px;
    border-collapse: collapse;
    /* display: flex; */
}

.four-selection__table td {
    border: 1px solid #3d424b;
    text-align: center;
    padding: 1rem;
    line-height: 1.5;
    display: block;
    width: 100%;
    padding: 8px;
    box-sizing: border-box;
}

.four-selection__table th.bg-gray {
    background-color: #f2f2f2;
    width: 25%;
    text-align: center;
    font-weight: 700;
    display: block;
    width: 100%;
    padding: 8px;
    box-sizing: border-box;
}

.sBox .four-selection__table .large {
    font-size: 2.4rem;
}

.four-selection__table .red {
    color: #a91f29;
    font-family: "Noto Serif JP", serif;
    font-size: 1.6rem;
}
.lists-title{
    text-align: center;
    margin-top: 3rem;
}
.lists-title span{
    padding: 1rem;
    font-size: 1.8rem;
    font-weight: 700;
    background: #1e2c5b;
    color: #fff;
    display: inline-block;
    width: 56%;
}
.four-selection__lists {
    padding: 3rem 2rem 1rem;
    background: #eff0f3;
    margin: -1.5rem 0 0 0;
    font-size: 1.6rem;
}

.four-selection__lists li {
    position: relative;
    padding-left: 20px;
    letter-spacing: -0.01em;
    line-height: 1.6;
    margin-bottom: 10px;
}

.four-selection__lists li::before {
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #e50012;
    left: 3px;
    top: 5px;
}

.four-selection__caution {
    color: #fff;
    font-size: 100%;
    font-weight: 400;
    line-height: 1.7;
    margin-top: 10px;
    font-family: 'Noto Sans JP', sans-serif;
}
.four-selection__caution a{
    color: #fff;
    text-decoration: underline;
}

.addCont01 .thBoxArea .sBox .btn-internal a {
    background-size: 3rem auto;
}

.addCont01 .thBoxArea .sBox .btn-internal a,
.addCont01 .thBoxArea .sBox .btn-web a {
    font-size: 1.6rem;
    padding: 2rem 4rem;
}
.addCont01 .thBoxArea .sBox .btn-web a{
    background: #e50012 url("img/arrow_wt.png") right 1.5rem top 50% no-repeat;
    background-size: 22px auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
.addCont01 .thBoxArea .sBox .btn-internal a{
    background: #1e2c5b url("img/arrow_wt_down.png") right 2rem top 50% no-repeat;
    background-size: 5px auto;
}
.lower .addCont01 .thBoxArea .sBox .btn-internal a{
    background: #1e2c5b url(img/arrow_wt.png) right 2rem top 50% no-repeat;
    background-size: 22px auto;
}

.addCont01 .thBoxArea .sBox .btn-internal,
.addCont01 .thBoxArea .sBox .btn-web {
    max-width: 90%;
    margin: 3rem auto 2rem;
}

.addCont01 .thBoxArea .sBox .btn-internal {
    margin: 10px auto 0;
}


/*addCont02*/

.index .addCont02 {
    margin: 0;
    padding: 0 0 14rem;
    background: url(img/knowledge_bg.png) no-repeat left 0rem top 7rem #f5f5f5;
}

.index .addCont02 .frame-wrap {
    margin: 4rem 0 0;
    display: flex;
    justify-content: flex-start;
    width: 100%;
    flex-wrap: wrap;
    gap: 45px;
}

.index .addCont02 .frame-wrap .frame.check {
    width: calc((100% - 10%)/3);
    position: relative;
    gap: 20px;
}

.index .addCont02 .frame-wrap .frame.check::before {
    position: absolute;
    content: "";
    width: 45px;
    height: 60px;
    left: 0;
    right: 0;
    margin: auto;
    top: -30px;
    display: flex;
    font-family: century, serif;
    justify-content: center;
    font-size: 5.4rem;
    margin-top: 20px;
}
.index .addCont02 .frame-wrap .frame.check:nth-child(1)::before {
    content: "01";
}
.index .addCont02 .frame-wrap .frame.check:nth-child(2)::before {
    content: "02";
}
.index .addCont02 .frame-wrap .frame.check:nth-child(3)::before {
    content: "03";
}
.index .addCont02 .frame-wrap .frame.check:nth-child(4)::before {
    content: "04";
}
.index .addCont02 .frame-wrap .frame.check:nth-child(5)::before {
    content: "05";
}

.index .addCont02 .frame-wrap .frame.check .inner {
    box-shadow: 7px 7px #e8e9ee;
    background: #fff;
    padding: 5rem 2.5rem;
}

.index .addCont02 .frame-wrap .frame-head {
    font-size: 2.4rem;
    text-align: center;
    line-height: 1.5;
    position: relative;
    padding-bottom: 25px;
    margin-bottom: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.index .addCont02 .frame-wrap .frame-head a{
    background: url(img/arrow_link.png) no-repeat right;
    background-size: 3rem auto;
    padding-right: 3.5rem;
    display: block;
}
.index .addCont02 .frame-wrap .frame-head::before {
    content: "";
    width: 58px;
    height: 4px;
    background: #e7211a;
    display: inline-block;
    position: absolute;
    bottom: 0;
    left: 0;
    margin: auto;
    right: 0;
}


/*addCont03*/

.index .addCont03 {
    margin: 0;
    padding: 8rem 0 4rem;
    counter-reset: company;
    width: 100%;
    overflow: hidden;
    background: url(./img/top-bg2.jpg) no-repeat #eff0f3;
    background-size: 100%;
    background-position: top center;
}

.index .addCont03 h2 {
    display: table;
    margin-left: 0 !important;
    margin-bottom: 15px !important;
    background-color: #3d424b;
    color: #fff;
}

.addCont03 .btn-web{
    width: 60%;
    margin:6rem auto 0;
}
.index .addCont03 .bgbd {
    background: #fff;
    padding: 50px 0 10px;
    width: 125%;
    margin: 4rem -12.5% 10rem;
    box-shadow: 5px 5px #e8e9ee;
}

.index .addCont03 .sTitArea .titM {
    font-size: 3rem;
    text-align: left;
    line-height: 1.4;
    color: #fff;
}

.index .addCont03 .bgbd .sTitArea {
    position: relative;
    padding: 20px 0 20px 30rem;
    box-sizing: border-box;
    margin: 0 0 80px -17%;
    background: #1e2c5b;
}

.index .addCont03 .bgbd .sTitArea::before {
    counter-increment: company;
    content: counter(company, decimal-leading-zero);
    position: absolute;
    left: 16%;
    font-family: century, serif;
    top: 18%;
    width: 10rem;
    height: 10rem;
    font-size: 5rem;
    padding: 3.7% 0 0 1.7%;
    color: #fff;
    background: url("img/icon_num_com.png") top left no-repeat;
    background-size: 94px auto;
}

.index .addCont03 .sTitArea .catch {
    font-size: 2rem;
    line-height: 1.2;
    margin: 0 0 0.5rem;
    color: #fff;
    font-family: "Noto Serif JP", serif;
}
.index .addCont03 .sTitArea .catch span{
    color: #5cf5fb;
    font-size: 2.2rem;
}
.index .addCont03 .subBox02 {
    margin: 80px 0;
}

.addCont03 .top-area{
    display: flex;
    justify-content: space-between;
    margin-bottom: 80px;
}
.addCont03 .top-area .float-img{
    margin-right: 50px;
    width: 450px;
}
.addCont03 .top-area .float-img .caption{
	text-align: center;
}
.addCont03 .top-area .top-area-info{
    width: calc(100% - 500px);
}
.addCont03 .four-selection__table{
    margin: 20px 0;
    /* width: 100%; */
}
.addCont03 .top-area .four-selection__table td:not([class]){
    text-align: center;
}
.index .addCont03 .sTit-wrap {
    border-left: 4px solid #e7211a;
    padding: 1px 20px;
    margin: 0 0 30px 0;
}

.index .addCont03 h4.sTit {
    font-size: 3rem;
    line-height: 1.4;
}

.index .addCont03 .sTit-wrap span {
    font-size: 1.6rem;
    font-family: "Noto Serif JP", serif;
    font-weight: normal;
    letter-spacing: .1em;
}

.index .addCont03 .icon.support {
    width: 100%;
    display: table;
    border-collapse: collapse;
}

.index .addCont03 .icon-list {
    display: table-cell;
    border: 1px solid #3d424b;
    text-align: left;
    padding: 2rem 2rem 2rem 11rem;
    width: 25%;
    background: #fff url(img/icon_01_off.png) no-repeat left 2rem top 2rem;
    background-size: 70px;
}
.index .addCont03 .icon-list .ttl{
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
    color: #1e2c5b;
    line-height: 1.4;
}

.subBox01 {
    margin-bottom: 80px;
}

.subBox04 {
    margin-bottom: 80px;
}

.index .addCont03 .subBox02 .dashed {
    margin: 0;
    background: #f8f8f8;
    width: auto;
    padding: 30px;
}

.index .addCont03 .subBox03 .frame-wrap {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    margin: 3rem 0 0;
    gap: 30px;
}

.index .addCont03 .subBox03 .frame.kutikomi {
    width: 50%;
    background: #f8f8f8;
    border-top: 4px solid #3d424b;
    margin-right: 0;
    box-shadow: 7px 7px #e8e9ee;
}
.index .addCont03 .subBox03 .frame.kutikomi .caption{
    text-align: left;
}
.index .addCont03 .subBox03 .frame.kutikomi .caption a{
    text-decoration: underline;
}

.index .addCont03 .subBox03 .frame.kutikomi .frame-head {
    font-size: 2.4rem;
    font-family: "Noto Serif JP", serif;
    padding: 2.2rem;
    border-bottom: 1px solid #ddd;
    /* text-align: center; */
    font-weight: bold;
    line-height: 1.6;
    min-height: 55px;
    display: flex;
    flex-direction: column;
    color: #1e2c5b;
    justify-content: center;
}
.index .addCont03 .subBox03 .frame.kutikomi .catch{
    color: #1e2c5b;
    font-size: 1.8rem;
    padding: 1.5rem 0 0.5rem;
}

.index .addCont03 .subBox03 .frame-body {
    padding: 1.0rem 2.5rem 2.5rem;
}

.index .addCont03 .subBox04 .infoBox table:not([class]) th {
    background: #454a4b;
}

.company-info__lists {
    flex-wrap: wrap;
    padding-top: 3px;
}

.company-info__lists li {
    position: relative;
    margin-right: 4%;
    padding-left: 20px;
    margin-bottom: 3px;
}

.company-info__lists li:nth-child(2n) {
    margin-right: 0;
}

.company-info__lists li::before {
    content: "";
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #e50012;
    left: 2px;
    top: 7px;
}


/*addCont05*/

.index .addCont05 {
    margin: 4rem 0  14rem;
    position: relative;
}

.index .addCont05::after {
    content: "";
    display: block;
    width: 84.5%;
    position: absolute;
    background: #a3a9c1;
    right: 0;
    top: 5rem;
    height: calc(100% - 18rem);
    z-index: -1;
    pointer-events: none;
}

.index .addCont05 .blueBox {
    position: relative;
}

.index .addCont05 .blueBox .subBox {
    position: relative;
    background: #fff;
    padding: 30px 30px 0;
    margin: 0 15px 0;
}

.index .addCont05 .blueBox .subBox .ph {
    width: 200px;
    float: left;
    margin: 0 27px 0 0;
}

.index .addCont05 .blueBox .subBox .titLArea {
    width: auto;
    overflow: hidden;
    text-align: left;
}

.index .addCont05 .blueBox .subBox .sTit a .pr__titL {
    font-size: 3rem;
    margin: 3rem 0 6rem;
    padding-bottom: 10px;
    line-height: 1.8;
    letter-spacing: .1em;
    background: url(./img/arrow_bk_big.png) no-repeat bottom;
    background-size: 100% auto;
}

.index .addCont05 .blueBox .subBox .sTit a span {
    font-size: 3rem;
    color: #e50012;
    margin: 0 0 15px;
    line-height: 1.8;
    letter-spacing: .1em;
    font-weight: bold;
}

.index .addCont05 .blueBox .subBox .sTit a:hover {
    opacity: 1;
}


/*addCont06*/

.index .addCont06 {
    margin: 0;
    padding: 4rem 0 4rem;
    background: url(img/addCont06_bg.png) center top 12rem no-repeat #eff0f3;
}

.index .addCont06 .frame-wrap {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin: 3rem 0;
    width: 100%;
}

.index .addCont06 .frame-wrap .frame.list {
    width: calc((100% - 6%)/3);
    border: 1px solid #3d424b;
    background-color: #fff;
    padding: 5px;
    box-sizing: border-box;
    margin: 0 3rem 3rem 0;
}

.index .addCont06 .frame-wrap .frame.list:nth-child(3n) {
    margin: 0 0 3rem 0;
}

.index .addCont06 .frame.list .inner {
    background: #fff;
}

.index .addCont06 .frame.list .frame-head {
    text-align: center;
    padding: 2rem 1.5rem 0 1.5rem;
    line-height: 1.4;
    /* display: flex; */
    /* align-items: center; */
}

.index .addCont06 .frame.list .frame-head a {
    font-size: 2.4rem;
    color: #1e2c5b;
    background: url(img/arrow_link.png) no-repeat right;
    background-size: 3rem auto;
    padding: 0 3rem 0 0;
    display: flex;
    align-items: center;
    text-align: left;
}

.index .addCont06 .frame.list .frame-body {
    padding: 2rem 2rem;
}
.index .addCont06 .frame.list table{
    margin: 2rem 0 0;
}
.index .addCont06 .frame.list table th{
    font-size: 1.3rem;
    font-weight: normal;
    padding: 10px;
}
.index .addCont06 .frame.list table td{
    padding: 10px;
}


/*addCont08*/

.index .addCont08 {
    margin: 4rem 0 0;
    padding: 0 0 14rem;
    background: #fff url(./img/top-bg4.jpg) center center no-repeat;
    background-size: 100%;
}

.index .addCont08 .frame-wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 3rem auto 0;
    width: 100%;
    counter-reset: step;
}

.index .addCont08 .frame-wrap .frame.preperation {
    width: calc((100% - 6.3%)/3);
    /* margin: 0 0 3rem 0; */
    background: #3d424b;
    color: #fff;
    border: solid 1px #3d424b;
}

.index .addCont08 .frame-wrap .frame.preperation .frame-img {
    width: 100%;
}

.index .addCont08 .frame-wrap .frame.preperation:nth-child(3n) {
    margin: 0;
}

.index .addCont08 .frame-head_01 {
    padding: 2rem 2rem 0;
    background-size: 100% auto;
    /* font-size: 2.4rem; */
    line-height: 1.5;
}
.index .addCont08 .frame-head {
    padding: 2.4rem 1.5rem 2rem 8rem;
    background: url(img/step.icon.png) left bottom no-repeat;
    background-size: 100% auto;
}
.index .addCont08 .frame .frame-head .sttl.rank {
    padding: 0 2rem 0 0;
    background: none;
    margin: 0;
    border: none;
    box-shadow: none;
    display: flex;
    position: relative;
    align-items: center;
    text-align: left;
}
.index .addCont08 .frame .frame-head_01 .sttl.rank::before {
    background: none;
    border: 1px solid #fff;
    font-size: 2.4rem;
    font-family: century, serif;
    color: #fff;
    font-weight: 500;
    line-height: 1.5;
    left: -67px;
    counter-increment: step;
    content: counter(step, decimal-leading-zero);
}
.index .addCont08 .frame .frame-head .sttl.rank::before {
    background: none;
    border: 1px solid #fff;
    font-size: 2.4rem;
    font-family: century, serif;
    color: #fff;
    font-weight: 500;
    line-height: 1.5;
    left: -67px;
    counter-increment: step;
    content: counter(step, decimal-leading-zero);
}

.index .addCont08 .frame .frame-head .sttl.rank a {
    color: #fff;
    font-size: 2.4rem;
    display: block;
    line-height: 1.6;
}

.index .addCont08 .frame-body {
    padding: 2.5rem 2.5rem 3.5rem;
}


/*accordion*/
.accordion-title {
    display: block;
    width: 35%;
    color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    padding: 25px 0;
    position: relative;
    cursor: pointer;
    user-select: none;
    background: #b9bbc0;
    border-radius: 40px;
    margin: 0 auto 60px;
    opacity: 1;
    box-shadow: 5px 5px 0px 0px #e1e2e4;
}

.accordion-title:hover {
    opacity: .7;
}

.accordion-title:last-of-type {
    border-bottom: 1px solid #010327;
}

.accordion-title::before,
.accordion-title::after {
    content: '';
    display: block;
    background-color: #fff;
    position: absolute;
    top: 50%;
    width: 15px;
    height: 2px;
    right: 25px;
}
.accordion-title span{
    position: relative;
}
.addCont06 .accordion-title span::after{
    content: 'もっと見る';
}
.toc .accordion-title span::after{
    content: '開く';
}
.accordion-title.is-active span::after{
    content: '閉じる';
}

.accordion-title::after {
    transform: rotate(90deg);
    transition-duration: .3s;
}

.accordion-title.is-active::before {
    opacity: 0;
}

.accordion-title.is-active::after {
    transform: rotate(0);
}

.index .addCont06 .frame-wrap.accordion-content,
.toc_parts.accordion-content{
    overflow: hidden;
    opacity: 0;
    height: 0;
    transition-duration: .3s;
}
.toc_parts.accordion-content{
    display: none;
}
.index .addCont06 .frame-wrap.accordion-content.is-open,
.toc_parts.accordion-content.is-open {
    opacity: 1;
    height: auto;
    transition-duration: .3s;
}
.toc_parts.accordion-content.is-open{
    display: block;
}
.addCont02 .job-description img {
    margin-top: -30px;
    width: 50%;
}
.bgTxt.list img {
    margin-top: -72px;
    width: 40%;
}
.bgTxt.reasons img  {
    margin-top: -75px;
    width: 40%;
}
.bgTxt.characteristics img  {
    margin-top: -72px;
    width: 70%;
}
.bgTxt.description,
.bgTxt.bgTxt.public-relations {
    margin-bottom: 3rem;
    width: 60%;
    /* margin: 0 0 2rem 0; */
}


/*--------------------------------------
	toc_parts
---------------------------------------*/

.toc_parts {
    background: #f4f4f7;
    margin: 5rem auto;
    width: 90%;
    padding: 4rem 5rem;
    box-sizing: border-box;
}

.toc_parts .ttl {
    padding: 0 0 0 1rem;
    font-size: 2rem;
    font-weight: bold;
    border-left: 4px solid #e50012;
}

#toc {
    margin: 1.5rem 0 0 0;
    padding: 0 2rem 0;
    border-top: 1px solid #ddd;
}

#toc .chapter {
    margin: 0 0 2rem;
    counter-reset: count;
}

#toc .chapter .chapter-h {
    margin: 2rem 0 0;
    padding: 0 0 0 3.5rem;
    font-size: 1.6rem;
    line-height: 1.8;
    position: relative;
    counter-increment: count;
    background: none;
}

#toc .chapter .chapter-h:last-child {
    margin-bottom: 0;
}

#toc ul.chapter .chapter-h::before {
    content: counter(count, decimal-leading-zero);
    position: absolute;
    top: 14px;
    left: 0;
    transform: translate(0, -50%);
    color: #e50012;
    font-size: 2rem;
    font-weight: bold;
    background: none;
    width: auto;
    height: auto;
    border-radius: 0;
}

#toc .chapter .chapter-h a {
    font-weight: bold;
    text-decoration: none;
}

#toc .chapter .chapter-h a:hover {
    opacity: .6;
}

#toc .chapter .chapter-h span {
    color: #0b072b;
    font-weight: bold;
}

#toc .chapter br {
    display: none;
}

.matome{
    padding: 20px;
    box-sizing: border-box;
    border:1px solid #3d424b;
    background: #fcedee;
    margin: 3rem 0 5rem;
}
.matome-ttl{
    padding: 20px 0 20px 80px;
    background: url(img/matome_icon.png) no-repeat left top;
    background-size: 60px auto;
    font-size: 2rem;
    font-family: "Noto Serif JP", serif;
    font-weight: bold;
    color: #1e2c5b;
    position: relative;
}
.matome p{
    padding-left: 80px;
}

@media screen and (max-width: 480px) {
    body {
        line-height: 1.7em;
        width: 100%;
        min-width: 100%;
    }
    .pc {
        display: none;
    }
    .pc_br {
        display: none;
    }
    .sp {
        display: block;
    }
    .sp_br {
        display: block;
    }
    img {
        max-width: 100%;
    }
	.bgTxt.reasons img {
    margin-top: -22px;
    width: 70%;
	}
	.bgTxt.characteristics img {
    margin-top: -16px;
    width: 100%;
}
    .bgTxt.public-relations img {
    margin-top: 30px;
    width: 40%;
　　}
.bgTxt.public-relations img {
    width: 70%;
    max-width: 90%;
    height: auto;
    max-height: 40px;
    object-fit: cover;
    margin-top: -0rem;
}
    p {
        font-size: 1.4rem;
        margin: 0 0 10px 0;
    }
    a {
        color: #444;
        text-decoration: none;
    }
    a:hover {
        opacity: 1;
    }
    .wi1000 {
        width: 100%;
        margin: 0 auto;
        padding: 0 1.5rem;
        box-sizing: border-box;
    }
    .baseBox {
        padding: 0 10px;
    }
    .category,
    .page {
        width: 100%;
        margin: 0 auto;
    }
    .category .baseBox,
    .page .baseBox {
        width: 100%;
        float: none;
        box-sizing: border-box;
    }

    /* ================== */
    /*header　*/
    /* ================== */
    header {
        position: relative;
    }
    header .rightTxt {
        text-align: left;
    }
    #headNoteArea {
        width: 100%;
        padding: 10px 4% 6px;
        font-size: 1.2rem;
        box-sizing: border-box;
        display: table;
        margin: auto;
    }
    #headNoteArea .areaInner {
        background: none;
        padding: 0;
        margin: 0 auto;
        display: table-cell;
        vertical-align: middle;
        width: 100%;
    }
    #headNoteArea .sitename,
    #headNoteArea .sitename a {
        font-size: 1.4rem;
        padding: 10px 50px 10px 0;
        text-align: left;
        margin: 0;
    }
    #headNoteArea .sitename a {
        background: none;
        padding: 0;
        font-weight: bold;
        margin: 0;
    }
    /* ハンバーガーメニュー */
    .out-frame {
        position: relative;
        width: 100%;
    }
    .out-frame.black::after {
        background: #FFF;
        opacity: 0.6;
        content: '';
        height: 10000px;
        right: 0;
        top: 0;
        padding: 0;
        position: fixed;
        width: 100%;
        z-index: 1;
        transition: all .5s ease;
    }
    .out-frame::after {
        background: #FFF;
        opacity: 0;
        content: '';
        right: 0;
        top: 0;
        position: fixed;
        width: 100%;
        z-index: 1;
        transition: all .5s ease;
    }
    .header-frame {
        position: relative;
        width: 100%;
        height: 64px;
    }
    .menu-btn {
        background: url(./img/sp-btn-menu_on.png) 0 0 no-repeat;
        background-size: 35px;
        position: absolute;
        top: 44px;
        right: 13px;
        height: 35px;
        width: 35px;
        z-index: 10;
    }
    .navOpenOut {
        background: rgba(255, 255, 255, 0.5);
        padding: 22px 13px 20px;
        box-sizing: border-box;
        height: 77px;
    }
    .navOpen {
        background: url(./img/sp-btn-menu_off.png) 0 0 no-repeat;
        background-size: 35px;
        position: inherit;
        top: inherit;
        right: 13px;
        height: 35px;
        width: 35px;
        z-index: 10;
        float: right;
    }
    #sp_titArea .is-fixed {
        position: fixed;
        top: 22px;
        right: 13.5px;
        z-index: 2;
    }
    .fixed {
        position: fixed;
        width: 100%;
        height: 100%;
    }
    .menu-btn img {
        opacity: 1;
    }
    .black .menu-btn img {
        opacity: 0;
    }
    .header-menu {
        display: none;
        position: fixed;
        top: 0;
        width: 100%;
        z-index: 10;
        height: 100%;
        overflow-y: scroll;
    }

    .header-menu ul.accordion li ul:not([class]) li:first-child a {
        padding: 12px 35px 12px 10px;
    }
    .header-menu ul:not([class]) li.delete {
        background: #b5b5b5 url("img/batu.png") 60% 50% no-repeat;
        background-size: 19px;
        padding: 10px;
        text-align: center;
        color: #fff;
        font-size: 1.3rem;
    }
    .header-menu ul.accordion ul:not([class]) {
        display: none;
    }
    .header-menu ul.accordion .subCat ul.subList {
        display: block;
    }
    .header-menu ul.accordion .tglMenu {
        display: block;
        padding: 18px 35px 18px 10px;
        background: #3d424b url(./img/arrow_down.png) 97% 50% no-repeat;
        background-size: 16px auto;
        border-bottom: 1px solid #FFF;
        text-decoration: none;
        line-height: 1.3;
        color: #fff;
        font-size: 14px;
        font-size: 1.4rem;
    }
    .header-menu ul.accordion .open {
        background: #3d424b url(./img/arrow_up_footer.png) 97% 50% no-repeat;
        background-size: 16px auto;
    }
    .header-menu ul.accordion ul:not([class]) li a {
        padding: 12px 30px 12px 20px;
        background: #FFF url("img/arrow_black.png") right 12px center no-repeat;
        background-size: 6px auto;
        color: #3d424b;
        border-bottom: 1px solid #3d424b;
        display: block;
    }
    .header-menu ul.accordion ul:not([class]) li.subCat a {
        padding: 12px 30px 12px 20px;
    }
    .header-menu ul.accordion .subCat ul.subList li a {
        border-bottom: 1px solid #444;
        padding: 12px 30px 12px 30px;
    }
    .header-menu ul.accordion li ul:not([class]) li:last-child a {
        border-bottom: none;
    }
    /*--------------------------------------
    Footer
    ---------------------------------------*/
    footer {
        box-sizing: border-box;
        width: 100%;
        padding: 0;
        /* margin: 40px 0 0; */
    }
    footer a:hover {
        text-decoration: none;
    }
    footer .areaInner {
        box-sizing: border-box;
        position: relative;
        width: 100%;
        margin: 0 auto;
        padding: 0;
    }
    footer .areaInner .footBox {
        margin: 0;
    }
    footer .areaInner .footBox .sttl a {
        display: block;
        box-sizing: border-box;
        font-size: 1.4rem;
        color: #FFF;
        background: url(img/arrow_right.png) right 10px center no-repeat;
        background-size: 16px auto;
        padding: 18px 40px 18px 4%;
    }
    footer .areaInner .footBox .sttl.tglMenu a {
        background: url(img/arrow_down.png) right 10px center no-repeat;
        background-size: 16px auto;
    }
    footer .areaInner .footBox .sttl.open a {
        background: url(img/arrow_up_footer.png) right 10px center no-repeat;
        background-size: 16px auto;
    }
    footer .areaInner .footBox .sttl {
        border-bottom: 1px solid #f3f3f3;
        padding: 0;
        margin: 0;
    }
    footer .areaInner .footBox .accChild {
        display: none;
        padding: 0;
        margin: 0;
        box-sizing: border-box;
        background: #fff;
    }
    footer .areaInner .footBox .accChild li {
        float: none;
        padding: 0;
        margin: 0;
        background: none;
        display: block;
    }
    footer .areaInner .footBox .accChild li a {
        display: block;
        box-sizing: border-box;
        background: url("img/arrow_black.png") right 12px center no-repeat;
        background-size: 6px auto;
        color: #3d424b;
        border-bottom: 1px dotted #3d424b;
        padding: 10px 40px 10px 4%;
        font-size: 13px;
        font-size: 1.3rem;
    }
    footer .areaInner .footBox .accChild li.subCat {
        margin: 0;
    }
    footer .areaInner .footBox .accChild li.subCat a {
        display: block;
        box-sizing: border-box;
        background: url("img/arrow_black.png") right 12px center no-repeat;
        background-size: 6px auto;
        color: #444;
        border-bottom: 1px dotted #444;
        padding: 10px 40px 10px 8%;
    }
    footer .areaInner .footBox .accChild li.subCat:last-child li:last-child a {
        border: none;
    }
    footer .areaInner .footBox .accChild .subList {
        padding: 0;
        margin: 0;
        display: block;
    }
    footer .areaInner .footBox .accChild .subList li {
        display: block;
    }
    footer .areaInner .footBox .accChild .subList li:first-child::before {
        content: "";
    }
    footer .areaInner .footBox .accChild .subList li::after {
        content: "";
    }
    footer .areaInner .footBox .accChild li.subCat::after {
        content: "";
    }
    footer .areaInner .footBox .accChild .subList li a {
        padding: 10px 40px 10px 14%;
        background: url("img/arrow_black.png") right 12px center no-repeat;
        background-size: 6px;
    }
    footer .areaInner .footBox .accChild li::after {
        content: "";
    }
    footer .areaInner .footBox .accChild li:last-child::after {
        content: "";
    }
    footer .areaInner .noticeArea {
        box-sizing: border-box;
        width: 90%;
        margin: 30px auto 30px;
        font-size: 12px;
        font-size: 1.2rem;
        line-height: 1.8em;
        color: #444;
    }
    footer .areaInner .noticeArea p {
        padding: 20px;
        font-size: 12px;
        font-size: 1.2rem;
    }
    footer .areaInner .noticeArea .botPrg {
        text-align: center;
        background: transparent;
        padding: 0;
        font-size: 10px;
        font-size: 1.0rem;
        margin: 10px 0 0;
    }
    footer .botArea {
        padding: 0;
    }
    footer .botArea .botInner {
        width: 100%;
    }
    footer p.copy {
        margin: 0;
        padding: 14px 15px 12px;
        font-size: 1.2rem;
        line-height: 1.3;
        text-align: center;
    }
    footer a {
        text-decoration: none;
    }
    footer .botArea .botInner .smap {
        display: none;
    }
    footer .areaInner .footBox .accChild .sp {
        display: block;
    }
    /*--------------------------------------
    PageTop
    ---------------------------------------*/
    #page-top {
        position: fixed;
        bottom: 12%;
        right: 3%;
        z-index: 2;
        width: 40px;
    }
    #page-top:hover {
        opacity: 1;
    }
    /* ================== */
    /*メインコンテンツ　*/
    /* ================== */
    .category .titLArea,
    .page .titLArea {
        margin: 15px auto 20px;
        background: url(img/low_h1.png) no-repeat top 1.9rem center;
        background-size: contain;
    }
    .category h1:not([class]),
    .page h1:not([class]) {
        margin: 0;
        font-size: 2.5rem;
        line-height: 1.3;
    }
    .category h2:not([class]),
    .page h2 {
        position: relative;
        /* margin: 70px 0 20px; */
        padding: 15px 20px 15px 20px;
        font-size: 2.3rem;
        line-height: 1.4;
    }
    .sitemap h2 a {
        color: #444;
    }
    .category h3:not([class]),
    .page h3:not([class]) {
        margin: 35px 0 20px;
        padding: 10px 15px 8px 45px;
        font-size: 2.1rem;
        line-height: 1.4;
        background-size: 26px auto;
    }
    .category h4:not([class]),
    .category h5:not([class]),
    .category h6:not([class]),
    .page h4:not([class]),
    .page h5:not([class]),
    .page h6:not([class]) {
        position: relative;
        margin: 35px 0 20px;
        padding: 6px 10px 6px 15px;
        font-size: 1.8rem;
        line-height: 1.4;
    }
    .sitemap h2 a {
        color: #444;
    }
    .contents ul:not([class]) li {
        min-height: 12px;
        padding: 0 0 4px 22px;
        font-size: 13px;
    }
    .contents ul:not([class]) li::before {
        top: 4px;
    }
    .contents .noCount .check, 
    .contents .noCount .point, 
    .contents .rank_wrap3 .check, 
    .contents .rank_wrap4 .point, 
    .addCont03 .point {
        padding: 16px 10px 16px 62px;
        font-size: 1.8rem;
    }
    .contents .rank::before {
        width: 50px;
        left: -10px;
        height: 50px;
        padding: 13px 0 0px 13px;
        line-height: 1.1;
        font-size: 2rem;
    }
    .contents .noCount .check::before, 
    .contents .noCount .point::before, 
    .contents .rank_wrap3 .check::before, 
    .contents .rank_wrap4 .point::before, 
    .addCont03 .point::before {
        font-size: 1rem;
        left: -10px;
    }

    /*--------------------------------------
    table
    ---------------------------------------*/
    .contents table:not([class]) {
        border-collapse: collapse;
        width: 100%;
        border: none;
    }
    .contents table:not([class]) tr {
        display: block;
        margin: 0;
    }
    .contents table:not([class]) tr:last-child {
        margin: 0;
    }
    .contents table:not([class]) th {
        color: #FFF;
        font-weight: bold;
        text-align: center;
        font-size: 1.5rem;
        border-top: none;
    }
    .contents table:not([class]) td {
        background: #fff;
        font-size: 1.3rem;
    }
    .contents table:not([class]) th,
    .contents table:not([class]) td {
        padding: 10px;
        display: block;
        line-height: 2.4rem;
        width: 100%;
        box-sizing: border-box;
        border-bottom: none;
        border-left: 1px solid #3d424b;
        border-right: 1px solid #3d424b;
    }
    .contents table:not([class]) td:first-of-type {
        border: 1px solid #3d424b;
        border-bottom: none;
    }
    .contents table:not([class]) td:last-of-type {
        border-bottom: 1px solid #3d424b;
    }

    /*--------------------------------------
    float img
    ---------------------------------------*/

    .contents .float-wrap {
        margin: 20px 0;
        padding: 0;
    }
    .contents .float-wrap .float-img,
    .contents .float-wrap.ct .float-img {
        margin: 0 0 12px 0;
        padding: 0;
        width: 100%;
    }
    .contents .float-wrap .fr {
        width: 100%;
        padding: 0;
        text-align: left;
    }
    .contents .float-wrap img {
        width: 100%;
    }
    .contents .caption {
        margin: 8px 0 0;
        font-size: 10px;
        font-size: 1.0rem;
        line-height: 1.3;
        word-break: break-all;
        color: #999;
        text-align: center;
    }
    .contents .category .float-wrap .fl,
    .contents .page .float-wrap .fl {
        width: 100%;
    }
    .contents .category .float-wrap .fr,
    .contents .page .float-wrap .fr {
        width: 100%;
    }

    /*--------------------------------------
    btn
    ---------------------------------------*/
    .btn-internal,
    .btn-web,
    .btn-link,
    .btn-tel,
    .btn-scroll,
    .accordion-title {
        width: 90%;
        margin: 35px auto;
        position: relative;
    }
    .btn-internal a,
    .btn-web a,
    .btn-link a,
    .btn-tel a {
        font-size: 1.6rem;
        padding: 15px 35px;
    }
    .btn-internal a {
        background: #1e2c5b url(img/arrow_wt.png) right 15px top 50% no-repeat;
        background-size: 2rem auto;
    }
    .btn-web a {
        background: #e50012 url("img/arrow_wt.png") right 15px top 50% no-repeat;
        background-size: 2rem auto;
    }
    .btn-tel {
        display: block;
    }
    .btn-tel a {
        background: url("img/icon_tell.png") left 20px top 50% no-repeat, url("img/arrow_link.png") right 15px top 50% no-repeat;
        background-color: #ffd166;
        background-size: 16px auto, 2rem auto;
        border-radius: 100px;
        color: #3d424b;
    }
    .btn-internal:hover,
    .btn-web:hover,
    .btn-link:hover,
    .btn-tel:hover {
        opacity: 1;
    }
    .btn-tel::before,
    .btn-internal::before,
    .btn-web::before {
        top: 5px;
        left: 5px;
    }
    .btn-scroll a {
        font-size: 1.4rem;
        padding: 10px;
    }
    .accordion-title {
        padding: 20px 0;
    }
    .btn-internal:hover a,
    .btn-web:hover a {
        transform: translate(6px, 6px) translateZ(0);
        border-width: 0 5px 5px 0;
        transition: 0.2s;
    }
    .btn-link a {
        color: #3d424b;
        font-size: 1.6rem;
        display: block;
        text-align: center;
        position: relative;
        background: #fff url(img/arrow_link.png) right 15px top 50% no-repeat;
        background-size: 2rem auto;
        font-weight: bold;
        text-decoration: none;
        border-radius: 100px;
        border: 1px solid #3d424b;
    }
    .btn-link a::before {
        content: '';
        width: 100%;
        height: 100%;
        background: #c2c2c2;
        border-radius: 100px;
        position: absolute;
        top: 5px;
        left: 5px;
        pointer-events: none;
        z-index: -1;
    }
    .btn-web a:hover {
        /* opacity: 1; */
        background: #ad1610 url("img/arrow_wt.png") right 15px top 50% no-repeat;
        background-size: 2rem auto;
    }
    .btn-web a:hover::before {
        border: 1px solid #000;
    }
    .btn-internal a:hover {
        opacity: 1;
        background: #101730 url("img/arrow_wt.png") right 15px top 50% no-repeat;
        background-size: 2rem auto;
    }
    .btn-internal a:hover::before {
        border: 1px solid #657379;
    }
    /*--------------------------------------
    pankuzu
    ---------------------------------------*/
    #pankuzuWrap {
        overflow: auto;
        white-space: nowrap;
    }
    #pankuzu {
        box-sizing: border-box;
        width: 100%;
        padding: 6px 10px 8px;
        font-size: 11px;
        font-size: 1.1rem;
        color: #838383;
        word-break: break-word;
        white-space: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
    }
    #pankuzu a {
        color: #838383;
    }
    .contents .sitemap {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .contents .sitemap h1:not([class]) {
        width: 100%;
    }
    .bgTxt {
        font-size: 6rem;
        margin: 0 0 2rem 0;
        letter-spacing: 1px;
        text-align: center;
    }
    .index .frame-wrap {
        display: block;
    }
    .index .frame-wrap .frame {
        width: 100%;
    }
    .index .headArea {
        padding: 0 0 0 1rem;
    }

    .index .wi1000 .titL {
        font-size: 2.5rem;
        margin: 0 auto 2rem;
        line-height: 1.4;
        padding: 1rem 1rem;
    }
    .index .wi1000 .titL a {
        display: block;
        line-height: 1.4;
        background: url(img/top_h2.png) no-repeat right 50%;
        background-size: 2.5rem auto;
        padding: 0 4rem 0 0;
    }

    /*addCont01*/
    .addCont01 {
        padding: 0rem 0 6rem;
    }
    .addCont01 .wi1000::after{
        width: 90%;
        bottom: -170px;
        left: 10px;
        background-size: 90% auto;
    }
    .addCont01 .wi1000 {
        padding: 0 1rem;
    }
    .index .headArea.back::before,
    .addCont01 .headArea::before {
        background-size: auto 30rem;
        left: -.8rem;
    }
    .addCont01::before {
        top: 6rem;
        height: calc(100% - 4rem);
    }
    .addCont01 .headArea {
        margin: 1rem auto;
    }
    .addCont01 .titL{
        font-size: 2.6rem;
        line-height: 1.4;
    }
    .addCont01 .thBoxArea {
        margin: 3rem auto 0;
        width: 96%;
    }
    .addCont01 .thBoxArea .sBox {
        width: 100%;
        margin: 0 0 2rem;
    }
    .addCont01 .thBoxArea .sBox .comName {
        font-size: 2rem;
        padding: 2.2rem 1rem 2rem;
        /* width: calc(100% - 20px); */
    }
	.addCont01 .thBoxArea .sBox .four-selection__table th.bg-gray {
        display: block;
        width: 100%;
        padding: 8px;
        box-sizing: border-box;
        font-size: 1.6rem;
    }
	.addCont01 .thBoxArea .sBox .four-selection__table td {
        display: block;
        width: 100%;
        padding: 8px;
        box-sizing: border-box;
    }
    .addCont01 .thBoxArea .sBox .comName span{
        font-size: 2rem;
    }
    .addCont01 .thBoxArea .sBox .com-catch {
        margin: 0 auto 2rem;
        font-size: 2rem;
    }
	.addCont01 .thBoxArea .sBox .lists-title span {
		font-size: 1.6rem;
	}
    .addCont01 .thBoxArea .sBox .btn-internal a, 
    .addCont01 .thBoxArea .sBox .btn-web a{
        padding:15px 35px ;
    }
    .addCont01 .thBoxArea .sBox .btn-internal, 
    .addCont01 .thBoxArea .sBox .btn-web,
    .addCont01 .thBoxArea .sBox .btn-tel{
        margin: 1.5rem auto;
    }
    .four-selection__inner{
        padding: 30px 15px 20px;
    }
	.addCont01 {
    margin: 0;
    }

    /*addCont02*/
    .index .addCont02 {
        padding: 0 0 3rem 0;
        margin: 0 auto;
        /* background-size: 150px auto; */
        background: url(img/knowledge_bg.png) no-repeat left -2rem top 5rem #f5f5f5;
        background-size: 160px auto;
    }
    .index .addCont02 .frame-wrap {
        margin: 4rem auto 0;
        display: block;
        width: 96%;
    }
    .index .addCont02 .frame-wrap .frame.check {
        width: 100%;
        margin: 0 0 4rem;
    }
    .index .addCont02 .frame-wrap .frame.check:nth-child(1)::before,
    .index .addCont02 .frame-wrap .frame.check:nth-child(2)::before,
    .index .addCont02 .frame-wrap .frame.check:nth-child(3)::before
	.index .addCont02 .frame-wrap .frame.check:nth-child(4)::before
	.index .addCont02 .frame-wrap .frame.check:nth-child(5)::before {
        font-size: 3.8rem;
    }
    .index .addCont02 .frame-wrap .frame-head {
        font-size: 2.1rem;
    }
    .index .addCont02 .frame-wrap .frame-head a{
        background-size: 2rem auto;
        padding-right: 2.5rem;
    }
    .index .addCont02 .frame-wrap .frame.check .inner {
        padding: 4rem 2rem 2.5rem;
    }
    .index .addCont02 .frame-wrap .frame.check:last-child {
        margin: 0;
    }

    /*addCont03*/
    .index .addCont03 {
        padding: 7rem 0 6rem;
    }
    .index .addCont03 .bgbd {
        padding: 2rem 0;
        width: 100%;
        margin: 2rem auto;
    }
    .index .addCont03 .bgbd .sTitArea {
        margin: 0 0 3rem 0;
        padding: 1rem 1rem 1rem 7rem;
    }
    .index .addCont03 .bgbd .sTitArea::before {
        width: 5rem;
        height: 5rem;
        font-size: 2.5rem;
        left: .5rem;
        background-size: 5rem auto;
        padding: 20px 0 0 11px;
        top: 25%;
    }
    .index .addCont03 .bgbd .sTitArea .titM {
        font-size: 2rem;
    }
    .index .addCont03 .sTitArea .catch {
        font-size: 1.8rem;
        margin: .5rem 0;
        font-weight: normal;
    }
	.index .addCont03 .sTitArea .catch span{
        font-size: 2.2rem;		
	}
    .addCont03 .top-area{
        display: block;
    }
    .addCont03 .top-area .float-img{
        margin: 0 auto 2rem;
        width: 100%;
    }
    .addCont03 .top-area .top-area-info{
        width: 100%;
    }
	.addCont03 .top-area .top-area-info .caption {
        width: 100%;
    }
    .addCont03 .lists-title{
        display: block;
        width: 80%;
        margin: 0 auto;
    }    
    .addCont03 .lists-title span{
        display: inline-block;
        width: 80%;
    }
	.addCont03 .four-selection__table{
		width: 100%;
	}
	.four-selection__table .caption {
  display: block;
  overflow-wrap: break-word; /* 長い単語があれば適切に折り返す */
  word-wrap: break-word; /* 長い単語があれば適切に折り返す */
  max-width: 100%; /* テーブルセルの幅に収まるようにする */ 
}
    .index .addCont03 .sTit-wrap {
        padding: 0 10px;
        margin: 6rem 0 3rem;
    }
    .index .addCont03 h4.sTit {
        font-size: 2.2rem;
    }
    .index .addCont03 .sTit-wrap span {
        font-size: 1.3rem;
    }

    .index .addCont03 .subBox01 .icon.support {
        display: block;
        margin-bottom: 3rem;
    }
    .index .addCont03 .subBox01 .icon-list {
        display: block;
        width: 100%;
        padding: 2rem 1rem 1rem 7rem;
        box-sizing: border-box;
        text-align: left;
        border-bottom: none;
        background-size: 54px;
        background-position: left 1rem top 2rem;
    }
    .index .addCont03 .subBox01 .icon-list:last-child{
        border-bottom: 1px solid #3d424b;
    }
    .index .addCont03 .icon-list .ttl{
        font-size: 2rem;
        margin: 0 0 1rem;
    }
    .subBox01,
    .subBox04,
    .index .addCont03 .subBox02{
        margin: 40px 0;
    }
    .addCont03 .btn-web{
        width: 90%;
        margin: 4rem auto 0;
    }
    .addCont03 .btn-tel{
        margin: 2rem auto 4rem;
    }

    .index .addCont03 .subBox02 .dashed {
        padding: 1rem;
        margin: 0;
    }

    .index .addCont03 .subBox03 .frame-wrap {
        display: block;
    }
    .index .addCont03 .subBox03 .frame.kutikomi {
        width: 100%;
        margin: 0 0 3rem 0;
    }
    .index .addCont03 .subBox03 .frame.kutikomi .frame-head {
        font-size: 1.8rem;
        padding: 1rem;
        line-height: 1.6;
    }
    .index .addCont03 .subBox03 .frame.kutikomi .catch{
        font-size: 1.6rem;
        padding: 1rem 0 0;
    }

    .company-info__lists {
        width: auto;
        display: block;
    }
    .company-info__lists li {
        width: auto;
        margin-right: 0;
    }
    .company-info__lists li::before {
        top: 6px;
    }

    /*addCont05*/
    .index .addCont05 {
        margin: 1rem auto;
    }
    .index .addCont05 .blueBox.wi1000 {
        width: 100%;
        padding: 0;
    }
    .index .addCont05 .blueBox .subBox {
        padding: 1.5rem;
        margin: 0;
    }
    .index .addCont05 .blueBox .subBox .upper {
        margin: 0 0 25px;
    }
    .index .addCont05 .blueBox .subBox .ph {
        margin: 0 auto 20px;
        float: none;
        width: 96%;
    }
    .index .addCont05 .blueBox .subBox .ph img {
        width: 100%;
    }

    .index .addCont05 .blueBox .subBox .sTit a span {
        font-size: 2.4rem
    }
    .index .addCont05 .blueBox .subBox .sTit a .pr__titL {
        font-size: 2.4rem;
        margin: 0 0 2rem;
        line-height: 1.2;
        letter-spacing: .1em;
    }

    /*addCont06*/
    .index .addCont06 {
        margin: 0;
        padding: 0 0 2rem 0;
    }
    .index .addCont06 .frame-wrap {
        display: block;
        width: 96%;
        margin: 3rem auto;
    }
    .index .addCont06 .frame-wrap .frame.list {
        width: 100%;
        padding: 0;
        margin: 0 0 2rem;
    }
    .index .addCont06 .frame.list .frame-head{
        padding: 2.4rem 2.4rem 2rem 2.4rem;
    }
    .index .addCont06 .frame.list .frame-head a {
        font-size: 2.2rem;
        background-size: 2rem;
        padding-right: 2.5rem;
    }

    .index .addCont06 .frame.list .frame-body {
        padding-top: 0;
    }

    /*addCont08*/
    .index .addCont08 {
        margin: 0;
        padding: 0 0 6rem;
    }
    .index .addCont08 .frame-wrap {
        display: block;
        width: 96%;
    }
    .index .addCont08 .frame-wrap .frame.preperation {
        width: 100%;
        margin: 0 0 2rem;
    }
    .index .addCont08 .frame-wrap .frame-img img {
        width: 100%;
        margin: auto;
    }
    .index .addCont08 .frame-head{
        /* padding: 1rem 5rem 1rem 1rem; */
        font-size: 2.2rem;
        line-height: 1.2;
    }
    .index .addCont08 .frame-body{
        padding: 0 1.5rem 1.5rem;
    }
    .index .addCont08 .frame .frame-head .sttl.rank a {
        /* padding: 15px 35px 10px 65px; */
        font-size: 1.8rem;
    }
    .index .addCont08 .frame .frame-head .sttl.rank::before {
        padding: 7px 0 0 10px;
    }

    /*addCont09*/

    .bgTxt.four-selection,
    .bgTxt.company-info,
    .bgTxt.list,
    .bgTxt.job-description,
    .bgTxt.column,
    .bgTxt.public-relations {
        text-align: center;
    }
    .bgTxt.four-selection img,
    .bgTxt.company-info img,
    .bgTxt.list img,
    .bgTxt.column img,
    .bgTxt.public-relations img {
        width: 80%;
        max-width: 100%;
        height: auto;
        max-height: 40px;
        object-fit: cover;
        margin-top: -0rem;
    }
    .bgTxt.four-selection img{
        margin-top: 5rem;
    }
    .bgTxt.list img {
        margin-top: -20px;
    }
    .bgTxt.column img {
        margin-top: -15px;
    }
    .bgTxt.job-description img{
        margin: -20px;
        padding-left: 5rem;
        width: 80%;
    }
    .bgTxt.public-relations img {
        margin: 30px 70px 0 70px;
        width: 100%;
    }
    .toc_parts {
        margin: 3rem auto;
        padding: 3rem 2.5rem 2rem;
    }
    .toc_parts .ttl {
        font-size: 1.6rem;
        border-left: 2px solid #e50012;
    }
    #toc {
        margin: 1.5rem 0 0 0;
        padding: 1rem 0 0;
    }
    #toc .chapter .chapter-h {
        margin: 1rem 0;
        padding: 0 0 0 3rem;
        font-size: 1.5rem;
        line-height: 1.6;
    }
    #toc ul.chapter .chapter-h::before {
        top: 11px;
        font-size: 1.8rem;
    }

    #toc li.chapter-h-three+.chapter-h-two {
        margin-top: 2rem;
    }
    .matome{
        padding: 12px;
    }
    .matome-ttl{
        padding: 10px 0 10px 70px;
        background-size: 60px auto;
    }
    .matome p{
        padding-left: 50px;
    }

    .index-banner {
        margin: 5rem 0 0 0;
        position: fixed;
        left:0;
        bottom: 0;
        z-index: 310;
        display: none;
        width:100%;
    }

    .index-banner a {
        text-decoration: none;
    }

    .index-banner a:hover {
        opacity: 0.6;
    }

    .text-banner-box.part03 {
        position: relative;
        max-width: 100%;
    }

    .text-banner-box.part03:before {
        content: "";
        position: absolute;
        max-width: 25%;
        width: 100px;
        height: 25px;
        background: url(img/banner_kazari.jpg)no-repeat;
        top: -13px;
        left: 2%;
        background-size: 100%;
        z-index: 1;
    }

    .text-banner-box.part03:after {
        content: none;
    }

    .text-banner-box.part03 .cmn02-paragraph {
        font-size: 1.5rem;
        padding-right: 30px;
        font-family: "Noto Serif JP", serif;
        color: #fff;
        background: url(img/arrow02_white.png) no-repeat right center;
        background-size: 10px auto;
    }
    .text-banner-box.part03 .cmn02-paragraph span{
        font-size: 2rem;
        padding-left: 0.5rem;
    }

    .text-banner-box.part03 .text-banner-box__text {
        padding: 2rem 2.7rem 2rem 2rem;
        position: relative;
        background: url(img/banner_bg.jpg) no-repeat;
        background-size: cover;
        display: flex;
        align-items: center;
        width: 100%;
        position: relative;
    }

			
}

/* ==================
    lower
   ================== */
.addCont01.lower {
    position: relative;
    /* padding: 12rem 0; */
    margin: 2rem 0 0;
}

/* ==================
    関連記事
   ================== */

#related-article p {
    margin: 0;
}

#related-article.related-article01-frame {
    margin: 20px auto;
    padding: 30px 50px;
    background: #f4f4f7;
    position: relative;
}

#related-article .related-article01-title {
    padding: 0 0 0 1rem;
    /* color: #333; */
    font-size: 22px;
    font-weight: bold;
    line-height: 1;
    /* background: url("./img/dummy-icon.png") no-repeat left center; */
    /* background-size: 50px auto; */
    position: relative;
}

#related-article .related-article01-title span {
    font-size: 20px;
    color: #333;
}

#related-article .related-article01-list {
    margin: 15px 0 0 0;
    padding: 0 20px 0;
    border-top: 1px solid #d0d3e0;
    font-weight: 700;
}

#related-article .related-article01-list p {
    margin: 0;
}

#related-article .related-article01-list li {
    margin: 2rem 0 0;
    padding: 0 0 0 25px;
    font-size: 100%;
    line-height: 1.7;
    position: relative;
}

#related-article .related-article01-list li+li {
    margin-top: 10px;
}

#related-article .related-article01-list li::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #e7211a;
    position: absolute;
    top: 6px;
    left: 0;
}

#related-article .related-article01-list a {
    display: block;
    text-decoration: none;
}

#related-article .related-article01-list a:hover {
    opacity: 0.6;
}

#related-article .relations-box#related-article .relations-box--column {
    display: flex;
    gap: 10px;
}

#related-article .relations-box__pic {
    flex: 0 0 150px;
}

@media screen and (max-width: 480px) {
    #related-article .related-article01-frame {
        padding: 20px 25px;
        margin: 6rem 1rem 3rem;
    }
    #related-article .related-article01-title span {
        font-size: 16px;
    }
    #related-article .related-article01-list {
        margin: 15px 0 0 0;
        padding: 10px 0 0;
    }
    #related-article .related-article01-list li {
        margin: 10px 0;
        padding: 0 0 0 30px;
        font-size: 15px;
        line-height: 1.6;
    }
    #related-article .related-article01-list li:last-child {
        margin-bottom: 0;
    }
}