﻿@import url("https://fonts.googleapis.com/css?family=Cabin&display=swap");

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
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;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

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

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: inherit;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title],
dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

th {
	text-align: left;
	vertical-align: top;
	font-weight: normal;
}

td {
	text-align: left;
	vertical-align: top;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0;
}

input,
select,
textarea,
img {
	vertical-align: middle;
}

ul,
dl,
ol {
	list-style: none;
}

em {
	font-style: normal;
}

* {
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

.all_wrap {
	overflow: hidden;
}

/* ========================================
    ■ 必須設定
======================================== */

/* 関数
----------------------------- */

.kenten,
.kenten_half { /* 圏点 */
	padding: 0.35em 0;
	background-repeat: repeat-x;
	background-size: 1em 0.5em;
	background-position: top left;
	background-image: -webkit-radial-gradient(0.4rem 0.4rem at center center, #3B3B3B 50%, transparent 50%);
	background-image: radial-gradient(0.4rem 0.4rem at center center, #3B3B3B 50%, transparent 50%);
	font-feature-settings: normal;
}

.kenten_half {
	background-size: 0.65em 0.5em;
}

/* utility class
----------------------------- */

.wrap {
	position: relative;
	width: 1020px;
	padding: 0 10px;
	box-sizing: border-box;
	margin: 0 auto;
}

.clearfix {
	overflow: hidden;
	zoom: 1;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

.hover:hover {
	opacity: 0.9;
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}

.scrollbar::-webkit-scrollbar {
	background: #ccc;
	width: 10px;
}

.scrollbar::-webkit-scrollbar-thumb {
	background: #aaa;
}

table.tbl-block,
table.tbl-block tbody,
table.tbl-block tr,
table.tbl-block th,
table.tbl-block td {
	display: block;
	text-align: left;
}

/* マーカー */

/* ・リスト */

.list-dot > li {
	position: relative;
	padding-left: 1em;
}

.list-dot > li::before {
	content: '・';
	display: inline-block;
	position: absolute;
	left: 0;
	top: 0.7em;
}

/* ========================================
    ■ General
======================================== */

html {
	font-size: 16px;
	min-width: 1020px;
	overflow-x: auto;
}

body {
	font-family: YuGothic, "Yu Gothic", "メイリオ", Meiryo, sans-serif;
	color: #3B3B3B;
	line-height: 1.6;
	font-weight: 500;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt" 1;
	letter-spacing: 0.025em;
}

.en {
	font-family: 'Cabin', sans-serif;
	font-style: italic;
}

a {
	color: #fff;
	text-decoration: underline;
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}

a::before,
a::after {
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}

a:hover {
	text-decoration: none;
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}

a:hover::before,
a:hover::after {
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}

img,
video,
object {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	border: none;
}

/* ========================================
    ■ cmn
======================================== */

.u-sp {
	display: none;
}

.u-nb {
	display: inline-block;
}

.bg_color {
	background: #F3F3F3;
}

.c-btn {
	display: block;
	background: -webkit-linear-gradient(left, #ff6f00 0%, #ffa60c 50%, #ff6f00 100%);
	background: linear-gradient(90deg, #ff6f00 0%, #ffa60c 50%, #ff6f00 100%);
	background-size: 200% 100%;
	background-position: left center;
	width: 695px;
	margin: 43px auto 0;
	line-height: 100px;
	text-decoration: none;
	font-size: 25px;
	font-weight: bold;
	letter-spacing: 0.17em;
	position: relative;
	box-shadow: 0px 4px 18px 4px rgba(0, 0, 0, 0.16);
	text-align: center;
}

.c-btn:after {
	content: '';
	top: 0;
	bottom: 0;
	margin: auto;
	right: 54px;
	position: absolute;
	display: block;
	background: url(../images/arr01@2x.png) no-repeat center;
	background-size: 34px;
	width: 34px;
	height: 28px;
}

.c-hl {
	color: #058393;
	font-size: 40px;
	text-align: center;
	font-weight: bold;
	letter-spacing: 0.18em;
}

.c-hl02 {
	color: #058393;
	font-size: 40px;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.13em;
}

.c-hl02_span {
	font-size: 18px;
	display: block;
	padding-bottom: 16px;
	font-weight: 500;
	letter-spacing: 0.08em;
}

.sa {
	opacity: 0;
	-webkit-transition: all 1.0s ease;
	transition: all 1.0s ease;
}

.sa.show {
	opacity: 1;
	-webkit-transform: none;
	-ms-transform: none;
	transform: none;
	-webkit-transition: all 1.0s ease;
	transition: all 1.0s ease;
}

.sa--lr {
	-webkit-transform: translate(-300px, 0);
	-ms-transform: translate(-300px, 0);
	transform: translate(-300px, 0);
	-webkit-transition: all 1.0s ease;
	transition: all 1.0s ease;
}

.sa--rl {
	-webkit-transform: translate(300px, 0);
	-ms-transform: translate(300px, 0);
	transform: translate(300px, 0);
}

.sa--up {
	-webkit-transform: translate(0, 70px);
	-ms-transform: translate(0, 70px);
	transform: translate(0, 70px);
}

.b_green {
	border-bottom: solid 2px #01AC8F;
	display: inline-block;
	padding-bottom: 5px;
}

/* ========================================
    ■ header
======================================== */

#header {
	position: fixed;
	z-index: 999999999;
	background: #000000;
	width: 100%;
}

#header .h_logo {
	width: 232px;
	padding: 18px 0;
	margin: 0 auto;
}

#header a:hover {
	opacity: 0.8;
}

/* ========================================
    ■ footer
======================================== */

#footer {
	padding-top: 96px;
	text-align: center;
	color: #fff;
	background: -webkit-linear-gradient(left, #01ac8f 0%, #058393 100%);
	background: linear-gradient(to right, #01ac8f 0%, #058393 100%);
}

#footer .footer_tx {
	font-size: 25px;
	line-height: 1.8;
	letter-spacing: 0.14em;
}

#footer .footer_logo {
	margin: 28px 0 19px;
}

#footer .footer_tx02 {
	font-size: 20px;
	line-height: 2;
	letter-spacing: 0.17em;
}

#footer .footer_tx02 .tx_color {
	color: #E8FF00;
}

