@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap');

:root {
	/* fonts */
	--font-noto-sans-jp: "Noto Sans JP";
	--font-noto-sans: "Noto Sans";

	/* font sizes */
	--h1: 53px;
	--h2: 46px;
	--h3: 42px;
	--h4: 39px;
	--h5: 30px;
	--h6: 20px;
	--h7: 18px;
	--h8: 16px;
	--h9: 15px;

	/* Colors */
	--color1: #1F8BF3;
	--color2: #12CD20;
	--color3: #FB9622;
	--color4: #DCEEFF;
	--color5: #808080;
	--color-bg: #F5F5F5;
	--color-text-base1: #1A1A1A;
	--color-text-base2: #616161;
	--color-text-base3: #1F8BF3;
	--color-text-base4: #FB9622;

	/* Padding */
	--base-Padding:40px;

	--w1: 1200px;
	--w2: 1025px;
	--w3: 843px;
	--w4: 375px;

	--base--point:1024px;
}


@media screen and (max-width: 1240px) {
	.pc{
		display: none !important;
	}
	:root {
	/* font sizes */
	--h1: 39px;
	--h2: 24px;
	--h3: 24px;
	--h4: 20px;
	--h5: 20px;
	--h6: 20px;
	--h7: 15px;
	--h8: 16px;
	--h9: 15px;

	/* Padding */
	--base-Padding:20px;
	}
}
@media screen and (max-width: 765px) {
	:root {
		/* font sizes */
		--h1: 28px;
	}
}
@media screen and (min-width: 1240px) {
	.sp{
		display:none !important;
	}
}


.w1{
max-width: var(--w1);
width: 100%;
margin:0 auto;
}
.w2{
	max-width: var(--w2);
	width: 100%;
	margin: auto;
}
.w3{
	max-width: var(--w3);
	width: 100%;
	margin: auto;
}
.w4{
	max-width: var(--w4);
	width: 100%;
	margin: auto;
}
.line_top{
	border-top:#DFDFDF 1px solid;
}
@media screen and (max-width: 765px) {
	:root {
		/* font sizes */
		--h1: 28px;
	}
}
.bg_color1{
	background-color: var(--color-bg);
}
.bg_color2{
	background-color: var(--color4);
}
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
	font-family: 'Noto Sans JP', sans-serif;
	
}
.h1_title,
h1{
	font-weight: bold;
	font-size: var(--h1);
	letter-spacing: -0.05em;
	line-height: 1.16;
	text-align: left;
	color:var(--color-text-base1);
}
.h2_title,
h2{
	font-weight: bold;
	font-size: var(--h2);
	letter-spacing: -0.05em;
	line-height: 1.25;
	text-align: center;
	color:var(--color-text-base1);
}
h3{
	font-weight: bold;
	font-size: var(--h3);
	letter-spacing: -0.05em;
	line-height: 1.4;
	color:var(--color-text-base1);
}
h4{
	font-weight: bold;
	font-size: var(--h4);
	letter-spacing: -0.05em;
	line-height: 1.4;
	color:var(--color-text-base1);
}
h5{
	font-weight: bold;
	font-size: var(--h5);
	letter-spacing: -0.05em;
	line-height: 1.4;
	color:var(--color-text-base1);
}
h6{
	font-weight: bold;
	font-size: var(--h6);
	letter-spacing: -0.03em;
	line-height: 1.74;
	text-align: left;
	color:var(--color-text-base1);
}
h6 img{
	vertical-align: middle;
	padding-right: 10px;
}

p{
	font-weight: normal;
	font-size:var(--h7);
	letter-spacing: -0.03em;
	line-height:1.61;
	text-align: left;
	color: var(--color-text-base2);
}
button{
	border: none;
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
}

html {
	font-size: 62.5%;
}

body,
table,
input,
textarea,
select,
option {
	font-family: 'Noto Sans JP', sans-serif , 'NotoSansCJKjp', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-weight: 500;
	-webkit-font-smoothing: antialiased;
	color: #1A1A1A;
	line-height: 1.8;
}
@font-face {
	font-family: 'Roboto Mono';
	src: url('./../webfonts/RobotoMono-Italic-VariableFont_wght.ttf') format('truetype'),
	url("./../webfonts/RobotoMono-VariableFont_wght.ttf") format("truetype");
	font-display: swap;
  }
.robot {
	vertical-align: middle;
	color:var(--color-text-base1);
	font-family: 'Roboto', 'Noto Sans JP','NotoSansCJKjp', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}
.robot span{
	display: inline-block;
	margin-top: -5px;
	vertical-align: middle;
}

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

ol,
ul {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}
.clear_fix::after {
	content: "";
	display: block;
	clear: both;
	}
:focus {
	outline: 0;
}

ins {
	text-decoration: none;
}

del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}
a{
	font-size: inherit;
}

a,
a:link {
	transition: .3s;
	color: inherit;
	text-decoration: none;
	cursor: pointer;
	
}

a:visited {
	color: inherit;
}

a:hover {
	opacity: 0.5;
	color: inherit;
}

a:active {
	color: inherit;
}

/*------------------------------------------------------------
	ボタンクラス
------------------------------------------------------------*/

a.no_btn{
	pointer-events: none;
	opacity: 0.5 !important;
}
a.no_btn:hover{
	pointer-events: none;
	opacity: 0.5 !important;
}

