@charset "utf-8";
/* -----------------------------------------------------------

駿台予備学校　共通部分　スタイル

----------------------------------------------------------- */


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

body {
	color : #333;
	margin : 0 auto !important;
	padding : 0;
}

a {
  text-decoration : none !important;
  -webkit-transition : color .2s, background-color .2s;
       -o-transition : color .2s, background-color .2s;
          transition : color .2s, background-color .2s;
}

#rendering-area{
	border: none;
}


/* ヘッダー
-------------------------------------------------------------------------*/

header *{
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

header {
	align-items : center;
	background : #fff;
	-webkit-box-align : center;
	-webkit-box-pack : justify;
	display : -webkit-box;
	display : -ms-flexbox;
	display : flex;
	-ms-flex-align : center;
	-ms-flex-pack : justify;
	height : 70px;
	justify-content : space-between;
	left : 0;
	padding : 0;
	padding : 0 5px;
	position : fixed;
	top : 0;
	width : 100%;
	z-index : 1000;
	font-family : Meiryo, "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-box-sizing : border-box;
			box-sizing : border-box;
}

/* 駿台ロゴ */

header .log a {
	display : block;
	padding : 0 5px;
}

header .log img {
	vertical-align : middle;
	width : 60px;
}


/* ナビメニュー */

header ul.h_ctg {
	display : -webkit-box;
	display : -ms-flexbox;
	display : flex;
	height : 60px;
	list-style : none;
	margin : 0;
	padding : 0;
}

header ul.h_ctg > li > a {
	color : #fff;
	display : block;
	padding : 0;
}

header ul.h_ctg > li > a span {
	display : block;
	text-align : center;
}

header ul.h_ctg > li > a [class^="icon-"],
header ul.h_ctg > li > a [class*=" icon-"] {
	font-size : 18px;
	margin : 0;
}

header span.m_cap {
	color : #fff;
	font-size : 10px;
}

header ul.h_ctg > li {
	align-items : center;
	background : #0061b1;
	border-radius : 6px;
	-webkit-box-align : center;
	-webkit-box-pack : center;
	display : -webkit-box;
	display : -ms-flexbox;
	display : flex;
	-ms-flex-align : center;
	-ms-flex-pack : center;
	height : 50px;
	justify-content : center;
	margin : 3px;
	position : relative;
	width : 50px;
	line-height: 1.5;
}

header ul.h_ctg .search_container {
	align-items : center;
	-webkit-box-align : center;
	-webkit-box-pack : center;
	display : -webkit-box;
	display : -ms-flexbox;
	display : flex;
	-ms-flex-align : center;
	-ms-flex-pack : center;
	justify-content : center;
	margin : 15px 0 8px;
}

#site-search-text{
	border-radius : 15px;
	font-size : 14px;
	height : 2.2em;
	overflow : hidden;
	padding : 3px 10px;
	width : 80%;
}

#site-search-btn{
	background : none;
	border : none;
	color : #fff;
	cursor : pointer;
	display : inline-block;
	font-family : "WebHostingHub-Glyphs";
	font-size : 2em;
	outline : none;
	padding: 0 0 0 8px !important;
	vertical-align : middle;
	border-radius:0;
	box-shadow:none;
}

header ul.h_ctg .cart{
	-webkit-box-ordinal-group:1;
	-ms-flex-order:1;
	-webkit-order:1;
	order:1;
}

header ul.h_ctg .login{
	-webkit-box-ordinal-group:3;
	-ms-flex-order:3;
	-webkit-order:3;
	order:3;
}

header ul.h_ctg .menu{
	-webkit-box-ordinal-group:5;
	-ms-flex-order:5;
	-webkit-order:5;
	order:5;
}

header ul.h_ctg .faq{
	-webkit-box-ordinal-group:2;
	-ms-flex-order:2;
	-webkit-order:2;
	order:2;
}

header ul.h_ctg .logout{
	-webkit-box-ordinal-group:4;
	-ms-flex-order:4;
	-webkit-order:4;
	order:4;
}

header .search_container input[type="text"]:focus {
	outline : 0;
}

header ul.sub_menu {
  margin-left : 10px;
}

header ul.sub_menu li {
  position : relative;
}

header ul.sub_menu li:last-child {
  margin-bottom : 20px;
}

header span.sub_type {
  font-size : 11px;
}

header .menu_pc {
	left : 6px;
	position : absolute !important;
	top : 2px;
}

header .nv_hd{
	margin-top:30px !important;
	padding: 10px 0 0 5px !important;
	border-top:1px dotted #fff !important;
}


header .faq{
	border:1px solid #0061b1 !important;
	background: #fff !important;
}

.noscroll{
	position:fixed;
	height:100%;
	width:100%;
}


#Login_edit{
	padding: 70px 0 0;
	overflow:hidden;
	-webkit-box-sizing : border-box;
			box-sizing : border-box;
}

#login-user {
	display: flex !important;
	justify-content: space-between;
	margin: 0px 0px !important;
	padding: 5px 10px 3px !important;
	vertical-align: middle !important;
	background: #d5edff;
	align-items: center;
	font-size: 16px;
	width: 100%;
	float:none;
	font-weight: normal !important;
	-webkit-box-sizing : border-box;
			box-sizing : border-box;
}

#Login_edit .if_uk {
	margin: 9px 10px 10px 20px;
	padding: 5px 10px;
	display: inline-block;
	font-size: 16px;
	background: #ffffff;
	color: #0f2d66;
	border-radius: 9px;
	box-shadow: 2px 1px 3px #036;
}

#Login_edit .if_uk span{
	font-size: 22px;
	color: #cb0000;
}