#footer .footer_info {
	background: #000;
	padding: 32px 0 25px;
}

#footer .footer_link,
#footer .footer_add {
	font-size: 20px;
	line-height: 2;
	letter-spacing: 0.14em;
}

#footer .c-btn {
	margin: 79px auto 108px;
	width: 586px;
}

#footer .c-btn:after {
	right: 35px;
}

#footer .copyright {
	padding-top: 67px;
	font-size: 20px;
	letter-spacing: 0.1em;
}

/* ========================================
    ■ kv
======================================== */

#keyv {
	width: 100%;
	min-height: 917px;
	max-width: 1600px;
	margin: 0 auto;
	padding-top: 80px;
	padding-right: 10px;
	padding-left: 10px;
	margin-top: 80px;
	position: relative;
}

#keyv .keyv_img {
	position: absolute;
	left: -376px;
	bottom: 48px;
	z-index: -1;
}

#keyv .keyv_box {
	background: rgba(255, 255, 255, 0.8);
	width: 900px;
	float: right;
	text-align: center;
	padding: 10px;
}

#keyv .keyv_box_span {
	display: inline-block;
	color: #FFA60C;
	border: solid 2px #FFA60C;
	width: 255px;
	line-height: 24px;
	padding-top: 2px;
	font-size: 15px;
	margin-bottom: 20px;
	font-weight: bold;
}

#keyv .keyv_box_tx {
	color: #929292;
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.22em;
	padding-bottom: 28px;
}

#keyv .keyv_box_hl {
	width: 675px;
	margin: 0 auto;
}

#keyv .keyv_box_list {
	overflow: hidden;
	width: 695px;
	margin: 36px auto 56px;
}

#keyv .keyv_box_list_item {
	float: left;
	width: 220px;
	background: #F3F3F3;
	font-size: 18px;
	line-height: 1.4;
	padding: 20px 7px 19px;
}

#keyv .keyv_box_list_item._02 {
	padding: 7px;
}

#keyv .keyv_box_list_item:nth-child(2) {
	margin: 0 15px;
}

#keyv .keyv_box02 .ico {
	width: 49px;
	margin-bottom: 17px;
}

#keyv .keyv_box02 p {
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0.08em;
	margin-top: -100px;
	padding-top: 100px;
}

/* ========================================
    ■ sec-01
======================================== */

#sec-01 {
	padding: 150px 0 0;
}

#sec-01 .c-hl_img {
	width: 62px;
	margin: 30px auto 0;
}

