.mv{ height: 47.5rem; background: url(../images/index/webp/mv-bg01.webp); padding-top: 6rem; }
.mv .main-slide{ margin: 0 auto; line-height: 0; width: 1020px; }

.mv .main-slide.slick-initialized .slick-box { transform: scale(1, 0); transform-origin: center top; transition: 1s transform cubic-bezier(0.25, 1, 0.5, 1); }
.mv .main-slide.slick-initialized .slick-box:nth-child(even) { transform-origin: center bottom; }
.mv .main-slide.slick-initialized .slick-box:nth-child(3n) { transform: scale(0, 1); transform-origin: left center; } 
.mv .main-slide.slick-initialized .slick-box:nth-child(4n) { transform: scale(0, 1); transform-origin: right center; }
.mv .main-slide.slick-initialized .slick-animate .slick-box { transform: scale(1, 1); }
.mv .main-slide .slick-image { width: 100%; height: auto; opacity: 0; }
.mv .main-slide .slick-slide { position: relative; opacity: 1 !important; }
.mv .main-slide .slick-boxWrapper { position: absolute; left: 0; top: 0; width: 100%; height: 100%; display: flex; flex-wrap: wrap; }
.mv .main-slide.slick-initialized .slick-box { transform: scale(1, 0); transform-origin: center top; transition: 1s transform cubic-bezier(0.25, 1, 0.5, 1); }
.mv .main-slide.slick-initialized .slick-box:nth-child(even) { transform-origin: center bottom; }
.mv .main-slide.slick-initialized .slick-box:nth-child(3n) { transform: scale(0, 1); transform-origin: left center; }
.mv .main-slide.slick-initialized .slick-box:nth-child(4n) { transform: scale(0, 1); transform-origin: right center; }
.mv .main-slide.slick-initialized .slick-animate .slick-box { transform: scale(1, 1); }
.mv .main-slide .slick-arrow{ width: 4rem; height: 4rem; position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; }
.mv .main-slide .slick-arrow.slick-next{ background: url(../images/index/btn-next01.png) no-repeat center/contain; right: 1rem; }
.mv .main-slide .slick-arrow.slick-prev{ background: url(../images/index/btn-prev01.png) no-repeat center/contain; left: 1rem; }

