@media all and (min-width: 641px) {
	* {
		box-sizing: border-box;
	}

	body {
		-webkit-text-size-adjust: 100%;
		-webkit-font-smoothing: antialiased;
	}

	/* 音声ブラウザ用 */
	.visually-hidden {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	a:link,
	a:visited {
		color: #231815;
		text-decoration: underline;
	}

	a:hover {
		text-decoration: none;
	}

	h2,
	h3,
	h4,
	h5,
	h6 {
		margin-bottom: 10px;
	}

	p,
	ul,
	ol,
	dl,
	table {
		margin-bottom: 10px;
	}

	html {
		font-size: 62.5%;
	}

	body {
		font-size: 1.6rem;
		font-family: "ヒラギノ角ゴPro W3", "Hiragino Kaku Gothic Pro", "Yu Gothic", "Meiryo", sans-serif;
		color: #231815;
		background: #ffffff;
		line-height: 1.75;
		word-wrap: break-word;
	}

	a {
		transition: color 0.3s ease;
	}

	img {
		display: inline-block;
		max-width: 100%;
		height: auto;
		vertical-align: bottom;
	}

	.button {
		transition: background-color 0.3s ease, transform 0.2s ease;
	}

	.blur {
		transition: all .2s ease-out;
		-webkit-filter: blur(4px);
		-moz-filter: blur(4px);
		-ms-filter: blur(4px);
		filter: blur(4px);
	}

	.container {
		width: 100%;
		min-width: 1280px;
	}

	.container-inner {
		width: 1200px;
		margin: 0 auto;
	}

	.sp {
		display: none;
	}

	#top {
		position: relative;
	}

	/* body 背景 */
	#bg-line-container {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 0;
		/* 最初は高さ0 */
		background: url(../images/common/bg.png) repeat-y center top 900px;
		background-size: 1465px auto;
		z-index: -1;
		/* コンテンツの下に配置 */
		pointer-events: none;
		/* 下端（先端）をぼかすグラデーションマスク */
		-webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) calc(100% - 150px), rgba(0, 0, 0, 0) 100%);
		mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) calc(100% - 150px), rgba(0, 0, 0, 0) 100%);
	}

	/* HEADER */
	#header {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		display: flex;
		align-items: center;
		z-index: 2000;
		transition: background-color 0.3s ease;
	}

	#header.fixed {
		background-color: rgba(255, 255, 255, 1);
		transition: background-color 0.3s ease;
		box-shadow: 0px 4px 4px -4px #b3b3b3;
	}

	#header .container-inner {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		align-items: flex-end;
		justify-content: space-between;
		padding: 50px 200px 0 50px;
		transition: padding 0.3s ease;
	}

	#header.fixed .container-inner {
		padding: 20px 200px 20px 50px;
		transition: padding 0.3s ease;
	}

#header .primary .h-logo {
		display: block;
		text-decoration: none;
		transition: width 0.3s ease;
	}

	#header.fixed .primary .h-logo img {
		width: 300px;
		transition: width 0.3s ease;
	}

	#header .secondary .pc-nav {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		margin-bottom: 0;
	}

	#header .secondary .pc-nav li {
		margin-left: 50px;
	}

	#header .secondary .pc-nav a {
		color: #fff;
		text-decoration: none;
		font-weight: bold;
	}

	#header.fixed .secondary .pc-nav a {
		color: #000080;
		transition: color 0.3s ease;
	}

	#header .h-logo a {
		display: block;
	}

	#header .h-logo:hover,
	#header .h-logo:active {
		opacity: 0.6;
	}

	#btn-nav {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 3000;
		pointer-events: none;
	}

	#btn-nav .container-inner {
		position: relative;
		width: 100%;
		min-width: 1280px;
	}

	#btn-nav button {
		position: absolute;
		top: 30px;
		right: 50px;
		z-index: 3000;
		pointer-events: auto;
	}

	#btn-nav.fixed button {
		top: 10px;
		right: 50px;
		transition: top 0.3s ease, right 0.3s ease;
	}

	#btn-nav.fixed img {
		width: 60px;
		height: 60px;
		transition: width 0.3s ease, height 0.3s ease;
	}

	#nav {
		display: none;
		position: fixed;
		width: 100%;
		top: 0;
		left: 0;
		z-index: 1000;
		background: url(../images/common/nav-bg.jpg) no-repeat center center;
		background-size: cover;
	}

	#nav .inner {
		width: 1200px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		flex-direction: row-reverse;
		margin: 0 auto;
		padding: 90px 0 90px;
	}

	#nav .nav-box {
		width: 640px;
		margin-bottom: 30px;
	}

	#nav .nav-box>ul {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
		height: 220px;
	}

	#nav .nav-box li {
		display: block;
		margin-bottom: 5px;
		font-weight: bold;
		line-height: 1.4;
		color: #231815;
	}

	#nav .nav-box>ul>li {
		width: 33%;
	}

	#nav .nav-box li a {
		display: block;
		text-decoration: none;
		color: #231815;
		cursor: pointer;
	}

	#nav .nav-box li.group {
		display: none;
	}

	#nav .nav-box li.parent>a {
		font-size: 2.4rem;
		margin-bottom: 10px;
	}

	#nav .nav-box li li {
		margin-bottom: 5px;
	}

	#nav .information {
		width: 500px;
	}

	#nav .information>span {
		display: block;
	}

	#nav .information .image {
		margin-bottom: 10px;
	}

	#nav .information .name {
		margin-bottom: 10px;
		font-size: 2.6rem;
		font-weight: bold;
	}

	#nav .information .address {
		margin-bottom: 5px;
	}