.btn1{
	background-color: var(--color3);
	min-width: 185px;
	height: 54px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 17px;
	color: #FFF !important;
	border: 1px solid var(--color3);
	transition: 0.3s;
	letter-spacing: normal;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn1:hover{
	background-color: #FFF;
	color: var(--color3) !important;
	opacity: 1 !important;
}
.btn1_1{
	background-color: var(--color1);
	min-width: 185px;
	height: 54px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 17px;
	color: #FFF !important;
	border: 1px solid var(--color1);
	transition: 0.3s;
	letter-spacing: normal;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn1_1:hover{
	background-color: #FFF;
	color: var(--color1) !important;
	opacity: 1 !important;
}
.btn1_2{
	background-color: var(--color2);
	min-width: 185px;
	height: 54px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 17px;
	color: #FFF !important;
	border: 1px solid var(--color2);
	transition: 0.3s;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn1_2:hover{
	background-color: #FFF;
	color: var(--color2) !important;
	opacity: 1 !important;
}
.btn1_3{
	background-color: var(--color3);
	min-width: 185px;
	height: 54px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 17px;
	color: #FFF !important;
	border: 1px solid var(--color3);
	transition: 0.3s;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn1_3:hover{
	background-color: #FFF;
	color: var(--color3) !important;
	opacity: 1 !important;
}
.btn2{
	font-size: 20px;
	width: 193px;
	padding: 0 30px 14px;
	font-weight: normal;
	background-repeat: no-repeat;
	background-image: url(../img/a.svg);
	background-position: center bottom;
	background-size:100% auto;
	transition: .3s;
}
.btn2:hover{
	opacity: 0.5;
}

.btn_2_1{
	background-color: var(--color1);
	min-width: 264px;
	height: 64px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 20px;
	color: #FFF !important;
	border: 1px solid #FFF;
	transition: 0.3s;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn_2_1:hover{
	background-color: #FFF;
	color: var(--color1) !important;
	opacity: 1 !important;
}
.btn_2_2{
	background-color: var(--color1);
	min-width: 264px;
	height: 64px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 20px;
	background-color: #FFF;
	color: var(--color-text-base3) !important;
	border: 1px solid #FFF;
	transition: 0.3s;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.btn_2_2:hover{
	opacity: 0.5;
}

.nobtn1{
	background-color: var(--color5);
	min-width: 185px;
	height: 54px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	font-size: 17px;
	color: #FFF !important;
	border: 1px solid var(--color5);
	transition: 0.3s;
	letter-spacing: normal;
	justify-content: center;
	cursor: pointer;
	box-sizing: border-box;
	border-radius: 50px;
}
.nobtn1:hover{
	background-color: #FFF;
	color: var(--color5) !important;
	opacity: 1 !important;
}

.btn_h1{
	background-color: var(--color3);
	min-width: 172px;
	height: 40px;
	padding: 8px 20px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	color: #FFF !important;
	border: 1px solid var(--color3);
	transition: 0.3s;
	cursor: pointer;
	border-radius: 50px;
	text-align: center;
	box-sizing: border-box;
}
.btn_h1:hover{
	background-color: #FFF;
	color: var(--color3) !important;
}
.cate_list{
	display: flex;
	gap: 25px;
	flex-wrap: wrap;
}
.cate_list a{
	background-color: #FFF;
	min-width: 100px;
	height: 54px;
	border-radius: 50px;
	padding: 8px 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	color: var(--color1) !important;
	border: 1px solid var(--color1);
	transition: 0.3s;
	cursor: pointer;
	border-radius: 50px;
	box-sizing: border-box;
}
.cate_list a:hover{
	background-color: var(--color1);
	color: #FFF !important;
	opacity: 1 !important;
}
.btn_h2{
	background-color: #FFF;
	min-width: 100px;
	height: 40px;
	border-radius: 50px;
	padding: 8px 25px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 15px;
	color: var(--color1) !important;
	border: 1px solid var(--color1);
	transition: 0.3s;
	cursor: pointer;
	border-radius: 50px;
	box-sizing: border-box;
}
.btn_h2:hover{
	background-color: var(--color1);
	color: #FFF !important;
	opacity: 1 !important;
}
.blog_list li.item:hover .btn_h2{
	background-color: var(--color1);
	color: #FFF !important;
	opacity: 1 !important;
}
@media all and (min-width: 1240px) {
	.sp{
		display: none;
	}
}
@media all and (max-width: 1240px) {
	.btn_2_1{
		background-color: var(--color1);
		min-width: 247px;
		height: 54px;
		padding: 8px 20px;
		display: inline-flex;
		align-items: center;
		font-size:18px;
		color: #FFF !important;
		border: 1px solid #FFF;
		transition: 0.3s;
		justify-content: center;
		cursor: pointer;
		box-sizing: border-box;
		border-radius: 50px;
	}
	.btn_2_2{
		background-color: var(--color1);
		min-width: 247px;
		height: 54px;
		padding: 8px 20px;
		display: inline-flex;
		align-items: center;
		font-size:18px;
		background-color: #FFF;
		color: var(--color-text-base3) !important;
		border: 1px solid #FFF;
		transition: 0.3s;
		justify-content: center;
		cursor: pointer;
		box-sizing: border-box;
		border-radius: 50px;
	}
}
.pankuzu{
	width: 100%;
	padding-top: 75px;
	background-color: #F5F5F5;
}
.pankuzu ol{
	max-width: 1200px;
	display: flex;
	margin: auto;
	padding: 7px 0;
}
.pankuzu ol li a{
	color:#1A1A1A !important;
}
.pankuzu ol li a{
	text-decoration: none;
	color: #1F8BF3 !important;
}
.pankuzu ol li:last-of-type a{
	color:#1A1A1A !important;
	
}
.pankuzu ol li a::after{
	content: url(../img/common/rr.svg);
	color:#1A1A1A;
	display: inline-block;
	padding: 0 8px;
	font-weight: 500;
	font-size: 1.4rem;
}

.pankuzu ol li.pp a::after{
	content: "/";
	color:#CCC;
	transform: translateY(-1px);
	padding: 0 8px;
	font-weight: 500;
	font-size: 1.2rem;

}
.pankuzu ol li:nth-last-child(2) a::after{
	content: url(../img/common/rr.svg) !important;
	color:#1A1A1A;
	display: inline-block;
	padding: 0 8px;
	font-weight: 500;
	transform: translateY(0);
	font-size: 1.4rem;
}
.pankuzu ol li:last-of-type a::after{
	display: none;
}
.pankuzu li,
.pankuzu span,
.pankuzu a{
	color: #1A1A1A;
	font-size: 1.4rem;
	font-weight: 400;
}
.pankuzu a{
	color: #1F8BF3;
}

/* ----------------------------------------------------------------------
 HEADER
---------------------------------------------------------------------- */
.btn_picup{
	display: block;
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	padding: 30px 14px;
font-weight: 500;
font-size: 18px;
line-height: 19px;
text-align: center;
color: #fff !important;
background-color: var(--color-text-base4);
border-radius: 6px 0 0 6px;
z-index: 1000;
}
.btn_picup:hover{
	opacity: 0.5;
}
#header {
	width: 100%;
	padding: 18px var(--base-Padding);
	display: flex;
	justify-content: space-between;
	align-items: center;
	box-sizing: border-box;
	
}

#header .logo {
}


#header nav ul{
	gap: 20px;
}
#header nav li{
	display: inline-flex;
	align-items: center;

}
#header nav li.p10{
	padding:0 5px 0 0;
	position: relative;
}
#header nav li.p10:hover .mega_menu{
	display: block;
}
#header nav li.p10:nth-child(4)::after{
	content: url(../img/common/pp.svg);
	padding-left: 5px;

}
/* 2024-12-05 */
#header nav li.p10:nth-child(5)::after{
	content: url(../img/common/pp.svg);
	padding-left: 5px;

}
#header nav li.p10 .mega_menu{
	display: none;
	width: 169px;
	height: 99px;
	position: absolute;
	top:35px;
	left: -30px;
	box-shadow: 0px 5px 5px rgba(0,0,0,0.1);
	background-color: #FFF;
	padding: 20px;
}
#header nav li.p10:nth-child(4):hover span{
	opacity: 1 !important;
	color: #1F8BF3 !important;
}
/* 2024-12-05 */
#header nav li.p10:nth-child(5):hover span{
	opacity: 1 !important;
	color: #1F8BF3 !important;
}
#header nav li.p10 .mega_menu a:hover{
	opacity: 1 !important;
	color: #1F8BF3 !important;
}	
#header nav li.p10 .mega_menu li{
	width: 100%;
	margin-bottom: 20px;
}
#header nav li span,
#header nav li a {
	cursor: pointer;
	font-size: 15px;
	font-weight: 500;
	transition: .3s;
	box-sizing: border-box;
}


