@charset "utf-8";
/*------------------------------------------------------------
	work
------------------------------------------------------------*/
#main .topSec {
	padding: 12.6rem 0 15rem;
	background-image: url(../img/work/bg01.png);
	background-position: center top 9.7rem;
}
#main .topSec .txtInner {
	align-items: flex-start;
}
#main .topSec .txtBox {
	width: 56rem;
}
#main .topSec .txtBox p {
	margin-right: 1rem;
}
#main .topSec .btnList {
	margin-top: 2.7rem;
	gap: 2rem 0;
	width: 60.5rem;
}
#main .topSec .btnList li {
	width: 29.1rem;
}
#main .topSec .btnList a {
    display: block;
    padding: 1.9rem 5.6rem;
    font-size: 2.0rem;
    line-height: 1.4;
    letter-spacing: 0.3rem;
    border-radius: 2rem;
    border: 1px solid #1D3443;
    background: #FFE url(../img/common/icon18.png) no-repeat right 4.8rem center / 3.1rem;
}
#main .topSec .btnList a:hover {
	opacity: 0.7;
}
#main .topSec .btnList .bgColor {
	background-color: #EAF4F3;
}
#main .sec .ttlBox {
	max-width: 147rem;
}
#main .sec .ttlBox .headLine02 {
	margin-bottom: 3.2rem;
}
#main .sec .mainPho {
	margin-bottom: -6.2rem;
	position: relative;
	z-index: 2;
}
#main .sec .mainPho img {
	width: 100%;
}
#main .sec .content {
	position: relative;
}
#main .sec .circle {
	position: absolute;
	z-index: -1;
}
#main .sec .circle01 {
	width: 101rem;
	right: -35rem;
	top: -35rem;
}
#main .sec .circle02 {
	width: 86.2rem;
	left: -45rem;
	bottom: -68rem;
	z-index: 1;
}
#main .sec .bgBox {
	margin-bottom: 10.5rem;
	padding: 4rem 5rem 4.5rem;
	align-items: center;
	border-radius: 12.15rem;
	background: rgba(255, 255, 255, 0.80);
	backdrop-filter: blur(5px);
	position: relative;
	z-index: 3;
}
#main .sec .bgBox .ttl {
	margin: 0 12rem 0.5rem 8.4rem;
	width: 54.7rem;
	font-size: 2.8rem;
	line-height: 1.5;
	letter-spacing: 0.3rem;
}
#main .sec .bgBox .txt {
	padding: 0.7rem 0 1.3rem 9.2rem;
	flex: 1;
	line-height: 1.5;
	position: relative;
}
#main .sec .bgBox .txt:before {
	position: absolute;
	left: 0;
	top: 0;
	width: 3px;
	height: 100%;
	background: #51E6DF;
	content: "";
}
#main .sec .inner {
	margin: 0 auto;
	max-width: 128rem;
}
#main .sec .inner h4 {
	margin-bottom: 5rem;
}
#main .sec .inner h4 .en {
	margin-bottom: -1rem;
	display: block;
	color: #1CD8D2;
	font-size: 4rem;
	font-weight: 500;
	letter-spacing: 0.3rem;
}
#main .sec .inner h4 .jp {
	margin-left: 0.8rem;
	font-size: 2.4rem;
	letter-spacing: 0.2rem;
}
#main .sec .inner .lBox {
	margin-left: 5%;
	width: 45%;
}
#main .sec .inner .oneday {
	position: relative;
	padding-bottom: 1.3rem;
}
#main .sec .inner .oneday:after {
	position: absolute;
	left: 11.4rem;
	top: 0;
	width: 3px;
	height: 100%;
	background-color: #51E6DF;
	content: "";
}
#main .sec .inner .oneday li {
	display: flex;
	align-items: center;
}
#main .sec .inner .oneday li:not(:last-child) {
	margin-bottom: 3.5rem;
}
#main .sec .inner .oneday .time {
	margin-right: 5rem;
	position: relative;
	width: 11.2rem;
	flex-shrink: 0;
	font-size: 3.2rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.3rem;
}
#main .sec .inner .oneday .time:after {
	position: absolute;
	left: 3rem;
	bottom: -2.5rem;
	width: 1.3rem;
	height: 0.7rem;
	background: url(../img/common/icon19.png) no-repeat left top/100%;
	content: "";
}
#main .sec .inner .oneday .txt {
	margin-top: 0;
	padding: 0 0.8rem;
	font-size: 2rem;
	line-height: 1.4;
	letter-spacing: 0.3rem;
}
#main .sec .inner .oneday li:last-child .time {
	padding-bottom: 0;
}
#main .sec .inner .oneday li:last-child .time:after {
	display: none;
}
#main .sec .inner .oneday li:first-child .txt {
	margin-left: -1.5rem;
}
#main .sec .inner .rBox {
	margin-top: -0.7rem;
	width: 64rem;
}
#main .sec .inner .rBox h4 {
	margin-bottom: 3.2rem;
}
#main .sec .inner .rBox h4 .en {
	margin-bottom: -0.3rem;
}
#main .sec .inner .rBox h4 .jp {
	margin-left: 0;
}
#main .sec .inner .rBox .txtList {
	margin-bottom: 5.6rem;
	gap: 2rem 1rem;
}
#main .sec .inner .rBox .txtList li {
	padding: 0 0.8rem 0 3.1rem;
	font-size: 2rem;
	line-height: 1.4;
	letter-spacing: 0.3rem;
	background: url(../img/common/icon17.png) no-repeat 0.8rem 1.1rem/1.2rem;
}
#main .sec .inner .rBox .midImg {
	margin: 0 auto;
	width: 29.9rem;
	transform: translateX(-5.7rem);
}
#main .sec01 {
	padding: 7.6rem 0 14rem;
	background-color: rgba(234, 244, 243, 0.5);
}
#main .sec02 {
	padding: 13rem 0 15rem;
}
#main .sec02 .bgBox {
	background: rgba(234, 244, 243, 0.8);
}
#main .sec02 .inner .rBox .txtList {
	margin-right: -3rem;
}
#main .sec02 .inner .rBox .txtList li {
	background-color: transparent;
}
#main .sec02 .inner h4 {
	color: #1CD8D2;
}
#main .sec02 .inner h4 .en {
	color: #1D3443;
}
#main .sec03 {
	padding: 9.5rem 0 15rem;
	background-color: rgba(234, 244, 243, 0.5);
}
#main .sec04 {
	padding-bottom: 14rem;
	position: relative;
}
#main .sec04 .content {
	padding: 13.5rem 2rem;
}
#main .sec04 .circle01 {
	top: 0;
	right: -20rem;
	width: 83.3rem;
}
#main .sec04 .circle02 {
	bottom: auto;
	top: 70rem;
	width: 83.3rem;
	left: -30rem;
}
#main .sec04 .circle03 {
	top: 110rem;
	right: -20rem;
	width: 83.3rem;
}
#main .sec04 .circle04 {
	top: 200rem;
	width: 83.3rem;
	left: -40rem;
}
#main .sec04 .circle05 {
	top: 320rem;
	right: -20rem;
	width: 83.3rem;
}
#main .sec04 .circle06 {
	top: 396rem;
	width: 83.3rem;
	left: -28rem;
}
#main .sec04 .line {
	position: absolute;
	left: 0;
	width: 100%;
	top: 51rem;
	opacity: 0.3;
}
#main .sec04 .line02 {
	top: 162rem;
	opacity: 1;
}
#main .sec04 .line03 {
	top: auto;
	bottom: 65.5rem;
	opacity: 1;
}
#main .sec04 .headLine02 {
	font-size: 3.4rem;
	letter-spacing: 0.3rem;
}
#main .sec04 .headLine02 .en {
	margin: 1rem 0 0 2rem;
}
#main .sec04 .inner01 {
	margin: 0 auto 17.5rem;
	max-width: 136rem;
	position: relative;
	z-index: 1;
}
#main .sec04 .imgBox {
	margin-bottom: 10rem;
	align-items: flex-end;
}
#main .sec04 .imgBox:last-child {
	margin-bottom: 0 !important;
}
#main .sec04 .imgBox:nth-child(2n) {
	margin-bottom: 14.5rem;
	flex-direction: row-reverse;
}
#main .sec04 .imgBox .phoBox {
	width: 64rem;
}
#main .sec04 .imgBox .phoBox img {
	border-radius: 2rem;
	width: 100%;
}
#main .sec04 .imgBox .txtBox {
	margin: 0 5rem 0 -6rem;
	padding: 4.7rem 11rem 6rem;
	flex: 1;
	background-color: #fff;
	border-radius: 2rem;
	position: relative;
	z-index: 1;
}
#main .sec04 .imgBox:nth-child(2n) .phoBox {
	margin-right: 1.3rem;
}
#main .sec04 .imgBox:nth-child(2n) .txtBox {
	margin: 0 -6.4rem 0 4rem;
}
#main .sec04 .listUl {
	margin: 0 auto 24rem;
	gap: 13rem 0;
	max-width: 142rem;
}
#main .sec04 .listUl li {
	width: 45.1%;
}
#main .sec04 .listUl .phoBox {
	margin-bottom: -5rem;
}
#main .sec04 .listUl .phoBox img {
	width: 100%;
	border-radius: 2rem;
}
#main .sec04 .listUl .txtBox {
	padding: 4.6rem 9.5rem 6rem;
	border-radius: 2rem;
	background: rgba(234, 244, 243, 0.50);
	backdrop-filter: blur(0.5rem);
}
#main .sec04 .listUl .txtBox h3 {
	justify-content: center;
}
@media all and (min-width: 897px) {
	#main .sec04 .listUl .txtBox.bg02 {
	background: rgba(255, 255, 255, 0.50);
}
}
@media all and (max-width: 896px) {
	#main .topSec {
		padding: 6rem 0;
		background-position: center top 4rem;
	}
	#main .topSec .txtInner {
		display: block;
	}
	#main .topSec .txtBox {
		width: auto;
	}
	#main .topSec .txtBox p {
		margin-right: 0;
	}
	#main .topSec .btnList {
		margin-top: 2.7rem;
		gap: 1rem;
		width: auto;
	}
	#main .topSec .btnList li {
		width: calc((100% - 1rem)/2);
	}
	#main .topSec .btnList a {
		padding: 1rem 3rem;
		font-size: 1.6rem;
		background-position: right 2rem center;
		background-size: 2.4rem;
	}
	#main .sec {
		padding: 3rem 0 4rem !important;
	}
	#main .sec .ttlBox .headLine02 {
		margin-bottom: 2rem;
	}
	#main .sec .mainPho {
		margin-bottom: -3rem;
		height: 50vw;
	}
	#main .sec .mainPho img {
		width: 100%;
		height: 100%;
		-o-object-fit: cover;
		object-fit: cover;
		-o-object-position: center;
		object-position: center;		
	}
	#main .sec .circle01 {
		width: 40rem;
		right: -20rem;
		top: -20rem;
	}
	#main .sec .circle02 {
		width: 40rem;
		left: -20rem;
		bottom: -20rem;
	}
	#main .sec .bgBox {
		margin-bottom: 5rem;
		padding: 3rem;
		display: block;
		border-radius: 5rem;
	}
	#main .sec .bgBox .ttl {
		margin: 0 0 2rem;
		width: auto;
        font-size: 1.7rem;
	}
	#main .sec .bgBox .txt {
		padding: 2rem 0 0;
	}
	#main .sec .bgBox .txt:before {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 3px;
	}
	#main .sec .inner {
		display: block;
	}
	#main .sec .inner h4 {
		margin-bottom: 3rem;
	}
	#main .sec .inner h4 .en {
		margin-bottom: -0.5rem;
		font-size: 2.4rem;
	}
	#main .sec .inner h4 .jp {
		margin-left: 0;
		font-size: 1.8rem;
	}
	#main .sec .inner .lBox {
		margin-left: 0;
		width: auto;
	}
	#main .sec .inner .oneday {
		padding-bottom: 0.7rem;
        width: fit-content;
        margin-left: auto;
        margin-right: auto;
	}
	#main .sec .inner .oneday:after {
		left: 9rem;
	}
	#main .sec .inner .oneday li:not(:last-child) {
		margin-bottom: 2rem;
	}
	#main .sec .inner .oneday .time {
		margin-right: 3rem;
		width: 9rem;
		font-size: 2.4rem;
	}
	#main .sec .inner .oneday .time:after {
		left: 2rem;
		bottom: -1.5rem;
	}
	#main .sec .inner .oneday .txt {
		font-size: 1.6rem;
	}
	#main .sec .inner .oneday li:first-child .txt {
		margin-left: -0.8rem;
	}
	#main .sec .inner .rBox {
		margin-top: 3rem;
		width: auto;
	}
	#main .sec .inner .rBox h4 {
		margin-bottom: 2rem;
	}
	#main .sec .inner .rBox .txtList {
		margin-bottom: 3rem;
        gap: 1rem;
        width: fit-content;
        flex-direction: column;
        margin-left: auto;
        margin-right: auto;
	}
	#main .sec .inner .rBox .txtList li {
		padding: 0 0.4rem 0 2rem;
		font-size: 1.6rem;
		background-position: 0.5rem 0.9rem;
		background-size: 0.8rem;
	}
	#main .sec .inner .rBox .midImg {
		width: 18rem;
		transform: translateX(0);
	}
	#main .sec02 .inner .rBox .txtList {
		margin-right: 0;
	}
	#main .sec04 {
		padding-bottom: 8rem !important;
	}
	#main .sec04 .content {
		padding: 6rem 2rem;
	}
	#main .sec04 .circle {
		width: 40rem !important; 
	}
	#main .sec04 .circle01 {
		right: -10rem;
	}
	#main .sec04 .circle02 {
		bottom: auto;
		top: 40rem;
		left: -15rem;
	}
	#main .sec04 .circle03 {
		top: 85rem;
		right: -10rem;
	}
	#main .sec04 .circle04 {
		top: 120rem;
		left: -10rem;
	}
	#main .sec04 .circle05 {
		top: 170rem;
		right: -10rem;
	}
	#main .sec04 .circle06 {
		top: auto;
		bottom: 10rem;
		left: -10rem;
	}
	#main .sec04 .line {
		display: none;
	}
	#main .sec04 .headLine02 {
		display: block;
		font-size: 2.4rem;
		text-align: center;
	}
	#main .sec04 .headLine02 .en {
		margin: 0;
		display: block;
	}
	#main .sec04 .inner01 {
		margin-bottom: 8rem;
	}
	#main .sec04 .imgBox {
		margin-bottom: 4rem !important;
		display: block;
	}
	#main .sec04 .imgBox .phoBox {
		width: auto;
	}
	#main .sec04 .imgBox .txtBox {
		margin: -2rem 0 0 !important;
		padding: 2rem;
	}
	#main .sec04 .imgBox:nth-child(2n) .phoBox {
		margin-right: 0;
	}
	#main .sec04 .listUl {
		margin-bottom: 4rem;
		display: block;
	}
	#main .sec04 .listUl li {
		margin-bottom: 4rem;
		width: auto;
	}
	#main .sec04 .listUl .phoBox {
		margin-bottom: -2rem;
	}
	#main .sec04 .listUl .txtBox {
		padding: 2rem;
	}
	#main .sec04 .listUl li:nth-child(2n) .txtBox {
		background: rgba(255, 255, 255, 0.50);
	}
}