@charset "UTF-8"; /* CSS Document */
/*--------------------------------------
　Main Index
---------------------------------------*/
#contents {
    width: 100%;
}

#index {
    width: 100%;
    margin: 0 auto;
    padding: 0;
}

.addInner {
    width: 1100px;
    max-width: 100%;
    margin: 0 auto;
}

/*--------------------------------------
　visArea
---------------------------------------*/
#visArea {
    margin: 0 auto;
}

#visArea .mainArea {
    background: url("img/mv_pic_pc.png") center top no-repeat;
    background-size: cover;
    min-height: 535px;
    display: block;
    padding: 6.7rem 0 6.5rem;
}

#visArea .mainArea .mainAreaInner {
    width: 1100px;
    max-width: 100%;
    margin: 0 auto;
    display: block;
}

#visArea .mainArea .siteNameArea {
    margin: 0 0 3rem;
}

#visArea .mainArea .siteName {
    margin: 0 auto 0 0;
}

#visArea .mainArea .siteName img {
    margin: 0 auto;
}

#visArea .mainArea .mainTxtBox {
    max-width: 620px;
    width: 100%;
    background: rgba(255, 255, 255, 0.9);
    padding: 4rem 5rem;
    margin: 0 auto 0 0;
    border-radius: 0 25px;
}

#visArea .mainArea .mainTxtBox .btn-internal {
    padding: 2rem 0;
}

#visArea .mainArea .catchArea {
    margin: 0 auto 2.2rem;
}

#visArea .mainArea .catchArea .catch {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.45;
    color: #1a2329;
    margin: 0 auto;
}

#visArea .mainArea .catchArea .catch span {
    color: #ae5e45;
    font-size: 2.7rem;
}

#visArea .mainArea .txtArea p {
    margin: 0 auto;
    font-size: 1.5rem;
}

#visArea .mainArea .txtArea p span {
    font-size: 1.5rem;
}

#visArea .mainArea .txtArea p + p {
    margin-top: 1.5rem;
}

/*--------------------------------------
　float img
---------------------------------------*/
.float-wrap .fl {
    width: 400px;
    margin: 0 40px 10px 0;
    text-align: center;
}

.float-wrap .fr {
    width: 400px;
    margin: 0 0 10px 40px;
}

.float-wrap .ct {
    width: 600px;
}

/*--------------------------------------
　frame-wrap
---------------------------------------*/
#contents .frame {
    width: 350px;
    margin: 0 0 0 25px;
}

#contents .frame-wrap .frame:nth-child(n+4) {
    margin-top: 25px;
}

#contents .frame .frame-body {
    padding: 0 30px 35px;
}

/*type-a*/
#contents .frame-wrap .type-a .frame-catch {
    padding: 20px 40px 20px;
}

#contents .frame-wrap .type-a .frame-head {
    padding: 20px 30px 20px;
}

#contents .frame-wrap .type-a .thumb {
    width: 250px;
}

#contents .frame-wrap .type-a ul.icoArea {
    width: 288px;
}

#contents .frame-wrap .type-a ul.icoArea li {
    width: 88px;
    margin: 0 0 0 12px;
}

#contents .frame-wrap .type-a ul.icoArea li:first-child {
    margin: 0 0 0 0;
}

#contents .frame-wrap .type-a ul.icoArea li:nth-child(3n+1) {
    margin: 0 0 0 0;
}

#contents .frame-wrap .type-a ul.icoArea li:nth-child(n+4) {
    margin-top: 18px;
}

/*type-b*/
#contents .frame-wrap .type-b .frame-head {
    padding: 20px 30px 20px;
}

#contents .frame-wrap .type-b .thumb {
    width: 250px;
}

/*type-c*/
#contents .frame-wrap .type-c .frame-head {
    padding: 20px 30px 20px;
}

#contents .frame-wrap .type-c .thumb {
    width: 180px;
}

/*btn-web*/
#contents .frame .frame-body .btn-web {
    width: 88%;
}

/*--------------------------------------
オリジナル
---------------------------------------*/
/***** addParts02 *****/
.addParts02, .addParts--recommended {
    width: 100%;
    padding: 7rem 0;
    position: relative;
    margin: 0 auto;
}

.addParts--recommended .btn-internal a {
    background: url(img/arrow_white_down.png) right 15px center no-repeat #e1724f;
    background-size: 11px auto;
}

.addParts02 .addInner {
    width: 1100px;
    max-width: 100%;
    margin: 0 auto;
}

.addParts02 p {
    margin: 0;
}

/*addTopArea*/
.addParts02 .addTopArea {
    padding: 0;
    margin: 0 auto 7.5rem;
}

/*sttl*/
#index .addParts02 .sttl {
    display: block;
    text-align: center;
    margin: 0 auto 3rem;
    position: relative;
}

.sttl--recommended .sttl__small {
    margin: 0 auto 1.5rem;
}

#index .addParts02 .sttl a {
    color: inherit;
    display: block;
    text-align: center;
    position: relative;
    padding: 0;
    background: none;
}

#index .addParts02 .sttl a::after {
    content: "";
    background: url(img/arrow_black.png) no-repeat right center;
    background-size: contain;
    width: 8px;
    height: 12px;
    position: absolute;
    margin: 1.7rem 0 0 2.2rem;
}

/*block*/
.addParts02 .block {
    background: #fff;
    padding: 6.5rem 0 3.3rem;
    margin: 13.5rem auto;
    position: relative;
    border-radius: 25px 0;
    display: block;
}

.addParts02 .block:last-child {
    margin: 0;
}

.addParts02 .blockTitArea {
    text-align: center;
    padding: 0 4rem;
    margin: 0 auto 3rem;
}

.addParts02 .blockTitSub {
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.6;
    margin: 2rem auto 0;
    color: #fff;
    position: absolute;
    top: -5.5rem;
    background: #243741;
    background-size: 300px auto;
    padding: 1.2rem 3rem 1.2rem 3rem;
    border-radius: 6px;
    z-index: 1;
    min-width: 514px;
    max-width: calc(100% - 8rem);
    left: 4rem;
}

.addParts02 .blockTitSub span {
    font-size: 3.4rem;
    color: #feb28f;
}

#index .addParts02 .blockTit {
    display: block;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    padding: 5rem 0 0;
    position: relative;
    color: #ae5e45;
    margin: 0 0 4rem;
}

.addParts02 .slick-slide:focus {
    outline: none;
}

.addParts02 .sliderArea .slider .slick-prev, .addParts02 .sliderArea .slider .slick-next {
    width: 29px;
    height: 29px;
    top: 250px;
}

.addParts02 .sliderArea .slider .slick-prev {
    background: url(img/low_slide_prev.png) no-repeat;
    background-size: contain;
    left: 160px;
}

.addParts02 .sliderArea .slider .slick-next {
    background: url(img/low_slide_next.png) no-repeat;
    background-size: contain;
    right: 160px;
}

.addParts02 .sliderArea .slider .slidePic {
    height: 500px;
}

/*slideTxtArea*/
.addParts02 .slideTxtArea {
    width: calc(100% - 30px);
    padding: 45px 0 20px 45px;
    margin: -30px auto 0;
    position: relative;
    z-index: 2;
}

.addParts02 .caption {
    margin: 0 0 1.2rem;
}

.addParts02 .slideTit {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.5;
    margin: 0 auto 1.5rem;
    color: #e20213;
}

.addParts02 .slideTxt {
    line-height: 1.6;
    font-size: 1.5rem;
    color: #1a2329;
}

.addParts02 .slideTxt + .slideTxt {
    margin-top: 1.2rem;
}

/*テキスト動き*/
.addParts02 .slideTxtArea {
    opacity: 0;
    transition: all 1s 0s ease;
    transition-delay: 300ms;
}

.addParts02 .slick-slide.slick-current .slideTxtArea, .addParts02 .slick-slide.is-active-next .slideTxtArea {
    opacity: 1;
}

.addParts02 .slideTxtInner {
    opacity: 0;
    margin-left: -15px;
    transition: all 0.5s 0s ease;
    transition-delay: 600ms;
}

.addParts02 .slick-slide.slick-current .slideTxtInner, .addParts02 .slick-slide.is-active-next .slideTxtInner {
    opacity: 1;
    margin-left: 0;
}

.addParts02 .sliderArea {
    margin: 4rem auto 0;
}

.addParts02 .sliderArea .mod_slide {
    margin-top: 3.5rem;
}

.addParts02 .priceAreaInner {
    padding: 2rem 3.5rem 2rem 9.5rem;
    border-radius: 6px;
    margin: 0 4rem 0 0;
    flex-shrink: 0;
    width: 376px;
    max-width: 100%;
}

