﻿/* 
open.php 用のスタイルシート
TODO: 使っていないクラスがあると思われるので、整理する
*/
@charset "UTF-8";


/*--------------------------------------------------------------------

共通要素 

--------------------------------------------------------------------*/
* {
	-webkit-appearance: none;
	-moz-box-sizing: border-box;
}
*,
*::before,
*::after {
	box-sizing: border-box;
}
body{
	width: 100%;
	margin: 0;
	padding: 0;
	overflow-y: visible;
	background: none repeat scroll 0 0 #fff;
	-webkit-text-size-adjust: 100%;
	font-family: 'Montserrat', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
	color: #333;
	overflow-y: scroll;
    min-width: 1350px;
}
img{
	vertical-align: bottom;
	margin:0;
	padding:0;
}
.inner{
	margin:0 auto;
	position:relative;

}
.clearfix:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}
* html .clearfix {
	zoom: 1;
} /* IE6 */
*:first-child+html .clearfix {
	zoom: 1;
} /* IE7 */
.fade {
	opacity: 1;
	transition: opacity .4s ease-in-out;
	-moz-transition: opacity .4s ease-in-out;
	-webkit-transition: opacity .4s ease-in-out;
}
.fade:hover {
	opacity: 0.5;
}
.aC_pc {
	text-align: center !important;
}
br.sp {
	display: none;
}
/* max-width:480px */
@media screen and (max-width:640px){
    body{
            min-width: 100%;
    }
	.aC_pc {
		text-align: left !important;
	}
	br.sp {
		display: block;
	}
}






/* ヘッダー
-------------------------------------- */

#headArea{
	position: absolute;
	z-index: 999;
	background: #fff;
	width: 100%;
	min-width: 1280px;
	box-shadow: 0  5px 10px 2px rgba(0,0,0,0.3);
}

#headArea.standby{
	position: fixed;
	top: -243px;
    transition: top 0.5s;
}

header#project {
	padding: 20px 0;
	width: 100%;
    border-bottom: 1px solid #C8C8C8;
}

header#project .inner{
	width: 95%;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}
header#project .tcc {
	float: left;
	display: block;
	width: 200px;

    padding: 10px 0;
    border-right: 1px solid #C8C8C8;
}
header#project .tcc img {

}
header#project h1 {
	float: left;
	width:auto;
	margin: 0px 0 0 40px;
	padding: 0;
	overflow: hidden;
}
header#project h1 img {

}
#headerMenu{
    float: right;
	margin-top: 10px;
}


#headerMenu a{
    display: inline-block;
    margin: 0 0 0 5px;
    background: #8c8c8c  url("../img/arw_s_w.png") no-repeat;
    background-position : right 10px center;
    padding: 15px 30px 15px 20px;
	text-decoration: none;
	color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: bold;
    font-size: 14px;
    line-height: 16px;   
    letter-spacing: 1px;
}
#headerMenu a:hover{
	background: #faa500  url("../img/arw_s_w.png") no-repeat;
    background-position : right 10px center;
	}



#headerMenu a.openBtn{
    background: #ed2525  url("../img/arw_s_w.png") no-repeat;
    background-position : right 10px center;
}
#headerMenu a.openBtn:hover{
	background: #faa500  url("../img/arw_s_w.png") no-repeat;
    background-position : right 10px center;
}


/* max-width:640px */
@media screen and (max-width:640px){
	
#headArea{
	min-width: 100%;
	
}
	
    header#project {
        height: auto;
		width: 100%;
		padding: 0;
    }
    header#project .inner{
		width: 100%;
    }
	header#project .tcc {
        width:25%;
	    margin-top: 0px;
        padding: 10px 0 10px 5px;
        border-right: none;
	}
	header#project .tcc img {
        width: 100%;    
	}
	header#project h1 {
		float: none;
		width: 100%;
		margin: 0;
		padding: 5px 10px 10px;
		text-align: center;
		overflow: hidden;
        border-top: 1px solid #C8C8C8;
	}
	header#project h1 img {
		width: 100%;
	}
	header#project #headerMenu {
        margin:8px 2px 0 0;
  display: flex;
  justify-content: center;
  align-items: center;
	}
    	
	

