@charset "UTF-8";
/*
Theme Name: （2023.7）theme-izumi
Theme URI: http://www.magical-remix.co.jp/
Description: 泉自動車学校様専用テンプレート（Web入校フォーム／Googleフォーム変更）
Author: 
Author URI: 
Version: 2.0
*/
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700&display=swap');

/* body,Anchor
------------------------------------------------*/
* { box-sizing: border-box; }
body {
	background: #fff;
	margin: 0;
	padding: 0;
	line-height: 1.8;
	font-weight: normal;
	font-style: normal;
	font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
	font-size: 15px;
	color: #333;
}
a { overflow: hidden; }
a:link,
a:visited {
	color: #005481;
	transition: 0.5s;
}
a:hover {
	text-decoration: none;
	color: #005481;
	transition: 0.5s;
}
a:hover img {
	opacity: 0.8;
	transition: 0.5s;
}
ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
input,textarea {
	border: 1px solid #ccc;
	padding: 3px;
	font-size: 15px;
}
.inner {
	width: 1000px;
	margin: 0 auto;
}
.align-right {
	text-align: right;
}
.flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.morebtn a {
	position: relative;
	display: block;
	padding: 4px 50px 4px 40px;
	font-size: 15px;
	color: #fff;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.1em;
	background: #0074C6;
	border: 2px solid #0074C6;
	border-radius: 25px;
	text-decoration: none;
}
.morebtn a:hover {
	background: #fff;
	color: #0074C6;
}
.morebtn a::after {
	position: absolute;
	top: 50%;
	right: 25px;
	width: 6px;
	height: 6px;
	content: "";
	border-top: solid 2px #fff;
	border-left: solid 2px #fff;
	transform: translate(0, -50%) rotate(135deg);
	transition: 0.5s;
}
.morebtn a:hover::after {
	border-color: #0074C6;
}
.morebtn.long a {
	border-radius: 10px;
	letter-spacing: normal;
	font-weight: bold;
	padding: 10px 40px 10px 25px;
}
@media screen and (max-width:767px) {
	body,input,textarea {
		font-size: 14px;
	}
	button,
	[type="button"],
	[type="reset"],
	[type="submit"] {
		-webkit-appearance: button;
	}
	.inner {
		width: 100%;
		padding: 0 20px;
	}
	.wrap_box {
		position: relative;
		height: 0;
		padding-top: 56.25%;
	}
	.wrap_box iframe,
	.wrap_box object,
	.wrap_box embed {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
	.morebtn.long a {
		border-radius: 0;
		padding: 10px 30px 10px 20px;
		font-size: 13px;
	}
	.morebtn.long a::after {
		right: 20px;
	}
}

/* スクロールフェードイン */
.scroll-fade {
	opacity: 0.1;
	transition: all 500ms;
}
.scroll-fade.up {
transform: translate(0, 50px);
}
.scroll-fade.right {
transform: translate(-50px, 0);
}
.scroll-fade.left {
transform: translate(50px, 0);
}
.scroll-fade.scrollin {
opacity: 1;
transform: translate(0, 0);
}
#main {
	max-width: 100vw;
	overflow-x: hidden;/*横からのフェードインによる横スクロール発生を防ぐ*/
}
@media screen and (max-width:767px) {
	.scroll-fade.view {
		opacity: 1;
		transform: translate(0, 0);
	}
}

