@charset "UTF-8";

html, body, div, span, iframe, h1, h2, h3, h4, h5, h6, p, a, address, em, img, strong, center, dl, dt, dd, ol, ul, li, label, table, caption, tbody, thead, tr, th, td, article, aside, figure, figcaption, footer, header, nav, section {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font-weight: normal;
}
html, body{
	box-sizing: border-box;
	overflow-x: hidden;
}
body{
	font-family: "noto-sans-cjk-jp", sans-serif;
	color: #333;
	font-size:15px;
	line-height: 1.7;
}




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

table {
	border-collapse: collapse;
	border-spacing: 0;
}
a {
}
img {
	vertical-align: bottom;
}


.cf {
	overflow: hidden;
}


/* Heading */
h1, h2, h3, h4, h5, h6, .site-title {
	clear: both;
	font-weight: 700;
	line-height: 1.5;
}

/* Link */
a {
	color: #2D41B2;
	text-decoration: underline;
	transition: all .15s ease-in-out;
}
a:hover {
	color: #639af6;
}
cite a, cite a {
	text-decoration: none;
}

/* Text */
p {
	margin: 0;
}
b, strong {
	font-weight: 700;
}
dfn, em, i {
	font-style: italic;
}
q {
	quotes: "" "";
}
cite {
	border-bottom: dotted 1px #999;
	font-style: normal;
}
code, kbd, tt, var {
	background-color: #f4f5f6;
	color: #666;
	font-family: Consolas, "Courier New", monospace;
	font-size: 90%;
}
abbr, acronym {
	border-bottom: 1px dotted #999;
	cursor: help;
}
mark, ins {
	background: linear-gradient( transparent 70%, #ffff66 70% );
	text-decoration: none;
}
ins.adsbygoogle {
	background-color: transparent;
}

/* List */
ol, ul, li {
	list-style: none;
}
ul, ol {
	margin: 0;
	padding: 0;
}
li > ul,
li > ol {
	margin-bottom: 0;
}
dl {
	margin: 0;
}
dt {
	font-weight: 600;
	margin-bottom: 0
}
dd {
	margin: 0;
}

/* Table */
table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 90%;
	margin: 0 0 1.8em;
	width: 100%;
}
caption {
	margin-bottom: 0.6em;
}
table th, table td {
	border: solid 1px #eee;
	padding: 1em 1.2em;
}
th {
	background-color: #f4f5f6;
	font-weight: 600;
	text-align: left;
}

/* Elements */
blockquote {
	color: #666;
	margin: 0 0 2em;
	padding: 12px 0 0 44px !important;
	position: relative;
}
blockquote:before {
	color: #ddd;
	content: "\201C";
	font-family: Georgia, serif;
	font-size: 84px;
	left: -5px;
	line-height: 1;
	position: absolute;
	top: -5px;
}
blockquote p {
	margin-bottom: 0.8em;
}
blockquote cite {
	font-size: 90%;
}
address {
	margin: 0 0 1.8em;
	font-style: normal;
}
pre {
	background-color: #f4f5f6;
	color: #666;
	font-family: Consolas, "Courier New", monospace;
	font-size: 90%;
	line-height: 1.4;
	margin: 0 0 1.7em;
	max-width: 100%;
	overflow: auto;
	padding: 1.5em;
	word-wrap: normal;
}
hr {
	background-color: #eee;
	border: 0;
	height: 2px;
	margin: 1.8em auto;
}
.wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
	max-width: 100px;
}

/* Media */
img {
	height: auto;
	max-width: 100%;
	vertical-align: middle;
}
figure {
	margin: 0;
}
embed,
iframe,
object {
	max-width: 100%;
}