#sec-01 .sec-01_list {
	margin-top: 54px;
	overflow: hidden;
}

#sec-01 .sec-01_list_item {
	margin-bottom: 45px;
	width: 800px;
	background: #F3F3F3;
	border-radius: 10px;
	line-height: 100px;
	box-sizing: border-box;
	padding: 0 10px;
	text-align: center;
	font-size: 25px;
	font-weight: bold;
	letter-spacing: 0.14em;
	position: relative;
}

#sec-01 .sec-01_list_item:after {
	position: absolute;
	bottom: -45px;
	content: '';
	display: block;
	background: url(../images/arr02@2x.png) no-repeat;
	width: 52px;
	height: 45px;
	background-size: 52px;
}

#sec-01 .sec-01_list_item._01 {
	clear: both;
}

#sec-01 .sec-01_list_item._01:after {
	left: 70px;
}

#sec-01 .sec-01_list_item._02 {
	float: right;
}

#sec-01 .sec-01_list_item._02:after {
	right: 70px;
}

/* ========================================
    ■ sec-02
======================================== */

#sec-02 {
	padding: 78px 0 80px;
}

#sec-02 .sec-02_list {
	overflow: hidden;
	margin-top: 52px;
}

#sec-02 .sec-02_list_item2 {
	float: left;
	width: 234px;
	height: 234px;
	text-align: center;
	background: #fff;
	padding: 15px;
	margin: 5px;
	border-radius: 10px;
}

#sec-02 .sec-02_list_item {
	float: left;
	width: 328px;
	text-align: center;
	background: #fff;
	padding: 38px 20px 54px;
	margin:2px;
	border-radius: 10px;
}


#sec-02 .sec-02_list_item .ico {
	width: 142px;
	margin: 0 auto 42px;
}

#sec-02 .sec-02_list_item .ico img {
	max-width: 100%;
}

#sec-02 .sec-02_list_item_ttl {
	position: relative;
	color: #058393;
	font-weight: bold;
	font-size: 18px;
	line-height: 1.78;
	padding-bottom: 90px;
	min-height: 154px;
}

#sec-02 .sec-02_list_item_ttl:after {
	content: '';
	position: absolute;
	display: block;
	background: #002E34;
	width: 2px;
	height: 35px;
	left: 0;
	right: 0;
	margin: auto;
	bottom: 28px;
}

#sec-02 .sec-02_list_item_tx {
	font-size: 18px;
	letter-spacing: 0.08em;
	line-height: 1.3;
}

/* ========================================
    ■ sec-03
======================================== */

#sec-03 {
	padding: 80px 0 105px;
	height:1780px;
}

#sec-03 .c-hl_img {
	width: 88px;
	margin: 40px auto 0;
}

#sec-03 .slide-dots01 {
	width: 60px;
	left: 0;
	right: 0;
	top: -50px;
	position: absolute;
	text-align: center;
	clear: both;
	overflow: hidden;
	margin: 0 auto;
}

#sec-03 .slide-dots01 li {
	display: inline-block;
}

#sec-03 .slide-dots01 li + li {
	margin-left: 20px;
}

#sec-03 .slide-dots01 li button {
	width: 20px;
	height: 20px;
	position: relative;
	text-indent: -9999px;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	border-radius: 10px;
}

#sec-03 .slide-dots01 li button:before {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
	border: solid 3px #002E34;
	position: absolute;
	top: 0;
	left: 0;
	border-radius: 10px;
	box-sizing: border-box;
}

#sec-03 .slide-dots01 li.slick-active {
	position: relative;
}

#sec-03 .slide-dots01 li.slick-active button:before {
	background: #002E34;
	border: solid 3px #002E34;
}

#sec-03 .slide-dots01 li.slick-active:after {
	position: absolute;
	content: '';
	display: block;
	left: -10px;
	background: #fff;
	height: 1px;
	width: 0;
	bottom: 10px;
}

#sec-03 .sec-03_list {
	overflow: hidden;
	margin-top: 57px;
	position: relative;
}

#sec-03 .sec-03_list_item {
	width: 482px;
	float: left;
	margin-right: 36px;
}

#sec-03 .sec-03_list_item img {
	max-width: 100%;
}

#sec-03 .sec-03_list_item:nth-child(1) .sec-03_list_item_ttl {
	background: #002E34;
}

#sec-03 .sec-03_list_item:nth-child(1) .sec-03_list_item_img {
	border-color: #002E34;
}

