@charset "UTF-8";
:root {
	--something: #5b1933;
}

/*----------------------------
	Common
----------------------------*/
.whole-wrap { margin-top: 70px; }
._posiabs { position: absolute; pointer-events: none; }
@media screen and (max-width: 680px) {
	.whole-wrap { margin-top: 50px; }
}

/*----------------------------
	fvsub
----------------------------*/
.fvsub .l-wrapper { padding: 150px 0; }
.fvsub__ttl { text-align: center; }
.fvsub__ttl img { width: auto; height: 95px; }

.fvsub__obj--star_right { top: 107px; right: -40px; width: 258px; }
.fvsub__obj--star_left { bottom: -46px; left: -65px; width: 520px; }
.fvsub__obj--cloud { bottom: -150px; right: -379px; width: 443px; }
@media screen and (max-width: 680px) {
	.fvsub { display: none; }
}


/*----------------------------
	Location
----------------------------*/
.sec--loca { padding-top: 75px; }
.sec--loca .l-wrapper { padding-left: 7px; padding-right: 7px; }
.loca-obj--star_right { top: 419px; right: -115px; width: 403px; }
.loca-obj--star_left { top: 230px; left: -100px; width: 682px; }

.loca-subttl {  }
.loca-subttl img { width: auto; height: 68px; }
.loca { display: flex; justify-content: space-between; align-items: flex-end; margin-top: 15px; }
.loca__cont { flex: 1; }

