@charset "UTF-8";

/* ===== リセットCSS ===== */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
html, body {
    width: 100%;
    height: 100%;
}
body {
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.6;
    font-feature-settings: 'palt';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #0A1325;
}
/* リストのデフォルトスタイルを削除 */
ul, ol {
    list-style: none;
}
/* aタグのデフォルトスタイルを削除 */
a {
    text-decoration: none;
    color: inherit;
}
/* ボタンのリセット */
button {
    border: none;
    background: none;
    cursor: pointer;
}
/* 画像のリセット */
img {
    display: block;
    max-width: 100%;
    height: auto;
}
.clearfix:after {
    display: block;
    visibility: hidden;
    clear: both;
    height: 0;
    content: ".";
    line-height: 0;
}

/* ===== PC・スマホの表示切り替え ===== */
.pc {
    display: none;
}
.sp {
    display: block;
}
@media screen and (min-width: 992px) {
    .pc {
        display: block;
    }
    .sp {
        display: none;
    }
}




/* ===== 共通レイアウト ===== */

/* メインビジュアル */
.main-visual {
    position: relative;
    text-align: center;
    width: 100%;
    overflow: hidden;
	height:calc(100vw*1.1);
	/*background:url("../img/sp-mv.jpg");
	background-size:100%;*/
}
.main-visual .mvttl1{
	position: absolute;
    z-index: 10;
    top: calc(100vw * 0.16);
    left: 12%;
    width: 43%;
}
.main-visual .mvttl2{
	position: absolute;
    z-index: 10;
    left: 12%;
    top: calc(100vw * 0.3);
    width: 57%;
}
.main-visual .mvttl3{
	position: absolute;
    z-index: 10;
    left: 12%;
    top: calc(100vw * 0.42);
    width: 40%;
}
.main-visual .mvnotebook1{
	position: absolute;
    width: 45%;
    z-index: 1;
        top: calc(100vw * 0.39);
    margin-left: -7%;
}
.main-visual .mvnotebook2{
	position: absolute;
    width: 39.4%;
    z-index: 1;
    top:calc(100vw * 0.46);
    left: 31%;
}
.main-visual .mvnotebook3{
	position: absolute;
    width: 42%;
    z-index: 1;
    top: calc(100vw * 0.33);
    left: 65%;
}
.main-visual .mvname_haruna{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 0.889);
    width: 20.5%;
    left: 4.5%;
}
.main-visual .mvname_tamae{
    position: absolute;
    z-index: 2;
    top: calc(100vw * 0.945);
    width: 21.9%;
    left: 37%;
}
.main-visual .mvname_kyoka{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 0.79);
    width: 25.5%;
    left: 70.7%;
}
.main-visual .mvphoto_haruna{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 0.47);
    width: 31%;
    left: 0;
}
.main-visual .mvphoto_tamae{
    position: absolute;
    z-index: 2;
    top: calc(100vw * 0.524);
    width: 27.4%;
    left: 37%;
}
.main-visual .mvphoto_kyoka{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 0.38);
    width: 29%;
    left: 71%;
}
.main-visual .produced{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 1.075);
    width: 15%;
    left: 34.7%;
}
.main-visual .baila{
	position: absolute;
    z-index: 2;
    top: calc(100vw * 1.055);
    left: 51%;
    width: 15%;
}
.text-container {
    position: absolute;
    margin: 0;
    padding: 0;
}

/* lead */
.lead-text {
    text-align: center;
    padding: 5vw 2.7vw;
    font-size: 3.5vw;
    color: #333333;
    font-weight: 500;
    line-height: 1.83;
    letter-spacing: 1px;
}

/* popup */
.popup-store {
	max-width: 55rem;
	margin: 5vw auto;
	padding: 0 9.5%;
	text-align: center;
	color: #333333;
	font-size: 0.75rem;
	line-height:2;
}
.popup-store .popup-title {
	font-size: 1rem;
	font-weight: bold;
	line-height:2.2;
}
.popup-store .popup-arrow {
	font-size: 1rem;
	margin: 0 0.5rem;
	font-weight:bold;
}
.popup-store .popup-date {
	font-weight: bold;
	font-size: 1rem;
	margin-bottom: 0.5rem;
}
.popup-store .popup-location {
	font-size: 0.77rem;
	margin-bottom: 1.2rem;
	line-height: 1.8;
	font-weight:500;
}
.popup-store .popup-description {
	border-top:1px solid #a6a6a6;
	padding-top:6%;
	margin-bottom: 1.5rem;
	line-height: 1.8;
	text-align: left;
}
.popup-store .popup-button {
	text-align: center;
}
.popup-store .popup-link {
	display: inline-block;
	padding: 0.2rem;
	border: 1px solid #000;
	color: #000;
	font-weight: bold;
	text-decoration: none;
	font-size:0.9rem;
	letter-spacing:1px;
	width:75%;
}