#header nav li a.active{
 color: var(--color1);
}

header{
	position: fixed;
	width: 100%;
	z-index: 1001;
	top:0px;
	left: 0;
	background: #FFF;
	transition: transform .3s;
}
header.on_on{
	transform: translateY(-100%);
}
.top_box{
	height: 124px;
}

.logo_header{
  position: fixed;
  top:50%;
  right: 0;
  transform: translate(0%,-50%);
  z-index: 1002;

}
.global-header{
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: 100%;
}
header nav{
	display: flex;
	padding: 0px;
	box-sizing: border-box;
}

header nav ul{
	display: flex;
	gap:0px;

}

header nav ul li a{
	display: block;
	text-align: center;
	font-size: 12px;
	font-style: normal;
	font-weight: 600;
	line-height: 1.2;
	font-weight: bold;
	cursor: pointer;
}

header nav ul li a:hover{
	opacity: 0.5;
}

.text_wline{
	width:100%;
	max-width: var(--w3);
	font-weight: 400;
	text-align: left;
	font-size: var(--font-size-h3);
	position: relative;
	margin: auto;
}
.text_wline span{
	display: inline-block;
	background-color: #FFF;
	padding-right: 40px;
	font-weight: 500;
}
.text_wline::after{
	content: "";
	width: 100%;
	position: absolute;
	background-color: #000;
	height: 1px;
	top:50%;
	left: 0;
	z-index: -1;
	position: absolute;
}

header nav ul li a{
	position: relative;
}
.connectors-parent{
	display: flex;
	align-items: center;
	gap:30px;
}
.connectors-parent .icon-login{
	margin-right: 5px;
	vertical-align:middle;
}
.connectors-parent .connectors a{
	font-size: 12px;
	font-style: normal;
	font-weight: 600;
	line-height: 1.2;
	font-weight: bold;
}


.menu_sp{
	position: fixed;
	right: 0px;
	top:0px;
	z-index: 1001;
	padding: 16px;
}
.menu_sp img{
	padding: 6px 2px;
}
.line_dot {
	border-top:#626466 1px dashed;
	border-bottom:#626466 1px dashed;
	margin: 24px 0;
}
.menu_sp.on img{
	padding: 0px 2px;
}
.menu_sp.on .open,
.menu_sp .close{
	display: none;
}
.menu_sp.on .close{
	display: block;
}

@media all and (min-width: 1240px) {
    .sp_h {
        display:none!important
    }
	.min800{
		min-width: 810px;
	}
}

@media all and (max-width: 1240px) {
    .pc_h {
        display:none!important
    }
}


