@charset "utf-8";

#contents {
	margin-top: 40px;
	max-width: 100%;
	margin-bottom: 150px;
	overflow: hidden;
}
#contents > #contentsInner {
	padding: 0;
}
#contentsInner > section {
	margin-top: 100px;
	margin-bottom: 0;
}
.susContainer {
	max-width: 1100px;
	padding: 0 50px;
	margin-inline: auto;
}
.pReadTxt {
	font-size: 20px;
	line-height: 1.75;
	margin-top: 20px;
}
@media only screen and (max-width:767px) {
	#contents {
		margin-top: 20px;
		margin-bottom: 85px;
	}
	#contentsInner > section {
		margin-top: 40px;
	}
	.susContainer {
		max-width: 1200px;
		padding: 0 20px;
		margin-inline: auto;
	}
	.pReadTxt {
		font-size: 13px;
	}
}
.image {
	width: 100%;
	margin-top: 50px;
}
@media only screen and (max-width:767px) {
	.image {
		height: auto;
		margin-top: 25px;
	}
}
.imageInner {
	margin: 0 auto;
	max-width: 100%;
}
.imageInner img {
	display: block;
	width: 100%;
	height: auto;
}

/* ---------- susBox ---------- */
.susBox {
	border-top-right-radius: 20px;
	border-bottom-right-radius: 20px;
	margin-left: calc(50% - 50vw + 10px);
}
.susBoxReverse {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	border-top-left-radius: 20px;
	border-bottom-left-radius: 20px;
	margin-left: 0;
	margin-right: calc(50% - 50vw + 10px);
}
@media only screen and (max-width:767px) {
	.susContainer:has(.susBox) {
		margin-top: 100px!important;
	}
	.susBox {
		margin-left: calc(50% - 50vw);
	}
	.susBoxReverse {
		margin-left: 0;
		margin-right: calc(50% - 50vw + 3px);
	}
}
.susBoxInner {
	padding: 0 80px 80px 42px;
	max-width: 1020px;
	margin-left: auto;
}
.susBoxReverse .susBoxInner {
	padding: 0 42px 80px 80px;
	margin-right: auto; 
	margin-left: 0;
}

.susBox01 {
	border-top: 2px solid #002e67;
	border-right: 2px solid #002e67;
	border-bottom: 2px solid #002e67;
}
.susBox02 {
	border-top: 2px solid #00b685;
	border-left: 2px solid #00b685;
	border-bottom: 2px solid #00b685;
	margin-top: 130px;
}
@media only screen and (max-width:767px) {
	.susBoxInner,
	.susBoxReverse .susBoxInner {
		padding: 0 12px 25px;
	}
	.susBox02 {
		margin-top: 60px;
	}
}

/* susBoxTitle */
.susBoxTitle {
	margin-top: -3em;
	width: fit-content;
}
.susBoxHeading {
	display: inline-block;
	font-size: 60px;
	font-weight: 700;
	line-height: 1.2;
	background-color: #fff;
	padding: 0 8px;
}
.susBoxReverse .susBoxTitle {
	margin-left: auto;
}
.susBox01 .susBoxTitle {
	color: #002e67;
}
.susBox01 .susBoxHeading {
	white-space: nowrap;
}

.susBox02 .susBoxTitle {
	color: #00b685;
}
.susBoxReverse .susBoxTitle {
	margin-left: auto;
}
@media screen and (max-width: 1100px) {
	.susBox01 .susBoxHeading {
		white-space: normal;
	}
}
@media only screen and (max-width:767px) {
	.susBox01 .susBoxTitle {
		margin-top: -4.3em;
		max-width: 250px;
	}
	.susBox02 .susBoxTitle {
		margin-top: -1.5em;
		
	}
	.susBoxHeading {
		font-size: 30px;
		line-height: calc(40 / 30);
	}
}

/* susBoxContent */
.susBoxContent {
	margin-top: 45px;
	padding-left: 8px;
}
.susBoxReverse .susBoxContent{
	padding-left: 0;
	padding-right: 8px;
}
@media only screen and (max-width: 767px) {
	.susBoxContent,
	.susBoxReverse .susBoxContent{
		margin-top: 22.5px;
		padding: 0 16px;
	}
}

/* susBoxCol2 */
.susBoxCol2 {
	display: flex;
	column-gap: 50px;
}
.susBoxTxt {
	font-size: 16px;
}
.susBoxCol2 .susBoxItem {
	flex: 1;
}
.susBoxItem:has(.susBoxImg) {
	width: min(calc(500 / 1366 * 100vw),500px);
}
.susBoxImg img {
	width: 100%;
	height: auto;
}

@media only screen and (max-width: 767px) {
	.susBoxCol2 {
		flex-direction: column;
		align-items: center;
		column-gap: 0;
		row-gap: 20px;
	}
	.susBoxItem:has(.susBoxImg) {
		width: min(calc(250 / 375 * 100vw),250px);
	}
	.susBoxTxt {
		font-size: 12px;
		line-height: 1.8;
	}
}

/* susBox linkbtn02 */
.susBox .linkbtn02 {
	max-width: 200px;
	margin-top: 20px;
}
.susBox .linkbtn02Inner {
	column-gap: 1em;
}
.susBox .linkbtn02Inner::before {
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	rotate: -45deg;
	width: 0.5em;
	height: 0.5em;
}

/* susGallery */
#susGallery .splide01 {
	pointer-events: none;
	margin-top: 120px;
}
#susGallery .splide02 {
	pointer-events: none;
	margin-top: 18px;
}
#susGallery .splide__slide img {
	height: 300px;
	width: auto;
	object-fit: cover; 
}
#susGallery .splide01 img {
	translate: calc(50% + 12px) 0;
}


@media only screen and (max-width: 767px) {
	#susGallery .splide01 {
		margin-top: 45px;
	}
	#susGallery .splide02 {
		margin-top: 10px;
	}
	#susGallery .splide__slide img {
		height: 150px;
	}
	#susGallery .splide01 img{
		translate: calc(50% + 6px) 0;
	}
}