.sec-intro .bg{ background: url(../images/index/webp/intro-bg01.webp) repeat center/50rem; }
.sec-intro .bg .wrap{ position:relative; z-index: 0; padding-top: 4.4rem; padding-bottom: 4rem; }
.sec-intro .bg .wrap:after{ content: ''; width: 11.4rem; height: 11.4rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; bottom: -3.8rem; left: -10.2rem; }
.sec-intro .bg .wrap .campaign_img{ position: absolute; bottom: 50px; right: -200px;}
.sec-intro .bg .wrap .campaign_img img{ width: 200px; height: auto;}
.sec-intro .item01{ width: 81.5rem; position: absolute; bottom: 0; right: -27.5rem; z-index: -1; line-height: 0; height: 100%; overflow: hidden; }
.sec-intro .item01:before{ content: ''; width: 7rem; height: 7rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; top: 34.5rem; right: 13rem; z-index: 2; }
.sec-intro .item01 img{ max-width: none; width: 100%; position: absolute; bottom: 0; }
.sec-intro .bg h2{ font-size: 4.8rem; color: #0058a1; line-height: 1.6; margin-bottom: 1rem; position: relative; }
.sec-intro .bg h2:before{ content: ''; width: 4.8rem; height: 4.8rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; top: -1rem; left: -7.8rem; }
.sec-intro .bg h2 small{ font-size: 3.8rem; }
.sec-intro .bg h2 strong{ background:linear-gradient(transparent 60%, rgba(246, 232, 144, 1) 80%); }
.sec-intro .bg h2 + p{ width: 34.3rem; height: 8.3rem; font-size: 1.8rem; font-weight: 700; color: #fff; line-height: 1.6; display: flex; justify-content: center; align-items: center; background: #0058a1; position: relative; margin-bottom: 4rem; }
.sec-intro .bg h2 + p:after{ content: ''; width: 0; height: 0; border-style: solid; border-width: 41.5px 0 41.5px 60px; border-color: transparent transparent transparent #0058a1; position: absolute; top: 0; right: -60px; }
.sec-intro .bg h2 + p strong{ font-size: 2.2rem; color: #f6e890; line-height: 1; }
.sec-intro .bg .main01{ margin-left: -16.5rem; }
.sec-intro .bg + .wrap{ margin-top: 11rem; }
.sec-intro .intro-list{ display: flex; justify-content: space-between; flex-wrap: wrap; }
.sec-intro .intro-list li{ position: relative; width: 42.5rem; position: relative; z-index: 0; }
.sec-intro .intro-list li:nth-of-type(n+3){ margin-top: 5rem; }
.sec-intro .intro-list li:before{ content: ''; width: calc(100% + 2px); height: calc(100% + 2px); background: #0058a1; clip-path: polygon(1.4rem 0, calc(100% - 1.4rem) 0, 100% 1.4rem, 100% calc(100% - 1.4rem), calc(100% - 1.4rem) 100%, 1.4rem 100%, 0 calc(100% - 1.4rem), 0 1.4rem); position: absolute; z-index: -1; left: -1px; top: -1px; }
.sec-intro .intro-list li span.text{ position: absolute; top:83px; left:120px; z-index: 1; letter-spacing: 0; color: #FFF; font-size: 13px;}
.sec-intro .intro-list li:after{ content: ''; width: 6.3rem; height: 6.5rem; background: no-repeat center/contain; position: absolute; top: -4rem; left: 50%; transform: translateX(-50%); }
.sec-intro .intro-list li:nth-of-type(1):after{ background-image: url(../images/index/intro-icon01.png); }
.sec-intro .intro-list li:nth-of-type(2):after{ background-image: url(../images/index/intro-icon02.png); }
.sec-intro .intro-list li:nth-of-type(3):after{ background-image: url(../images/index/intro-icon03.png); }
.sec-intro .intro-list li:nth-of-type(4):after{ background-image: url(../images/index/intro-icon04.png); }
.sec-intro .intro-list li h3{ font-size: 3.6rem; color: #fff; text-align: center; background: #0058a1; clip-path: polygon(1.4rem 0, calc(100% - 1.4rem) 0, 100% 1.4rem, 100% 100%, calc(100% - 1.4rem) 100%, 1.4rem 100%, 0 calc(100% - 1.4rem), 0 1.4rem); padding: 3rem 0 1.6rem; }
.sec-intro .intro-list li h3 span{ font-size:20px; line-height: 1; }
.sec-intro .intro-list li p{ background: #f6e890; font-size: 1.9rem; font-weight: 700; color: #0058a1; text-align: center; clip-path: polygon(0 0, 100% 0, 100% 0, 100% calc(100% - 1.4rem), calc(100% - 1.4rem) 100%, 1.4rem 100%, 0 calc(100% - 1.4rem), 0 0); padding: 1.3rem 0; }

h2.bottom-border{ font-size: 4.2rem; font-family: "游明朝", YuMincho, yu-mincho-pr6n, serif; font-weight: 500; color: #0058a1; text-align: center; background: url(../images/index/item-ttl01.png) no-repeat bottom center/13.2rem; padding-bottom: 4.4rem; }
h2.bottom-border.general span{ display: block; font-size: 2.6rem; line-height: 1.2; }

.bg-white{ background: #fff; border: solid 3px #0058a1; position: relative; z-index: 0; }
.bg-white:before{ content: ''; width: calc(100% - 2rem); height: calc(100% - 2rem); box-sizing: border-box; border: solid 1px #0058a1; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }

.sec-imprint{ margin-top: 10rem; background: url(../images/index/bg-border01.png) #e7eef2 center/3.6rem; padding: 10rem 0; }
.sec-imprint h2{ margin-bottom: 3rem; }
.sec-imprint h2 span{ display: table; font-size: 2.6rem; background: #0058a1; color: #fff; margin: 0 auto .8rem; padding: 0 1em; position: relative; }
.sec-imprint h2 span:after{ content: ''; width: 2.2rem; height: 2.2rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; top: -2rem; right: -2.2rem; }
.sec-imprint h2 strong{ background:linear-gradient(transparent 70%, #f6e890 70%); }
.sec-imprint .comp-row{ line-height: 0; width: 80rem; margin: 0 auto 9.5rem; }
.sec-imprint .bg-white{ padding: 0 7.5rem 7.5rem; }
.sec-imprint .bg-white:after{ content: ''; width: 18.2rem; height: 18.2rem; background: url(../images/index/imprint-item01.png) no-repeat center/contain; position: absolute; bottom: 2.2rem; right: 2rem; z-index: -2; }
.sec-imprint .bg-white h3{ font-size: 3.6rem; color: #0058a1; margin-top: -2.4rem; text-align: center; background: url(../images/index/item-ttl01.png) no-repeat bottom center/13.2rem; padding-bottom: 4.4rem; margin-bottom: 3.5rem; }
.sec-imprint .bg-white h3 span{ display: block; font-size: 2.6rem; color: #fff; text-align: center; background: url(../images/index/item-ttl02.png) no-repeat top center/auto 7rem; height: 7rem; padding-top: .6rem; margin-bottom: .8rem; }
.sec-imprint .bg-white h3 strong{ font-size: 4.8rem; line-height: 1; }
.sec-imprint .merit-row{ align-items: flex-start; }
.sec-imprint .merit-row ol{ width: calc(100% - 31rem); counter-reset: merit; }
.sec-imprint .merit-row ol li{ font-size: 1.8rem; font-weight: 700; color: #0058a1; padding-left: 6.6rem; position: relative; height: 5.1rem; display: flex; align-items: center; }
.sec-imprint .merit-row ol li:before{ content: ''; width: 3.6rem; height: 3.6rem; background: #0058a1; position: absolute; left: .8rem; top: 50%; transform: translateY(-50%) rotate(45deg); }
.sec-imprint .merit-row ol li:after{ counter-increment: merit; content: counter(merit); width: 5.1rem; height: 5.1rem; display: flex; justify-content: center; align-items: center; font-family: "游明朝", YuMincho, yu-mincho-pr6n, serif; font-weight: 500; color: #fff; line-height: 1; letter-spacing: 0; font-size: 2rem; position: absolute; left: 0; top: 0; }
.sec-imprint .merit-row ol li + li{ margin-top: 2rem; }
.sec-imprint .merit-row ol li strong{ font-size: 2.4rem; background:linear-gradient(transparent 60%, #f6e890 60%); }

.sec-difference{ background: url(../images/index/webp/difference-bg01.webp) no-repeat center/cover; padding: 10rem 0; }
.sec-difference h2{ margin-bottom: 2.8rem; }
.sec-difference h2 span{ display: inline-block; background: #6091c2; color: #fff; line-height: 1.6; padding: 0 .5em; margin-right: .3em; }
.sec-difference h2 span:nth-of-type(2){ background: #0058a1; margin: 0 .3em; }
.sec-difference h2 small{ font-size: 3rem; }
.sec-difference h2 + p{ font-size: 2.4rem; font-weight: 700; color: #0058a1; line-height: 1.6; text-align: center; margin-bottom: 3.6rem; }
.sec-difference .difference-row .left{ width: 55rem; background: #fff; position: relative; z-index: 0; padding: 4.2rem 5rem 5rem; display: flex; justify-content: space-between; }
.sec-difference .difference-row .left:before{ content: ''; width: calc(100% - 2rem); height: calc(100% - 2rem); box-sizing: border-box; border: solid 1px #0058a1; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }
.sec-difference .difference-row .left dl{ width: 16rem; }
.sec-difference .difference-row .left dl dt{ font-size: 2rem; font-weight: 700; color: #0058a1; text-align: center; margin-bottom: 1rem; }
.sec-difference .difference-row .left dl dd{ font-size: 1.4rem; letter-spacing: .04em; }
.sec-difference .difference-row .left dl dd img{ display: block; margin-top: 1.8rem; }
.sec-difference .difference-row .left dl:nth-of-type(2) dd img{ margin-left: auto; }
.sec-difference .difference-row .left .item01{ position: absolute; left: 50%; top: 5.8rem; transform: translateX(-50%); z-index: -1; }
.sec-difference .difference-row .right{ width: calc(100% - 55rem); background: #0058a1; color: #fff; }
.sec-difference .difference-row .right dl{ padding: 2rem 3.5rem; }
.sec-difference .difference-row .right dl:nth-of-type(1){ background: #6091c2; }
.sec-difference .difference-row .right dl dt{ font-size: 2.6rem; padding-left: 3.2rem; background: url(../images/index/difference-item01.png) no-repeat left center/2.4rem; margin-bottom: .8rem; }
.sec-difference .difference-row .right dl dd{ font-size: 1.6rem; }
.sec-difference .difference-row .right dl dd strong{ font-weight: 700; color: #f6e890; }

.sec-feature{ margin-bottom: 10rem; }
.sec-feature .wrap{ padding-top: 9rem; counter-reset: feature; }
.sec-feature h2{ font-size: 3.6rem; margin-bottom: 5.4rem; }
.sec-feature h2 span{ display: block; font-size: 2.6rem; text-align: center; }
.sec-feature h2 strong{ font-size: 4.8rem; line-height: 1; }
.sec-feature .feature-content{ padding: 16rem 0 5rem; position: relative; z-index: 0; }
.sec-feature .feature-content:before{ content: ''; width: calc(50vw + 51.5rem); height: calc(100% - 24rem); background: #0058a1; position: absolute; bottom: 0; left: calc(-50vw + 45rem); z-index: -1; }
.sec-feature .feature-content:nth-of-type(2):before{ left: auto; right: calc(-50vw + 45rem); }
.sec-feature .feature-content:nth-of-type(n+2){ margin-top: 10rem; }
.sec-feature .feature-content .image{ position: absolute; top: 0; right: -15rem; z-index: -1; }
.sec-feature .feature-content:nth-of-type(2) .image{ right: auto; left: -15rem; }
.sec-feature .feature-content .txt{ width: 58rem; padding: 8.2rem 7rem 6rem 5rem; position: relative; z-index: 2; }
.sec-feature .feature-content .txt.txt2{ width:70rem; padding: 8.2rem 3rem 6rem 1rem;}
.sec-feature .feature-content .txt:before{ content: ''; width: calc(100% + 2rem); height: 100%; background: rgba(255, 255, 255, .95); position: absolute; top: 0; right: 0; z-index: -1; }
.sec-feature .feature-content .txt:after,.sec-feature .feature-content .txt .number{ counter-increment: feature; content: counter(feature, decimal-leading-zero); font-family: "游明朝", YuMincho, yu-mincho-pr6n, serif; font-weight: 500; font-size: 13.7rem; line-height: 1; color: #b1cae0; position: absolute; top: -8rem; left:  4rem;}
.sec-feature .feature-content:nth-of-type(2) .txt{ margin-left: auto; }
.sec-feature .feature-content:nth-of-type(2) .txt:after{ right: 7rem; }
.sec-feature .feature-content .txt h3{ font-size: 2.2rem; font-weight: 700; color: #0058a1; margin-bottom: 1.5rem; }
.sec-feature .feature-content .txt h3 strong{ background:linear-gradient(transparent 60%, #f6e890 60%); padding-bottom: .1em; }
.sec-feature .feature-content .txt p{ font-size: 1.6rem; letter-spacing: .035em; }
.sec-feature .feature-content .txt + p{ font-size: 2.8rem; color: #fff; text-align: center; margin-top: 4rem; position: relative; }
.sec-feature .feature-content .txt + p span{ display: inline-block; }
.sec-feature .feature-content .txt + p span[class*="border-"]{ position: absolute; height: 2px; background: url(../images/index/border01.png) repeat-x bottom left/contain; top: 50%; transform: translateY(-50%); }
.sec-feature .feature-content .txt + p span.border-left{ left: 0; }
.sec-feature .feature-content .txt + p span.border-right{ right: 0; }
.sec-feature .feature-content .txt ~ dl,.poririn_wrap dl{ color: #fff; width: 80rem; margin: 0 auto; padding: 1.7rem 4rem 2rem 13rem; position: relative; background: url(../images/index/feature-item01.png) no-repeat left 3.6rem center/5.8rem; }
.sec-feature .feature-content .txt + dl,.poririn_wrap .txt + dl{ margin-top: 5rem; }
.sec-feature .feature-content .txt + dl:before,.poririn_wrap .txt + dl:before{ content: ''; width: 100%; height: 2px; background: url(../images/index/border01.png) repeat-x top left/contain; position: absolute; top: 0; left: 0; }
.sec-feature .feature-content .txt ~ dl:after{ content: ''; width: 100%; height: 2px; background: url(../images/index/border01.png) repeat-x top left/contain; position: absolute; bottom: 0; left: 0; }
.sec-feature .feature-content .txt ~ dl:last-of-type{ margin-bottom: 5rem; }
.sec-feature .feature-content .txt ~ dl dt,.poririn_wrap dl dt{ font-size: 1.8rem; position: relative; display: table; padding-bottom: .6rem; background: url(../images/index/border01.png) repeat-x bottom left/auto 2px; margin-bottom: 1rem; }
.sec-feature .feature-content .txt ~ dl dd,.poririn_wrap dl dd{ font-size: 1.4rem; letter-spacing: .05em; }
.sec-feature .feature-content .txt ~ dl dd:before{ content: ''; width: 2px; height: 100%; background: url(../images/index/border02.png) repeat-y top left/contain; position: absolute; left: 0; top: 0; }
.sec-feature .feature-content .txt ~ dl dd:after{ content: ''; width: 2px; height: 100%; background: url(../images/index/border02.png) repeat-y top left/contain; position: absolute; right: 0; top: 0; }
.sec-feature .feature-content .point-list li{ list-style:disc; margin-left: 15px; margin-bottom: 20px; letter-spacing: 0;}
.sec-feature .feature-content .point-list li + li{ margin-top: 10px;}
.sec-feature .bg-gray{ padding: 9rem 5rem; position: relative; z-index: 0; }
.sec-feature .bg-gray:before{ content: ''; width: calc(50vw +  51.5rem); height: 100%; background: #f1f1f1; position: absolute; top: 0; right: calc(-50vw + 45rem); z-index: -2; }
.sec-feature .bg-gray:after{ content: ''; width: 23.4rem; height: 23.4rem; background: url(../images/index/feature-item02.png) no-repeat center/contain; position: absolute; bottom: 2.4rem; right: -13rem; z-index: -1; }
.sec-feature .bg-gray h4{ font-size: 2.4rem; font-weight: 700; line-height: 1.55; text-align: center; padding: 2rem 0; background-image: url(../images/index/border03.png), url(../images/index/border03.png); background-size: auto 2px, auto 2px; background-repeat: repeat-x, repeat-x; background-position: top left, left bottom; margin-bottom: 5rem; }
.sec-feature .bg-gray picture + h4{ margin-top: 100px;}
.sec-feature .bg-gray h4 span{ position: relative; }
.sec-feature .bg-gray h4 span:after{ content: ''; width: 4rem; height: 4rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; top: 50%; right: -6rem; transform: translateY(-50%); }
.sec-feature .bg-gray h4 strong{ font-size: 3.8rem; }
.sec-feature .bg-gray h4 strong small{ font-size: 3rem; }
.sec-feature .bg-gray * + h4{ margin-top: 5.5rem; }
.sec-feature .bg-gray .img-row{ margin-bottom: 4.5rem; padding: 0 5rem; }
.sec-feature .bg-gray .img-row .txt{ width: 32.5rem; }
.sec-feature .bg-gray .img-row .txt h5{ font-size: 1.8rem; margin-bottom: 1rem; margin-top: 0; }
.sec-feature .bg-gray .img-row .txt h5 + picture{ line-height: 0; margin-bottom: 2.8rem; display: block; }
.sec-feature .bg-gray .img-row .txt p{ font-size: 1.6rem; letter-spacing: .05em; }
.sec-feature .bg-gray .img-row > picture{ display: block; width: 32.5rem; position: relative; }
.sec-feature .bg-gray .img-row:nth-of-type(1) > picture:before{ content: ''; width: 37.8rem; height: 16rem; background: url(../images/index/webp/feature06.webp) no-repeat center/contain; position: absolute; right: -13rem; bottom: -3rem; }
.sec-feature .bg-gray .img-row:nth-of-type(2) > picture:before{ content: ''; width: 21.1rem; height: 18rem; background: url(../images/index/webp/feature07.webp) no-repeat center/contain; position: absolute; right: -4rem; bottom: -3rem; }
.sec-feature .bg-gray .boost-list{ display: flex; justify-content: space-between; padding: 0 5rem; }
.sec-feature .bg-gray .boost-list li{ width: 21rem; height: 13rem; background: #0058a1; color: #fff; display: flex; justify-content: center; align-items: center; font-size: 1.4rem; font-weight: 700; text-align: center; position: relative; z-index: 0; }
.sec-feature .bg-gray .boost-list li:before{ content: ''; width: calc(100% - 1rem); height: calc(100% - 1rem); box-sizing: border-box; border: solid 1px #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }
.sec-feature .bg-gray .boost-list li span{ display: block; }
.sec-feature .bg-gray .boost-list li strong{ font-size: 2rem; color: #f6e890; line-height: 1.5; display: inline-block; }
.sec-feature .bg-gray .boost-list li:nth-of-type(1){ font-size: 1.8rem; }
.sec-feature .bg-gray .boost-list li:nth-of-type(1) strong{ font-size: 5rem; line-height: 1.2; }
.sec-feature .bg-gray > h5{ font-size: 2.3rem; font-weight: 700; color: #0058a1; text-align: center; margin-bottom: 2rem; }
.sec-feature .bg-gray .point-list{ display: flex; justify-content: space-between; flex-wrap: wrap; padding: 0 5rem; }
.sec-feature .bg-gray .point-list li{ width: 32.5rem; height: 10rem; background: #0058a1; color: #fff; display: flex; align-items: center; padding-left: 7.6rem; position: relative; z-index: 0; font-size: 1.4rem; font-weight: 700; letter-spacing: .06em; }
.sec-feature .bg-gray .point-list li:nth-of-type(n+3){ margin-top: 2.5rem; }
.sec-feature .bg-gray .point-list li:before{ content: ''; width: calc(100% - 1rem); height: calc(100% - 1rem); box-sizing: border-box; border: solid 1px; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }
.sec-feature .bg-gray .point-list li .no{ position: absolute; left: 2.5rem; top: 50%; transform: translateY(-50%); font-size: 3.6rem; color: #b1cae0; text-align: center; line-height: 1.2; }
.sec-feature .bg-gray .point-list li .no small{ display: block; font-size: 1.2rem; }
.sec-feature .bg-gray .point-list li > span{ display: block; }
.sec-feature .bg-gray .point-list li strong{ display: block; font-size: 2rem; color: #f6e890; line-height: 1.5; }

.img-box01{ height: 30rem; background: url(../images/index/webp/img-box01.webp) no-repeat center/cover; }

.sec-case{ background: url(../images/index/webp/case-bg01.webp) repeat center/50rem; padding: 8rem 0 12.5rem; }
.sec-case h2{ margin-bottom: 4.6rem; }
.sec-case h2 + picture{ display: block; line-height: 0; margin-bottom: 3.5rem; }
.sec-case table{ width: 100%; line-height: 2; }
.sec-case table th{ white-space: nowrap; width: 1px; font-size: 1.6rem; font-weight: 700; color: #0058a1; padding: 0 1.5em; border-left: solid 5px; }
.sec-case table td{ font-size: 1.6rem; }

.sec-case h3,.sec-flow h4{ position: relative; font-size:28px; color:#0058A1; text-align: center; font-family: "游明朝", YuMincho, yu-mincho-pr6n, serif; font-weight: 500; background: #FFF; padding: 15px 0; line-height: 1; margin: 120px 0 30px;}
.sec-case h3:before,.sec-case h3:after,.sec-flow h4:before,.sec-flow h4:after{ position: absolute; top:4px; left: 0; content:""; width:100%; height: 1px; background:#0058A1; }
.sec-case h3:after,.sec-flow h4:after{ top:auto; bottom: 4px;}
.sec-case h4{ font-size: 20px; color: #FFF; background:#0058A1; text-align: center; padding: 5px; margin: 40px 0 30px;}
.check_list{ margin-bottom: 30px;}
.check_list li{ position: relative; padding-left:50px; font-size: 19px; color:#0058A1; font-weight: bold;}
.check_list li + li{ margin-top: 20px;}
.check_list li:before{ position: absolute; top: 0; left: 5px; content: ""; background: url("../images/index/icon_check.png") no-repeat center/contain; width:35px; height:33px; }

.sec-flow{ padding: 9rem 0 10rem; background: url(../images/index/flow-bg01.jpg) center/2.4rem; }
.sec-flow h2{ margin-bottom: 5rem; }
.sec-flow .flow-list{  }
.sec-flow .flow-list li{ background: #0058a1; position: relative; color: #fff; }
.sec-flow .flow-list li + li{ margin-top: 3rem; }
.sec-flow .flow-list li .img{ width: 50%; height: 100%; position: absolute; top: 0; right: 0; background: no-repeat center/cover; }
.sec-flow .flow-list li:nth-of-type(even) .img{ right: auto; left: 0; }
.sec-flow .flow-list li:nth-of-type(1) .img{ background-image: url(../images/index/webp/flow01.webp); }
.sec-flow .flow-list li:nth-of-type(2) .img{ background-image: url(../images/index/webp/flow02.webp); }
.sec-flow .flow-list li:nth-of-type(3) .img{ background-image: url(../images/index/webp/flow03.webp); }
.sec-flow .flow-list li:nth-of-type(4) .img{ background-image: url(../images/index/webp/flow04.webp); }
.sec-flow .flow-list li .txt{ width: 50%; padding: 3.6rem 3.6rem 3.2rem 3.6rem; }
.sec-flow .flow-list li:nth-of-type(even) .txt{ margin-left: auto; }
.sec-flow .flow-list li .txt h3{ font-size: 2rem; font-weight: 700; padding-left: 5.5rem; position: relative; margin-bottom: 1.4rem; }
.sec-flow .flow-list li .txt h3 span{ width: 4rem; height: 4rem; border-radius: 2rem; background: #fff; color: #0058a1; display: block; position: absolute; left: 0; top: 50%; transform: translateY(-50%); text-align: center; padding-top: .5rem; }
.sec-flow .flow-list li .txt h3 span small{ display: block; font-size: 1rem; line-height: 1; }
.sec-flow .flow-list li .txt h3 span strong{ display: block; font-size: 2rem; line-height: 1; }

.sec-flow h4{ margin-bottom: 15px;}
.sec-flow h4 + p{ font-size: 16px; text-align: center; color:#0058A1; margin-bottom: 20px; }
.sec-flow picture + p{ font-size: 14px;}
.sec-flow .schedule_list{ margin-bottom: 40px;}
.sec-flow .schedule_list li{ position: relative; font-size:20px; font-weight: bold; background:#0058a1; text-align: center; color: #FFF; padding: 10px 0;}
.sec-flow .schedule_list li + li{ margin-top: 25px;}
.sec-flow .schedule_list li:before{ position: absolute; bottom:-13px; left:46%; content: ""; width: 0;height: 0;border-left: 20px solid transparent;border-right: 20px solid transparent; border-top: 20px solid #0058a1;}
.sec-flow .schedule_list li:nth-child(n+5){ background:#DCF0F9; color:#0058a1;  }
.sec-flow .schedule_list li:nth-child(n+5):before{ border-top-color:#DCF0F9; }

.sec-price{ padding: 9rem 0 10rem; background: #f1f1f1; margin-bottom: 8rem; }
.sec-price h2{ margin-bottom: 5rem; }
.sec-price .bg-white{ padding: 4rem 7rem 6rem; }
.sec-price .bg-white + .bg-white{ margin-top: 14.5rem; }
.sec-price .method h3{ font-size: 3.6rem; text-align: center; color: #0058a1; margin-bottom: 1rem; }
.sec-price .method h3 + p{ font-size: 2rem; font-weight: 700; color: #0058a1; text-align: center; margin-bottom: .8rem; }
.sec-price .bg-white table{ width: 100%; }
.sec-price .bg-white table + table{ margin-top: 1.2rem; }
.sec-price .bg-white table th,.table_merit th{ width: 24rem; background: #0058a1; font-size: 1.8rem; font-weight: 700; color: #fff; vertical-align: middle; padding: .8rem 0 .8rem 2.5rem; border: solid 4px #fff; border-left: none; }
.sec-price .bg-white table th.mincho{ line-height: 1.6; font-weight: 500; }
.sec-price .bg-white table th strong{ font-size: 3.2rem; line-height: 1.4; margin-top: 1rem; display: block; }
.sec-price .bg-white table td,.table_merit td{ background: #f1f1f1; vertical-align: middle; font-size: 1.6rem; padding: .8rem 2.5rem; border: solid 4px #fff; border-right: none; }
.sec-price .bg-white:not(.method) table td{ text-align: right; font-size: 1.4rem; }
.sec-price .bg-white:not(.method) table td.mincho{ font-size: 4rem; color: #0058a1; line-height: 1.4; }
.sec-price .bg-white:not(.method) table td.mincho small{ font-size: 1.8rem; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; margin-left: .5rem; vertical-align: text-bottom; }
.sec-price .office{ padding-top: 9rem; padding-bottom: 7rem; }
.sec-price .office h3, .sec-price .home h3{ font-size: 3rem; color: #fff; text-align: center; width: 100%; height: 8rem; background: url(../images/index/price-ttl01.png) no-repeat top center/contain; position: absolute; top: -4rem; left: 50%; transform: translateX(-50%); padding-top: .5rem; }
/*.sec-price .office h3:before{ content: ''; width: 17.4rem; height: 15.8rem; background: url(../images/index/price-ttl02.png) no-repeat center/contain; position: absolute; top: -7rem; left: -2rem; }*/
.sec-price .office h4{ font-size: 4.8rem; display: table; margin: 0 auto; color: #0058a1; line-height: 1.5; text-align: center; background-image: url(../images/index/price-ttl03.png), url(../images/index/price-ttl04.png); background-repeat: no-repeat, no-repeat; background-size: 2.6rem, 2.6rem; background-position: bottom 1.6rem left, bottom 1.6rem right; padding: 0 4.5rem; margin-bottom: 1.5rem; }
.sec-price .office h4 small{ display: block; font-size: 2.5rem; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; font-weight: 700; }
.sec-price .office .campain-row{ color: #0058a1; margin-bottom: .8rem; }
.sec-price .office .campain-row dl{ height: 15rem; display: flex; justify-content: center; align-items: center; line-height: 1.3; }
.sec-price .office .campain-row dl:nth-of-type(1){ width: 29.4rem; background: #f1f1f1; position: relative; }
.sec-price .office .campain-row dl:nth-of-type(1):after{ content: ''; width: 4.6rem; height: 1.6rem; background: url(../images/index/price-arrow01.png) no-repeat center/contain; position: absolute; top: 50%; right: -2.5rem; transform: translateY(-50%); }
.sec-price .office .campain-row dl:nth-of-type(2){ width: calc(100% - 29.4rem); background: #f6e890; line-height: 1.2; }
.sec-price .office .campain-row dl:nth-of-type(1) dd{ font-size: 4.4rem; }
.sec-price .office .campain-row dl:nth-of-type(1) dd small{ font-size: 1.4rem; }
.sec-price .office .campain-row dl:nth-of-type(2) dt{ font-size: 2rem; }
.sec-price .office .campain-row dl:nth-of-type(2) dd{ font-size: 6.2rem; text-align: center; }
.sec-price .office .campain-row dl:nth-of-type(2) dd small{ font-size: 1.4rem; }
.sec-price .office .campain-row + small{ display: block; font-size: 1.3rem; margin-bottom: 4rem; }
.sec-price .office .image{ display: block; margin-top: 3rem; width: 100%; }
.sec-price .home{ padding-top: 12rem; padding-bottom: 9rem; }
.sec-price .home h3 span{ font-size: 2.2rem; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; font-weight: 700; color: #0058a1; position: absolute; top: -5rem; left: 50%; transform: translateX(-50%); white-space: nowrap; padding: 0 3.4rem; background: url(../images/index/icon-shine01.png) no-repeat right top/3rem; }
.sec-price .home .home-list{ display: flex; justify-content: space-between; flex-wrap: wrap; margin-bottom: 4rem; position: relative; }
/*.sec-price .home .home-list:before{ content: ''; width: 31rem; height: 31rem; background: url(../images/index/price-item01.png) no-repeat center/contain; position: absolute; bottom: 4rem; right: 0; }*/
.sec-price .home .home-list li{ width: 32.5rem; }
.sec-price .home .home-list li:nth-of-type(n+3){ margin-top: 1.4rem; }
.sec-price .home .home-list li img{ display: block; margin-bottom: 1.5rem; }
.sec-price .home .home-list li h4{ font-size: 2rem; font-weight: 700; color: #0058a1; padding-left: 3.2rem; background: url(../images/index/price-ttl05.png) no-repeat left center/2.5rem; margin-bottom: .6rem; }
.sec-price .home table + small.right{ display: block; text-align: right; font-size: 1.2rem; margin-top: .8rem; padding-left: 1em; position: relative; }
.sec-price .home table + small.right:before{ content: '※'; position: absolute; left: 0; }
.sec-price .home .image{ display: block; width: 100%; margin: 2.4rem 0 6.5rem; }
.sec-price .home > h4{ font-size: 2rem; color: #0058a1; text-align: center; background-image: url(../images/index/border03.png), url(../images/index/border03.png); background-repeat: repeat-x, repeat-x; background-size: auto 2px, auto 2px; background-position: left top, left bottom; padding: 3rem 0; margin-bottom: 4rem; }
.sec-price .home > h4 span{ position: relative; }
.sec-price .home > h4 span:after{ content: ''; width: 3rem; height: 3rem; background: url(../images/index/icon-shine01.png) no-repeat center/contain; position: absolute; top: -1.6rem; right: -3rem; }
.sec-price .home .toothpaste .left{ width: 32.6rem; }
.sec-price .home .toothpaste .left img.logo{ display: block; margin-bottom: 2.5rem; }
.sec-price .home .toothpaste .left ul li{ font-size: 1.4rem; font-weight: 700; padding-left: 1.6rem; position: relative; letter-spacing: .05em; }
.sec-price .home .toothpaste .left ul li:before{ content: ''; width: .7rem; height: .7rem; border-radius: .7rem; background: #0058a1; position: absolute; left: 0; top: .9rem; }
.sec-price .home .toothpaste .left ul li + li{ margin-top: 1.2rem; }
.sec-price .home .toothpaste .right{ width: 35rem; }
.sec-price .home .toothpaste .right img{ display: block; margin-bottom: 2.7rem; }
.sec-price .home .toothpaste .right dl{ width: 17rem; }
.sec-price .home .toothpaste .right dl dt{ width: 100%; height: 3rem; background: #0058a1; color: #fff; display: flex; justify-content: center; align-items: center; font-size: 1.6rem; margin-bottom: .4rem; }
.sec-price .home .toothpaste .right dl dd{ width: 100%; height: 4rem; background: #f1f1f1; color: #0058a1; display: flex; justify-content: center; align-items: center; font-size: 2.2rem; }
.sec-price .home .toothpaste .right dl dd small{ font-size: 1rem; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }

.sec-dr{ margin-bottom: 10rem; }
.sec-dr h2{ margin-bottom: 9rem; }
.sec-dr .president-box{ background: url(../images/index/webp/dr-bg01.webp) no-repeat center/cover; color: #fff; padding: 8rem 10rem 7rem; position: relative; z-index: 0; letter-spacing: .05em; }
.sec-dr .president-box:before{ content: ''; width: calc(100% - 2rem); height: calc(100% - 2rem); border: solid 1px; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }
.sec-dr .president-box > .row{ align-items: flex-start; }
.sec-dr .president-box > .row:nth-of-type(1){ margin-bottom: 3.5rem; }
.sec-dr .president-box > .row:nth-of-type(1) .left{ width: 32.5rem; }
.sec-dr .president-box > .row:nth-of-type(1) .left img{ display: block; margin: -13rem 0 1.4rem; }
.sec-dr .president-box > .row:nth-of-type(1) .left h3{ justify-content: flex-start; align-items: center; }
.sec-dr .president-box > .row:nth-of-type(1) .left h3 small{ font-size: 1.3rem; line-height: 1.5; }
.sec-dr .president-box > .row:nth-of-type(1) .left h3 strong{ font-size: 3.4rem; line-height: 1; margin-left: 2.8rem; }
.sec-dr .president-box > .row:nth-of-type(1) .right{ width: 32.5rem; }
.sec-dr .president-box > .row:nth-of-type(1) .right p + p{ margin-top: 2.5rem; }
.sec-dr .president-box h4{ font-size: 1.8rem; text-align: center; position: relative; margin: 2rem 0; }
.sec-dr .president-box h4 span{ padding: 0 1em; display: inline-block; }
.sec-dr .president-box h4 span[class*="border-"]{ position: absolute; top: 50%; transform: translateY(-50%); height: 2px; background: url(../images/index/border01.png) repeat-x left/contain; }
.sec-dr .president-box h4 span.border-left{ left: 0; }
.sec-dr .president-box h4 span.border-right{ right: 0; }
.sec-dr .president-box .row > table{ width: 32.5rem; font-size: 1.3rem; }
.sec-dr .president-box .row > table th{ font-weight: 400; width: 1px; white-space: nowrap; padding-right: 1em; }
.sec-dr .president-box ul.row{ flex-wrap: wrap; }
.sec-dr .president-box ul.row li{ width: 32.5rem; font-size: 1.3rem; padding-left: 1.5rem; position: relative; }
.sec-dr .president-box ul.row li:before{ content: '・'; position: absolute; left: 0; }
.sec-dr .dr-box{ margin-top: 9rem; background: #e7eef2; padding: 4.5rem 10rem 4rem; position: relative; z-index: 0; }
.sec-dr .dr-box:before{ content: ''; width: calc(100% - 2rem); height: calc(100% - 2rem); border: solid 1px #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: -1; }
.sec-dr .dr-box:after{ content: ''; width: 10rem; height: 10rem; background: url(../images/index/feature-item02.png) no-repeat center/contain; position: absolute; top: 2.4rem; right: 2rem; }
.sec-dr .dr-box img{ position: absolute; top: -4rem; left: 10rem; }
.sec-dr .dr-box .txt{ width: 32.5rem; margin-left: auto; }
.sec-dr .dr-box .txt h3{ color: #0058a1; line-height: 1.7; padding-bottom: 1.4rem; background: url(../images/index/border03.png) repeat-x bottom left/auto 2px; margin-bottom: 1.5rem; }
.sec-dr .dr-box .txt h3 small{ display: block; font-size: 1.3rem; }
.sec-dr .dr-box .txt h3 strong{ font-size: 3.4rem; }
.sec-dr .dr-box .txt table{ font-size: 1.3rem; color: #0058a1; width: 100%; }
.sec-dr .dr-box .txt table th{ width: 1px; white-space: nowrap; font-weight: 400; padding-right: 1em; }

/*20220502*/
.sec-price .home table + small.right.pc-left {
    text-align: left;
}



/*20220502*/

/*20220516*/
.sec-price .home > h4.dual_w-text {
    font-size: 2rem;
    font-weight: 700;
    color: #0058a1;
    padding-left: 3.2rem;
    background: none;
    margin-bottom: 0.6rem;
    padding-top: 0;
/*    background: url(../images/index/price-ttl05.png) no-repeat left center/2.5rem;*/
}

.sec-price .home > h4.dual_w-text.dual-af {
    position: relative;
    margin-bottom: 20px;
}
.dual-icon {
    font-size: 3rem;
}

.sec-price .home > h4 span.dual-icon:after {
    content: none;
}
/*
.sec-price .home > h4.dual_w-text.dual-af::after {
    content: "⬇︎";
    position: absolute;
    font-size: 3rem;
    bottom: -45px;
    left: 50%;
    transform: translateY(-50%);
}
*/

.flex_wrap{ display: flex; justify-content:space-between; align-items:flex-start;}
.row.center{align-items:center;}
.flex_wrap div{ width: 390px;}
.poririn_wrap h5{ font-size: 2.4rem; font-weight: 700; color: #0058a1; line-height: 1.6; text-align: center; margin: 5rem 0 2rem;}
.point_text{ font-size: 16px; font-weight: bold; margin-top: 10px;}
.point_text span{ background: linear-gradient(transparent 60%, #f6e890 60%); padding-bottom: 0.1em; }
.point_text + .point_text{ margin-top: 20px;}
.table_merit{ margin-bottom: 40px;}
.table_merit th{ width: 40%; padding: 5px;}
.table_merit th:first-child{ background-color: #000;}
.table_merit th:nth-child(2){ width: 20%; background-color: #aaa;}
.table_merit td{ background: #FFF; border-color: #f1f1f1; border-right:#f1f1f1 4px solid; font-size: 14px; letter-spacing: 1px; }
.table_merit td strong{ border-bottom:#0058a1 2px solid; padding-bottom: 3px; }
.table_merit td:nth-child(2){ text-align: center;}
.table_merit th{border:#f1f1f1 4px solid; text-align: center;}
.poririn_wrap dl{ color: #0058a1; border:#0058a1 1px dotted; margin:0 0 80px;}
.poririn_wrap dl dt{ font-size: 1.8rem; position: relative; display: table; padding-bottom: .6rem; background: url(../images/index/border03.png) repeat-x bottom left/auto 2px; margin-bottom: 1rem; }
.poririn_wrap dl dd strong{ font-weight: bold;}
.text_center{ text-align: center;}
.small_text{ font-size: 15px; letter-spacing: 1px; line-height: 1;}

.menu{ position: relative; width: 900px; margin:50px auto; padding: 50px 0 50px;}
.menu:before,.menu:after{ position: absolute; bottom:0; left: 0; content:""; background:#0058A1; width: 100%; height: 1px;}
.menu:after{ bottom: 5px;}
.menu h2{ position: relative; background:#0058A1; padding: 22px 0;  font-size:36px; color: #FFF; text-align: center; padding-right: 40px; line-height: 1;}
.menu h2:before,.menu h2:after{ position: absolute; top:8px; left: 0; content:""; background:#FFF; width: 100%; height: 1px;}
.menu h2:after{ top:auto; bottom: 8px;}
.menu h2 span img{ position: absolute; top:20px; right: 175px; width: 37.7px; height:40px;}
.menu p{ font-size:20px; line-height: 1.8; text-align: center; color:#0058A1; font-weight: bold; margin: 35px 0;}
.menu h3{ position: relative; margin-bottom:25px; font-size:20px; font-weight: bold; color:#52B4DF; background:#F2F2F2; text-align: center; padding: 12px 0;}
.menu .box{ width:400px;}
.menu h3:after{ position: absolute; bottom: -12px; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); content:""; width: 0; height: 0; border-left: 12px solid transparent; border-right: 12px solid transparent; border-top: 12px solid #F2F2F2;}
.menu h3.green{ color:#55C6B0;}

.white_wrap{ background:url(../images/index/flow-bg01.jpg) center/2.4rem; padding: 30px 40px; }
.sec-feature .wrap.qa{ padding-top: 7rem;}
.qa h3{ color: #0058a1; font-size: 130%; margin-bottom: 10px;}
.qa h3 span{ background: linear-gradient(transparent 60%, #f6e890 60%);}
.white_wrap p + h3{ margin-top: 30px;}
.white_wrap p{ font-weight: 800;}

.sec-feature .feature-content .txt.none:after{ display: none;}
.sec-feature .feature-content .txt .number{ right:8rem;}

.sec-price .bg-white:not(.method) table.price_table td{ position: relative; font-size: 2rem; font-weight: bold; color: #0058a1; font-family: "游明朝", YuMincho, yu-mincho-pr6n, serif; text-align: center;}
.sec-price .bg-white:not(.method) table.price_table td .yajirushi{ position:absolute; top:5px; left: 50%;transform: translate(-50%, -50%); font-size:4rem; font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";}
.sec-price .bg-white table.price_table th{ background:#6091c2;}
.sec-price .bg-white:not(.method) table.price_table th,.sec-price .bg-white:not(.method) table.price_table td{ display: table-cell; width: 25rem; box-sizing: border-box; padding: 10px;}
.sec-price .bg-white:not(.method) table.price_table{display: table-cell; width: 100%;}


.del {color: #f00; text-decoration : line-through ;}
.del span {color: #000;}

    #whitening-price.table-wrap table.price_table td u{font-size: 2.5rem;}


@media screen and (max-width: 768px) {
    .sec-price .home > h4.dual_w-text {
        padding-left: 0;
        font-size: 1.5rem;
    }
    .sec-price .home .home-list.fd-cr {
        display: flex;
        flex-direction: column-reverse;
    }
    .sec-price .home .home-list.fd-cr li {
        width: 100%;
    }
    .sec-price .home > h4.dual_w-text.dual-af {
        margin-bottom: 0.6rem;
        font-size: 1.5rem;
        padding-bottom: 0;
    }
}


/*20220516*/