/* header
------------------------------------------------*/
#header {
	display: flex;
	justify-content: space-between;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	width: 100%;
	height: 100px;
	background: #fff;
	box-shadow: 0 1px 5px rgb(0,0,0,0.1);
	padding: 0 0 0 4%;
}
body {
	padding-top: 100px;
}
#header #logo {
	display: flex;
	align-items: center;
	width: 25%;
	margin: 0;
	line-height: 1;
}
#header #logo img {
	max-width: 100%;
	height: auto;
	width: 285px;
}
#nav {
	width: 65%;
}
#nav ul {
	display: flex;
}
#nav ul a {
	display: block;
	text-decoration: none;
	font-weight: bold;
}
#nav .subnav {
	justify-content: flex-end;
	height: 40px;
}
#nav .subnav a {
	color: #fff;
	text-align: center;
	line-height: 40px;
	height: 40px;
}
#nav .subnav a:hover {
	background: #fff !important;
	border-bottom: 2px solid;
}
#nav .subnav .entry {
	width: 24%;
}
#nav .subnav .entry a {
	background: #0074C6;
}
#nav .subnav .entry a:hover {
	border-color: #0074C6;
	color: #0074C6;
}
#nav .subnav .contact {
	width: 30%;
}
#nav .subnav .contact a {
	background: #FF8C00;
}
#nav .subnav .contact a:hover {
	border-color: #FF8C00;
	color: #FF8C00;
}
#nav .subnav .opencampus {
	width: 26%;
}
#nav .subnav .opencampus a {
	background: #FF000D;
}
#nav .subnav .opencampus a:hover {
	border-color: #FF000D;
	color: #FF000D;
}
#nav .subnav .students {
	width: 20%;
}
#nav .subnav .students a {
	background: #333;
}
#nav .subnav .students a:hover {
	border-color: #333;
	color: #333;
}
#nav .search-btn {
	cursor: pointer;
	display: block;
	background: #333 url("img/icon-search-white.svg") no-repeat center;
	background-size: 21px auto;
	width: 40px;
}
#nav .search-btn:hover {
	background: #fff url("img/icon-search-black.svg") no-repeat center;
	background-size: 21px auto;
	border-bottom: 2px solid #333;
	transition: 0.5s;
}
#nav .pc-block .mainnav {
	justify-content: space-around;
	margin: 17px 65px 0 0;
}
#nav .mainnav a {
	position: relative;
	display: inline-block;
	color: #333;
	padding-bottom: 2px;
}
#nav .mainnav a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #0074C6;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}
#nav .mainnav a:hover::after {
  transform: scale(1, 1);
}
.menu-trigger {
	display: block;
	position: absolute;
	top: 50px;
	right: 25px;
	z-index: 1002;
	width: 40px;
	height: 40px;
	cursor: pointer;
}
.menu-trigger .toggle-bar,
.menu-trigger .toggle-bar::before,
.menu-trigger .toggle-bar::after {
	position: absolute;
	width: 24px;
	height: 2px;
	background: #888;
	transition: all 0.2s;
}
.menu-trigger .toggle-bar {
	top: 18px;
	left: 8px;
}
.menu-trigger .toggle-bar::before,
.menu-trigger .toggle-bar::after {
	content: "";
	left: 0;
}
.menu-trigger .toggle-bar::before {
	top: -7px;
}
.menu-trigger .toggle-bar::after {
	top: 7px;
}
body.js-menu-open {
	width: 100%;
	height: 100%;
	position: fixed;
}
.js-menu-open .toggle-bar {
	background: transparent;
}
.js-menu-open .toggle-bar::before,
.js-menu-open .toggle-bar::after {
	top: 50%;
}
.js-menu-open .toggle-bar::before {
	transform: rotate(45deg);
}
.js-menu-open .toggle-bar::after {
	transform: rotate(-45deg);
}
.header-back {
	display: block;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	visibility: hidden;
	background: rgba(0, 0, 0, 0.4);
	opacity: 0;
	transition: 0.4s;
}
.js-menu-open .header-back {
	visibility: visible;
	opacity: 1;
}
#nav .slide {
	position: fixed;
	top: 0;
	right: -506px;
	z-index: 5;
	background: #fff;
	width: 506px;
	max-width: 100%;
	max-height: 100%;
	overflow: auto;
	color: #555;
	transition: right 0.4s, top  0.4s;
}
.js-menu-open #nav .slide {
	right: 0;
	box-shadow: -5px 3px 6px -4px rgba(0, 0, 0, 0.3);
}
#nav .slide .subnav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	background: url("img/bg-nav.svg") repeat;
	height: auto;
	padding: 45px 100px 20px 20px;
}
#nav .slide .subnav li {
	margin: 0 0 5px;
}
#nav .slide .subnav .entry,
#nav .slide .subnav .contact,
#nav .slide .subnav .opencampus,
#nav .slide .subnav .students {
	width: 49%;
}
#nav .slide .subnav .entry a,
#nav .slide .subnav .contact a,
#nav .slide .subnav .opencampus a,
#nav .slide .subnav .students a {
	border-radius: 5px;
	font-size: 15px;
}
#nav .slide .subnav .entry a:hover,
#nav .slide .subnav .contact a:hover,
#nav .slide .subnav .opencampus a:hover,
#nav .slide .subnav .students a:hover {
	color: #fff;
}
#nav .slide .subnav .entry a:hover {
	background: #0074C6 !important;
}
#nav .slide .subnav .contact a:hover {
	background: #FF8C00 !important;
}
#nav .slide .subnav .opencampus a:hover {
	background: #FF000D !important;
}
#nav .slide .subnav .students a:hover {
	background: #333 !important;
}
#nav .slide .mainnav {
	display: block;
	margin: 0;
	padding: 20px 100px 30px 30px;
}
#nav .slide .mainnav a {
	display: block;
	background: #0074C6;
	color: #fff;
	font-size: 15px;
	padding: 13px 20px;
	border-bottom: 2px solid #fff;
}
#nav .slide .mainnav a::after {
	content: none;
}
#nav .slide .mainnav a:before {
	position: absolute;
	top: 50%;
	right: 17px;
	width: 5px;
	height: 5px;
	content: "";
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: translate(0, -50%) rotate(135deg);
}
#nav .slide .mainnav li ul {
	display: flex;
	flex-wrap: wrap;
}
#nav .slide .mainnav li ul li {
	width: 100%;
}
#nav .slide .mainnav li ul li.half_list {
	width: 50%;
}
#nav .slide .mainnav li ul a,
#nav .slide .mainnav li.plus_list a {
	background: #fff;
	color: #0074C6;
	font-size: 13px;
	border-bottom: 2px solid #0074C6;
}
#nav .slide .mainnav li ul li.half_list:nth-child(2n) a {
	border-left: 2px solid #0074C6;
}
#nav .slide .mainnav li.plus_list a {
	border-bottom: 2px solid #ccc;
}
#nav .slide .mainnav li ul a:before,
#nav .slide .mainnav li.plus_list a:before {
	border-color: #0074C6;
}
#nav .slide .search-btn {
	background: none;
	cursor: auto;
	width: 100%;
}
#nav .slide .search-btn:hover {
	background: none;
	border: 0;
}
@media screen and (max-width:1310px) {
	#header {
		padding: 0 0 0 2%
	}
	#header #logo {
		width: 20%;
	}
	#nav {
		width: 78%;
		font-size: 14px;
	}
}
@media screen and (max-width:980px) {
	#header {
		padding: 0 0 0 1%
	}
	#header #logo {
		width: 13%;
	}
	#nav {
		width: 86%;
		font-size: 13px;
	}
}
@media screen and (max-width:767px) {
	#header {
		padding: 0 0 0 4%;
		height: 56px;
	}
	body {
		padding-top: 56px;
	}
	#header #logo {
		width: 150px;
	}
	#nav {
		width: auto;
	}
	.menu-trigger {
		top: 0;
		right: 0;
		width: 56px;
		height: 56px;
		background: #0074C6;
	}
	.menu-trigger .toggle-name {
		position: absolute;
		left: 0;
		bottom: 5px;
		width: 100%;
		text-align: center;
		font-family: 'Montserrat', sans-serif;
		font-size: 10px;
		color: #fff;
	}
	.menu-trigger .toggle-name:before {
		content: "MENU";
	}
	.menu-trigger .toggle-bar,
	.menu-trigger .toggle-bar::before,
	.menu-trigger .toggle-bar::after {
		width: 22px;
		background: #fff;
	}
	.menu-trigger .toggle-bar {
		top: 20px;
		left: 18px;
	}
	.menu-trigger .toggle-bar::before {
		top: 6px;
	}
	.menu-trigger .toggle-bar::after {
		top: -6px;
	}
	.js-menu-open .toggle-name:before {
		content: "CLOSE";
	}
	.js-menu-open .toggle-bar {
		background: transparent;
	}
	.js-menu-open .toggle-bar::before, .js-menu-open .toggle-bar::after {
		top: 50%;
	}
	#nav .pc-block {
		display: none;
	}
	#nav .slide {
		top: 56px;
		right: -100vw;
		width: 100vw;
		max-width: 100%;
		max-height: calc(100% - 56px);
		-webkit-overflow-scrolling: touch;
	}
	#nav .slide .subnav {
		padding: 20px;
	}
	#nav .slide .mainnav {
		padding: 0;
	}
	#nav .slide .subnav .entry a,
	#nav .slide .subnav .contact a,
	#nav .slide .subnav .opencampus a,
	#nav .slide .subnav .students a {
		font-size: 13px;
	}
}

