html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  background: transparent;
}

html {
    font-size: 62.5%;
}

body {
    max-width: 1800px;
    margin: 0 auto;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ul {
  list-style: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  transition: all 0.3s;
}

a:hover {
    filter: brightness(112%);
    transition: filter 0.3s;
}

.sec10 a {
    transition: all 0.3s;
}

.sec10 a:hover {
    filter: brightness(150%);
    transition: filter 0.3s;
}

img {
  vertical-align: bottom;
}

.cv-btn {
  transition: opacity 0.3s;
}

.cv-btn:hover {
  opacity: 0.75;
  transition: opacity 0.3s;
}

.bold {
    font-weight: bold;
}

body {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

.container {
  max-width: 1800px;
  margin: 0 auto;
}


.header {
  max-width: 1034px;
  margin: 10px auto 10px;
}

.header-contents {
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.header-contents h1 {
  margin: 0 !important;
}

.header-contents ul {
  margin-top: 10px;
}

.fv {
    width: 100%;
    height: 684px;
    margin: 0 auto;
    background-image: url(../img/pc/bg_fv.png);
    background-repeat: no-repeat;
    background-position: center bottom;
}

.fv .fv_title {
    padding-top: 20px;
    text-align: center;
}

.fv .contents {
    width: 960px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.fv .contents .content {
    width: 300px;
    height: 482px;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.fv .contents .content01 {
    background-image: url(../img/pc/product_fv01.png);
}

.fv .contents .content02 {
    background-image: url(../img/pc/product_fv02.png);
}

.fv .contents .content03 {
    background-image: url(../img/pc/product_fv03.png);
}

.content_title dl {
    height: 60px;
    display: flex;
    padding-left: 20px;
    font-weight: bold;
}

.content_title01 dl {
    font-size: 1.4rem;
}

.content_title01 dl dt {
    padding-top: 10px;
    line-height: 1.1;
}

.content_title01 dl dt span {
    font-size: 3.2rem;
}

.content_title01 dl dd {
    padding-top: 27px;
    padding-left: 10px;
    line-height: 1.2;
}

.content_title02 dl dt {
    font-size: 2.8rem;
    padding-top: 7px;
    line-height: 1.1;
}

.content_title02 dl dd {
    font-size: 1.8rem;
    padding-left: 11px;
    padding-top: 32px;
}

.content_title03 dl dt {
    font-size: 1.4rem;
    padding-top: 8px;
    line-height: 1.2;
}

.content_title03 dl dd {
    font-size: 2.8rem;
    padding-left: 30px;
    padding-top: 6px;
    line-height: 1.1;
}

.fv .content_btn {
    padding-top: 242px;
    text-align: center;
}

.content_txt p {
    font-size: 1.6rem;
    text-align: center;
    padding-top: 10px;
    line-height: 1.5;
}

.sec01 {
    text-align: center;
}

.sec01 h2 {
    font-size: 3.2rem;
    margin-top: 100px;
    margin-bottom: 50px;
}

.sec01 .sec01_btns {
    width: 1000px;
    margin: 0 auto 100px;
    display: flex;
    justify-content: space-between;
}

.sec02 {
    width: 100%;
    height: 300px;
    margin: 0 auto;
    background-image: url(../img/pc/bg_sec02.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    text-align: center;
    color: #fff;
}

.sec02 h3 {
    padding-top: 68px;
    font-size: 3.2rem;
    text-shadow: 2px 2px 4px #555;
}

.sec02 p {
    padding-top: 50px;
    font-size: 2.4rem;
    text-shadow: 2px 2px 4px #555;
    line-height: 1.6;
}

.sec03 {
    width: 100%;
    margin: 0 auto;
    background-color: #F3F3D3;
}

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

.sec03 .contents .content {
    padding-top: 95px;
}

.sec03 .contents .content .content_inner {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.sec03 .content_inner01 {
    height: 1200px;
    background-image: url(../img/pc/bg_sec03_01.png);
    position: relative;
}

.sec03 .content_inner02 {
    height: 777px;
    background-image: url(../img/pc/bg_sec03_02.png);
    position: relative;
}

.sec03 .content_inner03 {
    height: 932px;
    background-image: url(../img/pc/bg_sec03_03.png);
    position: relative;
}

.sec03 .ranking {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
}

.sec03 h4 {
    width: 100%;
    text-align: center;
    font-size: 2.8rem;
    position: absolute;
    top: 85px;
    left: 50%;
    transform: translateX(-50%);
}

.sec03 .content_inner01 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec03 .content_inner02 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 187px;
    left: 40%;
}

.sec03 .content_inner03 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 180px;
    left: 40%;
}

.sec03 .content_inner01 dl dt {
    padding-bottom: 48px;
}

.sec03 .content_inner02 dl dt {
    padding-bottom: 50px;
}

.sec03 .content_inner03 dl dt {
    padding-bottom: 90px;
}

.sec03 dl dd {
    padding-left: 180px;
}

.sec03 dl dd+dd {
    padding-top: 20px;
}

.sec03 .content_inner01 .content_btn {
    position: absolute;
    top: 740px;
    left: 40%;
}

.sec03 .content_inner01 .content_btn_2 {
    position: absolute;
    top: 1050px;
    left: 40%;
}

.sec03 .content_inner02 .content_btn {
    position: absolute;
    top: 638px;
    left: 40%;
}

.sec03 .content_inner03 .content_btn {
    position: absolute;
    top: 725px;
    left: 40%;
}

.sec03 .content_inner03 p {
    font-size: 1.4rem;
    position: absolute;
    top: 830px;
    left: 40%;
}


.link {
    text-align: right;
    padding: 20px 0 35px;
}

.link a {
    color: #2F2F2F;
    font-size: 1.6rem;
}

.sec04 {
    width: 100%;
    height: 300px;
    margin: 0 auto;
    background-image: url(../img/pc/bg_sec04.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    text-align: center;
    color: #fff;
}

.sec04 h3 {
    padding-top: 68px;
    font-size: 3.2rem;
    text-shadow: 2px 2px 4px #555;
}

.sec04 h3 span {
    font-size: 2.4rem;
}

.sec04 p {
    padding-top: 50px;
    font-size: 2.4rem;
    text-shadow: 2px 2px 4px #555;
    line-height: 1.6;
}

.sec05 {
    width: 100%;
    margin: 0 auto;
    background-color: #FBF5ED;
}

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

.sec05 .contents .content {
    padding-top: 95px;
}

.sec05 .contents .content .content_inner {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.sec05 .content_inner01 {
    height: 752px;
    background-image: url(../img/pc/bg_sec05_01.png);
    position: relative;
}

.sec05 .content_inner02 {
    height: 675px;
    background-image: url(../img/pc/bg_sec05_02.png);
    position: relative;
}

.sec05 .content_inner03 {
    height: 675px;
    background-image: url(../img/pc/bg_sec05_03.png);
    position: relative;
}

.sec05 .ranking {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
}

.sec05 h4 {
    width: 100%;
    text-align: center;
    font-size: 2.8rem;
    position: absolute;
    top: 85px;
    left: 50%;
    transform: translateX(-50%);
}

.sec05 .content_inner01 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec05 .content_inner02 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec05 .content_inner03 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec05 .content_inner01 dl dt {
    padding-bottom: 58px;
}

.sec05 .content_inner02 dl dt {
    padding-bottom: 60px;
}

.sec05 .content_inner03 dl dt {
    padding-bottom: 58px;
}

.sec05 dl dd {
    padding-left: 180px;
}

.sec05 dl dd+dd {
    padding-top: 16px;
}

.sec05 .content_inner02 dl dd+dd {
    padding-top: 30px;
}

.sec05 .content_inner01 .content_btn {
    position: absolute;
    top: 600px;
    left: 40%;
}

.sec05 .content_inner02 .content_btn {
    position: absolute;
    top: 530px;
    left: 40%;
}

.sec05 .content_inner03 .content_btn {
    position: absolute;
    top: 530px;
    left: 40%;
}

.sec06 {
    width: 100%;
    height: 300px;
    margin: 0 auto;
    background-image: url(../img/pc/bg_sec06.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    text-align: center;
    color: #2F2F2F;
}

.sec06 h3 {
    padding-top: 68px;
    font-size: 3.2rem;
    text-shadow: 2px 2px 4px #fff;
}

.sec06 h3 span {
    font-size: 2.4rem;
}

.sec06 p {
    padding-top: 50px;
    font-size: 2.4rem;
    text-shadow: 2px 2px 4px #fff;
    line-height: 1.6;
}


.sec07 {
    width: 100%;
    margin: 0 auto;
    background-color: #FBF5ED;
}

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

.sec07 .contents .content {
    padding-top: 95px;
}

.sec07 .contents .content .content_inner {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.sec07 .content_inner01 {
    height: 675px;
    background-image: url(../img/pc/bg_sec07_01.png);
    position: relative;
}

.sec07 .content_inner02 {
    height: 675px;
    background-image: url(../img/pc/bg_sec07_02.png);
    position: relative;
}

.sec07 .content_inner03 {
    height: 675px;
    background-image: url(../img/pc/bg_sec07_03.png);
    position: relative;
}

.sec07 .ranking {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
}

.sec07 h4 {
    width: 100%;
    text-align: center;
    font-size: 2.8rem;
    position: absolute;
    top: 85px;
    left: 50%;
    transform: translateX(-50%);
}

.sec07 .content_inner01 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec07 .content_inner02 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec07 .content_inner03 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 40%;
}

.sec07 .content_inner01 dl dt {
    padding-bottom: 66px;
}

.sec07 .content_inner02 dl dt {
    padding-bottom: 60px;
}

.sec07 .content_inner03 dl dt {
    padding-bottom: 64px;
}

.sec07 dl dd {
    padding-left: 180px;
}

.sec07 dl dd+dd {
    padding-top: 30px;
}

.sec07 .content_inner02 dl dd+dd {
    padding-top: 35px;
}

.sec07 .content_inner01 .content_btn {
    position: absolute;
    top: 530px;
    left: 40%;
}

.sec07 .content_inner02 .content_btn {
    position: absolute;
    top: 530px;
    left: 40%;
}

.sec07 .content_inner03 .content_btn {
    position: absolute;
    top: 530px;
    left: 40%;
}

.sec08 {
    width: 100%;
    height: 300px;
    margin: 0 auto;
    background-image: url(../img/pc/bg_sec08.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    text-align: center;
    color: #2F2F2F;
}

.sec08 h3 {
    padding-top: 68px;
    font-size: 3.2rem;
    text-shadow: 2px 2px 4px #fff;
}

.sec08 h3 span {
    font-size: 2.4rem;
}

.sec08 p {
    padding-top: 50px;
    font-size: 2.4rem;
    text-shadow: 2px 2px 4px #fff;
    line-height: 1.6;
}


.sec09 {
    width: 100%;
    margin: 0 auto;
    background-color: #FBF5ED;
}

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

.sec09 .contents .content {
    padding-top: 95px;
}

.sec09 .contents .content .content_inner {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.sec09 .content_inner01 {
    height: 1299px;
    background-image: url(../img/pc/bg_sec09_01.png);
    position: relative;
}

.sec09 .content_inner02 {
    height: 1290px;
    background-image: url(../img/pc/bg_sec09_02.png);
    position: relative;
}

.sec09 .content_inner03 {
    height: 980px;
    background-image: url(../img/pc/bg_sec09_03.png);
    position: relative;
}

.sec09 .ranking {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 h4 {
    width: 100%;
    text-align: center;
    font-size: 2.8rem;
    position: absolute;
    top: 85px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner01 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner02 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner03 dl {
    font-size: 1.6rem;
    position: absolute;
    top: 190px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner01 dl dt {
    padding-bottom: 58px;
    text-align: center;
}

.sec09 .content_inner02 dl dt {
    padding-bottom: 50px;
    text-align: center;
}

.sec09 .content_inner03 dl dt {
    padding-bottom: 52px;
    text-align: center;
}

.sec09 dl dd {
    padding-left: 120px;
}

.sec09 .content_inner02 dl dd {
    padding-left: 165px;
}

.sec09 .content_inner03 dl dd {
    padding-left: 165px;
}

.sec09 dl dd+dd {
    padding-top: 16px;
}

.sec09 .content_inner02 dl dd+dd {
    padding-top: 20px;
}

.sec09 .content_inner03 dl dd+dd {
    padding-top: 48px;
}


.sec09 .content_inner01 .content_txt {
    width: 100%;
    position: absolute;
    top: 486px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2.3rem;
}

.sec09 .content_inner01 .content_txt .p_title {
    line-height: 1.5;
}

.sec09 .content_inner01 .content_txt .p_title span {
    font-size: 2.8rem;
    font-weight: bold;
}

.sec09 .content_inner01 .content_txt .p_accent span {
    display: inline-block;
    text-align: center;
    padding: 10px 70px;
    border: 1px solid #D31515;
    font-size: 2.3rem;
    color: #D31515;
}

.sec09 .content_inner01 .content_lists {
    width: 690px;
    margin: 0 auto;
    position: absolute;
    top: 875px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.6rem;
    display: flex;
    flex-wrap: wrap;
}

.sec09 .content_inner01 .content_lists li {
    width: 345px;
    padding-top: 10px;
}

.sec09 .content_inner01 .content_lists .p_text  {
    margin: 30px auto 0px;
    color: #D31515;
}

.sec09 .content_inner02 .content_title {
    width: 100%;
    text-align: center;
    position: absolute;
    top: 470px;
    font-size: 2.3rem;
}

.sec09 .content_inner02 .content_names {
    width: 670px;
    margin: 0 auto;
    position: absolute;
    top: 790px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2.8rem;
    display: flex;
    justify-content: space-between;
}

.sec09 .content_inner02 .content_names li.name {
    padding-left: 58px;
}

.sec09 .content_inner01 .content_btn {
    position: absolute;
    top: 1155px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner02 .content_btn {
    position: absolute;
    top: 1150px;
    left: 50%;
    transform: translateX(-50%);
}

.sec09 .content_inner02 .content_btns {
    width: 678px;
    position: absolute;
    top: 1148px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: space-between;
}

.sec09 .content_inner03 .content_btn {
    position: absolute;
    top: 840px;
    left: 50%;
    transform: translateX(-50%);
}

.sec10 {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
    height: 698px;
    background-image: url(../img/pc/bg_sec10.png);
}

.sec10_inner {
    width: 900px;
    margin: 0 auto;
}

.sec10 h3 {
    text-align: center;
    padding-top: 100px;
    font-size: 2.8rem;
    color: #fff;
    line-height: 1.8;
}

.sec10 h3 span {
    display: block;
    font-size: 3.2rem;
}

.sec10 .contents .content {
    padding-top: 30px;
}

.sec10 .contents .content .content_inner {
    width: 100%;
    margin: 0 auto;
    background-repeat: no-repeat;
    background-position: center bottom;
}

.sec10 .content_inner01 {
    height: 334px;
    background-image: url(../img/pc/bg_sec10_01.png);
    position: relative;
}

.sec10 .content_inner02 {
    height: 334px;
    background-image: url(../img/pc/bg_sec10_02.png);
    position: relative;
}

.sec10 .content_inner03 {
    height: 334px;
    background-image: url(../img/pc/bg_sec10_03.png);
    position: relative;
}


.sec10 h4 {
    font-size: 2.8rem;
    position: absolute;
    top: 60px;
    left: 42%;
}

.sec10 .content_inner .content_txt {
    width: 100%;
    position: absolute;
    top: 120px;
    left: 42%;
    font-size: 1.6rem;
    width: 500px;
}

.sec10 .content_inner .content_txt p {
    text-align: left;
    line-height: 1.8;
}

.sec10 .content_inner .content_btn {
    position: absolute;
    top: 225px;
    right: 6%;
}




		body footer .footer-wrap {
		  background-color: #efeeec;
		}
		
		body footer .footer-wrap .footer {
		  width: 960px;
		  padding: 30px 0 40px;
		  margin: 0 auto;
		}
		
		body footer .footer-wrap .footer p {
		  font-size: 13px;
		  line-height: 1.6;
		}
		
		body footer .footer-wrap .footer .txt1 {
		  font-size: 16px;
		  font-weight: 700;
		}
		
		body footer .footer-wrap .footer .tel-wrap {
		  width: 958px;
		  border: solid 1px #222;
		  margin-top: 20px;
		  padding: 25px 0 25px 45px;
		}
		
		body footer .footer-wrap .footer .tel-wrap ul {
		  display: flex;
		  margin: 0 65px 15px 0;
		}
		
		body footer small {
		  font-size: 12px;
		  display: block;
		  text-align: center;
		  padding: 20px;
		}