@media screen and (max-width: 1240px) {
	html{
		overflow-x: hidden;
	}
	#header {
		width: 100%;
		padding: 10px var(--base-Padding);
		border-bottom: 1px solid #DFDFDF;
	}
	header.op{
	overflow-y: scroll;
	height: 100vh;
	display: block;
	padding:0 !important;
	border-bottom:none;
	}

	.cometa-logoset-dummy img{
		width: 200px;
		height: 40px;
		padding:0px;
	}
	header.op .cometa-logoset-dummy{
		display: none;
	}

	header.op img{
		padding:0 16px;
	}
	.global-header .cometa-logoset-dummy {
		display: none;
	}
	header nav ul li a.active{
		color: inherit;
		text-decoration: none;
	}
	header nav ul li a.active::after{
		display: none;
	}
	header {
		top:0;
	}
	header nav{
		height: 100vh;
		z-index: 100;
		display: block;
		justify-content: center;
		align-items: center;
		display: none;
		padding: 0px;
		width: 100%;
	}
	header nav>ul{
		margin-top: 40px;
		width: 100%;
	}

	#header nav ul li {
	    padding:20px 20px 10px !important;
		display: block;
		text-align: center !important;
	}
	#header nav li span,
	#header nav li a{
		font-size: 20px !important;
		color: #FFF !important;
	}
	#header nav li.p10 span,
	#header nav li.p10 a{
		color: #FFF !important;
	}
	#header nav li.p10:hover span{
color: #FFF !important;
	}
	#header nav li.p10:nth-child(4):hover span{
		opacity: 1 !important;
		color: #FFF !important;
	}
	/* 2024-12-05 */
	#header nav li.p10:nth-child(5):hover span{
		opacity: 1 !important;
		color: #FFF !important;
	}	
	#header nav li.p10 .mega_menu a:hover{
		opacity: 1 !important;
		color: #FFF !important;
	}	
	#header nav li.p10 .mega_menu{

		margin-top: 20px;
		position: static;
		background: none;
		display: none;
		box-shadow: none;
		height: auto;
		width: auto !important;
		padding: 0 !important;
		margin-bottom: 0px;

	}
	#header nav li.p10 .mega_menu li{
		width: auto !important;
		padding: 0 !important;
	}
	#header nav li.p10:nth-child(4)::after{
		position: absolute;
		right: 50%;
		margin-right: -80px;
		top:30px;
	}
	/* 2024-12-05 */
	#header nav li.p10:nth-child(5)::after{
		position: absolute;
		right: 50%;
		margin-right: -80px;
		top:30px;
	}
	#header nav li.p10 .mega_menu {
		
	}
	#header nav li a.btn_h1,
	#header nav li a.btn_h2{
		
		min-width: 247px;
		height: 60px;
		background-color: transparent;
		color: #FFF !important;
	}
	#header .pts30{
		display: none;
	}
	#header.op .pts30{
		display: block;
	}
	#header .pts30 {
		position: absolute;
		padding:10px 20px !important;
		bottom: 160px;
		left: 50%;
		transform: translateX(-50%);
		z-index: 10000;
	}
	#header .pts30.last{
		bottom: 70px;
	}
	#header .btn_h1{
		background-color: #FFF;
		color:var(--color1) !important;
		height: 60px;
		min-width: 247px;
		font-size: 20px !important;
		
	}
	#header .btn_h2{
		border: 1px solid #FFF;
		height: 60px;
		min-width: 247px;
		font-size: 20px !important;
	}
	header nav.on{
		margin: 0;
		top:0;
		left: 0;
		background:var(--color1);
		width: 100%;
		height: 100vh;
		display: flex;
		align-items: flex-start;
	}
	

	header nav ul{
		display: block;

	}
	header nav ul li a.on{
		color: inherit;
		text-decoration: none;
	}
	.logo_sp{
		position: fixed;
		top:0px;
		left: 0;
		padding: 0px 25px;
		z-index: 100;
		width: 100%;
		height: 60px;
		background: #FFF;
	}
	.logo_sp a{
		display: block;
		margin-top: 14px
	}
	.position_relative .logo_sp{
		background:#13439B;
	}

	#FOOTER .logo{
		width: 227px !important;

	}
	.btn_picup {
		top: 150px;
		transform: translateY(-50%);
		padding: 13px 12px;
		font-weight: 500;
		font-size: 14px;
		line-height: 15px;
		text-align: center;
		color: #fff;
		background-color: var(--color-text-base4);
		border-radius: 6px 0 0 6px;
		z-index: 1000;
	}
	.pankuzu ol li.pp a::after{
		transform: translateY(0px);
		font-size: 14px;
	
	}
}