/* area-title
------------------------------------------------*/
#area-title {
	background: #EBF8FF;
	height: 300px;
}
#area-title .inner {
	display: flex;
	align-items: center;
	height: 100%;
}
#area-title h1 {
	background: rgba(255,255,255,0.75);
	margin: 0;
	padding: 30px 50px;
	font-size: 36px;
	letter-spacing: 0.1em;
	color: #0074C6;
}
@media screen and (max-width: 767px) {
	#area-title {
		height: 200px;
	}
	#area-title h1 {
		padding: 20px 30px;
		font-size: 26px;
		letter-spacing: 0.06em;
		line-height: 1.5;
		max-width: 75%;
	}
}
@media screen and (max-width: 480px) {
	#area-title {
		height: 140px;
	}
	#area-title h1 {
		margin: 0 0 0 -20px;
		padding: 15px 20px;
		font-size: 18px;
		letter-spacing: 0.04em;
	}
}

/* main
------------------------------------------------*/
#main #path {
	font-size: 14px;
	margin: 20px 0;
}
@media screen and (max-width:767px) {
	#main #path {
		font-size: 13px;
	}
	#main img {
		display: block;
		max-width: 100%;
		height: auto;
		margin: 0 auto;
	}
	#main .table_wrap {
		max-width: 700px;
		overflow-x: auto;
		background: url(img/icon-scroll.svg) no-repeat left top;
    background-size: auto 30px;
    padding-top: 35px;
	}
	#main .table_wrap:-webkit-scrollbar {
		height: 5px;
	}
	#main .table_wrap:-webkit-scrollbar-track {
		background: #F1F1F1;
	}
	#main .table_wrap:-webkit-scrollbar-thumb {
		background: #BCBCBC;
	}
	#main .table_wrap table {
		table-layout: fixed;
		min-width: 100%;
	}
	#main .table_wrap table th {
		width: 120px !important;
		min-width: 120px !important;
	}
	#main .table_wrap table th[colspan] {
		width: 240px !important;
		min-width: 240px !important;
	}
	#main .table_wrap table td {
		width: 120px !important;
		min-width: 120px !important;
	}
}

