@media print, screen and (min-width: 768px) {
	
	body {
    	overflow-x: hidden;
	}
	
	.pc-none {
	    display: none !important;
	}
	.box {
		z-index:100;
	}
	.logo img {
		width: 260px;
	}
	.telbox {
		display: block;
		position: absolute;
		top: 10px; 
		right: 10px;
		padding: 6px 40px;
	}
	.telbox img {
		width: 250px;
		max-width: 700px;
	}
	.sp-telbox {
		display: none;
	}
	
	.outline table.sp-only {
		display: none;
	}
	
	/* グローバルナビゲーション
	----------------------------------------------------------------- */
	.gnav {
		position: relative;
		z-index: 10;
	}
	.gnav_box {
		width: 100%;
		position: absolute;
		top: -15px;
		left: 0;
		border-top: 1px solid #ddd;
		border-bottom: 1px solid #ddd;
	}
	.gnav_box nav {
		padding: 15px;
	    background: #fff;
	}
	.gnav_box .menuItems {
		display: -ms-flexbox;
	    display: flex;
	    -ms-flex-align: center;
	    align-items: center;
	    -ms-flex-pack: distribute;
	    justify-content: space-around;
	}
	.gnav_box .menuItems li{
		margin-bottom: 0;	
	}
	.gnav_box .menuItems li a {
		text-decoration: none;
		padding-bottom: 3px; /* 文字と下線に隙間を作る */
		color: #000;
		display: block;
	}
	.gnav_box .menuItems li a:after {
		content: '';
		width: 0;
		transition: all 0.3s ease;
		border-bottom: 3px solid #000;
		display: block;
	}
	.gnav_box .menuItems li a:hover:after {
		width: 100%;
		border-bottom: 3px solid #000;
	}
	
	.l-gnav__inner {
	    max-width: 1264px;
	    padding-right: 32px;
	    padding-left: 32px;
	    background-color: transparent;
	}
	.l-gnav__inner {
	    position: static;
	    width: 100%;
	    height: auto;
	    margin-right: auto;
	    margin-left: auto;
	    transition: none;
	}
	.l-gnav__button {
	    display: none;
	}
	.l-gnav__scroller {
	    position: relative;
	    border-radius: 28px;
	    background-color: #444;
	}
	.l-gnav__scroller {
	    padding: 0;
	    overflow: visible;
	}
	.l-gnav__categoryItems {
	    z-index: 1;
	    border-radius: 28px;
	    background-color: #444;
	}
	.l-gnav__categoryItems {
	    display: -ms-flexbox;
	    display: flex;
	    -ms-flex-align: center;
	    align-items: center;
	    -ms-flex-pack: distribute;
	    justify-content: space-around;
	    position: relative;
	}
	.l-gnav__categoryItem {
	    position: static;
	    -ms-flex-positive: 1;
	    flex-grow: 1;
	    overflow: hidden;
	}
	/*.is-initialized .l-gnav__link {
	    display: block;
	}
	.l-gnav__link {
	    opacity: 0;
	    visibility: hidden;
	    position: absolute;
	    width: 100%;
	    max-width: 1200px;
	    top: 0;
	    left: 0;
	    padding-top: 72px;
	    transition: opacity .1s ease-out, visibility .1s ease-out;
	}*/
	.l-gnav__headerMenu--sp {
	    display: none;
	}
	.l-gnav__categoryTitle {
	    padding: 18px 5px 17px;
	    font-size: 1.5rem;
	    line-height: 1.4;
	}
	.l-gnav__categoryTitle {
	    padding: 16px 5px 15px;
	    color: #fff;
	}
	.l-gnav__categoryTitle {
	    border-radius: 18px;
	    padding: 15px 5px 16px;
	    text-align: center;
	}
	.l-gnav__categoryItem > a::after {
	    content: "";
	    display: block;
	    position: absolute;
	    top: 50%;
	    left: 50%;
	    transform: translate(-50%, -50%);
	    width: calc(100% - 20px);
	    height: calc(100% - 20px);
	    border-radius: 28px;
	}
	div.side-menu {
		flex-basis: 300px;
		width: 250px;
		min-width: 250px;
		max-width: 250px;
		margin-top: 40px;
		font-weight: 600;
		color: #606060;
		font-size: 18px;
	}
	div.side-menu ul {
	    margin-top: 20px;
	    margin-bottom: 20px;
	    /*border-radius: 20px;
	    padding: 15px;
	    box-shadow: 0 3px 8px 0 rgba(0, 0, 0, 0.3);
	    background-color: #fff;*/
	}
	div.side-menu ul li {
	}
	div.side-menu ul li a {
		display: block;
		padding-left: 20px;
		height: 60px;
		background: url("/img/menu_tag.png") no-repeat center left;
		background-size: 250px auto;
		color: #333;
		line-height: 60px;
		font-size: 16px;
		text-decoration: none;
	}
	
	/* メインコンテンツ
	----------------------------------------------------------------- */
	main {
		margin-top: 50px;
		background: url("/img/brick_bg.png");
		background-color: #EFF1F0;
		padding: 0;
	}
	div.container {
		margin: 0 auto;
		display: -ms-flexbox;
	    display: flex;
	    -ms-flex-pack: center;
	    justify-content: center;
	    width: 100%;
	    padding: 10px;
	    max-width: 1000px;
	}
	div.top-container {
		margin: 0 auto;
	    width: 100%;
	    padding: 0 20px 20px 20px;
	    max-width: 1000px;
	}
	div.slide-box {
		max-width: 1264px;
		margin: 0 auto;
		padding: 0 20px;
	}
	
	.c-attention--top {
	    display: -ms-flexbox;
	    display: flex;
	    position: relative;
	    overflow: hidden;
	}
	.c-attention--top .c-attention__head {
	    min-width: 143px;
	    padding-top: 18px;
	    padding-bottom: 18px;
	    transition: padding 0s ease-in 0.25s;
	}
	.c-attention--top .c-attention__body {
	    display: -ms-flexbox;
	    display: flex;
	    -ms-flex-pack: center;
	    justify-content: center;
	    width: 100%;
	    border-radius: 0;
	    padding: 11px 17px 11px 19px;
	}
	.c-attention--top .c-attention__detail {
	    width: 100%;
	    padding: 6px 20px 6px 0;
	}
	.top-about {
		max-width: 600px;
		margin-left: 20px;
		text-align: center;
	}
	.about-image img {
		max-width: 500px;
	}
	
	.dl-pc-table {
		background-color: #FFF;
		border-top: 1px solid #E4E4E4;
		border-left: 1px solid #E4E4E4;
		margin: 20px 0;
		width: 100%;
		display: flex;
		flex-wrap: wrap;
	}
	.dl-pc-table dt {
		background-color: #FBFBFB;
		font-weight: bold;
	}
	.dl-pc-table dt,
	.dl-pc-table dd {
		margin-bottom: 0;
		padding: 15px;
		width: 50%;
		box-sizing: border-box;
		border-right:  1px solid #E4E4E4;
		border-bottom: 1px solid #E4E4E4;
	}
	div.day table {
		width: 100%;	
	}
	div.day th {
		width: 150px;
		padding-bottom: 50px;
	}
	div.day th.arrow {
		background: url('/img/arrow_big.png') center bottom no-repeat;
		background-size: 40px auto;
	}
	div.day td {
		padding: 0px 30px 45px 30px;
	}
	
	div.day td.colspan span {
		display: block;
		padding: 20px;
		text-align: center;
		border: 3px solid #91b4f3;
	}
	div.day img.clock {
		width: 100px;
	}
	div.day span.time {
		display: block;
		font-weight: 600;
		color: #3cb2f2;
	}

}