#headerMenu a{

    display: inline-block;
    margin: 0 0 0 5px;
    background: #000  url("../img/arw_s_w.png") no-repeat;
    background-position : right 2px center;
    padding: 10px 18px 10px 9px;
    font-weight:normal;
    font-size: 9px;
    letter-spacing:normal;
    float: right;
    }
#headerMenu a span{
    display: none;
    }
#headerMenu a:hover{
	background: #000  url("../img/arw_s_w.png") no-repeat;
    background-position : right 2px center;
	}
#headerMenu a.openBtn{
    background: #ed2525  url("../img/arw_s_w.png") no-repeat;
    background-position : right 2px center;
    }
#headerMenu a.openBtn:hover{
	background: #faa500  url("../img/arw_s_w.png") no-repeat;
    background-position : right 2px center;
}
    
}



/* カテゴリーメニュー
-------------------------------------- */
#cateMenu {
    padding: 0px 0 0 0;
}
#cateMenu .inner{
    max-width: 1400px;
}
#cateMenu  ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
    padding: 0;
	margin: 15px 0 5px;
}
#cateMenu ul li {
	list-style: none;
	width: 300px;
	border: 3px solid #333;
	text-align: center;
	padding: 10px 5px;
	font-size: 0.9rem;
}
#cateMenu ul li:last-child {

}#cateMenu a {
	text-decoration: none;
	color: #000;
	margin: 0 5px 8px;

}






#cateMenu  a:hover {
	color: #fff;
    background: #000;

}
#cateMenu  a.select {
	color: #fff;
    background: #000;
    pointer-events: none;
}
#cateMenuSp {
    display: none;
}


#cateMenu a li{
	background: url(../img/contactIndex_arrow2.png) no-repeat;
    background-position: 10px center ;
}
#cateMenu a.select li{
	background: url(../img/contactIndex_arrow.png) no-repeat;
    background-position: 10px center ;
}

#cateMenu  a li:hover{
	background: url(../img/contactIndex_arrow.png) no-repeat;
    background-position: 10px center ;
}






/* max-width:640px */
@media screen and (max-width:640px){
#cateMenu {
    display: none;
	}
#cateMenuSp {
    display:block;
    padding: 10px;
	}
#cateMenuSp .selectbox{
    border: 2px solid #bdbdbd;
    position:relative;
    background: #000;
    color: #fff;
	}
#cateMenuSp .selectbox::after{
    position: absolute;
    top: 35%;
    right: 3%;
    margin-top: -8px;
    content: "▼";
    color:#8B8B8B;
    pointer-events: none;
	}

#cateMenuSp select{
    width: 100%;
    border: none;
    -webkit-appearance:none;
    background: #000;
    color: #fff;
    font-size: 16px;
    padding: 3px 5px;
	}
}



/* タイプメニュー
-------------------------------------- */

#typeMenu {
    padding: 0 0 0;
    border-top: 1px solid #C8C8C8;
}
#typeMenu .inner{
    max-width: 1400px;
    text-align: center;
}
#typeMenu  ul {
	margin-bottom: 10px;
}
#typeMenu ul li {
    text-align: center;
    display: inline;
	padding: 10px 30px;
	font-size: 0.9rem;

}
#typeMenu a{
    border-right: 1px solid #474747;
	text-decoration: none;
    color: #777777;
	margin-bottom: 10px;
	display: inline-block;
}
#typeMenu a:hover {
	text-decoration:underline;
    color: #000;
}
#typeMenu a:last-child {
    border-right:none;
}
#typeMenu  a.select {
	color: #000;
    font-weight: bold;
    pointer-events: none;
}
#typeMenuSp {
    display: none;
}


/* max-width:640px */
@media screen and (max-width:640px){
#typeMenu {
    display: none;
	}
