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

/* --------------------------------------------------- */
#sec01 {
	max-width: 1300px;
	width: 90%;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	position: relative;
	z-index: 1;
}
#sec01 .box {
	line-height: 180%;
	font-size: 14px;
	width: 31%;
	margin-right: 3.5%;
	margin-bottom: 3.5%;
}
#sec01 .box:nth-child(3n) {
	margin-right: 0;
}
#sec01 .box a {
	display: block;
    position: relative;
    width: 100%;
    padding-top: 75%;
    margin: 0 auto 5px;
	box-shadow: 0px 0px 20px 2px rgba(0, 0, 0, .2);
}
#sec01 .box a img {
    position: absolute;
	width: 100%;
    height: 100%;
    top: 0;
    object-fit: cover;
}
#sec01 .box a:hover {
	box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, .3);
}
#sec01 .box .day {
	display: block;
	font-size: 8px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
#sec01 .box p {
	display: -webkit-box;             
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 3; 
}
@media (max-width: 1024px) {
	#sec01 .box p {
		font-size: 12px;
		-webkit-line-clamp: 2; 
		line-height: 160%;
	}
}
@media (max-width: 640px) {
	#sec01 {
		justify-content: space-between;
	}
	#sec01 .box {
        width: 47.7%;
        margin-right: 0;
        margin-bottom: 20px;
    }
}
@media (max-width: 480px) {
}
/* --------------------------------------------------- */
#sec02 {
	max-width: 1300px;
	width: 90%;
	margin: 0 auto 30px;
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 1;
}
#sec02 .left {
	width: 68%;
}
#sec02 .right {
	width: 27%;
	border-radius: 5px;
	box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, .1);
	background-color: #fff;
	padding: 15px 15px 10px;
}

#sec02 .left .day {
	display: inline-block;
	font-size: 10px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
#sec02 .left .category {
	display: inline-block;
	font-size: 10px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
#sec02 .left .ttl {
	font-size: 1.3em;
	line-height: 170%;
	margin-bottom: 30px;
	font-weight: 500;
}
#sec02 .left p {
	margin-bottom: 30px;
}

#sec02 .right .ttl {
	font-size: 14px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
#sec02 .right ul {
	margin-bottom: 25px;
}
#sec02 .right ul:last-child {
	margin-bottom: 0;
}
#sec02 .right li {
	font-size: 14px;
	line-height: 160%;
	border-top: #ccc 1px dashed;
}
#sec02 .right li a {
	display: block;
	padding: 10px 5px 10px 25px;
	background: url("../images/common/arrow16.png") no-repeat left 10px center;
	background-size: 5px;
}
#sec02 .right li a .day {
	display: block;
	font-size: 8px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	line-height: 140%;
}
#sec02 .right li a:hover {
	background-color: rgba(0,0,0,.02);
}
@media (max-width: 1024px) {
	#sec02 .left {
        width: 60%;
    }
	#sec02 .left .ttl {
		font-size: 1.2em;
	}
    #sec02 .right {
        width: 35%;
		padding: 5px 5px 5px;
    }
	#sec02 .right .ttl {
		padding-left: 10px;
	}
}
@media (max-width: 640px) {
	#sec02 {
        display: block;
    }
	#sec02 .left {
        width: 100%;
		margin-bottom: 40px;
    }
    #sec02 .right {
        width: 100%;
        padding: 15px 15px 10px;
    }
}
@media (max-width: 480px) {
	#sec02 .left .ttl {
		font-size: 1.1em;
	}
	#sec02 .left .day {
		font-size: 8px;
	}
	#sec02 .left p {
		line-height: 180%;
        margin-bottom: 20px;
    }
}
/* --------------------------------------------------- */

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