#sec-03 .sec-03_list_item:nth-child(2) {
	border-color: #01AC8F;
	margin-right: 0;
}

#sec-03 .sec-03_list_item:nth-child(2) .sec-03_list_item_ttl {
	background: #01AC8F;
}

#sec-03 .sec-03_list_item:nth-child(2) .sec-03_list_item_img {
	border-color: #01AC8F;
}

#sec-03 .sec-03_list_item_ttl {
	text-align: center;
	padding: 19px 27px 26px 20px;
	width: 100%;
	height: auto !important;
}

#sec-03 .sec-03_list_item_ttl img {
	width: 52px;
}

#sec-03 .sec-03_list_item_img {
	padding: 36px 44px 34px;
	border: solid 2px;
}

#sec-03 .sec-03_list_box {
	margin-top: 50px;
}

#sec-03 .sec-03_list_box_ttl {
	text-align: center;
	font-size: 23px;
	font-weight: bold;
	line-height: 1.4;
	padding: 19px;
}

#sec-03 .sec-03_list_box_ttl._01 {
	background: #F3F3F3;
}

#sec-03 .sec-03_list_box_ttl._02 {
	background: #FFE6BB;
}

#sec-03 .sec-03_list_box_list {
	margin-top: 37px;
}

#sec-03 .sec-03_list_box_list._01 {
	margin-left: 28px;
}

#sec-03 .sec-03_list_box_list._01 .sec-03_list_box_list_item:before {
	background: #002E34;
}

#sec-03 .sec-03_list_box_list._02 {
	margin-left: 68px;
}

#sec-03 .sec-03_list_box_list._02 .sec-03_list_box_list_item:before {
	background: #058393;
}

#sec-03 .sec-03_list_box_list_item {
	position: relative;
	font-size: 18px;
	font-weight: bold;
	padding-left: 32px;
	letter-spacing: 0.16em;
}

#sec-03 .sec-03_list_box_list_item + .sec-03_list_box_list_item {
	margin-top: 11px;
}

#sec-03 .sec-03_list_box_list_item:before {
	content: '';
	position: absolute;
	display: block;
	width: 8px;
	height: 8px;
	border-radius: 4px;
	top: 10px;
	left: 0;
}

#sec-03 .sec-03_list_box_list_item .tx_color {
	color: #FF6F00;
}

/* ========================================
    ■ sec-04
======================================== */

#sec-04 {
	padding: 69px 0 26px;
}

#sec-04 .c-hl_img {
	width: 125px;
	margin: 37px auto 0;
}

#sec-04 .c-hl_img img {
	max-width: 100%;
}

#sec-04 .sec-04_box {
	margin-bottom: 86px;
	min-height: 484px;
}

#sec-04 .sec-04_box.mg_top {
	margin-top: 76px;
}

#sec-04 .sec-04_box_ttl {
	background: #01AC8F;
	font-size: 23px;
	color: #fff;
	line-height: 70px;
	padding: 0 42px;
	letter-spacing: 0.2em;
}

#sec-04 .sec-04_box_ttl .en {
	font-size: 25px;
	padding-right: 135px;
	letter-spacing: 0;
}

#sec-04 .sec-04_box_list {
	margin-top: 10px;
	overflow: hidden;
}

#sec-04 .sec-04_box_list_item {
	float: left;
	background: #fff;
	font-size: 18px;
	font-weight: bold;
	line-height: 40px;
	text-align: center;
}

#sec-04 .sec-04_box_list_item._item03 {
	width: 320px;
}

#sec-04 .sec-04_box_list_item._item03:nth-child(2) {
	margin: 0 10px;
	width: 340px;
}

#sec-04 .sec-04_box_list_item._item02 {
	width: 495px;
}

#sec-04 .sec-04_box_list_item._item02:nth-child(2) {
	float: right;
}

#sec-04 .sec-04_boxin {
	margin-top: 49px;
	position: relative;
	padding-right: 548px;
}

#sec-04 .sec-04_boxin_img {
	position: absolute;
	top: 8px;
	right: 0;
}

#sec-04 .sec-04_boxin_ttl {
	position: relative;
	font-size: 23px;
	font-weight: bold;
	line-height: 1.75;
	padding-left: 38px;
	margin-bottom: 35px;
}

#sec-04 .sec-04_boxin_ttl:before {
	position: absolute;
	content: '';
	display: block;
	width: 10px;
	height: 82px;
	background: #058393;
	left: 0;
}