/* TITLE */
	#title {
		display: flex;
		align-items: center;
		justify-content: center;
		height: 400px;
		margin-bottom: 50px;
		background: url(../images/common/title-bg.jpg) no-repeat center bottom;
		background-size: 100% auto;
	}

	#title .title {
		color: #ffffff;
		font-size: 2.6rem;
		font-weight: bold;
		line-height: 1.2;
		text-shadow: 3px 3px 4px rgba(0, 0, 0, 0.6);
	}

	/* CONTENT */
	#content a {
		color: #231815;
		text-decoration: underline;
	}

	#content a:hover {
		text-decoration: none;
	}

	#breadcrumb {
		margin-bottom: 60px;
	}

	#breadcrumb li {
		display: inline-block;
		vertical-align: middle;
		font-size: 1.4rem;
	}

	#breadcrumb li a {
		color: #231815;
	}

	#breadcrumb li.on {
		color: #231815;
	}

	#main {
		float: left;
		width: 850px;
	}

	#side {
		float: right;
		width: 260px;
	}

	.section {
		margin-bottom: 200px;
	}

	.section-s {
		margin-bottom: 120px;
	}

	.section-ss {
		margin-bottom: 50px;
	}

	.pagetop {
		display: none;
		position: fixed;
		bottom: 10px;
		right: 10px;
		text-align: right;
		margin: 0;
		z-index: 5000;
	}

	.pagetop a {
		display: block;
	}

	.pagetop a:hover {
		text-decoration: none;
	}

	.inlink {
		margin-top: -100px;
		padding-top: 100px;
	}

	/* GMAP */
	#gmap {
		margin: 0;
	}

	#gmap .gmap-area {
		height: 550px;
		margin: 0;
	}

	#gmap .gmap-area iframe {
		width: 100%;
		height: 550px;
		margin: 0;
	}

	/* FOOTER */
	#footer {
		background: #036eb8;
		color: #ffffff;
	}

	#footer>.container-inner {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		flex-direction: row-reverse;
		margin: 0 auto;
		padding: 90px 0 0;
	}

	#footer a {
		color: #ffffff;
		text-decoration: none;
	}

	#footer #f-nav {
		width: 620px;
		margin-bottom: 30px;
		padding-top: 10px;
	}

	#footer #f-nav>ul {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
		height: 200px;
	}

	#footer #f-nav li {
		display: block;
		margin-bottom: 5px;
		line-height: 1.4;
	}

	#footer #f-nav>ul>li {
		width: 33%;
	}

	#footer #f-nav>ul>li.services>a {
		margin-bottom: 10px;
	}

	#footer #f-nav li a {
		display: block;
		cursor: pointer;
	}

	#footer #f-nav li.parent>a {
		font-size: 1.8rem;
		margin-bottom: 10px;
		font-weight: bold;
	}

	#footer #f-nav li li {
		margin-bottom: 5px;
	}

	#footer .f-sign {
		width: 500px;
	}

	#footer .f-name {
		display: block;
		margin-bottom: 10px;
	}

	#footer .f-name a {
		font-size: 2.6rem;
		font-weight: bold;
	}

	#footer .f-name a:hover {
		opacity: 0.6;
	}

	#footer .f-address {
		display: block;
		margin-bottom: 5px;
	}

	#footer .f-tel,
	#footer .f-fax {
		display: inline-block;
		vertical-align: middle;
		margin-right: 14px;
	}

	#footer #fbottom {
		padding: 10px 0;
		background: #036eb8;
	}

	#footer #fbottom a {
		color: #fff;
	}

	#footer .copyright {
		margin-bottom: 0;
		color: #fff;
		text-align: center;
	}

	/* SNIPPETS */
	/* YOUTUBE */
	/* ANCHOR */