#typeMenuSp {
    display:block;
    padding: 0 10px 10px;
	}
#typeMenuSp .selectbox{
    border: 2px solid #bdbdbd;
    position:relative;
    background: #000;
    color: #fff;
	}
#typeMenuSp .selectbox::after{
    position: absolute;
    top: 35%;
    right: 3%;
    margin-top: -8px;
    content: "▼";
    color:#8B8B8B;
    pointer-events: none;
	}

#typeMenuSp select{
    width: 100%;
    border: none;
    -webkit-appearance:none;
    background: #000;
    color: #fff;
    font-size: 16px;
    padding: 3px 5px;
	}
}



/* フォトコンリスト表示
-------------------------------------- */


#initiatives {
	padding: 243px 0 0 0;
    background-color: #ebebeb;
}
#initiatives .inner {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-evenly;
	align-content: flex-start;
	align-self: stretch;
    padding: 80px 0 100px;
    border-top: 1px #CCCCCC solid;
    border-bottom: 1px #CCCCCC solid;
}
/* #initiatives .inner::after {
	content: "";
	flex: auto;
} 4の倍数以外の時に使用 */

#initiatives img{
    border: 1px solid #7B7B7B;
    box-sizing: border-box;
}
#initiatives a {
	text-decoration: none;
    color: #000;
}
#initiatives a:hover{
	text-decoration:underline;
    color: #000;
}
#initiatives a:hover img{
    border: 1px solid #fff;
}
#initiatives a:last-child article {
	/* margin-left: 44px; */
}
#initiatives article {
	width: 400px;
    margin: 0 20px 100px;
}
#initiatives article img {
	width: 400px;
    margin-bottom: 15px;
}
#initiatives article h2{
    font-size: 16px;
    margin: 0 0 5px;
}
#initiatives article p.date{
    font-size: 12px;
    font-weight: bold;
    margin: 0;
}

@media screen and (max-width: 640px){
	#nodata {
		text-align: center;
		padding: 20px 10% 50px;
	}
}


/* max-width:640px */
@media screen and (max-width:640px){
	#initiatives {
		padding: 172px 10px 0;
	}
	#initiatives .inner {
		width: 100%;
        padding: 20px 0 0;
	}
    #initiatives article {
	    width: 100%;
        margin: 0 0 50px;
    }
    #initiatives article img {
	    width: 100%;
        margin-bottom: 15px;
    }
    #initiatives article h2{
    }
    #initiatives article p.date{
    }
}




/* 東京カメラ部について
-------------------------------------- */
#aboutTCC {
	padding: 83px 0 90px 0;
	background: #fff;
}
#aboutTCC .inner {
	width: 960px;
	display: flex;
}
#aboutTCC a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 480px;
}
#absoluteTCC a img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 218px;
	height: 72px;
	margin-top: 109px;
	margin-left: 36px;
}
#aboutTCC p {
	width: 480px;
	line-height: 1.6rem;
	font-size: 0.8rem;
}

/* max-width:480px */
@media screen and (max-width:480px){
	#aboutTCC {
		padding: 50px 0 30px 0;
		background: #fff;
	}
	#aboutTCC .inner {
		width: 100%;
		display: block;
		text-align: center;
	}
	#aboutTCC a {
		display: inline;
		width: auto;
	}
	#absoluteTCC a img {
		position: relative;
		top: 0;
		left: 0;
		margin-top: 0;
		margin-left: 0;
	}
	#aboutTCC p {
		width: 100%;
		padding: 20px;
		text-align: left;
		font-size: 0.9rem;
	}
}


