﻿@charset "utf-8";
/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
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, 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,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
a {
text-decoration: none;
}
button{
background-color: transparent;
border: none;
cursor: pointer;
outline: none;
padding: 0;
appearance: none;
}
/* =========================================================
◆base
========================================================= */
body{
	font-family: "メイリオ" , "A-OTF 新ゴ Pro",A-OTF Shin Go Pro,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
@media only screen and (max-width: 480px){
	body{
		position: relative;
	}
}
#Wrap{
	width: 100%;
	color: #030303;
	background: url("/_shared/img/common/header_bg.png")top left repeat-x;
	overflow: hidden;
}
#Wrap img{
	max-width: 100%;
}
p{
	margin-bottom: 0.5em;
	font-size: 15px;
	line-height: 1.75;
}
@media only screen and (max-width: 480px){
	p{
		font-size: 14px;
	}
}
a{
	color: #030303;
}
@media only screen and (min-width: 481px){
	a:hover{
		color: #88ba1d;
	}
}
#Main{
	background: #f8f7ee;
	padding-bottom: 140px;
}
.main_inner{
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 0 140px;
}
@media only screen and (max-width: 480px){
	.main_inner{
		width: 94%;
	}
}
/* =========================================================
◆parts
========================================================= */
.cFix:after{
	content:"";
	display:block;
	clear:both;
}
@media only screen and (min-width: 481px){
	.left{
		float: left;
	}
	.right{
		float: right;
	}
}
@media only screen and (max-width: 480px){
	.pc{
		display: none !important;
	}
}
@media only screen and (min-width: 481px){
	.sp{
		display: none !important;
	}
}
.listbox{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.listbox .item{
  display: block;
  width: 100%;
}
/* =========================================================
◆module
========================================================= */
.color01{color: #88ba1d;}
.color02{color: #dc9917;}
.color03{color: #b40e1d;}
.color04{color: #e987b2;}
/* =========================================================
◆common section
========================================================= */
header{
	max-width: 1100px;
	margin: 0 auto;
	padding: 12px 0;
}
@media only screen and (max-width: 480px){
	header{
		max-width: 94%;
	}
}
header .logo_block{
	margin-top: 16px;
}
header #Gnav ul{
	width: 450px;
  text-align: center;
}
header #Gnav li{
	padding-top: 40px;
  font-size: 1rem;
	font-weight: bold;
	position: relative;
}
@media only screen and (max-width: 480px){
	header #Gnav ul{
		margin-top: 10%;
	}
	header #Gnav li{
		display: block;
		width: 80%;
		margin: 0 auto 2rem;
    padding: 3rem 0 1rem;
		border-bottom: 1px solid #89b034;
	}
	header #Gnav li:last-child{
		border-bottom: none;
	}
}
header #Gnav li::before{
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	height: 34px;
	background-repeat: no-repeat;
}
header #Gnav .practice_icn::before{
	width: 36px;
	margin-left: -13px;
	background: url("/_shared/img/common/icn_header_001.png");
}
header #Gnav .lesson_icn::before{
	width: 36px;
	margin-left: -13px;
	background: url("/_shared/img/common/icn_header_002.png");
}
header #Gnav .school_icn::before{
	width: 58px;
	margin-left: -29px;
	background: url("/_shared/img/common/icn_header_003.png");
}
@media only screen and (max-width: 480px){
}
header #Gnav li a{
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
}
@media only screen and (max-width: 480px){
	header #Gnav li a{
		display: block;
		color: #fff;
	}
}
header #Gnav li span{
	display: block;
	font-size: 0.8em;
}
@media only screen and (max-width: 480px){
	#toggle_btn {
		position: fixed; /* bodyに対しての絶対位置指定 */
		right: 12px;
		top: 12px;
		display: block;
		width: 45px;
		height: 50px;
		cursor: pointer;
		z-index: 3;
		text-align: center;
		border-radius: 8px;
		background: rgb(255,255,255,0.5);
	}
	#toggle_btn span {
		display: block;
		position: absolute; /* .toggleに対して */
		width: 70%;
		border-bottom: solid 3px #89b034;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
		padding-top: 5px;
		right: 7px;
	}
	#toggle_btn span:nth-child(1) {
		top: 3px;
	}
	#toggle_btn span:nth-child(2) {
		top: 13px;
	}
	#toggle_btn span:nth-child(3) {
		top: 23px;
	}
	#toggle_btn span:nth-child(4) {
		border: none;
		top: 28px;
		left: 5px;
		font-size: 0.8em;
		color: #89b034;
	}
	/* 最初のspanをマイナス45度に */
	#toggle_btn.active span:nth-child(1) {
		top: 15px;
		left: 4px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	/* 2番目と3番目のspanを45度に */
	#toggle_btn.active span:nth-child(2),
	#toggle_btn.active span:nth-child(3) {
		top: 15px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	header #Gnav {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		transform: translateY(-100%);
		z-index: 2;
		padding-top: 50px;
		text-align: center;
		background: rgb(255,255,255,0.9);
		transition: all 0.5s;
		border-top: none;
		border-bottom: none;
	}
	header #Gnav.active {
		transform: translateY(0%);
	}
}
/* =========================================================
◆main
========================================================= */
.main_area{
	width: 800px;
}
@media only screen and (max-width: 480px){
	.main_area{
		width: 100%;
	}
}
.box{
	border-radius: 5px;
	background: #fff;
	filter: drop-shadow(0 0 2px rgba(0,0,0,0.6));
}
/* =========================================================
◆side
========================================================= */
.side_area{
	width: 270px;
}
@media only screen and (max-width: 480px){
	.side_area{
		width: 100%;
	}
}
.search_box{
	padding: 20px 20px 15px;
	text-align: center;
	background: #FFF;
}
.search_box h3{
	font-size: 1.1rem;
	font-weight: bold;
}
.search_box h3::first-letter{
	color: #2294c5;
}
.search_box span{
	font-size: 0.8rem;
	margin-bottom: 10px;
}
.search_box form{
	position: relative;
	margin-top: 10px;
}
.search_box .form_input{
	position: absolute;
	width: 100%;
	height: 30px;
	left: 0;
	top: 0;
	padding: 0 10px;
	border:solid 1px #c7c7c7;
}
.search_box .form_button{
	position: absolute;
	height: 30px;
	right: 0;
	top: 0;
	padding: 0 6px;
	color: #fff;
	font-size: 1rem;
	background-color: #89b034;
}
.search_box ul{
	margin-top: 55px;
	text-align: left;
}
.search_box ul li{
	margin: 0 10px 8px;
	font-size: 0.8rem;
	position: relative;
}
.search_box li a::before{
	content: "";
	position: absolute;
	top: 0;
	left: -15px;
	width: 12px;
	height: 12px;
	background: url("/_shared/img/common/icn_side_search_002.png");
}
.banner_area li{
	margin-bottom: 10px;
}
/* =========================================================
◆footer
========================================================= */
footer{
	padding: 40px 0 20px;
	background: url("/_shared/img/common/footer_bg_001.png")no-repeat right bottom;
}
footer a:hover{
	color: #8cd335;
}
footer .inner{
	max-width: 1100px;
	margin: 0 auto;
}
@media only screen and (max-width: 480px){
	footer .inner{
		max-width: 94%;
	}
}
footer .search_menu{
	display: inline-block;
	width: 20%;
	margin-right: 6%;
	margin-bottom: 70px;
	vertical-align: top;
}
footer .last{
	margin-right: 0;
}
footer .search_menu li{
	width: 100%;
	margin-bottom: 8px;
}
footer .search_menu li a{
	display: block;
	width: 88%;
	padding: 15px 0 15px 40px;
	border: 1px solid #a7a58a;
	color: #a7a58a;
	background-color: #fff;
	position: relative;
}
footer .search_menu li a::before{
	content: "";
	position: absolute;
	top: 50%;
	left: 20px;
	width: 6px;
	height: 6px;
	margin-top: -5px;
	border-top: 2px solid #a7a58a;
	border-right: 2px solid #a7a58a;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
@media only screen and (max-width: 480px){
	footer .search_menu{
		width: 85%;
		margin-right: 0;
		margin-bottom: 20px;
	}
	footer .search_menu li a{
		padding: 15px 0 15px 15%;
	}
}
footer .search_menu .list_top{
	padding: 0.3rem 0 0.5rem 0.5rem;
	background: transparent;
	border-left: solid 5px;
	border-bottom: solid 1px;
}
footer .menu{
	margin-bottom: 10px;
}
footer .menu li{
	display: inline-block;
	margin-right: 1rem;
}
@media only screen and (max-width: 480px){
	footer .menu li:first-child{
		display: block;
		margin-right: 0;
		margin-bottom: 1em;
	}
}
footer .menu a{
	color: #434017;
}
footer .copy{
	font-size: 0.8rem;
	color: #a7a58a;
}