/* BTN */
.btn-type01 a {
		position: relative;
		display: inline-block;
		padding-left: 80px;
		min-height: 42px;
		line-height: 42px;
		font-size: 2.2rem;
		font-weight: bold;
		text-decoration: none !important;
	}

	.btn-type01 a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		width: 62px;
		height: 42px;
		border-radius: 15px;
		background: url(../images/common/btn-type01.png) no-repeat center center #595757;
		background-size: 31px auto;
		transition: background-position 0.3s ease;
	}

	.btn-type01 a:hover::before {
		background-position: calc(50% + 8px) center;
	}

	.btn-type02 {
		text-align: center;
	}

	.btn-type02 a {
		font-size: 2.4rem;
		font-weight: bold;
		color: #fff !important;
		background: #036eb8;
		padding: 15px 60px;
		border-radius: 50px;
		text-decoration: none !important;
	}

	.btn-type02 a:hover {
		opacity: 0.8;
	}

	/* listmark */
	.listmark-type01>li {
		position: relative;
		padding-left: 20px;
	}

	.listmark-type01>li::before {
		content: "";
		position: absolute;
		top: 7px;
		left: 0;
		display: block;
		width: 14px;
		height: 14px;
		background: #F39800;
	}

	.listmark-temp>li {
		margin-left: 1em;
	}

	.listmark-temp>li span.mark {
		margin-left: -1em;
	}

	.listmark-disc>li {
		position: relative;
		padding-left: 15px;
		margin-bottom: 5px;
	}

	.listmark-disc>li::before {
		content: "";
		position: absolute;
		top: 0.7em;
		left: 0;
		width: 4px;
		height: 4px;
		background: currentColor;
		border-radius: 50%;
	}

	.listmark-indent>li {
		padding-left: 1em;
		text-indent: -1em;
	}

	.listmark-num>li {
		margin-left: 2em;
	}

	.listmark-num>li span.mark {
		margin-left: -2em;
	}

	/* title-level */
	.title-level01 {
		margin-bottom: 60px;
		text-align: center;
	}

	.title-level01 span {
		display: block;
		font-size: 1.6rem;
		font-weight: normal;
		margin-top: 10px;
	}

	.title-level02 {
		margin-bottom: 30px;
		padding: 20px;
		font-size: 2.4rem;
		font-weight: bold;
		background: #e2f4fd;
		border-top: 1px solid #9fa0a0;
		border-bottom: 1px solid #9fa0a0;
	}

	/* EM */
	.em-level01 {
		font-size: 2rem;
		font-weight: bold;
	}

	.em-level02 {
		font-size: 1.8rem;
		font-weight: bold;
	}

	.em-level03 {
		font-weight: bold;
	}

	/* TABLE */
	/* TYPE01 */
	table.type01 {
		width: 100%;
		background: #fff;
	}