.loca__cont__ttl {  }
.loca__cont__ttl__item { display: inline-flex; align-items: center; height: 52px; background: var(--c-wine); padding: 0 10px 2px; font-size: 4.3rem; font-weight: 700; line-height: 1; letter-spacing: 0.08em; color: #fff; }
.loca__cont__ttl__item:not(:first-of-type) { margin-top: 10px; }
.loca__cont__ttl__item ._bj { letter-spacing: -0.2em; }
.loca__cont__ttl__item ._j { letter-spacing: -0.4em; }
.loca__cont__txt { position: relative; width: 274px; margin-top: 50px; font-size: 1.8rem; font-weight: 500; line-height: 1.9445; color: var(--c-wine); }
.loca__cont__txt::after { position: absolute; display: block; background-repeat: no-repeat; background-position: center; background-size: contain; content: ""; }
.loca__stu { position: relative; width: 470px; border: 2px solid var(--c-wine); border-radius: 25px; padding: 0 30px 30px; color: var(--c-wine); }
.loca__stu::before { position: absolute; right: -10px; bottom: -10px; display: block; width: 100%; height: 100%; background: #fff; border: 2px solid var(--c-wine); border-radius: 25px; content: ""; z-index: -1; }
.loca__stu__img { margin-top: -84px; text-align: center; }
.loca__stu__img img { width: auto; height: 452px; }
.loca__stu__img figcaption { display: flex; justify-content: center; align-items: center; height: 50px; background: #fff; border: 2px solid var(--c-wine); border-radius: 25px; margin: 0 -60px; font-size: 2.0rem; font-weight: 700; line-height: 1; letter-spacing: 0.15em; text-indent: 0.15em; text-align: center; }
.loca__stu__info { margin-top: 47px; }
.loca__stu__info__upper { text-align: center; }
.loca__stu__info__name { font-size: 4.0rem; font-weight: 700; line-height: 1; letter-spacing: 0.05em; text-indent: 0.05em; }
.loca__stu__info__name::after { margin-left: 10px; font-size: 70%; content: "さん"; }
.loca__stu__info__from { margin-top: 21px; font-size: 2.0rem; font-weight: 700; line-height: 1.4; letter-spacing: 0.15em; text-indent: 0.15em; }
.loca__stu__info__txt { margin-top: 35px; font-size: 1.9rem; font-weight: 500; line-height: 1.842; letter-spacing: -0.025em; }
#campus1 .loca__stu { background: var(--c-mint); }
#campus1 .loca__cont__txt::after { top: 50%; transform: translateY(-58%); left: calc(100% + 30px); width: 259px; aspect-ratio: 259/404; background-image: url("../img/campus-1/obj_map_pc.png"); }
#campus2 .loca__stu { background: var(--c-dyellow); }
#campus2 .loca__cont__txt::after { top: 50%; transform: translateY(-67%); left: calc(100% + 30px); width: 272px; aspect-ratio: 272/314; background-image: url("../img/campus-2/obj_map.png"); }

@media screen and (min-width: 681px) {
	.loca-obj--star_single_left, .loca-obj--star_single_right { display: none; }
}
@media screen and (max-width: 680px) {
	.sec--loca { padding-top: 30px; }
	.sec--loca .l-wrapper { padding: 0; }
.loca-obj--star_right, .loca-obj--star_left { top: auto; }
.loca-obj--star_right { bottom: 480px; right: -15px; width: 89px; }
.loca-obj--star_left { bottom: 340px; left: -2px; width: 72px; }
	.loca-subttl {  }
	.loca-subttl img { height: 21px; }
	.loca { flex-direction: column; justify-content: flex-start; align-items: center; margin-top: 32px; }
	.loca__cont { flex: auto; }
	.loca__cont__ttl {  }
	.loca__cont__ttl__item { height: 31px; padding: 0 5px 2px; font-size: 2.0rem; }
	.loca__cont__txt { width: auto; margin-top: 30px; padding-left: 10px; padding-right: 10px; font-size: 1.2rem; line-height: 2.5; }
	.loca__cont__txt::after { position: relative; }
	.loca__stu { width: calc(100% - 55px); border-radius: 15px; padding: 0 30px 26px; }
	.loca__stu::before { right: -10px; bottom: -10px; border-radius: 15px; }
	.loca__stu__img { margin-top: -29px; }
	.loca__stu__img img { height: 188px; }
	.loca__stu__img figcaption { height: 30px; border-radius: 15px; margin: 0 -49px; font-size: 1.4rem; letter-spacing: 0.1em; text-indent: 0.1em; }
	.loca__stu__info { margin-top: 15px; }
	.loca__stu__info__name { font-size: 2.2rem; }
	.loca__stu__info__from { margin-top: 11px; font-size: 1.1rem; }
	.loca__stu__info__txt { margin-top: 18px; font-size: 1.2rem; line-height: 1.8334; letter-spacing: 0.05em; }

	#campus1 .loca__cont__txt::after, #campus2 .loca__cont__txt::after { top: auto; left: 50%; transform: translateX(-50%); margin-top: 42px; margin-bottom: 70px; }
	#campus1 .loca__cont__txt::after { width: 212px; aspect-ratio: 212/332; background-image: url("../img/campus-1/obj_map_sp.png"); }
	#campus2 .loca__cont__txt::after { width: 245px; aspect-ratio: 245/282; }

	.loca__cont__obj--cloud { top: -11px; right: -110px; width: 183px; }
	#campus1 .loca__cont__obj--star { top: -5px; right: 3px; width: 87px; }
	#campus2 .loca__cont__obj--star { top: 130px; right: -2px; width: 49px; }

	.loca-obj--star_single_left { top: 50%; transform: translateY(160%); left: -26px; width: 35px; z-index: 10; }
	.loca-obj--star_single_right { top: 50%; transform: translateY(160%); right: -28px; width: 27px; z-index: -2; }
}


/*----------------------------
	Area
----------------------------*/
.sec--area { margin-top: 84px; padding-bottom: 296px; }
.area-outer-wrap { position: relative; }
.area-outer-wrap:not(:first-of-type) { margin-top: 30px; }
.area__upper { display: flex; justify-content: space-between; align-items: center; }
.area__ttl { flex: 1; display: flex; justify-content: center; align-items: center; }
.area__ttl img { width: 294px; }
.area__main { width: 723px; border-radius: 10px; padding: 17px; }
.area__main img { border-radius: 8px; }
.area-wrap { margin-top: 30px; }

.area { position: relative; background: #fff; border-radius: 10px; padding: 17px; color: var(--c-wine); }
.area__label { position: absolute; top: -2px; left: 50%; transform: translateX(-50%); display: inline-flex; justify-content: center; align-items: center; min-width: 175px; height: 35px; border-radius: 0 0 10px 10px; padding-bottom: 2px; font-size: 1.4rem; font-weight: 700; line-height: 1; letter-spacing: 0.06em; }

.area__label::before { width: 13px; aspect-ratio: 13/17; background: url("../img/common/icon_area.png") no-repeat center/contain; content: ""; margin-right: 5px; }
.area__thumb {  }
.area__thumb__img { border-radius: 8px; }
.area__thumb__txt { margin-top: 19px; font-size: 1.6rem; line-height: 1.4375; letter-spacing: 0.025em;  }

.area__main, .area__main img, .area, .area__label, .area__thumb__img { border: 2px solid var(--c-wine); }

.area__upper--nara { flex-direction: row-reverse; }
.area__main--nara { background: var(--c-orange); margin-right: 30px; }
.area__main--kyoto { background: var(--c-mint); margin-left: 30px;  }
.area__main--osaka { background: var(--c-yellow); margin-left: 30px; }
.area__label--nara { background: var(--c-orange); }
.area__label--kyoto { background: var(--c-mint); }
.area__label--osaka { background: var(--c-yellow); }

.area-obj--upper_right { top: 170px; right: -150px; width: 160px; }
.area-obj--upper_left { bottom: 21px; left: -112px; width: 123px; }
._obj-cloud { width: 443px; }
.area-obj--upper_cloud_right { bottom: -30px; right: -377px; z-index: -1; }
.area-obj--upper_cloud_left { top: 45px; left: -365px; z-index: -1; }

.area-obj--lower_right { top: -5px; right: -176px; width: 200px; }
.area-obj--lower_left { top: 55px; left: -155px; width: 155px; }
.area-obj--lower_cloud_left { top: 530px; left: -370px; z-index: -1; }

.area-obj--star_bottom { bottom: -270px; left: 50%; transform: translateX(-49%); width: 795px; }

@media screen and (min-width: 681px) {
	.area-wrap { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr); grid-column-gap: 30px; grid-row-gap: 30px; }
}
@media screen and (max-width: 680px) {
	
.sec--area { margin-top: 108px; padding-bottom: 100px; }
.sec--area .l-wrapper { width: calc(100% - 60px); }
	.area-outer-wrap:not(:first-of-type) { margin-top: 100px; }
	.area__upper { flex-direction: column; }
	.area__ttl { flex: auto; margin-bottom: 30px; }
	.area__ttl img { width: 117px; }
	.area__main { width: auto; border-radius: 7px; padding: 10px; margin-left: 0 !important; margin-right: 0 !important; }
	.area__main img { border-radius: 5px; }
	.area-wrap { display: block; margin-top: 30px; }
	.area { display: flex; justify-content: space-between; align-items: center; border-radius: 7px; padding: 10px; }
	.area:nth-of-type(odd) {  }
	.area-outer-wrap:first-of-type .area:nth-of-type(even) { flex-direction: row-reverse; }
	.area:nth-of-type(odd) {  }
	.area-outer-wrap:last-of-type .area:nth-of-type(odd) { flex-direction: row-reverse; }
	.area-outer-wrap:first-of-type .area:nth-of-type(odd) .area__thumb__txt { margin-left: 20px; padding-right: 10px; }
	.area-outer-wrap:first-of-type .area:nth-of-type(even) .area__thumb__txt { margin-right: 20px; padding-left: 10px; }
	.area-outer-wrap:last-of-type .area:nth-of-type(odd) .area__thumb__txt { margin-right: 20px; padding-left: 10px; }
	.area-outer-wrap:last-of-type .area:nth-of-type(even) .area__thumb__txt { margin-left: 20px; padding-right: 10px; }
	.area:not(:first-of-type) { margin-top: 20px; }
	.area__label { top: -12px; min-width: 111px; height: 24px; border-radius: 0 0 5px 5px; padding-left: 5px; padding-right: 5px; font-size: 1.2rem; white-space: nowrap; }
	.area__label::before { width: 12px; aspect-ratio: 12/15; }
	.area__thumb { position: relative; width: 130px; }
	.area__thumb__img { border-radius: 5px; }
	.area__thumb__txt { flex: 1; margin-top: 0; font-size: 1.2rem; line-height: 1.58334; letter-spacing: 0.01em;  }

	.area-obj--upper_right img ,
	.area-obj--upper_left img { max-width: none; }
	.area-obj--upper_right { top: -85px; right: -40px; width: 101px; z-index: -1; }
	.area-obj--upper_left  { bottom: auto; top: -63px; left: -27px; width: 99px; }
	._obj-cloud { width: 221px; }
	.area-obj--upper_cloud_right { bottom: -110px; right: -148px; }
	.area-obj--upper_cloud_left { top: 64px; left: -141px; }

	.area-obj--lower_right { top: -5px; right: -36px; width: 84px; }
	.area-obj--lower_left { top: -80px; left: -45px; width: 129px; }
	.area-obj--lower_cloud_left { top: 250px; left: -140px; z-index: -1; }
	.area-obj--lower_cloud_right { bottom: 230px; right: -148px; z-index: -1; }

	.area-obj--star_bottom { bottom: -107px; left: 50%; transform: translateX(-47%); width: 346px; }

}


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

@media screen and (max-width: 680px) {
	
}


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

@media screen and (max-width: 680px) {
	
}

