@charset "utf-8";

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

   page

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


@media all and (min-width: 769px){

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
#indexTitle {
	margin: 0 0 40px;
	border-bottom: 1px solid #EFEFEF;
}

#indexTitle h1 {
	font-size: 24px;
	text-align: center;
	line-height: 100px;
	letter-spacing: .05em;
	background: url(../image/title_back.jpg) no-repeat 60% 60%;
}

#indexCont {
	margin: 0 auto;
	padding: 0 20px 20px;
	max-width: 1140px;
}

#indexCont p {
	margin: 0 0 40px;
}

.projectList {
	margin: 0 0 40px;
	padding: 0 0 16px;
	display: flex;
	justify-content: space-between;
	border-bottom: 1px dotted #CCC;
}

.projectList .thumb {
	width: 40%;
}

.projectList .thumb img {
	max-width: 100%;
	height: auto;
	box-shadow: 0 0 3px #CCC;
}

.projectList .text {
	width: 52%;
}

.projectList .text h2 {
	margin: 0 0 16px;
	font-size: 20px;
	font-weight: 500;
	letter-spacing: .04em;
	position: relative;
}

.projectList .text h2::before {
	position: absolute;
	width: 24px;
	height: 24px;
	content: "";
	top: -4px;
	left: -12px;
	background-color: #DBEFF8;
	z-index: -1;
}

.projectList .text dl {
	margin: 0 0 24px;
	line-height: 1.4;
}

.projectList .text dl dt {
	font-weight: 500;
}

.projectList .text dl dd {
	margin: 0 0 8px;
}

.projectList .text .btn a {
	width: 200px;
	display: block;
	padding: 6px 0;
	text-align: center;
	border: 2px solid #0B96CE;
	border-radius: 24px;
	text-decoration: none;
	position: relative;
}

.projectList .text .btn a::before {
	position: absolute;
	content: "";
	width: 42px;
	height: 1px;
	background-color: #0B96CE;
	top: 50%;
	right: -21px;
	transition: .2s linear;
}

.projectList .text .btn a:hover {
	border: 2px solid #0B96CE;
	background-color: #DBEFF8;
}

.projectList .text .btn a:hover::before {
	background-color: #0B96CE;
	right: -30px;
}



}





@media all and (max-width: 768px){

/*------------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------------*/
#indexTitle {
	margin: 0 0 40px;
	border-bottom: 1px solid #EFEFEF;
}

#indexTitle h1 {
	font-size: 20px;
	text-align: center;
	line-height: 100px;
	letter-spacing: .05em;
	background: url(../image/title_back.jpg) no-repeat 70% 60%;
}

#indexCont {
	width: 94%;
	margin: 0 auto;
	padding: 0 0 20px;
}

#indexCont p {
	margin: 0 0 40px;
}

.projectList {
	margin: 0 0 40px;
	padding: 0 0 16px;
	border-bottom: 2px dotted #CCC;
}

.projectList .thumb {
	margin: 0 0 3px;
}

.projectList .thumb img {
	max-width: 100%;
	height: auto;
	box-shadow: 0 0 3px #CCC;
}

.projectList .text h2 {
	margin: 0 0 16px;
	padding: 4px;
	font-size: 18px;
	font-weight: 500;
	letter-spacing: .04em;
	background-color: #DBEFF8;
}

.projectList .text dl {
	margin: 0 0 24px;
	line-height: 1.4;
}

.projectList .text dl dt {
	font-weight: 500;
}

.projectList .text dl dd {
	margin: 0 0 8px;
}

.projectList .text .btn a {
	width: 80%;
	display: block;
	margin: 0 auto;
	padding: 8px 0;
	text-align: center;
	border: 2px solid #0B96CE;
	border-radius: 24px;
	text-decoration: none;
	position: relative;
}

.projectList .text .btn a::before {
	position: absolute;
	content: "";
	width: 42px;
	height: 1px;
	background-color: #0B96CE;
	top: 50%;
	right: -21px;
	transition: .2s linear;
}

.projectList .text .btn a:hover {
	border: 2px solid #0B96CE;
	background-color: #DBEFF8;
}

.projectList .text .btn a:hover::before {
	background-color: #0B96CE;
	right: -30px;
}




}