/* banner */
.banner{
	width:80%;
	margin:20% auto;
}
.banner img{
	margin-bottom:5%;
}
.banner img:hover {
	opacity: 0.9;
}
.button .button-link:hover {
	opacity: 0.9;
}

/* button */
.button-wrapper {
	max-width: 62.5rem;
	margin: 20vw auto 0 auto;
	padding: 0 10%;
	font-family: "Montserrat" ;
}
.button {
	text-align: center;
}
.button:first-child {
	text-align: center;
	margin-bottom: 1.5rem;
}
.button .button-link {
	display: inline-block;
	padding: 0.4rem 0.2rem;
	border: 1px solid #000;
	color: #000;
	font-weight: bold;
	text-decoration: none;
	font-size:0.9rem;
	width:75%;
}
.button .button-link:hover {
	opacity: 0.9;
}

/* Staff Credit */
.staff-info {
    max-width: 62.5rem;
    margin: 20vw auto 5vw auto;
    text-align: center;
    font-size: 0.55rem;
    color: #333333;
    padding: 2.5vw;
	font-family: "Montserrat" ;
	line-height:2.5;
}
.staff-info .staff-title {
    font-size: 0.9rem;
    margin-bottom: 1.25vw;
	font-family:"Bellefair";
	color:#333333;
}

/* footer */
.onward-logo{
}
.onward-logo img{
	width: 150px;
	margin: 5rem auto 0 auto;
}
.copyright{
	text-align: center;
	font-size: 10px;
	margin: 40px auto 0 auto;
    padding-bottom:20px;
    color:#000;
	font-family: "Montserrat" ;
}

/* credit */
ul.credit{
	width:90%;
	margin:4% auto 25% auto;
	list-style: none;
	text-align:center;
	line-height:2;
}
ul.credit li{
	margin:0 0 10px 0;
	padding:0 0 5px 0;
	display: flex;
	flex-direction:column;
	align-items:center;
}
ul.credit li span.itemname{
	font-size:0.68rem;
	color:#435683;
}
ul.credit li span.detail{
	font-size: 0.65rem;
    font-weight: bold;
    color: #435683;
    padding: 2px 0;
    height: 21px;
	border-bottom:2px solid #435683;
}
ul.credit li span.detail:hover{
}