#contents .addParts02 .priceIcoArea .priceArea .priceTit {
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.4;
    color: #1a2329;
    max-width: inherit;
    padding: 0;
    margin: 0 auto 1.5rem;
}

#contents .addParts02 .priceIcoArea .priceArea ul {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

#contents .addParts02 .priceIcoArea .priceArea ul li {
    line-height: 1.5;
    padding: 0 0 0 1.6rem;
    position: relative;
    width: calc((100% - 2rem)/2);
    color: #1a2329;
}

#contents .addParts02 .priceIcoArea .priceArea ul li:nth-of-type(1) {
    order: 1;
}

#contents .addParts02 .priceIcoArea .priceArea ul li:nth-of-type(2) {
    order: 3;
    margin-top: 0.5rem;
}

#contents .addParts02 .priceIcoArea .priceArea ul li:nth-of-type(3) {
    order: 2;
}

#contents .addParts02 .priceIcoArea .priceArea ul li::before {
    content: "";
    position: absolute;
    top: 14px;
    left: 0;
    width: 7px;
    height: 7px;
    background: #ada07e;
    border-radius: 50%;
}

#contents .addParts02 .priceIcoArea .priceArea ul .priceIcoArea__list__big {
    font-size: 2.1rem;
}

#contents .addParts02 .priceIcoArea .priceArea ul .priceIcoArea__list__middle {
    font-size: 1.6rem;
}

.addParts02 .priceIcoArea .icoArea {
    width: 640px;
    float: right;
}

.addParts02 .priceIcoArea .icoArea li {
    width: 192px;
    margin: 0 0 0 32px;
    float: left;
}

.addParts02 .priceIcoArea .icoArea li:first-child {
    margin: 0 0 0 0;
}

.addParts02 .priceIcoArea .icoArea li:nth-child(3n+1) {
    margin: 0 0 0 0;
}

.addParts02 .priceIcoArea .icoArea li:nth-child(n+4) {
    margin-top: 40px;
}

.addParts02 .priceIcoArea .icoArea li .icoSet {
    text-align: center;
    margin: 0 0 25px;
}

.addParts02 .priceIcoArea .icoArea li .icoSet .ico {
    width: 80px;
    margin: 0 auto;
}

#contents .addParts02 .priceIcoArea .icoArea li .icoSet .icoTxt {
    display: inline-block;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    padding: 20px 0 10px;
    position: relative;
    letter-spacing: normal;
}

.addParts02 .priceIcoArea .caption {
    margin: 1rem auto 0;
}

.addParts02 .block__item {
    margin: 5rem auto 0;
    width: calc(100% - 8rem);
}

.addParts02 .block__item--feature {
    margin: 5.5rem auto 5rem;
}

.addParts02 .block__item--viral {
    margin-bottom: 5rem;
}

#index .addParts02 .block__item__title {
    text-align: center;
    font-size: 2.6rem;
    font-weight: 700;
    color: #1a2329;
}

#index .addParts02 .frame-wrap--feature, #index .addParts02 .frame-wrap--viral {
    display: flex;
    margin: 4rem auto 0;
    justify-content: space-between;
}

.frame--feature {
    width: calc((100% - 6rem)/2);
    position: relative;
    background: #f5f5f5;
    padding: 3rem;
}

#index .frame--feature .frame-head {
    font-size: 2rem;
    color: #e1724f;
    padding: 0 0 2rem 0;
    border-bottom: 2px dotted #333;
}

#index .frame--feature .frame-body {
    margin: 1.5rem auto;
}

#index h4.frame-catch--feature {
    position: absolute;
    top: -16px;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    background: #1b7aab;
    width: 180px;
    line-height: 30px;
    padding: 0 1rem;
    border-radius: 6px;
    font-size: 1.6rem;
    color: #fff;
    font-weight: 700;
}

.frame-head--feature {
    font-size: 1.8rem;
    font-weight: 700;
    color: #e20213;
    line-height: 1.66;
    padding: 1rem 0 3rem;
    margin: 0 auto 2.5rem;
    border-bottom: 2px dotted #333;
    display: flex;
    align-items: center;
    width: 100%;
}

#index .frame-body--feature p {
    color: #1a2329;
    font-size: 1.6rem;
    margin: 0 auto;
}

#index .frame-body--feature p + p {
    margin-top: 1.5rem;
}

.frame--viral {
    flex-grow: 1;
}

.frame--viral:nth-of-type(2) {
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding: 0 2.5rem;
    margin: 0 2.5rem;
}

@media all and (-ms-high-contrast: none) {
    /* IE対策 */
    .frame--viral {
        width: 306px;
        flex-shrink: 0;
    }

    .frame--viral:nth-of-type(2) {
        width: 358px;
    }
}

.frame-head--viral {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto 2rem;
}

.frame__img-wrap--viral {
    width: 63px;
    flex-shrink: 0;
    text-align: center;
    margin-right: 2.2rem;
}

#contents .frame__title--viral {
    margin: 0 auto;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.66;
    width: 100%;
}

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

.frame-body--viral p {
    font-size: 1.5rem;
}

.addParts02 .infoArea {
    width: 100%;
    padding: 0 40px;
    margin: 7rem auto 6rem;
}

.addParts02 .infoArea .infoBox {
    margin: 3.5rem auto 0rem;
}

.addParts02 .infoArea .infoBox:last-child {
    margin: 3.5rem auto 7rem;
}

.addParts02 .infoArea .infoBox .caption {
    text-align: right;
}

.addParts02 .infoArea .infoBox .mapArea {
    width: 380px;
    float: left;
}

#contents .addParts02 .infoArea .infoBox table {
    width: 100%;
    margin: 0;
}

#contents .addParts02 .infoArea .infoBox table th {
    width: 30%;
    font-size: 1.5rem;
}

#contents .addParts02 .infoArea .infoBox table td {
    font-size: 1.5rem;
    padding: 1.5rem 2.2rem;
}

#contents .addParts02 .infoArea .infoBox ul {
    max-width: 1100px;
    margin: 0 auto 5rem;
    padding: 0 7rem;
}

#contents .addParts02 .infoArea .infoBox ul li {
    padding: 0 0 0.6rem 2rem;
    position: relative;
    font-size: 1.6rem;
}

#contents .addParts02 .infoArea .infoBox ul li:last-of-type {
    padding-bottom: 0;
}

#contents .addParts02 .infoArea .infoBox ul li::before {
    content: "";
    display: block;
    background: #e4dbd1;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    top: 8px;
    left: 0;
}

#contents .addParts02 .infoArea .infoBox .note {
    margin-top: 1rem;
    color: #1a2329;
    font-size: 1.4rem;
}

/*--------------------------------------
　box-wrap
---------------------------------------*/
#contents .box-wrap {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#contents .box-wrap .box {
    display: block;
    width: calc((100% - 6.2rem)/2);
    margin: 0 0 0;
    box-sizing: border-box;
    background-color: #fff;
    position: relative;
}

#contents .box-wrap .box:nth-child(n+3) {
    margin-top: 40px;
}

#contents .box-wrap .box .permalink {
    display: none;
}

#contents .box-wrap .box .thumb {
    position: relative;
}

/*box-head*/
#index .box-wrap .box-head, #category .box-wrap .box-head, #page .box-wrap .box-head {
    display: block;
}

#index .box-wrap .box-head a, #category .box-wrap .box-head a, #page .box-wrap .box-head a {
    display: block;
    font-size: 100%;
}

#index .box-wrap .box-head a:hover, #category .box-wrap .box-head a:hover, #page .box-wrap .box-head a:hover {
    color: #1a2329;
    text-decoration: none;
}

#index .box-wrap .box-head::after, #category .box-wrap .box-head::after, #page .box-wrap .box-head::after {
    content: none;
}

#contents .box-wrap .box p {
    margin: 0;
}

/*type-b*/
#contents .box-wrap .type-b {
    padding: 3.3rem 3rem 3.5rem;
    background: #fff;
    background-size: 86px auto;
    border-radius: 0 25px;
}

#contents .box-wrap .type-b .box-head-area {
    display: table;
    margin: 0 auto 2.8rem;
    width: 100%;
}

#contents .box-wrap .type-b .thumb {
    display: table-cell;
    vertical-align: middle;
    width: 75px;
    position: relative;
}

#contents .box-wrap .type-b .box-head {
    display: table-cell;
    vertical-align: middle;
    font-size: 2rem;
    line-height: 1.6;
    font-weight: 700;
    padding: 0 0 0 2rem;
}

