@charset "utf-8";

/*==================================================
layout.css
================================================== */

/* ----------------------------------------
 - common
---------------------------------------- */

body * {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}

img {
	max-width: 100%;
	width: auto;
}

a {
	text-decoration: underline;
}
a:hover {
	text-decoration: none;
}
a:hover > img {
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	opacity: 0.8;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
	zoom: 1;
}

sup {
	font-size: 12px;
}

.only_pc {
	display: block;
}

.only_sp {
	display: none;
}

.notice {
	font-size: 12px!important;
}
.indent {
	display: block;
	text-indent: -1em;
	padding-left: 1em;
}

.bold_text {
	font-weight: bold!important;
}
.text_underline {
	text-decoration: underline;
}
.red_text {
	color: #ff0000!important;
}
.lightblue_text {
	color: #37bef0!important;
}

.dot_list > li {
	padding-left: 1em;
	position: relative;
}
.dot_list > li:before {
	content: "・";
	position: absolute;
	left: 0;
	font-size: inherit;
}

.align_center {
	text-align: center;
}

@media screen and (max-width: 736px) {

	body {
		font-size: 28px;
		font-size: 3.804vw;
	}

	img {
		width: 100%;
	}

	sup {
		font-size: 20px;
		font-size: 2.7171vw;
	}

	.only_pc {
		display: none;
	}

	.only_sp {
		display: block;
	}

	.notice {
		font-size: 3.261vw!important;
	}

}

/* ----------------------------------------
 - header
---------------------------------------- */
#header {
	position: relative;
	width: 100%;
	background: #ffffff;
	padding-bottom: 4px;
}
#header:after {
	content: "";
	position: absolute;
	width: 100%;
	height: 4px;
	bottom: 0;
	background: -webkit-linear-gradient(left,rgba(5,117,189,.99) 0,rgba(48,179,231,.99) 20%,rgba(62,177,100,.99) 40%,rgba(62,177,100,.99) 60%,rgba(48,179,231,.99) 80%,rgba(5,117,189,.99) 100%);
	background: linear-gradient(to right,rgba(5,117,189,.99) 0,rgba(48,179,231,.99) 20%,rgba(62,177,100,.99) 40%,rgba(62,177,100,.99) 60%,rgba(48,179,231,.99) 80%,rgba(5,117,189,.99) 100%);
}
#header > #header_inner {
	max-width: 1040px;
	margin: 0 auto;
	padding: 10px 0;
	overflow: hidden;
}
#header .logo_left {
	float: left;
	width: 180px;
}
#header .logo_right {
	float: right;
	width: 135px;
}
@media screen and (min-width: 737px) and (max-width: 1039px){
	#header > #header_inner {
		padding: 10px 20px;
	}
}

@media screen and (max-width: 736px){
	#header > #header_inner {
		padding: 10px 3.5%;
	}

	#header .logo_left {
		width: 26.5%;
	}

	#header .logo_right {
		width: 22%;
	}
}

/* ----------------------------------------
 - contents
---------------------------------------- */
#contents_wrap {
	width: 100%;
}
.contents {
	max-width: 1040px;
	margin: 0 auto;
}

@media screen and (max-width: 736px){
	.contents {
		padding: 0 3.5%;
	}
}