table.type01 th,
	table.type01 td {
		padding: 20px;
		text-align: left;
		border: 1px solid #898989;
	}

	table.type01 th {
		background: #f7f8f8;
		vertical-align: top;
	}

	/* TYPE02 */
	table.type02 {
		border-top: 1px solid #C9CACA;
	}

	table.type02 tr {
		border-bottom: 1px solid #C9CACA;
	}

	table.type02 th,
	table.type02 td {
		padding: 10px 10px 10px 50px;
	}

	table.type02 th {
		background: #efeae6;
	}

	/* TEXT */
	.rq {
		color: #E60012;
		font-weight: bold;
	}

	/* box */
	.bd-box {
		padding: 20px 30px 10px;
		border: 1px solid #8A5D2C;
		border-radius: 20px;
	}

	.bd-box02 {
		padding: 20px 30px 10px;
		border: 2px dashed #a4a1a1;
		border-radius: 10px;
	}

	.bd-box03 {
		padding: 20px 30px 10px;
		border: 2px solid #F18B00;
		border-radius: 20px;
	}

	.w-box {
		padding: 20px 30px 10px;
		background-color: #ffffff;
	}

	.tri-box>.box01 {
		float: left;
		width: 300px;
		margin-right: 30px;
	}

	.tri-box>.box02 {
		float: left;
		width: 300px;
	}

	.tri-box>.box03 {
		float: right;
		width: 300px;
	}

	.tri-box>.image {
		margin-bottom: 0;
		text-align: center;
	}

	#main .tri-box>.box01,
	#main .tri-box>.box02,
	#main .tri-box>.box03 {
		width: 200px;
	}

	.half-box>.boxl {
		float: left;
		width: 460px;
	}

	.half-box>.boxr {
		float: right;
		width: 460px;
	}

	.half-box .image {
		margin-bottom: 0;
		text-align: center;
	}

	#main .half-box>.boxl,
	#main .half-box>.boxr {
		width: 310px;
	}

	.imgr-box {
		display: flex;
		justify-content: space-between;
		flex-direction: row-reverse;
	}

	.imgl-box {
		display: flex;
		justify-content: space-between;
	}

	.imgr-box .text-box,
	.imgl-box .text-box {
		width: 600px;
	}

	.imgr-box .text-box .text,
	.imgl-box .text-box .text {
		text-align: justify;
	}

	.imgr-box .image-box,
	.imgl-box .image-box {
		width: 420px;
		text-align: center;
	}

	/* EDITOR */
	.alignleft {
		float: left;
	}

	.alignright {
		float: right;
	}

	.aligncenter {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}

	blockquote.alignleft,
	img.alignleft {
		margin: 0px 24px 10px 0;
	}

	.wp-caption.alignleft {
		margin: 0 24px 10px 0;
	}

	blockquote.alignright,
	img.alignright {
		margin: 0 0 10px 24px;
	}

	.wp-caption.alignright {
		margin: 10px 0 10px 24px;
	}

	blockquote.aligncenter,
	img.aligncenter,
	.wp-caption.aligncenter {
		margin-top: 10px;
		margin-bottom: 10px;
	}

	.content-article img {
		max-width: 100%;
		height: auto;
	}

	/* MW WP Formカスタマイズ */
	.mw_wp_form .p-country-name {
		display: none;
	}

	.mw_wp_form table.type02 {
		margin-bottom: 50px;
	}

	.mw_wp_form table.type02 th {
		font-size: 2.1rem;
		font-weight: bold;
	}

	.mw_wp_form table.type02 th,
	.mw_wp_form table.type02 td {
		padding: 15px 20px;
	}

	.mw_wp_form table.type02 td .error {
		display: block;
		margin-top: 10px;
		padding: 5px 20px;
		font-size: 1.4rem;
		color: #fff;
		background: #ff5a5a;
	}

	.mw_wp_form input[type="email"],
	.mw_wp_form input[type="tel"],
	.mw_wp_form input[type="text"],
	.mw_wp_form textarea {
		padding: 10px;
		border-radius: 4px;
		border: none;
		box-shadow: 0 0 0 1px #ccc inset;
		appearance: none;
		-webkit-appearance: none;
		-moz-appearance: none;
	}

	.mw_wp_form input[type="email"]:focus,
	.mw_wp_form input[type="tel"]:focus,
	.mw_wp_form input[type="text"]:focus,
	.mw_wp_form textarea:focus {
		outline: 0;
		box-shadow: 0 0 0 2px rgb(33, 150, 243) inset;
	}

	.mw_wp_form .mwform-radio-field input {
		position: absolute;
		white-space: nowrap;
		width: 1px;
		height: 1px;
		overflow: hidden;
		border: 0;
		padding: 0;
		clip: rect(0 0 0 0);
		clip-path: inset(50%);
		margin: -1px;
	}

	.mw_wp_form .mwform-radio-field .mwform-radio-field-text {
		cursor: pointer;
		display: inline-flex;
		align-items: center;
	}

	.mw_wp_form .mwform-radio-field .mwform-radio-field-text:before {
		content: "";
		display: inline-block;
		width: 1em;
		height: 1em;
		border: 1px solid #ccc;
		border-radius: 50%;
		margin-right: 4px;
		flex-shrink: 0;
		box-sizing: border-box;
	}

	.mw_wp_form .mwform-radio-field input:checked+.mwform-radio-field-text:before {
		border: 0.3em solid rgb(33, 150, 243);
		box-sizing: border-box;
	}

	.mw_wp_form .mwform-radio-field input:checked+.mwform-radio-field-text {
		color: rgb(33, 150, 243);
	}

	.mw_wp_form .mwform-radio-field input:focus+.mwform-radio-field-text {
		color: rgb(33, 150, 243);
	}

	.mw_wp_form .mwform-checkbox-field input {
		position: absolute;
		white-space: nowrap;
		width: 1px;
		height: 1px;
		overflow: hidden;
		border: 0;
		padding: 0;
		clip: rect(0 0 0 0);
		clip-path: inset(50%);
		margin: -1px;
	}

	.mw_wp_form .mwform-checkbox-field .mwform-checkbox-field-text {
		cursor: pointer;
		display: inline-flex;
		align-items: center;
		color: #666;
		position: relative;
	}

	.mw_wp_form .mwform-checkbox-field .mwform-checkbox-field-text:before {
		content: "";
		display: inline-block;
		width: 1em;
		height: 1em;
		border: 1px solid #ccc;
		border-radius: 3px;
		margin-right: 6px;
		flex-shrink: 0;
	}

	.mw_wp_form .mwform-checkbox-field input:checked+.mwform-checkbox-field-text:before {
		border: 1px solid rgb(33, 150, 243);
		background-color: rgb(33, 150, 243);
	}

	.mw_wp_form .mwform-checkbox-field input:checked+.mwform-checkbox-field-text:after {
		content: "";
		position: absolute;
		border: solid #fff;
		border-width: 0 2px 2px 0;
		left: 0.3em;
		top: 0;
		bottom: 0;
		margin: auto;
		width: 0.4em;
		height: 0.6em;
		transform: translateY(-2px) rotate(45deg);
	}

	.mw_wp_form .mwform-checkbox-field input:checked+.mwform-checkbox-field-text {
		color: rgb(33, 150, 243);
	}

	.mw_wp_form .btn-area {
		text-align: center;
	}

	.mw_wp_form .btn-area p {
		display: inline-block;
		margin: 0 5px;
	}

	.mw_wp_form .btn-area input[type="submit"],
	.mw_wp_form .btn-area input[type="button"] {
		margin: 0 auto 30px;
		padding: 15px 100px;
		color: #ffffff;
		font-size: 2.4rem;
		font-weight: bold;
		background: url(../images/common/anchor-w01.png) no-repeat 80px 25px #C30D23;
		background-size: 10px auto;
		border-radius: 15px;
		border: none;
		cursor: pointer;
	}

	.mw_wp_form .btn-area input[type="submit"]:hover,
	.mw_wp_form .btn-area input[type="button"]:hover {
		opacity: 0.8;
	}

	.mw_wp_form .btn-area input[type="submit"].back {
		background: #ccc;
	}

	.mw_wp_form table.type02 th {
		position: relative;
		padding-right: 50px;
	}

	.mw_wp_form table th::after {
		content: "任意";
		position: absolute;
		top: 50%;
		right: 10px;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		display: inline-block;
		padding: 0 5px;
		background: #ccc;
		font-size: 1.3rem;
		border-radius: 5px;
	}

	.mw_wp_form table th.required::after {
		content: "必須";
		color: #fff;
		background: #ff3c3c;
	}

	/*=========================================
	PAGINATION (Common)
	=========================================*/
	.nav-links {
		display: flex;
		justify-content: center;
		gap: 10px;
		margin-top: 40px;
	}

	.page-numbers {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 40px;
		height: 40px;
		background: #fff;
		border: 1px solid #dcdcdc;
		color: #231815;
		transition: all 0.3s ease;
		text-decoration: none !important;
	}

	.page-numbers.current,
	.page-numbers:hover {
		background: #036eb8;
		color: #fff !important;
		border-color: #036eb8;
	}

	/*=========================================
	PAGER (Single Post)
	=========================================*/
	#pager {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}

	#pager p {
		display: flex;
	}

	#pager p.next {
		margin-left: auto;
	}

	#pager a {
		box-sizing: border-box;
		display: flex;
		align-items: center;
		width: 300px;
		text-decoration: none;
		padding: 10px;
		border: solid 1px #BFBFBF;
		font-size: 1.4rem;
		line-height: 1.6;
	}

	#pager a:hover {
		opacity: 0.8;
	}

	#pager p.prev a {
		padding-left: 30px;
		background: url(../images/common/anchor-prev.png) no-repeat left 5px center;
		background-size: 10px auto;
	}

	#pager p.next a {
		padding-right: 30px;
		background: url(../images/common/anchor-next.png) no-repeat right 5px center;
		background-size: 10px auto;
	}
}