/* ----------------------------------------------------------------------
 FOOTER
---------------------------------------------------------------------- */
.footer_contact{
	width: 100%;
	padding: 80px 0 80px;
	background-color: var(--color1);
	text-align: center;
	color: #FFF !important;
}
.f_title{
	font-size: var(--font-size-h3);
	display: block;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

footer {
	border-top: 1px solid #DFDFDF;
    box-sizing: border-box;
    display: flex;
    width: 100%;
    padding:25px var(--base-Padding);
    align-items: center;
    font-size: var(--font-size-base);
	font-weight: normal;
    justify-content: space-between
}
footer span{
	font-size: 14px;
}
footer a{
	font-size: 13px;
	margin-left: 20px;
}


@media screen and (max-width: 1240px) {
	.footer_contact{
		width: 100%;
		padding: 50px 30px 50px !important;
		box-sizing: border-box;
	}
    footer {
        display:block;
        height: auto;
        padding: 24px
	}
	.footer_contact .flex_inline{
	    width: 300px;
	}
	footer a{
		margin-bottom: 5px;
		font-size: 13px;
		margin-left: 0px;
		
	}
	.pankuzu{
		padding-top: 55px;
	}
	.pankuzu li,.pankuzu span, .pankuzu a{
		font-size: 1.2rem;
		line-height: 1;
	}
	.pankuzu ol {
		max-width: 1200px;
		display: flex;
		margin: auto;
		padding: 12px 20px 7px;
		box-sizing: border-box;
	}
	section.flex_box .padding_top_70{
		padding-top: 45px !important;
	}
	section.flex_box .padding_top_70 h1{
		box-sizing: border-box;
		padding-right: 30px;
	}
	section.flex_box .padding_top_70 .margin_top_15 {
		margin-top: 5px !important;
	}
	
}


/* ----------------------------------------------------------------------
 Contactform - お問い合わせフォーム
---------------------------------------------------------------------- */
.ddStyle02{
	width: 620px;
}
.wpcf7 form {
	margin: 1.5em 1.5em 0;
}

.wpcf7 p {
	text-align: right;
	display: block !important;
	width: 100%;
	padding-bottom: 20px;
}

.wpcf7 input,
.wpcf7 textarea {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	padding: 15px;
	border: 1px solid #ccc;
	line-height: 1.2;
}

.wpcf7 select,
.wpcf7 input[type=checkbox],
.wpcf7 input[type=radio] {
	width: auto;
	padding: 8px;
	border: 1px solid #ccc;
}

.wpcf7 select,
.wpcf7 .wpcf7-list-item-label {
	font-size: 16px;
	line-height: 1.2;
}

.wpcf7 .wpcf7-list-item {
	display: block;
}

.wpcf7 textarea {
	height: 300px;
}

.wpcf7 input:focus,
.wpcf7 textarea:focus {
	border: 1px solid #bbb;
	outline: none;
}

.wpcf7 .wpcf7-submit:before,
.wpcf7 .wpcf7-submit:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.wpcf7 .wpcf7-submit:hover,
.wpcf7 .wpcf7-previous:hover {
	background-color: #FFF;
}

.wpcf7 .wpcf7-submit .wpcf7-not-valid {
	background: pink;
}

.scroll-box,
.wpcf7 .wpcf7-submit .wpcf7-response-output {
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	margin: 10px 0 0;
	padding: 8px 35px 8px 14px;
	border-radius: 6px;
}

.wpcf7 .wpcf7-submit .wpcf7-validation-errors {
	border: 1px solid #EED3D7;
	background-color: #F2DEDE;
	color: #B94A48;
}

.wpcf7 .wpcf7-submit .wpcf7-mail-sent-ok {
	border: 1px solid #BCE8F1;
	background-color: #D9EDF7;
	color: #3A87AD;
}

.wpcf7 .wpcf7-previous+br {
	display: none;
}

.wpcf7 form .wpcf7-response-output {
	margin: 1em 0.5em 2em;
	padding: 0;
	border: none;
	text-align: center;
	padding-bottom: 20px;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
	color: #dc3232;
	font-size: 1em;
}

.wpcf7 .te {
	position: relative;
}

.wpcf7 .te::after {
	position: absolute;
	left: 420px;
	top: 25px;
	content: "";
	border-right: #1A1A1A 2px solid;
	border-bottom: #1A1A1A 2px solid;
	transform: rotate(45deg);
	width: 6px;
	height: 6px;
}

.wpcf7 select {
	width: auto;
	width: 620px;
	padding: 14px;
	border: 1px solid #ccc;


	padding: 5px 15px;
	height: 60px;
	font-size: 1.6rem;
	letter-spacing: 0.06em;
	border: none;
	border-radius: 0;
	box-sizing: border-box;
	background-color: #FFF;
	-webkit-appearance: none;
	border: 1px solid #D9D9D9;
	border-radius: 5px;
	appearance: none;
}

@media all and (min-width: 1079px) {
	.wpcf7-form .submitList li input:hover {
		color: #990073;
		background-color: #fff;
	}

}

@media all and (max-width: 1240px) {
	.contact #main {
		padding: 0 20px;
		box-sizing: border-box;
	}

	.wpcf7 .te::after {
		position: absolute;
		left: 100%;
		margin-left: -30px;
	}

	.radio-554 .wpcf7-list-item.last {
		padding: 0 0 10px 0 !important;
	}

	.article {
		padding: 20px;
		background: #FFF;
	}

	.article_box {
		margin-top: 20px;
	}

	.wpcf7-form .dtStyle02_ {
		font-size: 1.1rem;
		font-weight: 700;
		font-family: 'Noto Sans JP', sans-serif;
		padding-bottom: 16px;
		display: inline-block;

	}

	.scroll-box {
		font-size: 1.2rem;
		line-height: 1.8;
		padding: 20px 14px 0;
		box-sizing: border-box;
	}

	.dd_center {
		padding: 0px 0;
		padding-left: 0 !important;
		display: inline-block;
	}

	.dt_center .wpcf7-list-item-label {
		display: inline-block;
		transform: translateY(5px);
		margin-left: 10px;
	}

	.dt_center {
		margin-top: 30px;
		display: flex;
		align-items: center;
		height: 20px;
	}

	.wpcf7-form dl {
		margin-bottom: 0px;
	}

	.wpcf7-form input[type="radio"] {
		height: 30px;
	}

	.wpcf7-form dt {
		margin-bottom: 14px;
		padding: 0 0 6px;
		width: auto;
		float: none;
		font-size: 1.4rem;
		text-align: center;
		border-bottom: 1px solid #707070;
	}
	

	.wpcf7-form dt:first-of-type {
		padding-top: 0px;
	}

	.wpcf7-form .dtStyle01 {
		margin-bottom: 22px;
		width: auto;
		float: none;
		padding-top: 0;
	}

	.wpcf7-form .dtStyle02 {
		width: 100%;
		margin-bottom: 5px;
		padding-bottom: 0;
		text-align: left;
		font-size: 1.1rem;
		border-bottom: none;
	}

	.wpcf7-form dd {
		margin-bottom: 25px;
		padding-left: 0;
	}

	.wpcf7-form dd:last-of-type {
		margin-bottom: 0;
	}
	dl dd {
		padding-bottom: 10px !important;
	}

	.wpcf7-form .ddStyle01 {
		margin-bottom: 0px;
		padding-left: 0;
	}

	.wpcf7-form .ddStyle02 {
		margin-bottom: 0px;
	}

	.wpcf7-form dd .radioList {
		margin-top: -18px;
	}

	.wpcf7-form dd .radioList li {
		margin-top: 18px;
		width: calc((100% - 10px) / 2);
	}

	.wpcf7-form dd .radioList li:nth-of-type(3n - 2) {
		width: calc((100% - 10px) / 2);
	}

	.wpcf7-form dd .radioList li input+span {
		padding-left: 30px;
		font-size: 1.3rem;
		background-size: 25px auto;
		background-image: url(../../img/common/icon08.png);
	}

	.wpcf7-form dd .radioUl {
		display: block;
	}

	.wpcf7-form dd .radioUl li {
		margin-bottom: 14px;
		width: auto;
	}

	.wpcf7-form dd .radioUl li:last-of-type {
		margin-bottom: 0;
	}

	.wpcf7-form dd .radioUl li input+span {
		padding-left: 30px;
		font-size: 1.1rem;
		background-size: 25px auto;
		background-position: left top;
	}

	.wpcf7-form dd .radioUl li input+span small {
		margin-bottom: 6px;
		padding: 4px 5px 6px;
		font-size: 0.9rem;
	}

	.wpcf7-form input[type="email"],
	.wpcf7-form input[type="tel"],
	.wpcf7-form input[type="text"],
	.wpcf7-form input[type="submit"],
	.wpcf7-form textarea {
		padding: 5px 8px;
		height: 48px;
		font-size: 1.2rem;
	}

	.wpcf7-form textarea {
		height: 200px;
	}

	.wpcf7-form dd p {
		margin-top: 2px;
		font-size: 0.9rem;
		color: #990073;
	}

	.wpcf7-form .submitList {
		margin-top: 50px;
		display: flex;
		justify-content: center;
	}

	.wpcf7-form .submitList li {
		width: 156px;
	}

	.wpcf7-form .submitList li input {
		height: 53px;
		font-size: 1.2rem;
		border-radius: 5px;
	}

	.post_content p.font_22 {
		font-size: 16px !important;
	}

	.post_content p.font_22.font_s_14 {
		font-size: 14px !important;
	}

	.post_content p.font_22 br {
		display: none;
	}

	.post_content p.font_22.font_s_14 br {
		display: block;
	}

	.post_content p.font_22.font_s_14 {
		font-weight: 500;
		line-height: 2 !important;
	}

	.simg1 .wp-image-45 {
		width: 70%;
	}

	.post_content p.padding_bottom_100 {
		padding-bottom: 40px !important;
	}

	.design1_content2 .item:first-of-type .content {
		border-top: none;
	}

	.design1_content2 .image,
	.design1_content1 .content_inner,
	.design1_content2 .content_inner,
	.design1_content2 .item .content {
		text-align: left;
		border-left: none !important;
		border-right: none !important;
	}

	.post_content h6 {
		margin-bottom: 0;
		padding-bottom: 0;
	}

	.design1_content2 .image {
		width: 100%;
		height: 70vw;
		float: none;
		position: relative;
		border: 1px solid #b3b3b3;
		box-sizing: border-box;
	}

	.cb_catch.rich_font_type4.padding_bottom_40 {
		padding-bottom: 0 !important;

	}

	.font_22.margin_top_0.font_s_16 {
		line-height: 1.8;

	}

	.sdgimg {
		width: 137px;
	}

}
.point li{
	position: relative;
	padding-left: 20px;
	font-size: var(--h7);
	margin-bottom: 30px;
	text-align: left;
	font-weight: 400;
	color: var(--color-text-base2);
}
.point li::after{
	position: absolute;
	content: "・";
	left: -5px;
	top:-4px;
	font-size: 24px;
}
.share-type2 ul.type2 li.default.twitter_button a:hover {

	background-color: #0CB43C !important;
	border-color: #0CB43C !important;
}