/* post
------------------------------------------------*/
#main .post-body {
	overflow: hidden;
	padding-bottom: 50px;
}
#main .post-body:after {
	content: "";
	display: block;
	clear: both;
}
#main .post-body h2 {
	background: #EBF8FF;
	margin: 50px 0 30px;
	padding: 10px 30px;
	border-top: 3px solid #0074C6;
	line-height: 1.5;
	font-size: 25px;
	font-weight: bold;
	letter-spacing: 0.1em;
}
.search #main .post-body h2,
.error404 #main .post-body h2 {
	margin-top: 0;
}
#main .post-body h3 {
	border-bottom: 1px solid #ccc;
	margin: 30px 0 20px;
	padding: 0 0 10px;
	font-size: 20px;
	font-weight: bold;
	color: #0074C6;
}
#main .post-body h4 {
	border-left: 3px solid #0074C6;
	margin: 30px 0 10px;
	padding: 0 0 0 10px;
	font-size: 16px;
	font-weight: bold;
	color: #0074C6;
}
#main .post-body ul {
	list-style: disc;
	padding: 0 0 0 2em;
}
#main .post-body table {
	width: 100%;
	border-collapse: collapse;
}
#main .post-body table th,
#main .post-body table td {
	padding: 5px 10px;
	border: 1px solid #ccc;
}
#main .post-body table th {
	background: #ebf8ff;
}
#main .post-body figure.wp-block-gallery {
	margin: 0;
}
@media screen and (max-width:767px) {
	#main .post-body h2 {
		margin: 40px 0 20px;
		padding: 10px 20px;
		font-size: 22px;
		letter-spacing: 0.05em;
	}
	#main .post-body h3 {
		margin: 20px 0 10px;
		font-size: 18px;
	}
	#main .post-body h4 {
		margin: 20px 0 10px;
		font-size: 15px;
	}
}
@media screen and (max-width:480px) {
	#main .post-body h2 {
		font-size: 18px;
	}
	#main .post-body h3 {
		font-size: 16px;
	}
	#main .post-body h4 {
		font-size: 14px;
	}
}