/* ----------------------------------------
 - main visual
---------------------------------------- */
#main_visual {
	padding: 0 0 20px;
	margin-top: 30px;
	margin-bottom: 60px;
	color: #ffffff;
	background-color: #37bef0;
}
#main_visual > h1 {
	margin: 0 auto;
}
#main_visual .inner_area {
	padding: 20px;
	margin: 0 auto;
}
#main_visual .desc_box .section_copy_text .station_name {
	margin-right: 5px;
	display: inline-block;
	border-radius: 5px;
	color: #37bef0;
	background-color: #ffffff;
	padding: 0 10px;
	line-height: 30px;
}
#main_visual .desc_box .desc_list {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	justify-content: flex-start;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	width: 100%;
	ms-flex: 0 1 auto;
}
#main_visual .desc_box .desc_list > li {
	-ms-flex: 0 1 auto;
	margin-right: 4%;
}
#main_visual .desc_box .desc_list > li:last-child {
	margin-right: 0;
	width: 80%;
}
#main_visual .desc_box .desc_item {
	display: flex;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	justify-content: flex-start;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	flex-wrap: nowrap;
	width: 100%;
	height: 100%;
	position: relative;
}
#main_visual .desc_box .desc_item > * {
	display: flex;
	flex-direction: column;
	justify-content: center;
	-webkit-justify-content: center;
	-moz-justify-content: center;
}
#main_visual .desc_box .desc_item > dt {
	color: #37bef0;
	background-color: #ffffff;
	width: 80px;
	min-height: 80px;
	flex: none;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	border-radius: 5px;
}
#main_visual .desc_box .desc_item > dd {
	padding: 0 20px;
	width: 100%;
	font-size: 20px;
	-ms-flex: 0 1 auto;
	word-break: keep-all;
}
#main_visual .desc_box .logo_list {
	display: flex;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	justify-content: flex-start;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	flex-wrap: nowrap;
	width: 100%;
	height: 100%;
	-ms-flex: 0 1 auto;
}
#main_visual .desc_box .logo_list > li {
	padding: 0 20px;
	border-right: 1px solid #ffffff;
	-ms-flex: 0 1 auto;
	display: flex;
	align-items: center;
}
#main_visual .desc_box .logo_list > li:first-child {
	padding-left: 0;
}
#main_visual .desc_box .logo_list > li:last-child {
	padding-right: 0;
	border-right: none;
}
#main_visual .desc_box .logo_list > li * {
	width: 100%;
	display: block;
}
#main_visual .present_box {
	margin: 40px auto 0;
}
#main_visual .present_box .present_list {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	width: 100%;
	ms-flex: 0 1 auto;
}
#main_visual .present_box .present_list > li {
	width: 52%;
	-ms-flex: 0 1 auto;
}
#main_visual .present_box .present_item {
	display: flex;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	flex-wrap: nowrap;
	width: 100%;
	height: 100%;
	position: relative;
}
#main_visual .present_box .present_item > * {
	display: flex;
	flex-direction: column;
	justify-content: center;
	-webkit-justify-content: center;
	-moz-justify-content: center;
}
#main_visual .present_box .present_item > dt {
	width: 180px;
	flex: none;
	background-color: #cccccc;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
#main_visual .present_box .present_item > dd {
	color: #000000;
	background-color: #ffffff;
	padding: 20px;
	width: 100%;
	-ms-flex: 0 1 auto;
}
#main_visual .present_box .present_item > dd * {
	flex: none;
}
#main_visual .present_box .present_image {
	margin-top: 15px;
	text-align: center;
}
#main_visual .present_box #scratch {
	padding-right: 4%;
	margin-right: -4%;
	z-index: 2;
}
#main_visual .present_box #scratch .present_item:after {
	position: absolute;
	display: block;
	content: "";
	width: 8%;
	background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #ffffff 50%) no-repeat top left/100% 50.5%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #ffffff 50%) no-repeat bottom right/100% 50.5%;
	top: 0;
	bottom: 0;
	left: 100%;
	margin: 0;
}
#main_visual .present_box #scratch .present_item > dt {
	background-color: #e9546b;
}
#main_visual .present_box #scratch .present_item > dd {
	color: #e9546b;
}
#main_visual .present_box #w_chance {
	padding-left: 4%;
	z-index: 1;
}
#main_visual .present_box #w_chance .present_item:before {
	position: absolute;
	display: block;
	content: "";
	width: 8%;
	background-color: #f39800;
	top: 0;
	bottom: 0;
	left: -8%;
	margin: 0;
}
#main_visual .present_box #w_chance .present_item > dt {
	background-color: #f39800;
}
#main_visual .present_box #w_chance .present_item > dt > .strong_text {
	font-size: 60px;
	line-height: 1;
}
#main_visual .present_box #w_chance .present_item > dd {
	color: #f39800;
}
#main_visual .download_box {
	margin: 40px auto 0;
	max-width: 100%;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	-webkit-align-items: center;
	-moz-align-items: center;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
}
#main_visual .download_box .section_copy_text {
	width: 100%;
	flex: none;
}
#main_visual .download_box .download_text_area {
	width: 50%;
	text-align: center;
	flex: none;
}
#main_visual .download_box .download_text_area .search_text {
	margin: 0 auto;
	width: 59.5%;
}
#main_visual .download_box .download_text_area .detail_btn {
	margin: 20px auto 0;
	width: 74%;
}
#main_visual .download_box .download_btns {
	width: 50%;
	display: flex;
	justify-content: center;
	-webkit-justify-content: center;
	-moz-justify-content: center;
	flex: none;
}
#main_visual .download_box .download_btns > li {
	padding: 25px 10px;
	text-align: center;
}
#main_visual .download_box .download_btns > li .btn img {
	height: 60px;
}
#main_visual .download_box .download_notice {
	margin-top: 20px;
}