/* ----------------------------------------------------------------------
 Contactform - お問い合わせフォーム
---------------------------------------------------------------------- */
.ccc{
	position: absolute;
	left: -90px;
	bottom: -50px;
}
select,
::placeholder{
	color: #CBCBCB !important;
}
dl{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	
}
dl dt{
	padding-bottom: 24px;
	width:  220px;
	text-align: left;
	font-size: var(--h7);
	display: flex;
	align-items: center;
	color: var(--color-text-base2);
	font-weight: 400;
}
dl dt span{color: #1F8BF3 !important;padding-left: 8px;}

dl dd{
	padding-bottom: 24px;
}
dl dt:last-of-type{
	align-items:flex-start;
	padding-top: 15px;
}
dl dd:last-of-type{
	padding-bottom: 10px;
}

/*CONTACTフォーム */
.wpcf7 input,select{
	height: 60px;
	width: 620px;
	border-radius: 6px;
	border: 1px solid #DFDFDF !important;
	font-size: var(--h7) !important;
}
textarea{
	border-radius: 6px;
	border: 1px solid #DFDFDF !important;
	font-size: var(--h7) !important;
}

.wpcf7-radio label {
	position      : relative;
	display       : inline-block;
	width         : 18px;
	height        : 18px;
	border        : 1px solid #666;
	border-radius : 100%;
	cursor        : pointer;
}
.wpcf7-radio label span{
  padding-left: 30px;
  white-space: nowrap;

}
.wpcf7-radio label:before {
	content          : '';
	display          : block;
	width            : 6px;
	height           : 6px;
	border-radius    : 100%;
	position         : absolute;
	top              : 6px;
	left             : 6px;
	z-index          : 1;
	background-color : #13439B;
}

.link_button{
	text-align: right;
}
#sideBar input[type="submit" i] {
	font-size: 1.5rem !important;
	padding: 22px 0px 22px 0px;
	color: #9E9E9E !important;
	display: inline-block;
	margin: auto;
	background: url(../img/top/search.svg) 20px center no-repeat;
	cursor: pointer;
	transition: 0.3s;
	border-radius: 50px;
	margin-top: 30px;
	line-height: 0;
	width: 40px;
	border: none !important;

}
#sideBar input[type="submit" i]:hover{
	color:  #1F8BF3 !important;
}