/* Form */
button,
input,
input[type="search"],
select,
textarea {
	background-color: #fff;
	box-sizing: border-box;
	line-height: 1.6;
	max-width: 100%;
}
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	background-color: #333;
	border: none;
	border-radius: 5px;
	color: #fff;
	cursor: pointer;
	font-size: 90%;
	line-height: 1;
	padding: 1.1em 1.5em;
	text-transform: uppercase;
	transition: .3s ease-in-out;
}
button:hover,
button:focus,
input[type="button"]:hover,
input[type="button"]:focus,
input[type="reset"]:hover,
input[type="reset"]:focus,
input[type="submit"]:hover,
input[type="submit"]:focus {
	background-color: #555;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
textarea {
	border: solid 1px #e6e6e6;
	color: #777;
	margin-top: 0.6em;
	padding: 0.6em;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus {
	color: #444;
}
input[type="file"] {
	margin-top: 0.6em;
}
select {
	border: solid 1px #e6e6e6;
	padding: 0.6em;
}
textarea {
	max-width: 720px;
	width: 100%;
}


.pc_br{
	display: none;
}
.sp_br{
	display: block;
}




/* ===============================================
layout
=============================================== */

#content{
	padding-top: 100px;
}

.full_bg{
	margin-left: calc(50% - 50vw + var(--sgb-scroll-bar-width, 0px)/2) !important;
	max-width: calc(100vw - var(--sgb-scroll-bar-width, 0px)) !important;
	width: calc(100vw - var(--sgb-scroll-bar-width, 0px)) !important;
}

.top-bar-content,.main-header-content,.featured-entry-content,.home-header-content,.jumbotron-content,.site-content,.container-content,.footer-widget-content,.site-bottom-content {
	max-width: 100%!important;
	padding-left: 30px!important;
    padding-right: 30px!important;
}
.site-content{
	padding-left: 30px!important;
    padding-right: 30px!important;
	margin-left: auto;
	margin-right: auto;
}

.full_bg{
	margin-left: calc(50% - 50vw + var(--sgb-scroll-bar-width, 0px)/2) !important;
	max-width: calc(100vw - var(--sgb-scroll-bar-width, 0px)) !important;
	width: calc(100vw - var(--sgb-scroll-bar-width, 0px)) !important;
}

.full_bg__content {
	max-width: 1024px!important;
	margin:auto;
	padding:40px 20px;
}

.bg_gray{
	background-color:#F5F5F7!important;
}


.top_contents{
	padding-bottom:50px;
}

.page_heading{
	margin-bottom:20px;
}


.page_ttl{
	border-bottom:1px solid;
	border-image: linear-gradient(to right, #2D41B2, #F07B7B) 1;
	font-weight:400;
	margin:0;
	padding:0 5px 10px;
}

.page_ttl h1{
	font-size:24px;
	font-weight:400;
}
.page_ttl p{
	display:inline;
	margin-bottom:10px;
	font-size:20px;
	color:#2D41B2;
	background: linear-gradient(90deg, #2D41B2 0%, #8E6392 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.lead_text{
	padding:10px 5px 0;
}



.breadcrumb{
	padding:10px 5px 0;
}
.breadcrumb a{
	text-decoration: none;
	color:#2D41B2;
}
.breadcrumb span{
	position: relative;
	padding: 0 15px 0 10px;
}
.breadcrumb span:before{
	content: '';
	width: 4px;
	height: 4px;
	border: 0;
	border-top: solid 2px #333;
	border-right: solid 2px #333;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	left: 8px;
	bottom: 0;
	margin: auto;
}






/*ページャー*/
.pagination{
	text-align: center;
	margin: 30px 0 0;
}
.pagination .page-numbers{
	background-color:#fff;
	border:1px solid #E6E6E6;
	font-weight: bold;
}
.pagination .page-numbers:hover{
	border-color: #ccc;
}
.pagination .page-numbers.current{
	background-color:#fff;
	border-color: #ccc;
	color:#2D41B2;
}




/* ===============================================
margin,padding
=============================================== */

.mt0{
	margin-top: 0;
}
.mt5{
	margin-top: 5px;
}
.mt10{
	margin-top: 10px;
}
.mt15{
	margin-top: 15px;
}
.mt20{
	margin-top: 20px;
}
.mt30{
	margin-top: 30px;
}
.mt40{
	margin-top: 40px;
}
.mt50{
	margin-top: 50px;
}
.mt60{
	margin-top: 60px;
}
.mt70{
	margin-top: 70px;
}
.mt80{
	margin-top: 80px;
}
.mt90{
	margin-top: 90px;
}
.mt100{
	margin-top: 100px;
}


.mb0{
	margin-bottom: 0;
}
.mb5{
	margin-bottom: 5px;
}
.mb10{
	margin-bottom: 10px;
}
.mb15{
	margin-bottom: 15px;
}
.mb20{
	margin-bottom: 20px;
}
.mb30{
	margin-bottom: 30px;
}
.mb40{
	margin-bottom: 40px;
}
.mb50{
	margin-bottom: 50px;
}
.mb60{
	margin-bottom: 60px;
}
.mb70{
	margin-bottom: 70px;
}
.mb80{
	margin-bottom: 80px;
}
.mb90{
	margin-bottom: 90px;
}
.mb100{
	margin-bottom: 100px;
}
.mr0{
	margin-right: 0;
}
.mr5{
	margin-right: 5px;
}
.mr10{
	margin-right: 10px;
}
.mr15{
	margin-right: 15px;
}
.mr20{
	margin-right: 20px;
}
.mr30{
	margin-right: 30px;
}
.mr40{
	margin-right: 40px;
}
.mr50{
	margin-right: 50px;
}
.mr60{
	margin-right: 60px;
}
.mr70{
	margin-right: 70px;
}
.mr80{
	margin-right: 80px;
}
.mr90{
	margin-right: 90px;
}
.mr100{
	margin-right: 100px;
}




.ml0{
	margin-left: 0;
}
.ml5{
	margin-left: 5px;
}
.ml10{
	margin-left: 10px;
}
.ml15{
	margin-left: 15px;
}
.ml20{
	margin-left: 20px;
}
.ml30{
	margin-left: 30px;
}
.ml40{
	margin-left: 40px;
}
.ml50{
	margin-left: 50px;
}
.ml60{
	margin-left: 60px;
}
.ml70{
	margin-left: 70px;
}
.ml80{
	margin-left: 80px;
}
.ml90{
	margin-left: 90px;
}
.ml100{
	margin-left: 100px;
}


/* 管理バー表示時だけ */
body.admin-bar #header {
	top: 32px; /* 管理バー分 */
}
/*body.admin-bar #content {
	padding-top: calc(70px + 32px);
}*/
@media (max-width: 782px) {
	#wpadminbar {
		display: none !important;}
	html {
		margin-top: 0 !important;}
	body.admin-bar #header {
		top: 0;}
	/*body.admin-bar #content {
		margin-top: 70px;}*/
}
@media only screen and (min-width: 768px) {
	.pc_br{
		display: block;
	}
	.sp_br{
		display: none;
	}
}

/*========= 1024px〜の場合 =========*/
@media only screen and (min-width: 1024px) {
	.page_ttl h1{font-size:36px;}
	body{font-size:16px!important;}
}


@media screen and (min-width: 1240px) {
	#content{
		padding-top: 150px;
	}

	
	
	.top-bar-content,.main-header-content,.featured-entry-content,.home-header-content,.jumbotron-content,.site-content,.container-content,.footer-widget-content,.site-bottom-content,.main-header-content {
		max-width: 1180px!important;
		padding-left: 0!important;
		padding-right: 0!important;
	}
	.site-content{
		max-width: 1180px!important;
		padding-left: 0!important;
		padding-right: 0!important;
	}
	.full_bg__content {
		max-width: 1180px !important;
		padding-left: 0;
		padding-right: 0;
	}
}