#contents .box-wrap .type-b .box-head a {
    display: block;
    width: 100%;
    color: inherit;
    background: url("img/arrow_black.png") right center no-repeat;
    background-size: 8px auto;
    padding: 0 2.8rem 0 0;
    position: relative;
}

#contents .box-wrap .type-b .box-head a:hover {
    opacity: 0.6;
}

#contents .box-wrap .type-b p {
    font-size: 1.5rem;
}

#contents .box-wrap .type-b p + p {
    margin-top: 1.5rem;
}

#contents .box-wrap .type-b p.answer {
    font-size: 1.8rem;
    font-weight: 700;
    color: #e1724f;
}

/*--------------------------------------
　frame-wrap
---------------------------------------*/
#contents .frame-wrap {
    width: 100%;
    max-width: 1100px;
    margin: 5.5rem auto 0;
}

#contents .frame-wrap .inner {
    margin: 0 auto;
}

#contents .frame {
    display: block;
    box-sizing: border-box;
    margin: 0 0 0 25px;
}

#contents .frame-wrap .frame:first-child {
    margin: 0;
}

#contents .frame-wrap .frame:nth-child(3n+1) {
    margin: 0;
}

#contents .frame-wrap .frame:nth-child(n+4) {
    margin-top: 16px;
}

#contents .frame-wrap .frame a {
    display: block;
    text-decoration: none;
}

/*frame-head*/
#index .frame .frame-head, #category .frame .frame-head, #page .frame .frame-head {
    display: block;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.5;
}

#index .frame .frame-head a, #category .frame .frame-head a, #page .frame .frame-head a {
    width: auto;
    font-size: 100%;
    text-decoration: none;
}

#index .frame .frame-head a:hover, #category .frame .frame-head a:hover, #page .frame .frame-head a:hover {
    opacity: 0.6;
}

#contents .frame .frame-head p {
    margin: 0;
}

#contents .frame .frame-body {
    padding: 0;
}

#contents .frame .frame-body .frame-catch {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
    color: #1a2329;
    margin: 0 0 15px;
}

#contents .frame .frame-body p {
    margin: 0;
}

#contents .frame p.caption {
    margin: 10px 15px 0;
}

/*type-a*/
#contents .frame-wrap .type-a {
    background: #f5f5f5;
    padding: 3rem 3.4rem 3.3rem;
    position: relative;
}

#contents .frame-wrap .type-a:nth-child(n+4) {
    margin-top: 4.5rem;
}

#contents .frame-wrap .type-a::before {
    content: "";
    width: 36px;
    height: 27px;
    position: absolute;
    background: url(img/check_frame_ico.png) no-repeat;
    background-size: contain;
    top: -14px;
    left: 0;
    right: 0;
    margin: 0 auto;
}

#contents .frame-wrap .type-a .frame-head {
    font-size: 2rem;
    line-height: 1.5;
    font-weight: 700;
    padding: 0 0 2.3rem;
    border-bottom: 2px dotted #333;
    margin: 0 auto 2rem;
    display: flex;
    align-items: center;
    max-width: 100%;
    font-feature-settings: "palt";
}

#contents .frame-wrap .type-a .frame-head a {
    display: flex;
    width: 100%;
    background: url(img/arrow_black.png) right center no-repeat;
    background-size: 8px auto;
    padding: 0 2rem 0 0;
    position: relative;
    height: 100%;
    align-items: center;
}

#contents .frame-wrap .type-a .frame-head a:hover {
    opacity: 0.6;
}

#contents .frame-wrap .type-a .frame-body p {
    margin: 0 auto;
    font-size: 1.5rem;
}

#contents .frame-wrap .type-a .frame-body p + p {
    margin-top: 1.5rem;
}

/*type-b*/
#contents .frame-wrap .type-b {
    background: #fff;
    padding: 0;
}

#contents .frame-wrap .type-b .frame-head {
    font-size: 2rem;
    line-height: 1.4;
    font-weight: 700;
    padding: 4.2rem 4rem 3.7rem 8.5rem;
    margin: 0 auto 2rem;
    position: relative;
    background: url(img/frame_head_b_ico.png) no-repeat left 3rem center;
    background-size: 40px auto;
    display: flex;
    align-items: center;
}

@media all and (-ms-high-contrast: none) {
    /* IE対策 */
    .addParts__title--company .sttl__small::before, .addParts__title--company .sttl__small::after {
        width: 40rem;
    }

    #contents .frame-wrap .type-a .frame-head, #contents .frame-wrap .type-b .frame-head {
        display: table;
        vertical-align: middle;
        table-layout: fixed;
        width: 100%;
        max-width: 100%;
    }
}

@supports (-ms-ime-align: auto) {
    /* Edge対策 */
    #contents .frame-wrap .type-a .frame-head, #contents .frame-wrap .type-b .frame-head {
        display: table;
        vertical-align: middle;
        table-layout: fixed;
        width: 100%;
        max-width: 100%;
    }
}

#contents .frame-wrap .type-b .frame-head::after {
    content: "";
    border-bottom: 2px dotted #333;
    width: calc(100% - 7rem);
    height: 2px;
    position: absolute;
    left: 0;
    bottom: 0;
    top: auto;
    right: 1rem;
    z-index: inherit;
    transform: none;
    margin: 0 auto;
}

#contents .frame-wrap .type-b .frame-head a {
    width: calc(100% + 0.9rem);
    background: url("img/arrow_black.png") right center no-repeat;
    background-size: 8px auto;
    padding: 0 2.8rem 0 0;
    position: relative;
    margin: 0 -0.9rem 0 0;
    height: 100%;
    display: flex;
    align-items: center;
}

#contents .frame-wrap .type-b .frame-head a:hover {
    opacity: 0.6;
}

#contents .frame-wrap .type-b .thumb {
    width: 200px;
    margin: 0 auto;
}

#contents .frame-wrap .type-b .caption {
    text-align: left;
    padding: 0;
    word-break: break-all;
}

#contents .frame-wrap .type-b .frame-body {
    margin: 0 auto 3rem;
    padding: 0 3rem;
}

#contents .frame-wrap .type-b .frame-body h4 {
    font-size: 1.6rem;
    margin: 3rem 0 1rem;
}

#contents .frame-wrap .type-b .frame-body p {
    font-size: 1.5rem;
}

#contents .frame-wrap .type-b .frame-body p + p {
    margin-top: 1.5rem;
}

#contents .frame-wrap .type-b .frame-body table {
    box-sizing: border-box;
    width: 100%;
    letter-spacing: 0;
    margin: 0 0 3rem;
}

#contents .frame-wrap .type-b .frame-body table th {
    width: 28%;
    font-size: 1.4rem;
    padding: 1.1rem 1rem;
}

#contents .frame-wrap .type-b .frame-body table td {
    font-size: 1.4rem;
    padding: 1.1rem 1.5rem;
}

#contents .frame-wrap .type-b .frame-body ul {
    max-width: 1100px;
    margin: 2rem auto 3rem;
    padding: 0 1rem;
}

#contents .frame-wrap .type-b .frame-body ul li {
    padding: 0 0 0.6rem 2rem;
    position: relative;
    font-size: 1.5rem;
    word-break: break-word;
}

#contents .frame-wrap .type-b .frame-body ul li:last-of-type {
    padding-bottom: 0;
}

#contents .frame-wrap .type-b .frame-body ul li::before {
    content: "";
    display: block;
    background: #e4dbd1;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    top: 8px;
    left: 0;
}

#contents .frame-wrap .type-b .frame-body .btn-link {
    text-align: left;
}

/*type-c*/
#contents .frame-wrap .type-c {
    background: #fff;
    padding: 3.5rem 3rem 4.5rem;
    border-radius: 0 25px;
}

#contents .addParts--point .frame-wrap .type-c {
    width: 100%;
    padding: 6rem 4rem 4rem;
    background: #f5f5f5;
}

#contents .addParts--point .frame-wrap .type-c .flame {
    max-width: 380px;
}

#contents .addParts--point .frame-wrap .type-c .textArea {
    display: flow-root;
    padding: 0 3rem 0rem 0;
}

#contents .frame-wrap .type-c .eng {
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.06em;
    text-align: center;
    color: #fff;
    text-shadow: 1px 1px 0 #333, -1px -1px 0 #333, -1px 1px 0 #333, 1px -1px 0 #333, 0px 1px 0 #333, -1px 0 #333, -1px 0 0 #333, 1px 0 0 #333;
    margin: -10px 0 0;
}

#contents .frame-wrap .type-c .frame-head {
    font-size: 2rem;
    line-height: 1.6;
    font-weight: 700;
    padding: 6.5rem 0 0;
    margin: 0 auto 2rem;
    position: relative;
    max-width: 100%;
}