/* area-contact
------------------------------------------------*/
#area-contact {
	background: url("img/bg-nav.svg") repeat;
	padding: 40px 0;
}
#area-contact h2 {
	text-align: center;
	font-size: 15px;
	letter-spacing: 0.1em;
	margin: 0 0 30px;
	line-height: 1;
}
#area-contact h2 span {
	display: block;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.08em;
	font-size: 35px;
	line-height: 35px;
	margin: 0 0 20px;
}
#area-contact h2 span:first-letter {
	color: #0074C6;
}
#area-contact .flex li {
	width: 32%;
	position: relative;
}
#area-contact .flex li a {
	display: block;
	text-decoration: none;
	color: #fff;
	border-radius: 10px;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0.05em;
	height: 70px;
	line-height: 70px;
}
#area-contact .flex li a:hover {
	background: #fff !important;
}
#area-contact .flex li a:before {
	position: absolute;
	top: 50%;
	right: 17px;
	width: 5px;
	height: 5px;
	content: "";
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: translate(0, -50%) rotate(135deg);
}
#area-contact .flex .entry a {
	background: #0074C6;
	border: 2px solid #0074C6;
}
#area-contact .flex .entry a:hover {
	border-color: #0074C6;
	color: #0074C6;
}
#area-contact .flex .entry a:hover:before {
	border-color: #0074C6;
}
#area-contact .flex .entry span {
	display: block;
	position: absolute;
	top: -20px;
	left: 15px;
	background: url(img/btn-entry-comment.svg) no-repeat;
	background-size: cover;
	width: 145px;
	height: 44px;
}
#area-contact .flex .contact a {
	background: #FF8C00;
	border: 2px solid #FF8C00;
}
#area-contact .flex .contact a:hover {
	border-color: #FF8C00;
	color: #FF8C00;
}
#area-contact .flex .contact a:hover:before {
	border-color: #FF8C00;
}
#area-contact .flex .opencampus a {
	background: #FF000D;
	border: 2px solid #FF000D;
}
#area-contact .flex .opencampus a:hover {
	border-color: #FF000D;
	color: #FF000D;
}
#area-contact .flex .opencampus a:hover:before {
	border-color: #FF000D;
}
#area-contact p {
	text-align: center;
	font-size: 14px;
}
#area-contact p .freetel {
	background: url("img/icon-freetel.svg") no-repeat left center;
	background-size: auto 30px;
	padding: 0 0 0 60px;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.08em;
	font-size: 35px;
}
@media screen and (max-width:767px) {
	#area-contact .flex {
		justify-content: center;
		margin: 40px 0 0;
	}
	#area-contact .flex li {
		width: 400px;
		margin: 0 0 10px;
	}
	#area-contact p .freetel {
		font-size: 28px;
	}
}
@media screen and (max-width:480px) {
	#area-contact {
		padding: 40px 0 20px;
	}
	#area-contact h2 {
		font-size: 13px;
	}
	#area-contact h2 span {
		font-size: 24px;
		line-height: 24px;
	}
	#area-contact .flex li {
		width: 280px;
		margin: 0 0 10px;
	}
	#area-contact .flex li a {
		height: 50px;
		line-height: 50px;
		font-size: 15px;
	}
	#area-contact .flex .entry span {
		width: 123px;
		height: 36px;
	}
	#area-contact p {
		font-size: 12px;
	}
}