.wpcf7 input[type="submit" i] {
	font-size: 1.5rem !important;
	padding: 22px 0px 22px 0px;
	color: #FFF !important;
	display: inline-block;
	margin: auto;
	background: #1F8BF3;
	cursor: pointer;
	transition: 0.3s;
	border-radius: 50px;
	margin-top: 30px;
	line-height: 0;
	width: 320px;
	border: 1px solid #1F8BF3 !important;

}
.wpcf7 input[type="submit" i]:hover{
	color:  #1F8BF3 !important;
	border: 1px solid #1F8BF3;
}
.wpcf7 .wpcf7-list-item{
	display: inline-block;
}
.wpcf7-radio label input[type="radio"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	margin     : 0px;
	position   : absolute;
	z-index    : 2;
	top        : 2px;
	left       : -17px;
	width      : 17px;
	height     : 10px;
	display    : block;
	box-shadow : 18px 0px #FFF;
  border-radius: 20px;
}
.wpcf7-radio label input[type="radio"]:checked {
	box-shadow : none;
}
.wpcf7-radio label input[type="radio"]:focus {
	box-shadow : 20px 0px #FFF;
	opacity    : 0.2;
}
.wpcf7 form{
	margin: 0 !important;
}
.wpcf7 select, .wpcf7 .wpcf7-list-item-label{
	color: #1A1A1A;
}
@media all and (max-width: 1240px) {
  .wpcf7-list-item {
    margin: 0 1em 10px 0 !important;
}
.wpcf7-radio label:before {
	content          : '';
	display          : block;
	width            : 6px;
	height           : 6px;
	border-radius    : 100%;
	position         : absolute;
	top              : 6px;
	left             : 6px;
	z-index          : 1;
	background-color : #13439B;
}
.wpcf7-radio label input[type="radio"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	margin     : 0px;
	position   : absolute;
	z-index    : 2;
	top        : 0px;
	left       : -17px;
	width      : 17px;
	height     : 8px;
	display    : block;
	box-shadow : 18px 0px #FFF;
  border-radius: 20px;
}
.wpcf7-radio label input[type="radio"]:focus {
	box-shadow : 18px 0px #FFF;
	opacity    : 0.2;
}
.wpcf7-form input[type="radio"] {
    height: 16px;
}
#company .link_button {
	margin-top: 30px;
    text-align: center;
    padding: 0px 0 30px;
}
#company .link_button{

}

.wpcf7-form .dtStyle02{
  font-size: 1.5rem;
  padding-top: 8px;
  padding-bottom: 0px;
}
.wpcf7 textarea {
    height: 180px !important;
}
.wpcf7-radio label span{
	white-space:normal;
	word-break: keep-all;
	width: 200px;
	display: block;
}
.wpcf7 p{
	padding-bottom: 0;
}
.wpcf7 select {
	padding: 0px 15px;
	width:100%;
	max-width: 100%;
}
.ccc {
	width: 83px;
    position: absolute;
    left: 0px;
    bottom: -40px;
}
}
.slick-dotted.slick-slider{
	margin-bottom: 0 !important;
}
.doui .wpcf7-checkbox{
	position: absolute;
	top:0;
	left:50%;
	margin-left:  -165px;
}
.doui .wpcf7-form-control-wrap{
display: block;
}
.doui .wpcf7-not-valid-tip{
	position: absolute;
	bottom: -55px;
	left:50%;
	
	transform: translateX(-50%);
}
.wpcf7 form .wpcf7-response-output{
	padding-bottom:  !important;
text-align: right !important;
white-space: nowrap;
width: 100%;
}
.wpcf7-not-valid-tip{
	text-align: left;
	font-size: 16px !important;
}
.wpcf7-response-output{
	position: absolute;
	bottom:20px;
	left:50%;
	padding-bottom: 20px;
	font-size: 16px !important;
	transform: translateX(-50%);
}

@media all and (max-width: 1240px) {
	.wpcf7 form .wpcf7-response-output{
		padding-bottom: 0 !important;
	
	}
	.doui .wpcf7-checkbox{
		margin-left:  -135px;
	}
	.wpcf7-not-valid-tip{
		font-size: 13px !important;
	}
	.doui .wpcf7-not-valid-tip{
		bottom: -35px;
	}
	.wpcf7-response-output{
		position: absolute;
		bottom:20px;
		left:50%;
		font-size: 13px !important;
		transform: translateX(-50%);
	}
	.wpcf7 select, .wpcf7 .wpcf7-list-item-label { font-size:14px; line-height:1.2; }
	.wpcf7 form{max-width: 620px;
		margin:auto !important;}


}