#contents .frame-wrap .type-c .frame-head a {
    display: block;
    width: 100%;
    background: url("img/arrow_black.png") right center no-repeat;
    background-size: 8px auto;
    padding: 0 20px 0 0;
    position: relative;
    letter-spacing: normal;
}

#contents .frame-wrap .type-c .frame-head a:hover {
    opacity: 0.6;
}

#contents .frame-wrap .type-c .thumb {
    width: 160px;
    margin: 0 auto 25px;
}

#contents .frame-wrap .type-c .thumb img {
    border-radius: 100px;
}

/*btn-web*/
#contents .frame .frame-body .btn-web {
    width: 85%;
    margin: 25px auto 0;
}

/* addParts--point */
.addParts--point {
    margin: 0 auto;
    padding: 8.5rem 0 12rem;
    background: #fff;
    background-size: cover;
}

#index h2, #index h3, #index h4, #index h5 {
    background: none;
    border-radius: 0;
    border: none;
}

#index h2::before, #index h2::after {
    content: none;
}

#index .addParts__title--point {
    font-size: 3.4rem;
    font-weight: 700;
    max-width: 100%;
    color: #1a2329;
    background: none;
    border-radius: 0;
    margin: 0 auto 4.5rem;
    padding: 0;
}

#index .addParts__title--point a {
    color: inherit;
    display: inline-block;
}

#index .frame-wrap--point {
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
}

#index .frame-wrap--point .frame-head {
    color: #1a2329;
}

#index .frame-wrap--point .frame:first-of-type .frame-head {
    background: url(img/point01_ico.png) no-repeat top left;
    background-size: 120px auto;
}

#index .frame-wrap--point .frame:nth-of-type(2) .frame-head {
    background: url(img/point03_ico.png) no-repeat top left;
    background-size: 151px auto;
}

#index .frame-wrap--point .frame:nth-of-type(3) .frame-head {
    background: url(img/point02_ico.png) no-repeat top left;
    background-size: 140px auto;
}

#index .frame-wrap--point .frame-body p {
    font-size: 1.6rem;
    line-height: 1.75;
}

#index .frame-wrap--point .frame-body p span {
    font-size: 1.8rem;
}

#index .frame-wrap--point .frame-body p + p {
    margin-top: 1.5rem;
}

#index .frame-wrap--point ul {
    max-width: 1100px;
    margin: 1rem auto;
    padding: 0;
}

#index .frame-wrap--point ul li {
    padding: 0 0 0.6rem 2rem;
    position: relative;
}

#index .frame-wrap--point ul li:last-of-type {
    padding-bottom: 0;
}

#index .frame-wrap--point ul li::before {
    content: "";
    display: block;
    background: #e20213;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    top: 8px;
    left: 0;
}

/* addParts--check */
.addParts--check {
    margin: 9rem auto 12rem;
}

.addTopArea--check {
    margin: 0 auto 8rem;
}

.addTopArea__img-wrap--check {
    float: right;
    margin: 0 0 1.5rem 9.5rem;
    width: 550px;
}

.addTopArea__img-wrap--check .caption {
    color: #fff;
    text-align: center;
}

#index .addParts__title--check {
    padding: 6rem 1.5rem 0 0rem;
    width: 449px;
    max-width: 100%;
    float: left;
    margin: 0 auto 4rem;
    background: url(img/addparts_check_title_deco.png) no-repeat top left;
    background-size: 330px auto;
    text-align: left;
    color: #1a2329;
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.47;
}

#index .addParts--pr {
    background-color: #4c9777;
    margin: 0 auto;
    padding: 9rem 0 5rem;
    color: #fff;
}

#index .addParts--pr .textArea {
    display: flow-root;
}

#index .addParts__title--pr {
    padding: 4.5rem 0rem 0 0rem;
    max-width: 476px;
    width: 100%;
    float: left;
    margin: 0 auto 4rem;
    background: url(img/addparts_pr_title_deco.png) no-repeat top left;
    background-size: 330px auto;
    text-align: left;
    color: #1a2329;
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.47;
}

#index .addParts__title--pr a {
    color: #fff;
    background: url(img/arrow_white.png) no-repeat right 0.1rem center;
    background-size: 9px auto;
}

@-moz-document url-prefix() {
    /* Firefox対策 */
    #index .addParts__title--check {
        padding: 4.5rem 0.5rem 0 5rem;
        font-feature-settings: "palt";
    }
}

#index .addParts__title--check a {
    color: inherit;
    display: inline;
    background-size: 8px auto;
    padding-right: 3.2rem;
}

.addTxt--check {
    margin: 0;
    width: 100%;
    max-width: 100%;
    line-height: 1.75;
}

.addTxt--check + .addTxt--check {
    margin-top: 1.5rem;
}

#index .frame-wrap--check {
    margin: 0 auto;
    padding: 1.3rem 0 0;
    display: flex;
    flex-wrap: wrap;
}

#contents .addParts--check .btn-internal {
    margin-top: 5rem;
    position: relative;
    z-index: 0;
}

#contents .addParts--check .btn-internal a {
    background: url(img/arrow_white_up.png) right 15px center no-repeat #e1724f;
    background-size: 11px auto;
}

#contents .addParts--check.addParts--pr .btn-internal a {
    background: url(img/arrow_white.png) right 15px center no-repeat #e1724f;
    background-size: 7px auto;
    position: relative;
    box-shadow: 6px 6px 0px 0px #fff;
}

/* addParts--knowledge */
.addParts--knowledge {
    background: #f5f5f5;
    padding: 8rem 0;
}

#index .addParts__title--knowledge {
    display: block;
    padding: 5rem 0 0;
    background: url(img/knowledge_tit_ico.png) no-repeat top 1rem center;
    background-size: 178px auto;
    font-size: 3.4rem;
    font-weight: 700;
    color: #1a2329;
    margin: 0 auto 6.5rem;
}

#index .addParts__title--knowledge a {
    display: inline-block;
    color: inherit;
    padding-right: 2.8rem;
    background-size: 8px auto;
}

#index .addParts--knowledge .box-wrap {
    margin-bottom: 5rem;
}

/* addParts--company */
.addParts--company {
    background: #f5f5f5;
    padding: 8rem 0 7rem;
}

#index .addParts--company .sttl {
    display: block;
    text-align: center;
    margin: 0 auto 2rem;
    position: relative;
    padding: 5.5rem 0 0;
    background: url(img/company_tit_ico.png) no-repeat top center;
    background-size: 172px auto;
    font-size: 3.4rem;
    font-weight: 700;
    color: #3b3523;
    max-width: 100%;
}

.addParts__title--company .sttl__small {
    font-size: 2.4rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-align: center;
    margin: 0 auto 1.5rem;
    color: #243741;
}

.addParts__title--company .sttl__small::before, .addParts__title--company .sttl__small::after {
    content: "";
    border-top: 2px solid;
    flex-grow: 1;
    min-width: 10rem;
    max-width: 40rem;
}

.addParts__title--company .sttl__small::before {
    margin-right: 3.5rem;
}

.addParts__title--company .sttl__small::after {
    margin-left: 3.5rem;
}

#index .addParts--company .sttl a {
    color: #243741;
    display: block;
    text-align: center;
    position: relative;
    padding: 0;
    background: none;
}

#index .addParts--company .sttl a::after {
    content: "";
    background: url(img/arrow_black.png) no-repeat right center;
    background-size: contain;
    width: 8px;
    height: 12px;
    position: absolute;
    margin: 1.7rem 0 0 2.2rem;
}

.addParts__box--company {
    margin: 0 auto;
}

.addParts__box--company + .addParts__box--company {
    margin-top: 6.8rem;
}

#index .frame-wrap--company, #index .frame-wrap__accordion--company {
    display: flex;
    flex-wrap: wrap;
    margin: 4.5rem auto 0;
}

#index .frame-wrap__accordion--company {
    margin-top: 0;
}

#index .btn-accordion--company {
    width: 450px;
    z-index: 0;
    max-width: 90%;
    background: #fff url(img/arrow_plus.png) no-repeat right 1.7rem center;
    background-size: 11px auto;
    font-size: 1.8rem;
    font-weight: 700;
    padding: 1.9rem 3.5rem;
    display: block;
    text-align: center;
    text-decoration: none;
    border: 1px solid;
    line-height: 1.7;
    position: relative;
    transition: 0.2s;
    margin: 5rem auto 0;
}

#index .btn-accordion--company.is-open {
    background-image: url(img/arrow_minus.png);
    background-repeat: no-repeat;
}