/* メディアクエリ - PC表示 */
@media screen and (min-width: 992px) {
	.main-visual{
		width:100%;
		height:calc(100vw*0.6875);
		/*background:url("../img/pc-mv.jpg");
		background-size:100%;*/
	}
	.main-visual .mvttl1{
		top: calc(100vw * 0.097);
    	left: 15.5%;
    	width: 24%;
	}
	.main-visual .mvttl2{
    	left: 15.5%;
		top: calc(100vw * 0.175);
        width: 31.7%;
	}
	.main-visual .mvttl3{
    	left: 15.5%;
		top: calc(100vw * 0.26);
        width: 22.3%;
	}
	.main-visual .mvnotebook1{
		width: 36%;
        top: calc(100vw * 0.185);
        margin-left: 0;
        left: 5.5%;
		z-index:0;
	}
	.main-visual .mvnotebook2{
		width: 31.7%;
        top: calc(100vw * 0.225);
        left: 34.4%;
		z-index:2;
	}
	.main-visual .mvnotebook3{
		width: 34.5%;
        top: calc(100vw * 0.112);
        left: 59.3%;
	}
	.main-visual .mvname_haruna{
		z-index:1;
		top: calc(100vw * 0.58);
        width: 16.5%;
        left: 14.5%;
	}
	.main-visual .mvname_tamae{
		top: calc(100vw * 0.61);
        width: 17.6%;
        left: 39.6%;
		z-index:3;
	}
	.main-visual .mvname_kyoka{
		top: calc(100vw * 0.5);
        width: 20%;
        left: 65%;
	}
	.main-visual .mvphoto_haruna{
		top: calc(100vw * 0.24);
		width: 25.3%;
		left: 11%;
		z-index:1;
	}
	.main-visual .mvphoto_tamae{
		position: absolute;
    	z-index: 4;
    	top: calc(100vw * 0.275);
    	width: 22.2%;
    	left: 39.7%;
	}
	.main-visual .mvphoto_kyoka{
		position: absolute;
		z-index: 2;
		top: calc(100vw * 0.164);
		width: 24.2%;
		left: 65%;
	}
	.main-visual .produced{
        top: calc(100vw * 0.611);
        width: 9.5%;
        left: 69.7%;
	}
	.main-visual .baila{
        top: calc(100vw * 0.6);
        left: 80%;
        width: 9.4%;
	}
	
	/* lead */
	.lead-text{
		margin-top:3rem;
		font-size:1.1rem;
		margin-bottom:0;
	}
	
	/* popup */
	.popup-store{
		margin: 0 auto 5vw auto;
	}
	.popup-store .popup-title{
		font-size:1.2rem;
	}
	.popup-store .popup-date{
		font-size:1.2rem;
	}
	.popup-store .popup-location {
		font-size: 0.95rem;
		margin-bottom: 1.6rem;
	}
	.popup-store .popup-date {
		margin-bottom: 0.8rem;
	}
	.popup-store .popup-description{
		text-align:center;
		line-height:1.8;
		font-size:0.95rem;
		margin-bottom: 1.5rem;
		padding-top:3.5%;
	}
	.popup-store .popup-link{
		width:41%;
	}

	
	/* banner */
	.banner{
		width:680px;
		margin:7rem auto;
	}
	.banner .button .button-link{
		width:45%;
	}
	
	/* button */
	.button-wrapper{
		margin: 0 auto;
	}
	.button .button-link{
		width:35%;
	}
	
	/* Staff Credit */
	.staff-info {
        font-size: 0.85rem;
		margin:8vw auto;
		line-height:2.38;
	}
	.staff-info .staff-title{
		font-size:1.3rem;
		line-height: 1.7;
	}
	
	/* credit */
	ul.credit {
		width: 700px;
		margin: 40px auto 0 auto;
	}
	ul.credit li{
		flex-direction:row;
		text-align: center;
  		vertical-align: middle;
		justify-content:center;
		padding:0;
	}
	ul.credit li span.detail{
		padding:0;
		height: 16px;
		font-size:0.55rem;
		display: inline-block;
		margin-left: 30px;
		font-family: "Montserrat", sans-serif;
	}
	ul.credit li span.itemname{
		font-size: 0.76rem;
		letter-spacing: 0.5px;
	}
}





/* 特集 */
.main-visual{
}
.subttl{
	width:100%;
	padding:10% 0 6% 0;
}
.subttl .subttlbox{
	width:50%;
	margin:0 auto;
	padding:3%;
	position:relative;
}
.subttl .subttlbox .subttl1{
	margin:0 auto;
	width:90%;
}
.subttl .subttlbox .line {
    position: absolute;
    transition: all 0.6s ease;
	background-color: #000;
}
.subttl .subttlbox .line-top {
    top: 0;
    left: 0;
    height: 2px;
    width: 12px;
    transform-origin: left center;
	background-color: #000;
}
.subttl .subttlbox .line-left {
    top: 0;
    left: 0;
    width: 2px;
    height: 12px;
    transform-origin: top center;
    transition-delay: 0.2s;
	background-color: #000;
}
.subttl .subttlbox .line-bottom {
    bottom: 0;
    right: 0;
    height: 2px;
    width: 12px;
    transform-origin: right center;
    transition-delay: 0.4s;
	background-color: #000;
}
.subttl .subttlbox .line-right {
    bottom: 0;
    right: 0;
    width: 2px;
    height: 12px;
    transform-origin: bottom center;
    transition-delay: 0.6s;
	background-color: #000;
}
.subttl .logo{
	width:46%;
    margin: 3% auto 5% auto;
}
.subttl .subttl2{
	width:34%;
	margin:0 auto;
}

.lead-text{
	width:100%;
	padding:0 0  17% 0;
	line-height:2;
	font-size:0.9rem;
}