#Login_edit .if_uk a{
	color: #0f2d66;
	text-decoration:none;
}

#Login_edit .if_uk a:hover{
	color: #6a8ac7;
	text-decoration:none;
}

#logout {
	width: 50px;
	height: 50px;
	margin-top: 3px;
}

/* Mainコンテンツ
-------------------------------------------------------------------------*/
#Main{
	display:block;
}


/* ヘッダー固定分のページ内リンク対応
-------------------------------------------------------------------------*/
.In-page_link{
	padding: 70px 0 0 0;
	margin: -70px 0 0 0;
}



/* 災害情報
-------------------------------------------------------------------------*/

@-webkit-keyframes saigaiFI {
  from {
    opacity : 0;
    -webkit-transform : translateY(20px);
            transform : translateY(20px);
  }
  to {
    opacity : 1;
    -webkit-transform : translateY(0);
            transform : translateY(0);
  }
}

@keyframes saigaiFI {
  from {
    opacity : 0;
    -webkit-transform : translateY(20px);
            transform : translateY(20px);
  }
  to {
    opacity : 1;
    -webkit-transform : translateY(0);
            transform : translateY(0);
  }
}


#Disaster {
  -webkit-animation-duration : 2s;
          animation-duration : 2s;
  -webkit-animation-iteration-count : 1;
          animation-iteration-count : 1;
  -webkit-animation-name : saigaiFI;
          animation-name : saigaiFI;
	background : #fff;
	overflow : hidden;
	padding : 10px;
	text-align : center;
	width : 100%;
	line-height: 1.5;
	position:relative;
	-webkit-box-sizing : border-box;
			box-sizing : border-box;
}

#Disaster .Dis_txt {
	line-height: normal;
	padding: 5px 0 8px;
}

#Disaster .Disasterbtn a {
	display: inline-block;
	margin: 5px;

}





/*-- Footer -------------------------------------------------------------------------*/

footer{
	font-family : Meiryo, "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	background:#7fb0d8;
	padding:15px 8px 10px;
	font-size: 16px;
	-webkit-box-sizing : border-box;
			box-sizing : border-box;
}

footer .link-list{
	display:flex;
}

footer .link-list div.list1{
	width:180px;
}

footer .link-list div.list2{
	width:250px;
}

footer .link-list div.list3{
	flex-grow: 1;
}

footer h2{
	display:block;
	font-size:16px;
	margin:0 0 5px;
	padding:0px;
	font-weight:normal;
	text-shadow:0.1px 0.1px 0 #333;
	border:none;
	text-align:left;
	background:#7fb0d8;
	color: #333333;
}

/*固有のリスト表現*/
footer ul{
	margin: 0 0 20px;
	padding-left: 1.4em;
	line-height:1.7;
	color:#555555;
	list-style:disc;
}

footer li{
	text-indent:-0.3em;
	font-size:12px;
}

footer ul.li_tit li:first-child{
	text-shadow:0.1px 0.1px 0 #333;
	list-style: none;
	text-indent: -1.4em;
	font-size: 14px;
}

footer .list3 ul {
	width: 45%;
	display: inline-block;
	vertical-align: top;
	box-sizing: border-box;
}


footer a:link,
footer a:visited{
	color:#444;
}

footer a:hover{
	color:#006699;
}

footer .footer-info{
	font-size:11px;
	color:#666363;
}

footer p{
	margin:0;
	border:none !important; /*Genecode対応*/
}

.footer-info p:first-child{
	margin-bottom:8px;
}

footer .privacy{
	text-align:right;
}

footer .privacy a{
	color:#f5f5f5;
}

footer .privacy .icon-squareplay{
	vertical-align: middle;
}


#pageTop {
  display:none;
  bottom : 20px;
  position : fixed;
  right : 20px;
  line-height:1.5;
  z-index: 999;
}

#pageTop a {
  background-color : #333;
  border-radius : 30px;
  color : #fff;
  display : block;
  font-weight : bold;
  height : 43px;
  opacity : .8;
  padding : 8px 4px 0 4px;
  text-align : center;
  text-decoration : none;
  width : 43px;
  z-index : 999;
  -webkit-box-sizing : border-box;
  box-sizing : border-box;
}

#pageTop a i{
	margin: 3px 0 0 3px;
	display: inline-block;
	font-size:12px;
}

#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}




/*スマホ
---------------------------------------------------------------------------------------------------------------------------*/	
@media screen and (max-width:768px) {
#rendering-area {
	background : #fff;
	width : 100% !important;
	overflow:hidden;
}

#body-column-left.body-column{
	margin:0;
}

.body-column{
	width:100% !important;
}

#body-column-right{
	margin:0;
}

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

br.clear{
	display:none;
}

#right-column{
	display:none;
}

.menu_pc {
	left : 0;
	top : 0;
}

#login-user{
	flex-direction: column;
}

#Login_edit .if_uk{
	font-size: 14px;
}

#breadcrumb-link{
	display:none;
}

.parts-frame{
	border:none;
	box-shadow:none;
}

/*-- footer -------------------------------------------------------------------------*/	

#footer{
	width:100%;
}

footer .link-list{
	display: none;
}

footer h2 {
	text-align: center;
	
}

.link-list div.list1,
.link-list div.list2 {
	width: 98%;
}

.link-list .list3 ul { 
	width: 98%;
	text-align: center;
}

footer li {
	font-size: 14px;
	list-style: none;
	border: 1px solid #587f9f;
	padding: 5px 8px;
	margin: 8px;
	text-align: center;
	color: #fff;
	border-radius: 5px;
}

footer ul {
	padding-left: 0;
}

footer li a {
	display: block;
}

}



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

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