/* side
------------------------------------------------*/
#side {
	background: #EBF8FF;
	padding: 20px 0;
}
#side a {
	position: relative;
	display: block;
	padding: 10px 10px 10px 35px;
	text-decoration: none;
	color: #333;
}
#side a:before {
	position: absolute;
	top: 50%;
	left: 10px;
	width: 8px;
	height: 8px;
	content: "";
	border-top: solid 2px #0074C6;
	border-left: solid 2px #0074C6;
	transform: translate(0, -50%) rotate(135deg);
	transition: 0.5s;
}
#side .current_page_item a,
#side a:hover {
	color: #0074C6;
}
#side dl {
	margin: 0;
	font-weight: bold;
}
#side dt {
	font-size: 26px;
}
#side dt a {
	border-bottom: 2px solid #0074C6;
}
#side dd,
#side dd ul {
	margin: 0;
}
#side dd li a {
	border-bottom: 1px solid #0074C6;
	font-size: 18px;
}
#side dd li li a {
	padding: 10px 10px 10px 60px;
	font-weight: normal;
}
#side dd li li a:before {
	left: 35px;
}
@media screen and (max-width:767px) {
	#side dt {
		font-size: 24px;
	}
	#side dd li a {
		font-size: 17px;
	}
}
@media screen and (max-width:480px) {
	#side dt {
		font-size: 22px;
	}
	#side dd li a {
		font-size: 16px;
	}
}

/* area-slid
------------------------------------------------*/
#area-slid {
	padding-top: 20px;
}
#area-slid .slick-slide {
	margin: 0 5px;
}
#area-slid .slick-list {
	padding: 0 60px;
}
#area-slid .slick-slide img {
	max-width: 100%;
	height: auto;
}
@media screen and (max-width: 767px) {
	#area-slid .slick-list {
		padding: 0 40px;
	}

}

/* area-link
------------------------------------------------*/
#pagescroll {
	margin: 20px 0;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 0.08em;
	font-size: 16px;
	text-align: right;
}
#pagescroll a {
	display: block;
	position: relative;
	color: #0074C6;
	text-decoration: none;
	padding: 0 23px 0 0;
}
#pagescroll a:after {
	content: '';
	position: absolute;
	top: 45%;
	right: 3px;
	width: 7px;
	height: 7px;
	border-left: solid 2px #0074C6;
	border-top: solid 2px #0074C6;
	transform: rotate(45deg);
}
#pagescroll a:hover {
	opacity: 0.8;
}
#area-link a {
	text-decoration: none;
}
#area-link .btnlink li {
	width: 32%;
	margin: 0 0 20px;
}
#area-link .btnlink li a {
	display: block;
	color: #333;
	letter-spacing: 0.1em;
	height: 95px;
	line-height: 95px;
	border: 2px solid #ccc;
	border-radius: 10px;
	padding: 0 0 0 115px;
	font-weight: bold;
}
#area-link .btnlink li a:hover {
	border-color: #0074C6;
	color: #0074C6;
}
#area-link .btnlink .link01 a {
	background: #fff url("img/btnimg-footer01.jpg") no-repeat left center;
	background-size: 95px auto;
}
#area-link .btnlink .link02 a {
	background: #fff url("img/btnimg-footer02.jpg?d=2024") no-repeat left center;
	background-size: 95px auto;
}
#area-link .btnlink .link03 a {
	background: #fff url("img/btnimg-footer03.png") no-repeat left center;
	background-size: 95px auto;
}
#area-link .btnlink .link04 a {
	background: #fff url("img/btnimg-footer04.jpg") no-repeat left center;
	background-size: 95px auto;
}
#area-link .btnlink .link05 a {
	background: #fff url("img/btnimg-footer05.jpg") no-repeat left center;
	background-size: 95px auto;
}
#area-link .btnlink .link06 a {
	background: #fff url("img/btnimg-footer06.jpg") no-repeat left center;
	background-size: 95px auto;
}
@media screen and (max-width:767px) {
	#area-link .btnlink li {
		width: 48%;
	}
	#area-link .btnlink li a {
		height: 75px;
		line-height: 75px;
		padding: 0 0 0 85px;
		letter-spacing: 0.05em;
	}
	#area-link .btnlink .link01 a,
	#area-link .btnlink .link02 a,
	#area-link .btnlink .link03 a,
	#area-link .btnlink .link04 a,
	#area-link .btnlink .link05 a,
	#area-link .btnlink .link06 a {
		background-size: 75px auto;
	}
}
@media screen and (max-width:480px) {
	#area-link .btnlink li {
		width: 100%;
		margin: 0 0 10px;
	}
	#area-link .btnlink li a {
		height: 60px;
		line-height: 60px;
		padding: 0 0 0 75px;
		letter-spacing: 0.03em;
	}
	#area-link .btnlink .link01 a,
	#area-link .btnlink .link02 a,
	#area-link .btnlink .link03 a,
	#area-link .btnlink .link04 a,
	#area-link .btnlink .link05 a,
	#area-link .btnlink .link06 a {
		background-size: 60px auto;
	}
}