.case1,
.case2,
.case3{
	width:100%;
}
.case1 .bg{
	background:#f8f5f1;
	width:100%;
	height:calc(100vw*1);
	position:absolute;
	z-index:0;
}
.casettl{
	color:#435683;
	width:100%;
	padding:0 0 1% 8%;
	position: relative;
}
.casettl .case{
	font-family:"Bellefair";
	font-size:1.6rem;
	margin-right:7px;
	display: inline-block;
}
.casettl .caseno{
	font-family:"Bellefair";
	font-size:1.6rem;
	margin-right:9px;
	display: inline-block;
}
.casettl .caseline{
	width:1px;
	height:20px;
	display:inline-block;
	background:#435683;
	margin-right:15px;
}
.casettl .casename{
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: italic;
	font-size:0.7rem;
	position: absolute;
    margin-top: 0.65rem;
}
p.casesubttl{
	font-size:1.2rem;
	padding:0 0 1% 8%;
	letter-spacing:1.2px;
}
.case1 .photo1{
	width:80%;
	margin:5% 20% 7% 0;
}
.case1 .dressingroom{
	width:26%;
	margin: 9% auto 0 27%;
	position:absolute;
	z-index:10;
}
.case1 .photo2{
	width:46%;
	margin:0 8% 10% auto;
}
.case2 .photo1{
	width:80%;
	margin:5% 0 7% 20%;
}
.case2 .dressingroom{
	width:26%;
	margin:6% auto 0 49%;
	position:absolute;
	z-index:10;
}
.case2 .photo2{
	width:46%;
	margin: 0 auto 10% 8%;
}
.case3 .photo1{
	width:80%;
	margin:5% 20% 7% 0;
}
.case3 .dressingroom{
	width:26%;
	margin: 9% auto 0 26%;
	position:absolute;
	z-index:10;
}
.case3 .photo2{
	width:46%;
	margin:0 8% 10% auto;
}
.profilebox{
	width:84%;
	margin:0 auto;
	border:1px solid #435683;
	color:#435683;
	background:#ffffff;
}
.profilebox .profilettl{
	position: relative;
    width: 30%;
    margin: -4% 5% 0 70%;
}
.profilebox .profilettl .circle{
    width: calc(100vw * 0.21);
    height: calc(100vw * 0.07);
    border-radius: 50%;
    background: #ffffff;
    border: 1px solid #435683;
    box-sizing: border-box;
	position:absolute;
}
.profilebox .profilettl .profilettl2{
	font-family:"Bellefair";
	position:absolute;
	left:16%;
	top:calc(100vw*0.012);
	font-size:0.86rem;
}
.profilebox .profilename{
	font-size:0.8rem;
	margin:6% 0 0 7%;
	font-weight:bold;
}
.profilebox .profileline{
	width:100%;
	height:1px;
	background:#435683;
	margin:2.6% 0;
}
.profilebox .profiledetail{
	color:#000000;
	font-size:0.8rem;
	line-height:1.7;
	margin:0 6% 3% 7%;
}