@media screen and (min-width: 737px){
	#main_visual .desc_box .section_copy_text .indent {
		display: inline;
		padding-left: 0;
		font-weight: normal;
	}
}
@media screen and (min-width: 737px) and (max-width: 1039px){
	#main_visual .inner_area {
		margin: 0 20px;
	}
	#main_visual .download_box .download_btns > li .btn img {
		height: 5.775vw;
	}
	#main_visual .download_box .download_btns > li .qr img {
		height: 10.667vw;
	}
}
@media screen and (max-width: 736px){
	#main_visual {
		margin: 3.533vw -3.5% 10.87vw;
		border: none;
	}
	#main_visual .inner_area {
		padding: 2.717vw 3.5%;
	}
	#main_visual .desc_box .section_copy_text {
		text-align: left;
	}
	#main_visual .desc_box .section_copy_text .station_name {
		margin-right: 1.359vw;
		padding: 0 2.038vw;
		line-height: 5.707vw;
	}
	#main_visual .desc_box .section_copy_text .indent {
		font-weight: normal;
	}
	#main_visual .desc_box .desc_list {
		display: block;
	}
	#main_visual .desc_box .desc_list > li {
		margin: 0 0 4.076vw;
	}
	#main_visual .desc_box .desc_list > li:last-child {
		width: 100%;
	}
	#main_visual .desc_box .desc_item {
		display: block;
	}
	#main_visual .desc_box .desc_item > * {
		display: block;
	}
	#main_visual .desc_box .desc_item > dt {
		width: 100%;
		min-height: auto;
		font-size: 32px;
		font-size: 4.348vw;
		line-height: 8.152vw;
	}
	#main_visual .desc_box .desc_item > dd {
		padding: 2.717vw 2.717vw 0;
		width: 100%;
		font-size: 28px;
		font-size: 3.804vw;
	}
	#main_visual .desc_box .logo_list > li {
		padding: 2.717vw;
	}
	#main_visual .present_box {
		margin: 5.435vw auto 0;
	}
	#main_visual .present_box .present_list {
		display: block;
	}
	#main_visual .present_box .present_list > li {
		width: 100%;
	}
	#main_visual .present_box .present_item {
		display: block;
		height: auto;
	}
	#main_visual .present_box .present_item > * {
		display: block;
		align-items: center;
	}
	#main_visual .present_box .present_item > dt {
		width: 100%;
		font-size: 32px;
		font-size: 4.348vw;
		line-height: 8.152vw;
	}
	#main_visual .present_box .present_item > dd {
		padding: 4.076vw 2.717vw;
	}
	#main_visual .present_box .present_image {
		margin-top: 4.076vw;
	}
	#main_visual .present_box #scratch,
	#main_visual .present_box #w_chance {
		padding: 0;
		margin: 0;
	}
	#main_visual .present_box #scratch .present_item:after,
	#main_visual .present_box #w_chance .present_item:before {
		display: none;
	}
	#main_visual .present_box #w_chance .present_item > dt > .strong_text {
		font-size: inherit;
		line-height: inherit;
	}
	#main_visual .download_box {
		margin: 5.435vw auto 0;
		display: block;
	}
	#main_visual .download_box .download_text_area {
		width: 88%;
		margin: 0 auto;
	}
	#main_visual .download_box .download_text_area .search_text {
		width: 77.5%;
	}
	#main_visual .download_box .download_text_area .detail_btn {
		margin: 2.717vw 0 0;
		width: auto;
	}
	#main_visual .download_box .download_btns {
		width: 100%;
		margin: 4.076vw auto;
		padding: 0 9.5%;
		justify-content: space-between;
		-webkit-justify-content: space-between;
		-moz-justify-content: space-between;
	}
	#main_visual .download_box .download_btns > li {
		margin: 0 ;
		width: auto;
		padding: 0;
		background: none;
	}
	#main_visual .download_box .download_btns > li:nth-child(1) {
		width: 42.5%;
	}
	#main_visual .download_box .download_btns > li:nth-child(2) {
		width: 53%;
	}
	#main_visual .download_box .download_btns > li .btn img {
		height: auto;
	}
	#main_visual .download_box .download_notice {
		flex: 1;
		margin-top: 2.717vw;
	}
}