/* footer
------------------------------------------------*/
#footer a {
	text-decoration: none;
}
#footer .flex {
	padding: 30px 4% 20px;
}
#footer .bg {
	background: #EFEFEF;
	padding: 30px 4%;
}
#footer .footer-logo {
	width: 20%;
	margin: 0;
	padding: 0 0 10px;
}
#footer .footer-logo img {
	max-width: 100%;
	height: auto;
}
#footer .flex {
	align-items: center;
}
#footer li img {
	width: 36px;
	height: 36px;
}
#footer nav {
	width: 68%;
	text-align: right;
}
#footer nav ul,
#footer .bg,
#footer .bg ul {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#footer nav ul li a {
	position: relative;
	display: inline-block;
	font-weight: bold;
	color: #333;
}
#footer nav ul li:not(.icon) a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #0074C6;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}
#footer nav ul li a:hover::after {
  transform: scale(1, 1);
}
#footer .bg ul {
	width: 67%;
}
#footer .bg ul li a {
	color: #333;
	font-size: 12px;
}
#footer .bg ul li a:hover {
	color: #0074C6;
}
#footer .bg small {
	width: 21%;
	font-size: 14px;
	color: #888;
}
@media screen and (max-width:900px) {
	#footer nav {
		width: 76%;
		font-size: 14px;
	}
	#footer .bg ul {
		width: 75%;
	}
	#footer .bg small {
		font-size: 10px;
	}
}
@media screen and (max-width:767px) {
	#footer .flex {
		padding: 0;
	}
	#footer .bg {
		padding: 20px;
	}
	#footer .footer-logo {
		width: 100%;
		order: 1;
		margin: 30px 0;
		padding: 0;
	}
	#footer .footer-logo img {
		display: block;
		width: 245px;
		margin: 0 auto;
	}
	#footer .flex > ul {
		order: 2;
		display: flex;
		justify-content: center;
		width: 100%;
	}
	#footer .flex > ul li:last-child {
		margin: 0 0 0 40px;
	}
	#footer nav {
		width: 100%;
		order: 3;
		text-align: left;
		margin: 30px 0 0;
	}
	#footer nav ul {
		flex-wrap: wrap;
		border-top: 2px solid #0074C6;
	}
	#footer nav ul li {
		width: 50%;
		border-bottom: 2px solid #0074C6;
	}
	#footer nav ul li:nth-child(2n) {
		border-left: 2px solid #0074C6;
	}
	#footer nav ul li:last-child {
		width: 100%;
	}
	#footer nav ul li a {
		display: block;
		color: #0074C6;
		padding: 20px;
	}
	#footer nav ul li:not(.icon) a::after {
		content: none;
	}
	#footer nav ul li a:before {
    position: absolute;
    top: 50%;
    right: 17px;
    width: 5px;
    height: 5px;
    content: "";
    border-top: 2px solid #0074C6;
    border-left: 2px solid #0074C6;
    transform: translate(0, -50%) rotate(135deg);
	}
	#footer .bg {
		display: block;
	}
	#footer .bg ul {
		flex-wrap: wrap;
		width: 100%;
	}
	#footer .bg ul li {
		width: 50%;
		margin: 0 0 15px;
	}
	#footer .bg small {
		display: block;
		width: 100%;
		text-align: right;
	}
}
@media screen and (max-width:480px) {
	#footer nav ul li a {
		font-size: 12px;
	}
}