#sec-04 .sec-04_boxin_tx {
	font-size: 18px;
	letter-spacing: 0.16em;
	line-height: 1.67;
	text-align: justify;
}

#sec-04 .sec-04_boxin_tx span {
	color: #FF6F00;
}

/* ========================================
    .cta
======================================== */

.cta {
	padding: 115px 0 92px;
	background: -webkit-linear-gradient(left, #01ac8f 0%, #058393 100%);
	background: linear-gradient(to right, #01ac8f 0%, #058393 100%);
	position: relative;
}

.cta_img {
	position: absolute;
	top: 52px;
	left: calc(50% - 998px);
}

.cta_box {
	padding-left: 416px;
}

.cta_box .cta_box_tx {
	font-size: 25px;
	color: #fff;
	letter-spacing: 0.15em;
	padding-bottom: 19px;
}

.cta_box .cta_box_tx .tx_color {
	color: #E8FF00;
}

.cta_box .cta_box_tx.en {
	font-size: 90px;
}

.cta_logo {
	width: 578px;
}

.cta .c-btn {
	width: 586px;
	margin: 40px auto 0;
}

.cta .c-btn:after {
	right: 35px;
}

/* ========================================
    ■ sec-05
======================================== */

#sec-05 {
	padding: 86px 0 70px;
}

#sec-05 .c-hl_img {
	width: 91px;
	margin: 42px auto 0;
}

#sec-05 .sec-05_list {
	overflow: hidden;
	margin-top: 83px;
	margin-bottom: 20px;
}

#sec-05 .sec-05_list_item {
	width: 468px;
	margin-bottom: 86px;
}

#sec-05 .sec-05_list_item:nth-child(odd) {
	float: left;
}

#sec-05 .sec-05_list_item:nth-child(even) {
	float: right;
}

#sec-05 .sec-05_list_item_ttl {
	background: #01AC8F;
	color: #fff;
	text-align: center;
	line-height: 80px;
	font-size: 23px;
	font-weight: bold;
	margin-bottom: 47px;
}

#sec-05 .sec-05_list_item_img {
	width: 407px;
	margin: 0 auto 26px;
}

#sec-05 .sec-05_list_item_tx {
	text-align: justify;
	padding: 0 25px;
	font-size: 18px;
	letter-spacing: 0.08em;
}

#sec-05 .sec-05_logolist {
	overflow: hidden;
}

#sec-05 .sec-05_logolist_item {
	float: left;
	width: 230px;
	margin-right: 26px;
	margin-bottom: 30px;
}

@media all and (-ms-high-contrast: none) {

body {
	font-family: "メイリオ", Meiryo, sans-serif;
}

#sec-04 .sec-04_boxin {
	padding-right: 530px;
}

#footer .footer_tx02 {
	letter-spacing: 0.12em;
}

/* added @20210129 */
/* ========================================
    ■ sec-PL   ※Partner Logo List
======================================== */
#sec-PL {
	padding: 78px 0 80px;
}

#sec-PL .sec-PL_list {
	overflow: hidden;
	margin-top: 52px;
}

#sec-PL .sec-PL_list_item {
	float: left;
	width: 328px;
	text-align: center;
	background: #fff;
	padding: 38px 20px 54px;
	border-radius: 10px;
	
	margin: 4px;
}

#sec-PL .sec-PL_list_item .ico {
	width: 142px;
	margin: 0 auto 42px;
}

#sec-PL .sec-PL_list_item .ico img {
	max-width: 100%;
}
/* end @20210129 */



}

@media screen and (min-width: 751px) {

.c-btn:hover {
	background-position: right center;
}

#sec-02 .sec-02_list_item:nth-child(1) .sec-02_list_item_ttl {
	padding-top: 20px;
}

#sec-05 .sec-05_logolist_item:nth-child(4n) {
	margin-right: 0;
}

}