/* フッター
-------------------------------------- */
footer {
	background: #2a2a2a;
	color: #fff;
}
footer #footerPageTop {
	position: relative;
	top: -36px;
	text-align: center;
}
footer #footerMenu {
	padding: 10px 0 0 0;
	margin: 0 auto 75px auto;
}
footer #footerMenu ul {
	display: flex;
	justify-content: center;
}
footer #footerMenu ul li {
	list-style: none;
	border-right: 1px solid #fff;
	margin: 0 15px 0 0;
	padding: 0 15px 0 0;
}
footer #footerMenu ul li:last-child {
	border-right: none;
	padding-right: 30px;
}
footer #footerMenu a {
	text-decoration: none;
	color: #fff;
}
footer #footerMenu a:hover {
	text-decoration: underline;
	color: #ccc;
}
footer #copyright {
	padding: 0 0 50px 0;
	text-align: center;
	line-height: 1.8rem;
	font-size: 0.8rem;
	font-weight: normal;
	font-family: "MS ゴシック", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, sans-serif;
}

/* max-width:480px */
@media screen and (max-width:480px){
	footer #footerMenu {
		padding: 0;
		margin: 0 auto 30px auto;
	}
	footer #footerMenu ul {
		flex-direction: column;
		margin: 0;
		padding: 0;
	}
	footer #footerMenu ul li {
		border-right: none;
		border-top: 1px solid #999;
		margin: 0;
		padding: 0;
		line-height: 1;
	}
	footer #footerMenu ul li a{
		display: block;
		width: 100%;
		margin: 0;
		padding: 20px;
	}
	footer #footerMenu ul li a:hover{
		text-decoration: none;
		background: #444;
	}
	footer #footerMenu ul li:last-child {
		border-bottom: 1px solid #999;
		padding: 0;
	}

	footer #copyright {
		padding: 0 20px 30px 20px;
		text-align: left;
		line-height: 1.4rem;
	}
}





/* 開催中
-------------------------------------- */


.openPage header#project {
    background: #000;
	position: absolute;
	z-index: 999;
	width: 100%;
	min-width: 1280px;
	box-shadow: 0  5px 10px 2px rgba(0,0,0,0.3);
}

.openPage header#project.standby{
	position: fixed;
	top: -111px;
    transition: top 0.5s;
}

.openPage header#project h1{
    margin: 10px 0 0 40px;
}



.openPage #headerMenu a{
    background: #fff  url("../img/open_arw_s_w.png") no-repeat;
    background-position : right 10px center;
    color: #000;
}
.openPage #headerMenu a:hover{
    background: #faa500  url("../img/open_arw_s_w.png") no-repeat;
    background-position : right 10px center;
}

.openPage #initiatives {
	padding-top: 111px;
}

.openPage #initiatives article h2 {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 10px;
    text-align: justify;
}

.openPage #initiatives article img {
    margin-bottom: 10px;
}

.openPage #initiatives article p.date {
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    margin: 0 0 10px;
}
.openPage #initiatives article p.date span{
    font-weight: 900;
    font-size: 20px;

}

.openPage #initiatives article p.date span.week{
    font-weight: 700;
    margin: 0 -5px 0 -6px;
    font-size: 16px;
}

/* max-width:480px */
@media screen and (max-width:480px){

	.openPage header#project {
	min-width: 100%;
}
 .openPage header#project h1{
        margin: 0px;
	 padding: 0 10px 5px;
	 
}
   .openPage header#project h1 img{
	   vertical-align: middle;
	 
}
   

 .openPage #initiatives .inner {
    padding: 50px 0 0;
}

 .openPage #initiatives article {
    margin: 0px 0 60px;
}
    
.openPage #headerMenu a{
    background-position : right 2px center;
    }

.openPage #headerMenu a:hover{
    background-position : right 2px center;
    }
}

/* オンラインイベント固定メニュー
-------------------------------------- */

#fixNavionlineEvent{
	z-index: 1000;
	position: fixed;
	transition: all 0.5s;
	bottom: -140px;
	right: 0;
	opacity: 1;
}
#fixNavionlineEvent img,
#fixNavionlineEvent a:hover img {
	border: 0;
}

/* max-width:640px */
@media screen and (max-width:640px){
	#fixNavionlineEvent img{
		width: 100%;
		height: auto;
	}
}