/* ----------------------------------------
 - section
---------------------------------------- */
section {
	margin-bottom: 80px;
}

section .section_inner {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 20px;
}
section .section_title {
	font-size: 36px;
	font-weight: bold;
	line-height: 66px;
	text-align: center;
	margin-bottom: 30px;
	color: #37bef0;
	border-top: 4px solid #37bef0;
	border-bottom: 4px solid #37bef0;
}
section .section_sub_title {
	font-size: 26px;
	font-weight: bold;
	line-height: 40px;
	margin-bottom: 5px;
	color: #37bef0;
}
section .section_copy_text {
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 20px;
	color: inherit;
	text-align: center;
	line-height: 1.5em;
}
section .item_list {
	margin-top: 20px;
}
section .item_list > li {
	margin-bottom: 30px;
	padding-bottom: 30px;
	border-bottom: 1px dotted #cccccc;
}
section .item_list > li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
section .item_list > li > *:last-child {
	margin-bottom: 0;
}
section .item_list > li p:not(.notice) {
	margin: 10px 0;
}
section .image {
	margin: 10px 0;
	text-align: center;
}
section .text_list + .text_list {
	margin-top: 10px;
}

@media screen and (max-width: 736px){
	section {
		margin-bottom: 10.87vw;
	} 

	section .section_inner {
		padding: 0;
	} 
	section .section_title {
		font-size: 42px;
		font-size: 5.706vw;
		line-height: 9.511vw;
		margin-bottom: 5.435vw;
	}
	section .section_sub_title {
		font-size: 32px;
		font-size: 4.348vw;
		line-height: 6.793vw;
		margin-bottom: 2.717vw;
	}
	section .section_copy_text {
		font-size: 32px;
		font-size: 4.348vw;
		margin-bottom: 4.076vw;
	}
	section .section_sub_text {
		font-size: 32px;
		font-size: 4.348vw;
		padding-bottom: 1.359vw;
		margin: 4.076vw 0 2.717vw;
		border-width: 2px;
	}
	section .item_list {
		margin-top: 5.435vw;
	}
	section .item_list > li {
		margin-bottom: 5.435vw;
		padding-bottom: 5.435vw;
		border-bottom: 2px dotted #cccccc;
	}
	section .item_list > li p:not(.notice) {
		margin: 2.717vw 0 0;
	}
	section .image {
		margin: 2.717vw auto;
	}
	section .text_list + .text_list {
		margin-top: 2.717vw;
	}
}