@media screen and (max-width: 750px) {

.wrap {
	width: 100%;
	padding: 0 10px;
	min-width: 320px;
}

html {
	min-width: 320px;
}

img {
	display: block;
	max-width: 338px;
	width: 100%;
	margin: 0 auto;
}

.u-pc {
	display: none;
}

.u-sp {
	display: block;
}

.c-btn {
	box-shadow: 0px 4px 10px 4px rgba(0, 0, 0, 0.16);
}

.c-btn {
	margin: 28px auto 0;
	width: 100%;
	font-size: 14px;
	line-height: 80px;
	letter-spacing: 0.05em;
}

.c-btn:after {
	font-size: 16px;
	line-height: 80px;
	background-size: 20px;
	width: 20px;
	height: 20px;
	right: 20px;
}

.c-hl {
	letter-spacing: 0.1em;
	font-size: 20px;
}

.c-hl02 {
	font-size: 25px;
}

.c-hl02_span {
	font-size: 15px;
	padding-bottom: 6px;
}

.sa--up {
	-webkit-transform: translate(0, 30px);
	-ms-transform: translate(0, 30px);
	transform: translate(0, 30px);
}

.b_green {
	padding-bottom: 0;
}

#header .h_logo {
	width: 116px;
	padding: 7px 0;
}

#footer {
	padding-top: 60px;
}

#footer .footer_tx {
	font-size: 18px;
}

#footer .footer_logo {
	max-width: 322px;
	width: 100%;
	margin: 20px auto 10px;
}

#footer .footer_tx02 {
	font-size: 16px;
	max-width: 322px;
	width: 100%;
	margin: 0 auto;
}

#footer .footer_link,
#footer .footer_add {
	font-size: 16px;
}

#footer .c-btn {
	width: 100%;
	max-width: 340px;
	margin: 36px auto 45px;
}

#footer .c-btn:after {
	right: 20px;
}

#footer .copyright {
	padding-top: 30px;
	font-size: 16px;
}

#keyv {
	margin-top: 36px;
	padding-top: 25px;
	min-height: 0;
}

#keyv .keyv_img {
	position: relative;
	left: 0;
	right: 0;
	bottom: 0;
	margin: 40px -10px 0;
}

#keyv .keyv_box {
	width: 100%;
	max-width: 340px;
	float: none;
	margin: 0 auto;
	padding: 0;
}

#keyv .keyv_box_span {
	font-size: 10px;
	width: 150px;
	line-height: 20px;
	margin-bottom: 10px;
}

#keyv .keyv_box_tx {
	font-size: 14px;
	padding-bottom: 10px;
}

#keyv .keyv_box_hl {
	width: 100%;
}

#keyv .keyv_box_list {
	width: 100%;
	margin: 15px auto;
}

#keyv .keyv_box_list_item {
	width: 32%;
	font-size: 10px;
	padding: 14px 5px;
}

#keyv .keyv_box_list_item:nth-child(2) {
	margin: 0 2%;
}

#keyv .keyv_box02 .ico {
	margin-top: -100px;
	padding-top: 100px;
	width: 30px;
	margin-bottom: 10px;
}

#keyv .keyv_box02 p {
	font-size: 14px;
	margin-top: -100px;
	padding-top: 100px;
}

#sec-01 {
	padding: 60px 0 0;
}

#sec-01 .c-hl_img {
	margin: 10px auto 0;
}

#sec-01 .sec-01_list {
	margin-top: 25px;
}

#sec-01 .sec-01_list_item {
	width: 90%;
	line-height: 60px;
	font-size: 16px;
	line-height: 1.5;
	padding: 10px;
	margin-bottom: 35px;
}

#sec-01 .sec-01_list_item:after {
	bottom: -25px;
	width: 25px;
	height: 25px;
	background-size: 25px;
}

#sec-01 .sec-01_list_item._01:after {
	left: 30px;
}

#sec-01 .sec-01_list_item._02:after {
	right: 30px;
}

#sec-02 {
	padding: 60px 0;
}

#sec-02 .sec-02_list {
	margin-top: 30px;
}

#sec-02 .sec-02_list_item {
	float: none;
	width: 100%;
	padding: 20px 15px;
}

#sec-02 .sec-02_list_item:nth-child(2) {
	margin: 20px 0;
}

/* added @20210129 */
#sec-02 .sec-02_list_item:nth-child(4) {
	margin: 8px 0px 0px 0px;
}

#sec-02 .sec-02_list_item:nth-child(5) {
	margin: 8px 0px 8px 8px;
}

#sec-02 .sec-02_list_item:nth-child(6) {
	margin: 8px 0px 0px 0px;
}
/* @20210129 */

#sec-02 .sec-02_list_item .ico {
	margin: 0 auto 20px;
}

#sec-02 .sec-02_list_item_ttl {
	padding-bottom: 45px;
	font-size: 16px;
	min-height: 0;
}