/* search-area
------------------------------------------------*/
.search-area:not(.innav) {
	display: none;
	position: fixed;
	width: 600px;
	padding: 30px;
	z-index: 2;
	border-radius: 10px;
	background: #fff;
}
#modal-bg {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.3);
	z-index: 1;
}
.search-area input {
	border: 0;
	outline: none;
}
.search-area div {
	display: flex;
	align-items: center;
	background: #fff;
	border: 2px solid #0074C6;
	border-radius: 5px;
	padding: 10px 15px;
}
.search-area .s {
	width: calc(100% - 22px);
	padding: 5px;
}
.search-area .searchbtn {
	padding: 0;
	width: 22px;
}
.search-area:not(.innav) .closebtn {
	display: block;
	background: #0074C6;
	width: 40px;
	height: 40px;
	border-radius: 20px;
	position: absolute;
	top: -20px;
	right: -20px;
	cursor: pointer;
}
.search-area:not(.innav) .closebtn:before,
.search-area:not(.innav) .closebtn:after {
	content: "";
	position: absolute;
	top: 50%;
	left: 10px;
	width: 20px;
	height: 2px;
	background: #fff;
}
.search-area:not(.innav) .closebtn:before {
	transform: rotate(45deg);
}
.search-area:not(.innav) .closebtn:after {
	transform: rotate(-45deg);
}

/* follow-btn
------------------------------------------------*/
#follow-btn {
	display: none;
}
@media screen and (max-width:767px) {
	#footer {
		padding-bottom: 50px;
	}
	.entry_form + #area-link + #footer {
		padding-bottom: 0;
	}
	#follow-btn {
		display: flex;
		position: fixed;
		left: 0px;
    bottom: 0px;
		width: 100%;
		padding: 0 3px;
	}
	#follow-btn li {
		width: 32.5%;
		position: relative;
	}
	#follow-btn li a {
		display: flex;
		align-items: center;
		justify-content: center;
		height: 100%;
		text-decoration: none;
		color: #fff;
		border: 1px solid #fff;
		border-top-left-radius: 10px;
		border-top-right-radius: 10px;
		font-size: 12px;
		font-weight: bold;
		letter-spacing: 0.05em;
		padding: 5px;
		text-align: center;
		line-height: 1.2;
	}
	#follow-btn li a:before {
		position: absolute;
		top: 50%;
		right: 10px;
		width: 5px;
		height: 5px;
		content: "";
		border-top: 2px solid #fff;
		border-left: 2px solid #fff;
		transform: translate(0, -50%) rotate(135deg);
	}
	#follow-btn .entry a {
		background: #0074C6;
		border: 2px solid #0074C6;
	}
	#follow-btn .entry span {
		display: block;
		position: absolute;
		top: -10px;
		left: 5px;
		background: url(img/btn-entry-comment-sp.svg) no-repeat;
		background-size: cover;
		width: 54px;
		height: 25px;
	}
	#follow-btn .contact a {
		background: #FF8C00;
		border: 2px solid #FF8C00;
	}
	#follow-btn .opencampus a {
		background: #FF000D;
		border: 2px solid #FF000D;
	}
}
