@charset "UTF-8";
/* CSS Document */

body {
	font-family: 'Noto Sans Japanese', sans-serif; 
}
h1 {
	font-size: 30px;
	letter-spacing: 0.1em;
	line-height: 1;
	text-shadow: none;
	opacity: 0;
	font-weight: 500;
	color: #fff;
}
h2 {
    font-weight: 600;
		letter-spacing: 0.08em;
}
section.full.txt-white h2 {
    font-weight: 500;
}
h3 {
    font-weight: 600;
}
section.full.txt-white h3 {
    font-weight: 500;
}
h4 {
    font-weight: 600;
    letter-spacing: 0.08em;
}
section.full.txt-white h4 {
    font-weight: 500;
}
p {
    letter-spacing: 0.03em;
    line-height: 2em;
    text-align: justify;
}
@media screen and (max-width:750px) and (orientation: portrait){
h1 {
	font-size: 26px;
}
}


 
/*ベース背景色*/
body {
	background: #fff;
}
section,
footer {
	border-top-color: #fff;
	background: #fff;
}

/*ベース文字色*/
a,
header .nav_wrap ul li a {
	color: #000;
}
.flow ul li {
	border-color: #000;
}
header #hang ul li a:hover {
	background: #000;
}

/*ベース色--------------------------------------------------------- */
/*navの現在地文字色*/
header .nav_wrap ul li a.active {
	color: #0a6fac;
}
/*nav:hoverの文色*/
header .nav_wrap ul li a:hover {
	color: #0a6fac;
}
/*navのsecond開いてる文字色*/
header .nav_wrap ul li a.show {
	color: #0a6fac;
}
/*リンク画像:hover背景色*/
.btn1:hover .cover {
	background: #0a6fac;
}
.btn2 {
	background: #0a6fac;
}
.btn3:before {
	background: #0a6fac;
}
/*リンクテキスト:hover文字色*/
p a:hover {
	color: #0a6fac;
}
p a:after {
	color: #0a6fac;
}
/*newsアイコン色*/
.more-list article time p.new:after,
.news dt p:after {
	color: #0a6fac;
}
/*listアイコン色*/
ul.list li p:before {
	color: #0a6fac;
}
/*accessアイコン色*/
ul.access li p:before {
	color: #0a6fac;
}
/*checkboxとradio背景色*/
.contact input[type="checkbox"]:checked:before,
.contact input[type="radio"]:checked:before {
	background: #0a6fac;
}
/*submit背景色*/
.contact button[type="submit"] {
	background: #0a6fac;
}
.contact button[type="submit"]:hover {
	background: #000;
}
/*footer navの背景色*/
footer nav {
	background: #0a6fac;
}

/* header--------------------------------------------------------- */

/*headerの背景色*/
header {
	background: #fff;
}
/*contactの背景色*/
header .contact {
	background: #0a6fac;
}
header .contact a:before {
	background: #000;
}

/*contactの文字色*/
header .contact a {
	color: #fff;
}



header .logo {
	width: auto;
	padding-left: 20px;
}
header .logo img {
    max-height: 60px;
    margin: 0 auto;
}
header .nav_wrap {
    letter-spacing: 0.1em;
}
header .nav_wrap ul {
    margin-left: 40px;
}
header .sns .fb a i,
header .sns .li a i,
header .sns .ig a i {
    font-size: 2.2em;
}
header .sns .fb a img,
header .sns .li a img,
header .sns .ig a img {
	width: 27px;
	padding-top: 2px;
}
@media screen and (max-width:750px) and (orientation: portrait){
header .sns .ig a img {
	width: 22px;
	padding-top: 1px;
}
}
header .sns {
    margin-right: 30px;
}
header .sns div {
    padding-top: 2px;
		margin-left: 16px;
}
header .yoyaku {
	float: right;
	margin-right: 20px;
}
header .yoyaku a {
	color: #fff;
	background: #c1272d;
	text-align: center;
	height: 40px;
	width: 180px;
	line-height: 40px;
	border-radius: 4px;
	display: block;
}
@media screen and (max-width:750px) and (orientation: portrait){
header .logo img {
    max-height: 40px;
}
header .sns {
    margin-top: 5px;
		margin-right: 60px;
}
header .sns .fb a i,
header .sns .li a i,
header .sns .ig a i {
    font-size: 1.5em;
}
header .yoyaku {
	float: none;
	margin-right: auto;
	margin-left: 45px;
	margin-top: 50px;
}
header .yoyaku a {
	padding-right: 10px;
	padding-left: 10px;
}
}


/* contents--------------------------------------------------------- */
#contents.top main {
    height: 570px;
}
.sec_inr {
    width: 900px;
}
section .news dl:last-child {
	border-bottom: 1px solid #c9caca;
	padding-bottom: 30px;
}
.flow ul li:hover:after {
	border: 4px solid #0a6fac;
}
.btn2::before {
    background: #00557c;
}
@media screen and (max-width:750px) and (orientation: portrait){
.sec_inr {
    width: 84%;
}
}

/*slider topのリンク色*/
.slick-box_top .slick-slide p:after {
	color: #0a6fac;
}
.slick-dots li.slick-active button:before {
	color: #0a6fac;
}
.check table td:before {
	color: #0a6fac;
}
.faq article p:before {
	color: #0a6fac;
}
/*背景画像メイン*/
#contents.top main {
	background: url(../images/bg_01.jpg) no-repeat fixed center 60px;
}
@media screen and (max-width:750px) and (orientation: portrait){
#contents.top main {
	background: url(../images/main_sp.jpg) no-repeat fixed center top;
	background-size: 100% auto;
	height: 100vh;
}
}
#contents main {
	background: url(../images/bg_03.jpg) no-repeat fixed center top;
}
/*背景画像1*/
section.full.bg_img1 {
	background-image: url(../images/bg_02.jpg);
}
/*背景画像2*/
section.full.bg_img2 {
	background-image: url(../images/bg_04.jpg);
}
.flex.item {
	margin-right: -5px;
	margin-left: -5px;
	margin-top: -30px;
}
.flex.item .box {
	margin-right: 5px;
	margin-left: 5px;
}
.flex.item p {
	line-height: 1.3;
	color: #fff;
	background: #0a6fac;
	text-align: center;
	padding: 10px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
}
@media screen and (max-width:750px) and (orientation: portrait){
.flex.item .box {
	margin-bottom: 5px;
}
.flex.item .box:last-child {
	margin-bottom: 50px;
}
.flex.item p {
	height: 20px;
}
}
.gallery li {
	width: 210px;
}
@media screen and (max-width:750px) and (orientation: portrait){
.gallery li {
	width: 40vw;
}
}
.more-list {
    border-top: none;
}
.privacy-item  ul {
	margin-left: 20px;
}
.privacy-item  ul,
.privacy-item  ul li {
	list-style: disc;
}
.privacy-item ol {
	margin-left: 20px;
}
.privacy-item ol,
.privacy-item ol li {
	font-size: 14px;
	list-style-type: decimal;
}
a.btn2.half {
	width: 50%;
}

/* footer--------------------------------------------------------- */

/*footerの背景色*/
footer {
	background: #eee;
}
/*navの文字色*/
footer nav ul li a {
	color: #fff;
}
/*nav:hoverの文色*/
footer nav ul li a:hover {
	color: #fff;
}