.case1 .selectbox{
	width:100%;
	display: flex;
	flex-flow: column;
	margin-top:10%;
}
.case2 .selectbox{
	width:100%;
	display: flex;
	flex-flow: column;
	margin-top:10%;
}
.case3 .selectbox{
	width:100%;
	display: flex;
	flex-flow: column;
	margin-top:10%;
}
.selectbox .selectphoto{
	width:70%;
	margin:0 auto;
}
.selectbox .notebook{
	width:90%;
	margin:5% auto;
	background:url("../img/notebook.png");
	background-size:100%;
	padding:10% 0;
	text-align:center;
	color:#435683;
	font-weight:bold;
	background-repeat: no-repeat;
	height: calc(100vw * 0.7);
}
.case2 .selectbox .notebook{
	width:90%;
	margin:5% auto;
	background:url("../img/notebook2.png");
	background-size:100%;
	padding:10% 0;
	text-align:center;
	color:#435683;
	font-weight:bold;
	background-repeat: no-repeat;
	height: calc(100vw * 0.7);
}
.selectbox .notebook .notebook1{
	width:38%;
	margin:0 auto 4% auto;
}
.selectbox .notebook .notebook2{
	font-size:0.8rem;
	margin:0 auto 4% auto;
}
.selectbox .notebook .notebook3{
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: italic;
	font-size:1.2rem;
	line-height:1.4;
	margin:0 auto 4% auto;
}
.selectbox .notebook .notebook4{
	font-size:0.75rem;
	margin:0 auto;
}
.selfstyling{
	width:84%;
	margin:3% auto 0 auto;	
}
.selfstyling .selfttl{
	font-family:"Bellefair";
	line-height:1;
	font-size: 2.05rem;
	color:#435683;
}
.selfstyling .selfphotobox{
	width:100%;
	position:relative;
	height:calc(100vw*1.13);
	margin-top: -1.8%;
}
.selfstyling .selfphotobox .selectphoto{
	width:100%;
	position:absolute;
	z-index:0;
}
.selfstyling .selfphotobox .no{
	position:absolute;
	z-index:2;
	width:26%;
	right:0;
	bottom:calc(100vw*0.05);
	color:#fff;
	text-align:center;
	font-family: "Montserrat", sans-serif;
}
.selfstyling .selfphotobox .no .no1{
	font-size:0.5rem;
	line-height:0.5rem;
	display: block;
}
.selfstyling .selfphotobox .no .no2{
	font-size:2.2rem;
	font-style: italic;
	display: block;
	line-height:2.2rem;
}
.selfstyling .selfphotobox .no .no3{
	font-size:0.6rem;
	line-height:0.6rem;
	display: block;
	font-weight:600;
}
.interviewttl{
	position:relative;
	width:26%;
	margin:8% auto 5% auto;
	height:calc(100vw*0.05);
}
.interviewttl .circle{
    width: calc(100vw * 0.25);
    height: calc(100vw * 0.07);
    border-radius: 50%;
    background: #ffffff;
    border: 1px solid #435683;
    box-sizing: border-box;
	position:absolute;
}
.interviewttl .interviewttl2{
	font-family:"Bellefair";
	position:absolute;
	left:16%;
	top:calc(100vw*0.014);
	font-size:0.85rem;
}
.interviewbox{
	width:84%;
	margin:0 auto;
	padding:3.2% 7%;
	position:relative;
}
.interviewbox p{
	font-size: 0.74rem;
    line-height: 1.8;
    letter-spacing: 0.5px;
}
.interviewbox .line {
    position: absolute;
    transition: all 0.6s ease;
	background-color: #435683;
}
.interviewbox .line-top {
    top: 0;
    left: 0;
    height: 2px;
    width: 26px;
    transform-origin: left center;
	background-color: #435683;
}
.interviewbox .line-left {
    top: 0;
    left: 0;
    width: 2px;
    height: 26px;
    transform-origin: top center;
    transition-delay: 0.2s;
	background-color: #435683;
}
.interviewbox .line-bottom {
    bottom: 0;
    right: 0;
    height: 2px;
    width: 26px;
    transform-origin: right center;
    transition-delay: 0.4s;
	background-color: #435683;
}
.interviewbox .line-right {
    bottom: 0;
    right: 0;
    width: 2px;
    height: 26px;
    transform-origin: bottom center;
    transition-delay: 0.6s;
	background-color: #435683;
}
.beigebox{
	background:#f8f5f1;
	padding-top:10%;
}
@media screen and (min-width: 992px) {
	.subttl{
		width:560px;
		padding:20px 0 0 0;
		margin:0 auto;
	}
	.subttl .subttlbox{
		width:330px;
		margin:0 auto;
		padding:11px 5px;
		position:relative;
	}
	.subttl .subttlbox .subttl1{
		margin:0 auto;
		width:84%;
	}
	.subttl .subttlbox .line {
		position: absolute;
		transition: all 0.6s ease;
		background-color: #000;
	}
	.subttl .subttlbox .line-top {
		top: 0;
		left: 0;
		height: 2px;
		width: 16px;
		transform-origin: left center;
		background-color: #000;
	}
	.subttl .subttlbox .line-left {
		top: 0;
		left: 0;
		width: 2px;
		height: 16px;
		transform-origin: top center;
		transition-delay: 0.2s;
		background-color: #000;
	}
	.subttl .subttlbox .line-bottom {
		bottom: 0;
		right: 0;
		height: 2px;
		width: 16px;
		transform-origin: right center;
		transition-delay: 0.4s;
		background-color: #000;
	}
	.subttl .subttlbox .line-right {
		bottom: 0;
		right: 0;
		width: 2px;
		height: 16px;
		transform-origin: bottom center;
		transition-delay: 0.6s;
		background-color: #000;
	}
	.subttl .logobox{
		width:560px;
		display:flex;
		margin: 32px 0 0 0;
	}
	.subttl .logobox .logo{
		width: 300px;
		margin:0;
	}
	.subttl .logobox .subttl2{
		width: 233px;
        margin: 3px 0 0 27px;
		height:28px;
	}
	.lead-text{
		padding: 0 0 130px 0;
		line-height: 2.1;
		font-size: 17px;
	}
	.case1,
	.case2,
	.case3{
		width:1020px;
		margin:0 auto 160px auto;
	}
	.casettl{
		padding: 0 0 15px 40px;
	}
	.casettl .case{
		font-size: 2.2rem;
		margin-right:7px;
	}
	.casettl .caseno{
		font-family:"Bellefair";
		font-size:2.2rem;
		margin-right:14px;
	}
	.casettl .caseline{
		width:1px;
		height:25px;
		display:inline-block;
		background:#435683;
		margin-right:18px;
	}
	.casettl .casename{
		font-family: "Montserrat", sans-serif;
		font-optical-sizing: auto;
		font-weight: 600;
		font-style: italic;
		font-size:0.94rem;
		position: absolute;
		margin-top: 0.9rem;
	}
	.case2 .casettl{
		padding: 0 0 15px 400px;
	}
	p.casesubttl{
		font-size: 2rem;
        padding: 0 0 6px 40px;
        letter-spacing: 0.5px;
        line-height: 1.4;
	}
	.case2 p.casesubttl{
		font-size: 2rem;
		padding: 0 0 6px 400px;
        letter-spacing: 0.5px;
        line-height: 1.4;
	}
	.case1 p.casesubttl{
		font-size: 2rem;
        padding: 0 0 6px 40px;
        letter-spacing: 0.5px;
        line-height: 1.4;
	}
	.case1 .photobox{
		width:1020px;
		height:655px;
		position:relative;
		margin: 50px 0 0 35px;
	}
	.case1 .photobox .photo1{
		width:580px;
		margin:0;
		position:absolute;
	}
	.case1 .photobox .dressingroom{
		width:145px;
		margin:0;
		position:absolute;
		z-index:10;
		right:0;
		top:220px;
	}
	.case1 .photobox .photo2{
		width:300px;
		margin:0;
		position:absolute;
		right:75px;
		top:205px;
	}
	.case2 .photobox{
		width:1020px;
		height:655px;
		position:relative;
		margin: 50px 0 0 35px;
	}
	.case2 .photobox .photo1{
		width:580px;
		margin:0;
		position:absolute;
		right: 80px;
	}
	.case2 .photobox .dressingroom{
		width: 145px;
        margin: 0 0 0 -50px;
        position: absolute;
        z-index: 10;
        left: 0;
        top: 250px;
	}
	.case2 .photobox .photo2{
		width:300px;
		margin:0;
		position:absolute;
		left:0;
		top:205px;
	}
	.case2 .photobox .profilebox{
		right:80px;
	}
	.case3 .photobox{
		width:1020px;
		height:655px;
		position:relative;
		margin: 50px 0 0 35px;
	}
	.case3 .photobox .photo1{
		width:580px;
		margin:0;
		position:absolute;
	}
	.case3 .photobox .dressingroom{
		width:145px;
		margin:0;
		position:absolute;
		z-index:10;
		right:0;
		top:220px;
	}
	.case3 .photobox .photo2{
		width:300px;
		margin:0;
		position:absolute;
		right:75px;
		top:205px;
	}
	.profilebox{
		width:580px;
		margin:0;
		position:absolute;
		top:445px;
	}
	.profilebox .profilettl{
		position:relative;
		width: 123px;
		margin: -20px 0 0 430px;
	}
	.profilebox .profilettl .circle{
		width: 123px;
		height: 37px;
		position:absolute;
	}
	.profilebox .profilettl .profilettl2{
		position: absolute;
        left: 24px;
        top: 5px;
        font-size: 1.2rem;
	}
	.profilebox .profilename{
		font-size: 1.1rem;
        margin: 35px 0 13px 40px;
	}
	.profilebox .profileline{
		width:100%;
		height:1px;
		background:#435683;
		margin:0;
	}
	.profilebox .profiledetail{
		font-size: 1.05rem;
        line-height: 1.7;
        margin: 14px 35px 18px 40px;
	}
	.case1 .selectbox{
		width:100%;
		display: flex;
		flex-flow: column;
		flex-direction:row;
		margin-top:65px;
		height:630px;
	}
	.case2 .selectbox{
		width:100%;
		display: flex;
		flex-flow: column;
		flex-direction: row-reverse;
		margin-top:65px;
		position:relative;
		height:630px;
	}
	.case3 .selectbox{
		width:100%;
		display: flex;
		flex-flow: column;
		flex-direction:row;
		margin-top:65px;
		height:630px;
	}
	.selectbox .selectphoto{
		width: 465px;
        margin: 0 0 0 35px;
		height:627px;
	}
	.case2 .selectbox .selectphoto{
		width: 465px;
        margin: 0 40px 0 0;
		/*position:absolute;*/
		z-index:0;
	}
	.selectbox .notebook{
		width: 550px;
        margin: 120px 0 0 -30px;
        text-align: left;
        padding: 80px 0;
        z-index: 1;
	}
	.case2 .selectbox .notebook{
        margin: 0;
        position: absolute;
        z-index: 1;
        left: 0;
        top: 115px;
        width: 550px;
		height:400px;
		padding: 80px 0 0 0;
	}
	.selectbox .notebook .notebook1{
		width: 170px;
        margin: 0 0 30px 80px;
	}
	.selectbox .notebook .notebook2{
		font-size: 1.05rem;
		margin: 0 0 15px 80px;
		text-align:left;
	}
	.selectbox .notebook .notebook3{
		font-size:1.6rem;
		line-height: 1.5;
        margin: 0 0 15px 80px;
		text-align:left;
	}
	.case1 .selectbox .notebook .notebook3{
		font-size:1.4rem;
	}
	.selectbox .notebook .notebook4{
		font-size:1.08rem;
		margin: 0 0 0 80px;
		text-align:left;
	}
	.selfstyling{
		width:530px;
		margin:125px auto 0 auto;	
	}
	.selfstyling .selfttl{
		line-height:1.1;
		font-size: 2.4rem;
	}
	.selfstyling .selfphotobox{
		width:100%;
		position:relative;
		height:713px;
		margin-top: -1.8%;
	}
	.selfstyling .selfphotobox .selectphoto{
		width:100%;
		position:absolute;
		z-index:0;
	}
	.selfstyling .selfphotobox .no{
		position: absolute;
        z-index: 2;
        width: 140px;
        right: 0;
        bottom: 30px;
        color: #fff;
        text-align: center;
        font-family: "Montserrat", sans-serif;
	}
	.selfstyling .selfphotobox .no .no1{
		        font-size: 0.65rem;
        line-height: 0.9rem;
        display: block;
	}
	.selfstyling .selfphotobox .no .no2{
		font-size: 3.8rem;
        font-style: italic;
        display: block;
        line-height: 3.9rem;
	}
	.selfstyling .selfphotobox .no .no3{
		font-size: 0.9rem;
        line-height: 0.8rem;
        display: block;
        font-weight: 600;
	}
	.interviewttl{
		width:152px;
		margin:53px auto 20px auto;
		height:38px;
	}
	.interviewttl .circle{
		width: 152px;
		height: 38px;
	}
	.interviewttl .interviewttl2{
		left: 17%;
        top: calc(100vw * 0.0045);
        font-size: 1.2rem;
	}
	.interviewbox{
		width:850px;
		margin:0 auto;
		padding:20px 45px;
		position:relative;
	}
	.interviewbox p{
		font-size: 1rem;
        line-height: 1.7;
        letter-spacing: 1px;
	}
	.interviewbox .line-top {
		width: 33px;
	}
	.interviewbox .line-left {
		height: 36px;
	}
	.interviewbox .line-bottom {
		width: 33px;
	}
	.interviewbox .line-right {
		height: 36px;
	}
	.beigebox{
		padding-top:100px;
	}
}
@media screen and (max-width: 390px) {
	.selectbox .notebook .notebook3 {
    	font-size: 1.1rem;
	}
	p.casesubttl {
	    font-size: 1.1rem;
	}
	ul.credit li span.itemname {
		font-size: 0.6rem;
	}
}