/* ----------------------------------------
 - pagetop
---------------------------------------- */
#pagetop {
	position: fixed;
	right: 30px;
	bottom: 30px;
	width: 50px;
	height: 50px;
	overflow: hidden;
	background: #4ccaf2 url(/railways/college/images/icon_arrow_white.png) no-repeat left top;
	background-size: cover;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	text-indent: -9999px;
	display: none;
	z-index: 9999;
	border: 1px solid #ffffff;
}
#pagetop:hover {
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	opacity: 0.8;
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
	zoom: 1;
}

#pagetop > a {
	display: block;
	width: 100%;
	height: 100%;
}
@media screen and (max-width: 736px){
	#pagetop {
		right: 3.5%;
		bottom: 7.813vw;
		width: 10.87vw;
		height: 10.87vw;	
		border-width: 2px;
	}
}

/* ----------------------------------------
 - footer
---------------------------------------- */
footer {
	background-color: #ffffff;
	position: relative;
}
#footer:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 4px;
	top: 0;
	background: -webkit-linear-gradient(left,rgba(5,117,189,.99) 0,rgba(48,179,231,.99) 20%,rgba(62,177,100,.99) 40%,rgba(62,177,100,.99) 60%,rgba(48,179,231,.99) 80%,rgba(5,117,189,.99) 100%);
	background: linear-gradient(to right,rgba(5,117,189,.99) 0,rgba(48,179,231,.99) 20%,rgba(62,177,100,.99) 40%,rgba(62,177,100,.99) 60%,rgba(48,179,231,.99) 80%,rgba(5,117,189,.99) 100%);
}
footer .footer_inner {
	max-width: 1040px;
	margin: 0 auto;
	overflow: hidden;
	padding: 14px 0 10px;
}
footer #copyright {
	float: right;
	font-size: 12px;
	line-height: 42px;
}
footer .footer_logo {
	float: left;
	width: 150px;
}
@media screen and (min-width: 737px) and (max-width: 1039px){
	footer .footer_inner {
		padding: 14px 20px 10px;
	}
}

@media screen and (max-width: 736px){
	footer .footer_inner {
		max-width: 1040px;
		margin: 0 auto;
		overflow: hidden;
		padding: 2.717vw 0 1.369vw;
	}
	footer #copyright {
		float: none;
		text-align: center;
		font-size: 2.717vw;
		line-height: 6.793vw;
	}
	footer .footer_logo {
		float: none;
		padding: 0;
		width: 36%;
		margin: 0 auto 1.369vw;
	}
}

/* download */
#download .search_text {
	width: 286px;
	margin: 25px auto 20px;
}
#download .detail_btn {
	width: 350px;
	margin: 0 auto 30px;
}
#download .downloads {
	width: 680px;
	margin: 35px auto 40px;
	display: flex;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
}
#download .downloads > li {
	width: 340px;
	text-align: center;
}
#download .downloads img {
	width: 100%;
}
#download .downloads .appstore {
	width: 160px;
	margin: 20px auto;
}
#download .downloads .googleplay {
	width: 200px;
	margin: 20px auto;
}
#download .downloads .qr {
	width: 120px;
	margin: 20px auto 0;
}
@media screen and (max-width: 736px){
	#download .search_text {
		width: 64%;
		margin: 5.435vw auto 4.076vw;
	}
	#download .detail_btn {
		width: 82.5%;
		margin: 0 auto 4.755vw;
	}
	#download .downloads {
		width: 76%;
		margin: 4.755vw auto;
	}
	#download .downloads > li {
		float: none;
		width: auto;
		padding: 0;
		background: none;
		margin: 0 2%;
	}
	#download .downloads > li:nth-child(1) {
		width: 42.5%;
	}
	#download .downloads > li:nth-child(2) {
		width: 53%;
	}
	#download .downloads img {
		width: 100%;
	}
	#download .downloads .appstore {
		width: 100%;
		margin: 0;
	}
	#download .downloads .googleplay {
		width: 100%;
		margin: 0;
	}
}