#index .btn-accordion--company::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid #333;
    border-width: 0 1px 1px 0;
    position: absolute;
    right: -6px;
    bottom: -6px;
    z-index: -1;
}

#index .btn-accordion--company:hover {
    cursor: pointer;
    opacity: 0.6;
}

#index .btn-accordion--company + .addParts__accordion--company {
    display: none;
    width: 100%;
    margin: 6rem auto 2rem;
}

.frame__item--company {
    background: #fff;
    border-radius: 6px;
    margin: 0 3.1rem 3.1rem;
    padding: 2rem 2rem 2.2rem;
}

.frame__item__head--company {
    display: flex;
    margin: 0 0 1.8rem -0.3rem;
    align-items: center;
    justify-content: space-between;
}

.frame__item__img-wrap--company {
    flex-shrink: 0;
    width: 54px;
    text-align: center;
    margin: 0 1.8rem 0 0;
}

#index .frame__item__title--company {
    margin: 0 auto;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.625;
    width: 100%;
}

#index .frame__item--company p:not(.frame__item__title--company) {
    font-size: 1.5rem;
    margin: 0 auto;
}

#index .frame__item--company p:not(.frame__item__title--company) + p:not(.frame__item__title--company) {
    margin-top: 1.5rem;
}

@media screen and (max-width: 480px) {
    /*------------
  Index
  ------------*/#contents {
        width: 100%;
    }

    #index {
        margin: 0 auto;
    }

    /*--------------------------------------
   visArea
  ---------------------------------------*/
    #visArea {
        margin: 0 auto 3rem;
        background: none;
    }

    #visArea .mainArea {
        background: none;
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
        padding: 0;
        min-height: auto;
    }

    #visArea .mainArea .mainAreaInner {
        background: #EDE4E3;
        padding: 0 0 3rem 0rem;
    }

    #visArea .mainArea .siteNameArea {
        /* display: block; */
        background: url(img/mv_pic_sp.jpg) top 26px center no-repeat;
        background-size: cover;
        height: 250px;
        width: 100%;
        margin: 0 auto;
        padding: 0.8rem 10%;
    }

    #visArea .mainArea .siteNameAreaInner {
        display: block;
    }

    #visArea .mainArea .siteName {
        text-align: center;
        margin: 0 auto;
        display: block;
    }

    #visArea .mainArea .mainTxtBox {
        width: 90%;
        background: none;
        padding: 0;
        margin: 2rem auto 0;
    }

    #visArea .mainArea .catchArea {
        margin: 0 auto 1.7rem;
    }

    #visArea .mainArea .catchArea .catch {
        font-size: 2rem;
        line-height: 1.4;
        text-align: left;
    }

    #visArea .mainArea .txtArea p {
        font-size: 1.4rem;
    }

    #visArea .mainArea .catchArea .catch span {
    color: #ae5e45;
    font-size: 2.5rem;
        
    }
    /*--------------------------------------
   footer
  ---------------------------------------*/
    footer .areaInner .logo a {
        /*pointer-events: none;*/
    }

    /*--------------------------------------
   box-wrap
  ---------------------------------------*/
    #contents .box-wrap .box {
        width: 100%;
    }

    /*--------------------------------------
   frame-wrap
  ---------------------------------------*/
    #contents .frame {
        width: 100%;
        margin: 0 0 2rem;
    }

    #contents .frame-wrap .frame:nth-child(n+4) {
        margin-top: 0;
    }

    #contents .frame .frame-body {
        padding: 0;
    }

    /*type-a*/
    #contents .frame-wrap .type-a .frame-catch {
        padding: 1.5rem 2.5rem;
    }

    #contents .frame-wrap .type-a .frame-head {
        padding: 1.8rem 1.5rem;
    }

    #contents .frame-wrap .type-a .thumb {
        width: 80%;
    }

    #contents .frame-wrap .type-a ul.icoArea {
        width: 100%;
    }

    #contents .frame-wrap .type-a ul.icoArea li {
        width: calc(100% / 3);
        margin: 0 0 0 0;
    }

    #contents .frame-wrap .type-a ul.icoArea li:first-child {
        margin: 0 0 0 0;
    }

    #contents .frame-wrap .type-a ul.icoArea li:nth-child(3n+1) {
        margin: 0 0 0 0;
    }

    #contents .frame-wrap .type-a ul.icoArea li:nth-child(n+4) {
        margin-top: 1.6rem;
    }

    /*type-b*/
    #contents .frame-wrap .type-b .frame-head {
        padding: 1.8rem 1.5rem;
    }

    #contents .frame-wrap .type-b .thumb {
        width: 80%;
    }

    /*type-c*/
    #contents .frame-wrap .type-c .frame-head {
        padding: 0.5rem 1.8rem 2rem;
    }

    #contents .frame-wrap .type-c .thumb {
        width: 60%;
    }

    /*btn-web*/
    #contents .frame .frame-body .btn-web {
        width: 85%;
    }

    /*--------------------------------------
  オリジナル
  ---------------------------------------*/
    /***** addParts02 *****/
    .addParts02 {
        padding: 3rem 0 6rem;
    }

    .addParts02 .addInner {
        width: 92%;
        margin: 0 auto;
    }

    .addParts02 p {
        margin: 0;
    }

    /*addTopArea*/
    .addParts02 .addTopArea {
        padding: 0 0;
        margin: -9rem auto 3rem;
        padding-top: 9rem;
    }

    /*sttl*/
    #index .addParts02 .sttl {
        margin: 0 auto 1.5rem;
        padding: 5.5rem 0 0;
        background-size: 182px auto;
        font-size: 2.2rem;
        line-height: 1.5;
        max-width: 100%;
    }

    /*block*/
    .addParts02 .block {
        padding: 6.8rem 0 2rem;
        margin: 7rem auto;
    }

    .addParts02 .block:last-child {
        margin: 7rem auto 0;
    }

    .addParts02 .blockTitArea {
        padding: 0 5%;
        margin: 0 auto;
    }

    .addParts02 .blockTitSub {
        font-size: 2rem;
        min-width: auto;
        max-width: 90%;
        left: 5%;
        padding: 1rem 5% 1rem;
        line-height: 1.42;
        top: -5.5rem;
    }

    .addParts02 .blockTitSub span {
        font-size: 2.5rem;
    }

    #index .addParts02 .blockTit {
        font-size: 3rem;
        padding: 0;
        max-width: 100%;
        line-height: 1.7;
        margin: 0 0 0rem;
    }

    /*slideTxtArea*/
    .addParts02 .slideTxtArea {
        width: calc(100% - 30px);
        padding: 3rem 0 1.5rem 1.5rem;
        margin: -1.5rem auto 0;
    }

    .addParts02 .slideTxtArea::before {
        width: 15px;
    }

    .addParts02 .caption {
        margin: 0 0 1.2rem;
    }

    .addParts02 .slideTit {
        font-size: 1.6rem;
        margin: 0 auto 1rem;
    }

    .addParts02 .slideTxt {
        font-size: 1.4rem;
    }

    /*テキスト動き*/
    .addParts02 .slideTxtArea {
        opacity: 0;
        transition: all 1s 0s ease;
        transition-delay: 300ms;
    }

    .addParts02 .slick-slide.slick-current .slideTxtArea, .addParts02 .slick-slide.is-active-next .slideTxtArea {
        opacity: 1;
    }

    .addParts02 .slideTxtInner {
        opacity: 0;
        margin-left: -15px;
        transition: all 0.5s 0s ease;
        transition-delay: 600ms;
    }

    .addParts02 .priceIcoArea {
        width: 92%;
        padding: 3rem 0 0;
        margin: 0 auto 4rem;
        position: relative;
    }

    .addParts02 .priceIcoArea .priceArea {
        width: 100%;
        padding: 1.5rem;
        margin: 0 auto;
        display: block;
    }

    .addParts02 .priceIcoArea .icoArea {
        width: 100%;
        float: none;
    }

    .addParts02 .priceIcoArea .icoArea li {
        width: 100%;
        margin: 0 0 3rem;
        float: none;
    }

    .addParts02 .priceIcoArea .icoArea li:first-child {
        margin: 0 0 3rem;
    }

    .addParts02 .priceIcoArea .icoArea li:nth-child(3n+1) {
        margin: 0 0 3rem;
    }

    .addParts02 .priceIcoArea .icoArea li:nth-child(n+4) {
        margin: 0 0 3rem;
    }

    .addParts02 .priceIcoArea .icoArea li:last-child {
        margin: 0 0 0;
    }

    .addParts02 .priceIcoArea .icoArea li .icoSet {
        display: table-cell;
        vertical-align: middle;
        width: 85px;
        text-align: center;
        margin: 0 0 0;
    }

    .addParts02 .priceIcoArea .icoArea li .icoSet .ico {
        width: 45px;
        margin: 0 auto;
    }

    #contents .addParts02 .priceIcoArea .icoArea li .icoSet .icoTxt {
        display: inline-block;
        font-size: 1.5rem;
        font-weight: 700;
        line-height: 1.4;
        text-align: center;
        padding: 1rem 0 0.6rem;
        position: relative;
    }

    .addParts02 .priceIcoArea .icoArea li > .icoTxt {
        display: table-cell;
        vertical-align: middle;
        width: calc(100% - 95px);
    }

    .addParts02 .infoArea {
        width: 92%;
        padding: 0;
        margin: 4.5rem auto 0;
    }

    #contents .addParts02 .infoArea .infoTit {
        width: 100%;
    }

    .addParts02 .infoArea .infoBox .mapArea {
        width: 100%;
        overflow: hidden;
        margin: 0 0 2.5rem;
        float: none;
    }

    #contents .addParts02 .infoArea .infoBox table {
        display: table;
        width: 100%;
        margin: 0;
        float: none;
    }

    #contents .addParts02 .infoArea .infoBox table th {
        display: table-cell;
        width: 35%;
        border-right: 1px solid #333;
        padding: 1rem 2%;
        font-size: 1.4rem;
    }

    #contents .addParts02 .infoArea .infoBox table td {
        display: table-cell;
        padding: 1rem;
        font-size: 1.4rem;
    }

    #contents .addParts02 .infoArea .infoBox ul {
        max-width: 100%;
        margin: 0 auto 0rem;
        padding: 0 1rem;
    }

    #contents .addParts02 .infoArea .infoBox ul li {
        font-size: 1.5rem;
    }

    #contents .addParts02 .infoArea .infoBox .note {
        font-size: 1.3rem;
    }

    .sttl--recommended .sttl__small {
        margin: 0 auto 0.5rem;
    }

    /*block*/
    .addParts02 .slick-slide:focus {
        outline: none;
    }

    .addParts02 .sliderArea .slider .slick-prev, .addParts02 .sliderArea .slider .slick-next {
        width: 24px;
        height: 24px;
        top: 135px;
    }

    .addParts02 .sliderArea .slider .slick-prev {
        left: 0px;
    }

    .addParts02 .sliderArea .slider .slick-next {
        right: 0;
    }

    .addParts02 .sliderArea .slider .slidePic {
        height: 260px;
        background-color: #fff;
    }

    .addParts02 .sliderArea {
        margin: 2rem auto 0;
    }

    .addParts02 .sliderArea .mod_slide {
        margin-top: 2rem;
    }

    .addParts02 .priceIcoArea .priceArea::before {
        width: 55px;
        height: 55px;
        top: -3px;
        left: -8px;
    }

    .addParts02 .priceAreaInner {
        padding: 1.5rem 12.5%;
        margin: 0 auto 1.5rem;
        width: 100%;
        max-width: 100%;
    }

    #contents .addParts02 .priceIcoArea .priceArea .priceTit {
        max-width: inherit;
        margin: 0 auto 1rem;
    }

    .addParts02 .priceIcoArea .priceArea .price {
        font-size: 2.4rem;
        padding: 0 0 0 2.5rem;
        background-size: 18px auto;
        margin: 0 -1rem;
    }

    .addParts02 .priceIcoArea .priceArea .price span {
        font-size: 1.6rem;
    }

    .addParts02 .priceIcoArea .priceArea .price .price__small {
        font-size: 1.4rem;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul {
        width: 100%;
        display: block;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul li {
        padding: 0 0 0 2.5rem;
        width: 100%;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul li:nth-of-type(2), #contents .addParts02 .priceIcoArea .priceArea ul li + li {
        margin-top: 0.5rem;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul li::before {
        left: 10px;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul .priceIcoArea__list__big {
        font-size: 2rem;
    }

    #contents .addParts02 .priceIcoArea .priceArea ul .priceIcoArea__list__middle {
        font-size: 1.6rem;
    }

    .addParts02 .priceIcoArea .icoArea {
        width: 640px;
        float: right;
    }

    .addParts02 .priceIcoArea .icoArea li {
        width: 192px;
        margin: 0 0 0 32px;
        float: left;
    }

    .addParts02 .priceIcoArea .icoArea li:first-child {
        margin: 0 0 0 0;
    }

    .addParts02 .priceIcoArea .icoArea li:nth-child(3n+1) {
        margin: 0 0 0 0;
    }

    .addParts02 .priceIcoArea .icoArea li:nth-child(n+4) {
        margin-top: 40px;
    }

    .addParts02 .priceIcoArea .icoArea li .icoSet {
        text-align: center;
        margin: 0 0 25px;
    }

    .addParts02 .priceIcoArea .icoArea li .icoSet .ico {
        width: 80px;
        margin: 0 auto;
    }

    #contents .addParts02 .priceIcoArea .icoArea li .icoSet .icoTxt {
        display: inline-block;
        font-size: 1.5rem;
        font-weight: 700;
        line-height: 1.4;
        text-align: center;
        padding: 20px 0 10px;
        position: relative;
        letter-spacing: normal;
    }

    .addParts02 .block__item {
        margin: 4.5rem auto 0;
        width: 92%;
    }

    .addParts02 .block__item--feature {
        margin-top: 4.5rem;
    }

    .addParts02 .block__item--viral {
        margin-bottom: 4rem;
    }

    #index .addParts02 .block__item__title {
        font-size: 1.8rem;
        max-width: 100%;
    }

    #index .frame--feature .frame-head {
        font-size: 1.8rem;
        max-width: 100%;
    }

    #index .addParts02 .frame-wrap--feature, #index .addParts02 .frame-wrap--viral {
        display: block;
        margin: 3rem auto 0;
        width: 100%;
        max-width: 100%;
    }

    #index .frame-wrap--viral {
        margin-top: 2rem;
    }

    .frame--feature {
        width: 100%;
        background-size: 70px auto;
        background-position: right 1rem bottom;
        padding: 3rem 8% 2.5rem;
    }

    .frame--feature + .frame--feature {
        margin-top: 3.5rem;
    }

    .frame-catch--feature {
        top: -13px;
        font-size: 1.5rem;
        line-height: 26px;
        background-size: 12px auto;
    }

    .frame-head--feature {
        font-size: 1.7rem;
        padding-bottom: 1.5rem;
        margin: 0 auto 2rem;
    }

    #index .frame-body--feature p {
        font-size: 1.4rem;
    }

    .frame--viral {
        width: 100%;
    }

    .frame--viral:nth-of-type(2) {
        border: none;
        padding: 0;
        margin: 0 auto;
    }

    .frame--viral + .frame--viral {
        border-top: 1px solid #ddd;
        padding-top: 2rem;
        margin-top: 2.5rem;
    }

    .frame-head--viral {
        display: flex;
        flex-wrap: nowrap;
        justify-content: space-between;
        align-items: center;
        margin: 0 auto 1.5rem;
    }

    .frame__img-wrap--viral {
        width: 50px;
        margin-right: 1.2rem;
    }

    #index .frame__title--viral {
        font-size: 1.7rem;
    }

    .frame-body--viral {
        margin: 0 3%;
    }

    #index .frame-body--viral p {
        font-size: 1.4rem;
        margin: 0 auto 1.5rem;
    }

    #index .frame-body--viral p + p {
        margin-top: 1.5rem;
    }

    .addParts02 .infoArea .infoBox {
        margin: 1.5rem auto 0;
    }

    .addParts02 .infoArea .infoBox:last-child {
        margin: 3.5rem auto 3rem;
    }

    .addParts02 .infoArea .infoBox .mapArea {
        width: 380px;
        float: left;
    }

    #contents .addParts02 .infoArea .infoBox table {
        width: 100%;
        margin: 0;
    }

    /*--------------------------------------
  　box-wrap
  ---------------------------------------*/
    #contents .box-wrap {
        width: 100%;
        max-width: 100%;
        margin: 6rem auto;
    }

    #contents .box-wrap .box {
        display: block;
        box-sizing: border-box;
        width: 100%;
        border-bottom: 1px dashed #bbb;
        padding: 4rem 0 3rem;
        margin: 0 0 0;
        float: none;
        position: relative;
    }

    #contents .box-wrap .box:nth-child(even) {
        float: none;
    }

    #contents .box-wrap .box:nth-child(even)::before {
        content: none;
    }

    #contents .box-wrap .box:nth-child(n+3) {
        margin-top: 0;
    }

    #contents .box-wrap .box:last-child {
        margin: 0;
    }

    #contents .box-wrap .box .permalink {
        display: none;
    }

    #contents .box-wrap .box .thumb {
        position: relative;
    }

    /*box-head*/
    #index .box-wrap .box-head, #category .box-wrap .box-head, #page .box-wrap .box-head {
        display: block;
    }

    #index .box-wrap .box-head a, #category .box-wrap .box-head a, #page .box-wrap .box-head a {
        display: block;
        font-size: 100%;
    }

    #index .box-wrap .box-head a:hover, #category .box-wrap .box-head a:hover, #page .box-wrap .box-head a:hover {
        color: #1a2329;
        text-decoration: none;
    }

    #index .box-wrap .box-head::after, #category .box-wrap .box-head::after, #page .box-wrap .box-head::after {
        content: none;
    }

    #contents .box-wrap .box p {
        margin: 0;
    }

    #contents .box-wrap .box .btn-internal {
        margin: 2rem auto;
    }

    /*type-a*/
    #contents .box-wrap .type-a .thumb {
        position: relative;
    }

    #contents .box-wrap .type-a .thumb::before {
        content: "";
        width: 55px;
        height: 54px;
        background: url("img/box-wrap_a_circle.png") no-repeat;
        background-size: 100% auto;
        position: absolute;
        top: -15px;
        left: 10px;
    }

    #contents .box-wrap .type-a .box-head {
        font-size: 1.7rem;
        line-height: 1.4;
        font-weight: 500;
        color: #1a2329;
        padding: 2rem 1rem;
        margin: 0 0 0;
    }

    #contents .box-wrap .type-a .box-head a {
        display: block;
        width: 100%;
        font-size: 1.7rem;
        line-height: 1.4;
        color: #1a2329;
        background: url("img/arrow_black.png") right center no-repeat;
        background-size: 8px auto;
        padding: 0 2rem 0 0;
        position: relative;
    }

    #contents .box-wrap .type-a .box-head a:hover {
        opacity: 1;
    }

    #contents .box-wrap .type-a .box-body .smallPic {
        width: 75px;
        float: left;
    }

    #contents .box-wrap .type-a .box-body p {
        width: calc(100% - 95px);
        float: right;
    }

    /*type-b*/
    #contents .box-wrap .type-b {
        padding: 2rem 5%;
        border: none;
        background-size: 80px auto;
        background-position: right 1rem bottom 1rem;
        margin: 0 auto 2.5rem;
    }

    #contents .box-wrap .type-b .box-head-area {
        padding: 0;
        margin: 0 auto 1.5rem;
    }

    #contents .box-wrap .type-b .thumb {
        width: 50px;
    }

    #contents .box-wrap .type-b .box-head {
        font-size: 1.7rem;
        line-height: 1.4;
        padding: 0 0 0 1.2rem;
    }

    #contents .box-wrap .type-b .box-head a {
        background-size: 6px auto;
        padding: 0 2rem 0 0;
    }

    #contents .box-wrap .type-b .box-head a:hover {
        opacity: 1;
    }

    #contents .box-wrap .type-b p {
        font-size: 1.4rem;
    }

    #contents .box-wrap .type-b p.answer {
        font-size: 1.6rem;
    }

    /*--------------------------------------
  　frame-wrap
  ---------------------------------------*/
    #contents .frame-wrap {
        width: 100%;
        max-width: 100%;
        margin: 3rem auto;
    }

    #contents .frame-wrap .inner {
        margin: 0 auto;
    }

    #contents .frame {
        display: block;
        box-sizing: border-box;
        width: 100%;
        margin: 0 0 2rem;
        background-color: #fff;
        float: none;
    }

    #contents .frame-wrap .frame:first-child {
        margin: 0 0 2rem;
    }

    #contents .frame-wrap .frame:nth-child(3n+1) {
        margin: 0 0 2rem;
    }

    #contents .frame-wrap .frame:nth-child(n+4) {
        margin-top: 0;
    }

    #contents .frame-wrap .frame:last-child {
        margin: 0 0 0;
    }

    #contents .addParts--point .frame-wrap .type-c .textArea {
        padding: 3rem 0 0 0;
        display: inline-block;
    }

    #contents .frame-wrap .frame a {
        display: block;
        text-decoration: none;
    }

    /*frame-head*/
    #index .frame .frame-head, #category .frame .frame-head, #page .frame .frame-head {
        display: block;
        font-size: 1.7rem;
        font-weight: 700;
        line-height: 1.4;
    }

    #index .frame .frame-head a, #category .frame .frame-head a, #page .frame .frame-head a {
        width: auto;
        font-size: 100%;
        text-decoration: none;
    }

    #index .frame .frame-head a:hover, #category .frame .frame-head a:hover, #page .frame .frame-head a:hover {
        opacity: 1;
    }

    #contents .frame .frame-head p {
        margin: 0;
    }

    #contents .frame .frame-body .frame-catch {
        font-size: 1.6rem;
        font-weight: 700;
        line-height: 1.5;
        color: #1a2329;
        margin: 0 0 1.5rem;
    }

    #contents .frame .frame-body p {
        margin: 0;
    }

    #contents .frame p.caption {
        margin: 1rem 1rem 0;
    }

    /*type-a*/
    #contents .frame-wrap .type-a {
        padding: 2.5rem 6%;
    }

    #contents .frame-wrap .type-a + .type-a {
        margin-top: 3rem;
    }

    #contents .frame-wrap .type-a .frame-catch {
        font-size: 1.4rem;
        line-height: 1.5;
        text-align: center;
        color: #8c8200;
        border-top: 5px solid #e6dc14;
        padding: 1.5rem 2.5rem;
        position: relative;
    }

    #contents .frame-wrap .type-a .frame-catch::before {
        content: "";
        background: linear-gradient(to right, #bbbbbb, #bbbbbb 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%) 0% 0%;
        background-size: 6px 1px;
        width: 100%;
        height: 1px;
        position: absolute;
        left: 0;
        bottom: 0;
    }

    #contents .frame-wrap .type-a .frame-catch::after {
        content: "";
        width: 19px;
        height: 11px;
        background: url("img/frame-wrap_baloon.png") no-repeat;
        background-size: 100% auto;
        position: absolute;
        left: calc(50% - 10px);
        bottom: -10px;
    }

    #contents .frame-wrap .type-a .frame-head {
        font-size: 1.7rem;
        padding: 0 0 2rem;
        margin: 0 auto 1.8rem;
    }

    #contents .frame-wrap .type-a .frame-head a {
        padding: 0 2rem 0 0;
        background-size: 6px auto;
    }

    #contents .frame-wrap .type-a .frame-head a:hover {
        opacity: 1;
    }

    #contents .frame-wrap .type-a .frame-body p {
        font-size: 1.4rem;
    }

    #contents .frame-wrap .type-a .thumb {
        width: 80%;
        margin: 0 auto;
    }

    #contents .frame-wrap .type-a .caption {
        text-align: center;
        padding: 0 20px;
    }

    #contents .frame-wrap .type-a ul.icoArea {
        width: 100%;
        text-align: center;
        padding: 0 1.5rem;
        margin: 2rem auto;
    }

    #contents .frame-wrap .type-a ul.icoArea li {
        width: calc(100% / 3);
        padding: 0 0.6rem;
        margin: 0 0 0 0;
        float: left;
    }

    #contents .frame-wrap .type-a ul.icoArea li:first-child {
        margin: 0 0 0 0;
    }

    #contents .frame-wrap .type-a ul.icoArea li:nth-child(3n+1) {
        margin: 0 0 0 0;
    }

    #contents .frame-wrap .type-a ul.icoArea li:nth-child(n+4) {
        margin-top: 1.6rem;
    }

    #contents .frame-wrap .type-a ul.icoArea .ico {
        width: 57px;
        margin: 0 auto;
    }

    #contents .frame-wrap .type-a ul.icoArea .icoTxt {
        display: inline-block;
        font-size: 1.2rem;
        font-weight: 700;
        line-height: 1.4;
        text-align: center;
        padding: 10px 0 8px;
        position: relative;
    }

    /*type-b*/
    #contents .frame-wrap .type-b {
        padding: 0 0 2.5rem;
    }

    #contents .frame-wrap .type-b .frame-head {
        font-size: 1.7rem;
        padding: 2.5rem 5% 2rem 15%;
        margin: 0 auto 1.5rem;
        position: relative;
        max-width: 100%;
        background-size: 32px auto;
        background-position: left 5% center;
    }

    #contents .frame-wrap .type-b .frame-head::after {
        width: 90%;
        left: 0;
        bottom: 0;
        right: 0;
    }

    #contents .frame-wrap .type-b .frame-head a {
        margin: 0 auto;
        width: 100%;
        background-size: 6px auto;
        padding: 0 2rem 0 0;
    }

    #contents .frame-wrap .type-b .frame-head a:hover {
        opacity: 1;
    }

    #contents .frame-wrap .type-b .thumb {
        width: 80%;
        margin: 0 auto;
    }

    #contents .frame-wrap .type-b .frame-body {
        margin: 0 auto 0rem;
        padding: 0 5%;
    }

    #contents .frame-wrap .type-b .frame-body h4 {
        font-size: 1.5rem;
    }

    #contents .frame-wrap .type-b .frame-body p {
        font-size: 1.4rem;
    }

    #contents .frame-wrap .type-b table {
        width: 90%;
    }

    #contents .frame-wrap .type-b table th {
        display: table-cell;
        width: 40%;
        font-size: 1.3rem;
        border-right: 1px solid #333;
        padding: 1rem 1rem;
    }

    #contents .frame-wrap .type-b table td {
        display: table-cell;
        font-size: 1.3rem;
        padding: 1rem;
    }

    #contents .frame-wrap .type-b .frame-body table th {
        width: 40%;
    }

    #contents .frame-wrap .type-b .frame-body ul {
        max-width: 100%;
        margin: 2rem auto 2rem;
    }

    #contents .frame-wrap .type-b .frame-body ul li {
        font-size: 1.4rem;
    }

    #contents .frame-wrap .type-b .frame-body .btn-link {
        margin: 0 auto;
    }

    /*type-c*/
    #contents .frame-wrap .type-c {
        padding: 2rem 5% 3rem;
    }

    #contents .frame-wrap .type-c .eng {
        font-size: 2.6rem;
        font-weight: 700;
        line-height: 1;
        letter-spacing: 0.06em;
        text-align: center;
        color: #fff;
        text-shadow: 1px 1px 0 #333, -1px -1px 0 #333, -1px 1px 0 #333, 1px -1px 0 #333, 0px 1px 0 #333, -1px 0 #333, -1px 0 0 #333, 1px 0 0 #333;
        margin: 3rem 0 0;
        position: relative;
        top: -1rem;
    }

    #contents .frame-wrap .type-c .frame-head {
        font-size: 1.8rem;
        padding: 4rem 0 0;
        margin: 0 0 1.5rem;
    }

    #contents .frame-wrap .type-c .frame-head a {
        display: block;
        width: 100%;
        background: url("img/arrow_black.png") right center no-repeat;
        background-size: 8px auto;
        padding: 0 2rem 0 0;
        position: relative;
    }

    #contents .frame-wrap .type-c .frame-head a:hover {
        opacity: 1;
    }

    #contents .frame-wrap .type-c .thumb {
        width: 60%;
        margin: 0 auto 2rem;
    }

    #contents .frame-wrap .type-c .thumb img {
        border-radius: 100px;
    }

    /*btn-web*/
    #contents .frame .frame-body .btn-web {
        width: 85%;
        margin: 25px auto 0;
    }

    /* addParts--point */
    .addParts--point {
        margin: 0 auto;
        padding: 4.5rem 4%;
        background-size: cover;
        background-position: center;
    }

    #index h2 {
        background: none;
    }

    #index h2::before, #index h2::after {
        content: none;
    }

    #index .addParts__title--point {
        font-size: 2.2rem;
        margin: 0 auto 2.5rem;
    }

    #index .frame-wrap--point {
        margin: 0 auto;
        display: block;
        max-width: 100%;
        width: 100%;
    }

    #index .frame-wrap--point .frame:first-of-type .frame-head, #index .frame-wrap--point .frame:nth-of-type(2) .frame-head, #index .frame-wrap--point .frame:nth-of-type(3) .frame-head {
        background-size: auto 2.5rem;
    }

    #index .frame-wrap--point .frame-body p {
        font-size: 1.4rem;
    }

    #index .frame-wrap--point .frame-body p span {
        font-size: 1.6rem;
    }

    /* addParts--check */
    .addParts--check {
        margin: 5rem auto 5rem;
        width: 92%;
    }

    .addTopArea--check {
        margin: 0 auto 3rem;
        min-height: auto;
    }

    .addTopArea--check::before, .addTopArea--check::after {
        content: none;
    }

    .addTopArea__img-wrap--check {
        float: none;
        margin: 0 auto 3rem;
        text-align: center;
        width: 100%;
    }

    #index .addParts__title--check {
        padding: 4rem 5% 0 0;
        width: 100%;
        float: none;
        margin: 0 auto 1.5rem;
        background-size: contain;
        font-size: 2.2rem;
    }

    #index .addParts__title--check a {
        padding-right: 3rem;
        background-size: 6px auto;
    }

    #index .frame-wrap--check {
        width: 100%;
        max-width: 100%;
        padding: 1.3rem 0 0;
        display: block;
        margin: 0 auto;
    }

    #index .addParts--pr {
        width: 100%;
        padding: 5rem 0 2rem;
    }

    #index .addParts--pr .addInner {
        width: 92%;
    }

    #index .addParts__title--pr {
        padding: 8vw 5% 0;
        width: 100%;
        float: none;
        margin: 0 auto 1.5rem;
        background-size: contain;
        font-size: 2.2rem;
    }

    #contents .addParts--check.addParts--pr .btn-internal a {
        background-position: right 1rem center;
        background-size: 6px auto;
    }

    /* addParts--knowledge */
    .addParts--knowledge {
        padding: 5rem 4% 4rem;
        background-size: 100px auto;
    }

    #index .addParts__title--knowledge {
        margin: 0 -3% 1.5rem;
        padding: 4.5rem 0 0;
        background-size: 160px auto;
        font-size: 2.2rem;
        max-width: 106%;
        font-feature-settings: "palt";
    }

    #index .addParts__title--knowledge a {
        display: inline;
        padding-right: 1.5rem;
        background-size: 6px auto;
    }

    #index .box-wrap--knowledge {
        margin: 3rem auto 0;
    }

    /* addParts--company */
    .addParts--company {
        margin: 0 auto;
        padding: 4rem 4%;
    }

    #index .addParts--company .sttl {
        padding: 2.8rem 0 0;
        background-size: 115px auto;
        font-size: 2rem;
        line-height: 1.5;
        max-width: 100%;
    }

    .addParts__title--company .sttl__small {
        margin: 0 auto 0.5rem;
        font-size: 1.6rem;
    }

    .addParts__title--company .sttl__small::before, .addParts__title--company .sttl__small::after {
        min-width: 10%;
    }

    .addParts__title--company .sttl__small::before {
        margin-right: 1rem;
    }

    .addParts__title--company .sttl__small::after {
        margin-left: 1rem;
    }

    #index .addParts--company .sttl a::after {
        width: 6px;
        height: 9px;
        margin: 1.1rem 0 0 1rem;
    }

    .addParts__box--company {
        margin: 3rem auto 0;
    }

    .addParts__box--company + .addParts__box--company {
        margin-top: 5rem;
    }

    #index .frame-wrap--company, #index .frame-wrap__accordion--company {
        display: block;
        margin: 2.5rem auto 0;
        width: 100%;
        max-width: 100%;
    }

    #index .frame-wrap__accordion--company {
        margin-top: 0;
    }

    #index .btn-accordion--company {
        width: 85%;
        background-size: 9px auto;
        font-size: 1.4rem;
        padding: 1.8rem 2.5rem;
        line-height: 1.4;
        margin: 2.5rem auto 0;
        background-position: right 1rem center;
    }

    #index .btn-accordion--company.is-open {
        background-image: url(img/arrow_minus.png);
        background-repeat: no-repeat;
    }

    #index .btn-accordion--company:hover {
        opacity: 1;
    }

    #index .btn-accordion--company + .addParts__accordion--company {
        margin: 3rem auto 0;
    }

    .frame__item--company {
        margin: 0 5% 2.5rem;
        padding: 1.5rem 5% 1.7rem;
    }

    .frame__item__head--company {
        margin: 0 0 1rem -0.3rem;
    }

    .frame__item__img-wrap--company {
        width: 50px;
        margin: 0 1rem 0 0;
    }

    #index .frame__item__title--company {
        font-size: 1.5rem;
    }

    #index .frame__item--company p:not(.frame__item__title--company) {
        font-size: 1.4rem;
    }

    #index .frame__item--company p:not(.frame__item__title--company) + p:not(.frame__item__title--company) {
        margin-top: 1rem;
    }

    .addParts--recommended .btn-internal a {
        background: url(img/arrow_white_down.png) right 8px center no-repeat #e1724f;
        background-size: 10px auto;
    }
}