/* 背景レイヤー */
.bg-wrapper {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: var(--doc-height, 100vh);
  pointer-events: none;
  z-index: -1;
}

.bg1,
.bg2 {
  position: absolute;
  left: 0;
  width: 100%;
  transform-origin: left center;
  transform: scaleX(0);
  background-color: #f8f5f1;
}

.bg1 {
  top: 0;
  height: var(--bg1-height, 0px);
}

.bg2 {
  top: var(--bg2-top, 0px);
  height: var(--bg2-height, 0px);
}

@keyframes revealBG {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

.bg1.reveal,
.bg2.reveal {
  animation: revealBG 0.6s ease-out forwards;
}

.bg2.reveal {
  /*animation-delay: 0.6s;*/
}

/* animation */

/*zoomoutMV*/
.fadeZoomOutTFixMV.wow.animated {
    animation-name: fadeZoomOutTFixMV;
    animation-duration: 6s;
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    animation-delay: 0.2s;
    animation-iteration-count: 1;
    animation-direction: normal;
    animation-fill-mode: forwards;
    will-change: transform;
}
.fadeZoomOutTFixMV {
    opacity: 0;
    transform-origin: top;
    transform: scale(1.1);
}
@keyframes fadeZoomOutTFixMV {
  0% {
    opacity: 0;
    transform: scale(1.1);
  }
  20% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* slide-downMV（上辺固定のまま） */
.slide-down-fixMV.wow.animated {
  animation-name: slide-down-fixMV;
  animation-duration: 1.4s;
  animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  animation-delay: 0.6s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  will-change: transform;
}

.slide-down-fixMV {
  opacity: 0;
}

@keyframes slide-down-fixMV {
  0% {
    transform: translateY(-10%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

/* slide-rightMV（右辺固定のまま） */
.slide-right-fixMV.wow.animated {
  animation-name: slide-right-fixMV;
  animation-duration: 1.4s;
  animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  animation-delay: 0.6s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  will-change: transform;
}

.slide-right-fixMV {
  opacity: 0;
}

@keyframes slide-right-fixMV {
  0% {
    transform: translateX(-10%);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

/* slide-leftMV（左辺固定のまま） */
.slide-left-fixMV.wow.animated {
  animation-name: slide-left-fixMV;
  animation-duration: 1.4s;
  animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  animation-delay: 0.6s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  will-change: transform;
}

.slide-left-fixMV {
  opacity: 0;
}

@keyframes slide-left-fixMV {
  0% {
    transform: translateX(10%);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
/* slide-upMV（下辺固定のまま） */
.slide-up-fixMV.wow.animated {
  animation-name: slide-up-fixMV;
  animation-duration: 1.4s;
  animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  animation-delay: 0.6s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
  will-change: transform;
}

.slide-up-fixMV {
    opacity: 0;
}
@keyframes slide-up-fixMV {
  0% {
    transform: translateY(10%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

/* fadeTopBottomBig (上→下) */
.fadeTopBottomBig.wow.animated {
    animation-name: fadeTopBottomBig;
    animation-duration: 1s; /* 短縮 */
    animation-timing-function: ease;
    animation-delay: 0.4s;
    animation-iteration-count: 1;
    animation-direction: normal;
    animation-fill-mode: forwards;
    opacity: 0;
    will-change: opacity;
}
.fadeTopBottomBig {
    opacity: 0;
}
@keyframes fadeTopBottomBig {
  0% {
    opacity: 0;
    transform: translateY(-1vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* fadeBottomTopBig (下→上) */
.fadeBottomTopBig.wow.animated {
    animation-name: fadeBottomTopBig;
    animation-duration: 1s; /* 短縮 */
    animation-timing-function: ease;
    animation-delay: 0.4s;
    animation-iteration-count: 1;
    animation-direction: normal;
    animation-fill-mode: forwards;
    opacity: 0;
    will-change: opacity;
}
.fadeBottomTopBig {
    opacity: 0;
}
@keyframes fadeBottomTopBig {
  0% {
    opacity: 0;
    transform: translateY(1vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* タブレット用 */
@media screen and (min-width: 768px) and (max-width: 991px) {
  	.profilebox .profilettl {
    	margin: -3% 5% 0 75%;
	}
	.profilebox .profilettl .circle {
		width: calc(100vw * 0.15);
		height: calc(100vw * 0.045);
	}
	.profilebox .profilettl .profilettl2{
	    left: 12%;
        top: calc(100vw * 0.005);
		font-size: 1.2rem;
	}
	.case1 .selectbox .notebook,
	.case2 .selectbox .notebook,
	.case3 .selectbox .notebook{
		height: calc(100vw * 0.47);
	}
	.selfstyling .selfttl {
	    line-height: inherit;
	}
	.interviewttl{
		width:17%;
	}
	.interviewttl .circle{
		width: calc(100vw * 0.17) !important;
		height: calc(100vw * 0.05) !important;		
	}
    .interviewttl .interviewttl2{
        left: 14%;
        top: calc(100vw * 0.008);
        font-size: 1.2rem;
    }
}