/*------------------------------------------------------------------------------
	
	スマホ、タブレット用表示
	
-------------------------------------------------------------------------------*/
@media only screen and (max-width: 768px) {
	
	.sp-none {
	    display: none !important;
	}
	#drawer {
	    display: block;
	    -webkit-transform: translateZ(0);
	    -webkit-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
	    -moz-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
	    -o-transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
	    transition: all 400ms cubic-bezier(0.19, 1, 0.22, 1);
	    -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	    -moz-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	    -o-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	    transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	    position: fixed;
	    right: -340px;
	    top: 0;
	    z-index: -10;
	    width: 340px;
	    height: 100%;
	    overflow-y: scroll;
	    background: #fff;
	    padding-top: 20px;
	    padding-bottom: 30px;
	    -webkit-overflow-scrolling: touch;
	}
	.gnav {
		position: fixed;
	    top: 0;
	    right: -300px;
	    width: 300px;
	    height: 100%;
	    padding-top: 50px;
	    background:#333;
	    font-size: 16px;
	    box-sizing: border-box;
	    z-index: 2
	}
	
	ul.menuItems {
		padding-left: 20px;
		padding-top: 40px;
	}
	ul.menuItems>li {
		padding: 1rem 0;
		font-weight:600;
		text-align: left;
		position: relative;
		background: url(/img/line.gif) no-repeat top left;
	}
	ul.menuItems>li i {
		position: absolute;
		top: 1.6rem;
		right: 30px;
		color:#a4cff7
	}
	ul.menuItems li:hover ul.second-level {
		display: block;
	}
	ul.menuItems li ul.second-level {
		display: none;
		position: relative;
		padding: 0;
		z-index: 1001;
	}
	ul.menuItems li ul.second-level li {
		text-align: left;
	}
	ul.menuItems li ul.second-level li a{
		display: block;
		padding-top: 6px;
		padding-left: 1em;
		text-decoration:none;
	}
	
	.recruit-box {
		display: none;
	}
	.sp-recruit-btn {
		display: block;
		position: absolute;
		bottom: 40px;
		right: 15px;
	}
	.sp-recruit-btn a {
		position: relative;
		display: inline-block;
		padding: 10px 15px 10px 40px;
		background-color: #fff;
		border: 3px solid #b7d32e;
		color: #419617;
		font-weight: 600;
		border-radius: 100vh;
		text-decoration: none;
	}
	.sp-recruit-btn .leaf-image {
		position:absolute;
		top: 2px;
		left: -5px;
		width: 40px;
	}
	.sp-recruit-box {
		margin: 15px;
		padding: 15px;
		border: 4px solid #fff;
		background-color: #a6c5ef;
		color: #443434;
		border-radius: 20px;
	}
	.sp-recruit-box .sp-recruit {
		position: relative;
	}
	.sp-recruit-box .sp-recruit .bird-image {
		position: absolute;
		top: -72px;
		right: -40px;
		width: 100px;
	}
	.sp-recruit-box ul {
		margin: 5px 0;
		padding: 8px 0 8px 30px;
		list-style-type: disc;
		border-top: dashed 2px #3f82ff;
		border-bottom: dashed 2px #3f82ff;
	}
	
	div.left-box {
		flex-basis: auto;
	    min-width: auto;
	}
	
	div.top-container {
		padding: 10px;	
	}
	.top-attention h3 {
		margin: 0;
		padding-bottom: 15px;
		background: url("/img/blackboard_line_big.png") left bottom no-repeat;
		background-size: 100% auto;
		display: -ms-flexbox;
	    display: flex;
	    -ms-flex-pack: space-between;
	    justify-content: space-between;
	}
	.top-attention h3 span.date{
		font-size: 14px;
	}
	.attention-title {
		padding: 10px 30px;
		color: #fff;
		background: url("/img/blackboard_bg.png") center center repeat-y;
		background-size: contain;
		max-height: 250px;
		overflow: auto;
	}
	/*.top-attention {
		background: url("/img/blackboard.png") center center no-repeat;
		padding: 80px 20px 30px 30px;
		width: 350px;
	    height: ;
	    background-size: 350px auto;
	}*/
	
	div.aboutname div.pc-none {
		padding: 10px 0 20px 0;
	}
	dl.dl-sp-table dt {
		margin-bottom: 0.1em;
		font-weight: 600;
		color: #ff499e;
	}
	dl.dl-sp-table dd {
		margin-bottom: 1.5em;
		padding-left: 0.5em;
		border-left: 3px solid #ff499e;
	}
	
	div.day table {
		width: 100%;	
	}
	div.day th {
		width: 120px;
		padding-bottom: 50px;
	}
	div.day th.arrow {
		background: url('/img/arrow_big.png') center bottom no-repeat;
		background-size: 40px auto;
	}
	div.day td {
		padding-bottom: 50px;
	}
	
	div.day td.colspan span {
		display: block;
		padding: 20px;
		text-align: center;
		border: 3px solid #91b4f3;
	}
	div.day img.clock {
		width: 100px;
	}
	div.day span.time {
		display: block;
		font-weight: 600;
		color: #3cb2f2;
	}
	
	.access .map .inner {
		padding-top: 100%;
	}
	.access ul li {
		padding-bottom: 5px;
		font-weight: bold;
		font-size: 16px;
	}
	.access ul li img {
		width: 40px;
		margin-right: 0.75em;
	}
	.introduce .playground h4 {
		position: absolute;
		top: 12px;
		left: 15px;
		margin: 0;
		color: white;
		background: #FEB902;
		font-size: 15px;
		padding: 10px 15px;
		box-shadow: 0 0 8px gray;
	}
	.introduce .playground .photo {
		margin-left: 15px;
		margin-right: 15px;
		border: 15px solid #fff;
		box-shadow: 0 0 8px gray;
	}
	.introduce .playing img {
		max-width: 180px;
	}
	
	.outline table.pc-only {
		display: none;
	}
	.outline table {
		width: auto;
		margin: 10px auto 5px;
	}
	.outline table th {
		background-color: #c0bbbb;
		font-weight: 200;
		font-size: 12px;
	}
	.outline table th.thread {
		background-color: #e9727e;
		font-weight: 600;
	}
	.outline table td.thread {
		background-color: #ef9fa7;
		font-weight: 600;
	}
	.outline table td.line {
		background-color: #cdcdcd;
	}
	
	/* FAQ */
	.faq>div {
		width: 100%;
	    display: block;
	}
	.faq>div div.masonry-item {
		padding: 20px 0;
		width: 100%;
	}
	.faq>div dl.box2 {
		margin-top: 40px;
	}
	
	/* ------------------ */
	#modal {
	    display: none;
	    position: fixed;
	    left: 25px;
	    top: 50%;
	    z-index: 99;
	    transform: translate(0, -50%);
	    max-width: 90%;
	    max-height: 70vh;
	    box-sizing: border-box;
	    padding: 32px;
	    border-radius: 8px;
	    background-color: #fff;
	    overflow: scroll;
	}
	.box-deco1 .box-title {
		font-size: 16px;
	}
}
/*------------------------------------------------------------------------------
	
	スマホ用表示
	
-------------------------------------------------------------------------------*/
@media only screen and (max-width: 628px) {
	
	dl.accepted {
		padding-bottom: 300px;
		background: url('/img/sakura_bg.png') bottom center no-repeat;
		background-size: 400px auto;
	}
	dl.accepted dt em.lines {
	    display: inline-block;
	    height: 60px;
	    line-height: 30px;
	}
	.wrap_scroll_table {
	  width: 300px;
	  overflow-x: scroll;
	  white-space: nowrap;
	  margin: 0 auto;
	}
	
	.scroll_table {
	  margin-top: 10px;
	  max-width: 300px;
	  margin: 0 auto;
	  text-align: center;
	}
}

@media only screen and (min-width: 769px) and (max-width: 925px) {
	.faq>div div.masonry-item {
		padding: 20px 0;
		width: 350px;
	}
}