#sec-02 .sec-02_list_item_ttl:after {
	height: 20px;
	bottom: 15px;
}

#sec-02 .sec-02_list_item_tx {
	font-size: 14px;
}

#sec-03 {
	padding: 60px 0;
}

#sec-03 .c-hl_img {
	margin: 20px auto 0;
	width: 70px;
}

#sec-03 .sec-03_list {
	overflow: inherit;
	margin: 70px -20px 0;
}

#sec-03 .sec-03_list_item {
	width: calc(100vw - 40px);
}

#sec-03 .sec-03_list_item_img {
	padding: 20px;
	text-align: center;
}

#sec-03 .sec-03_list_box {
	margin-top: 30px;
}

#sec-03 .sec-03_list_box_ttl {
	font-size: 18px;
}

#sec-03 .sec-03_list_box_list {
	margin-top: 20px;
}

#sec-03 .sec-03_list_box_list._01 {
	margin: 20px 10px 0;
}

#sec-03 .sec-03_list_box_list._02 {
	margin: 20px 10px 0;
}

#sec-03 .sec-03_list_box_list_item {
	font-size: 14px;
	padding-left: 20px;
}

#sec-03 .sec-03_list_box_list_item:before {
	top: 6px;
}

#sec-04 {
	padding: 60px 0 20px;
}

#sec-04 .c-hl_img {
	width: 154px;
	margin: 44px auto 0;
}

#sec-04 .sec-04_box {
	margin-bottom: 40px;
	min-height: 0;
}

#sec-04 .sec-04_box.mg_top {
	margin-top: 53px;
}

#sec-04 .sec-04_box_ttl {
	padding: 15px 15px;
	font-size: 18px;
	line-height: 1.5;
}

#sec-04 .sec-04_box_ttl .en {
	font-size: 20px;
	display: block;
}

#sec-04 .sec-04_box_list_item {
	font-size: 10px;
	letter-spacing: -0.02em;
}

#sec-04 .sec-04_box_list_item._item03 {
	width: 32%;
}

#sec-04 .sec-04_box_list_item._item03:nth-child(2) {
	width: 32%;
	margin: 0 2%;
}

#sec-04 .sec-04_box_list_item._item02 {
	width: 48%;
}

#sec-04 .sec-04_boxin {
	padding-right: 0;
	margin-top: 20px;
}

#sec-04 .sec-04_boxin_img {
	position: relative;
	top: 0;
	margin-top: 35px;
}

#sec-04 .sec-04_boxin_ttl {
	font-size: 15px;
	padding-left: 26px;
	margin-bottom: 15px;
}

#sec-04 .sec-04_boxin_ttl:before {
	width: 8px;
	height: 60px;
	top: -6px;
}

#sec-04 .sec-04_boxin_tx {
	font-size: 14px;
}

.cta {
	padding: 48px 0 180px;
}

.cta_img {
	top: auto;
	bottom: 31px;
	width: 220px;
	left: calc(50% - 191px);
}

.cta_box {
	padding-left: 0;
	width: 100%;
	max-width: 322px;
	margin: 0 auto;
}

.cta_box .cta_box_tx {
	font-size: 15px;
	letter-spacing: 0.03em;
	text-align: center;
}

.cta_logo {
	width: 100%;
	max-width: 322px;
	margin: 0 auto;
}

.cta .c-btn {
	width: 100%;
	max-width: 340px;
	margin: 36px auto 0;
}

.cta .c-btn:after {
	right: 20px;
}

#sec-05 {
	padding: 60px 0 20px;
}

#sec-05 .c-hl_img {
	margin: 20px auto 0;
	width: 80px;
}

#sec-05 .sec-05_list {
	margin-top: 40px;
	margin-bottom: 10px;
}

#sec-05 .sec-05_list_item {
	width: 100%;
	margin-bottom: 40px;
}

#sec-05 .sec-05_list_item_ttl {
	font-size: 18px;
	line-height: 50px;
	margin-bottom: 20px;
}

#sec-05 .sec-05_list_item_img {
	max-width: 407px;
	width: 100%;
}

#sec-05 .sec-05_list_item_tx {
	font-size: 14px;
	padding: 0;
}

#sec-05 .sec-05_logolist_item {
	width: 49%;
	margin-right: 0;
	margin-bottom: 2%;
}

#sec-05 .sec-05_logolist_item:nth-last-child(2n) {
	margin-right: 2%;
}

}