#header .nohover{
	opacity: 1 !important;
	}

/* ----------------------------------------------------------------------
 料金プラン
---------------------------------------------------------------------- */
#pricing-plans {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 40px;
	flex-wrap: wrap;
}

.pricing-plan {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    padding: 15px;
    text-align: left;
    width: 300px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    height: 660px;
}

.pricing-plan-best {
	border: 3px solid var(--color1);
}

@media screen and (max-width: 765px) {
    #pricing-plans {
        flex-direction: column;
        align-items: center;
    }

    .pricing-plan {
        width: 100%;
        max-width: 300px;
    }
}

.pricing-plan h3 {
    font-size: 2em;
    margin-bottom: 15px;
}

.price {
    color: var(--color-text-base1);
    margin: 20px 0;
    align-self: center;
	padding-top: 40px;
	line-height: 1.2;
    font-weight: bold;
}

.price-yen {
    font-size: 2em;
}

.pricing-plan .price .price-value {
    font-size: 5em;
    font-weight: bold;
}

.price-text {
    color: var(--color-text-base2);
    font-weight: normal;
}

.discount {
    color: var(--color-text-base1);;
    background-color: #EEE;
    border-radius: 4px;
    display: inline-block;
	padding: 3px;
	padding-left: 20px;
	padding-right: 20px;
    font-size: 0.8em;
    font-weight: normal;
}

.discount-value {
	font-size: 1.2em;
    font-weight: bold;
}

.price-month {
    color: var(--color-text-base1);
    font-size: 1.2em;
    font-weight: bold;
	padding-top: 20px;
}

.price-per-month {
    font-size: 0.8em;
    font-weight: normal;
	align-self: center;
}

.pricing-plan a {
    align-self: center;
}

.features-list {
    list-style-type: none;
    margin-top: 20px;
    padding-left: 20px;
	padding-bottom: 20px;
    font-size: 1em;
	color: var(--color-text-base2);
    align-self: flex-start;
}

.features-list li {
    margin-bottom: 10px;
	font-size: 0.9em;
	display: flex;
	align-items: center;
}

.features-list li img {
	height: 16px;
	width: 16px;
	padding-right: 10px;
}

#pricing-steps {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 40px;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
}
#pricing-steps-m {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 40px;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
    flex-direction: column;
}

.pricing-step-box {
    width: 100px;
    height: 100px;
    background-color: #fff;
	border: 3px solid #000;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    padding: 10px;
    display: flex;
    justify-content: center;
	position: relative;
    text-align: center;
}

.pricing-step-box-3 {
	padding-left: 20px;
	padding-right: 20px;
}

.pricing-step-box-end {
	border-color: red;
	color: red;
	padding: 45px 35px;
}

.pricing-step-box-end-m {
	border-color: red;
	color: red;
	padding-left: 105px;
	padding-right: 105px;
}

.pricing-step-allow {
	color: red;
}

.pricing-step-m {
	display: none;
}

@media screen and (min-width: 765px) {
	#pricing-steps {
		display: flex;
	}
	
	#pricing-steps-m {
		display: none;
	}	
}

@media screen and (max-width: 765px) {
	#pricing-steps {
		display: none;
	}
	
	#pricing-steps-m {
		display: flex;
	}	
}

#pricing-notes {
    display: flex;
    justify-content: center;
    margin-top: 20px;
}

.pricing-note {
    text-align: left;
	width: 800px;
}

@media screen and (max-width: 765px) {
    .pricing-note {
        width: 100%;
        max-width: 400px;
    }
}

.pricing-cc {
    width: 93px;
    position: absolute;
    right: -75px;
    bottom: -40px;
}

@media screen and (max-width: 765px) {
    .pricing-cc {
    	width: 70px;
        right: -10px;
    }
}

.condition ul {
	list-style: inside;
}

.plan-comment {
    color: var(--color-text-base1);
	align-self: center;
    text-align: center;
    font-weight: bold;
}

.plan-comment-header {
    font-size: 1.2em;
    font-weight: bold;
}

/* ----------------------------------------------------------------------
 チラシダウンロード
---------------------------------------------------------------------- */
#download-banner {
	
}

@media screen and (min-width: 765px) {
	#download-banner {
		display: contents;
	}
}

@media screen and (max-width: 765px) {
	#download-banner {
		display: none;
	}
}

.download-banner-box {
	width: 380px;
    height: 170px;
    background-color: #C1E5F5;
	border: 1px solid #99CCFF;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
	padding: 10px;
    gap: 10px;
    display: flex;
}

.download-banner-box img {
    object-fit: cover;
	width: 110px;
    height: 150px;
}

.download-banner-box-items {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.download-banner-box-item-header {
	align-self: flex-start;
	padding-top: 10px;
	font-size: 1em;
	font-weight: bold;
	letter-spacing: -0.03em;
}

.download-banner-box-item {
	align-self: flex-start;
	padding: 10px;
	font-size: 0.8em;
	font-weight: normal;
	letter-spacing: -0.03em;
}

.top-page-padding-top {
	padding-top: 20px;
}


/* ----------------------------------------------------------------------
 投稿用
---------------------------------------------------------------------- */
.post-group .post-line-height_1 {
	line-height: 1; /* 行間 */
}

.post-group .post-margin-top_0 {
	margin-top: 0px;  /* 上の余白 */
}

.post-group .post-margin-bottom_0 {
	margin-bottom: 0px;  /* 下の余白 */
}

.post-group .post-padding-bottom_0 {
	padding-bottom: 0px; /* 下の内側の余白 */
}

.post-group table tr:first-child td {
	background-color: var(--color4);
	font-weight: bold;
}
