@charset "UTF-8";

/* mainvisual */

.pre-inc .mainvisual{
	max-width: 100%;
	margin: 0 auto;
	aspect-ratio: 32 / 23;
	overflow: hidden;
}
.pre-inc .mainvisual img{
	width: 100%;
}
.pre-inc .mv_section{
	position: relative;
	width: 100%;
	height: 100%;
}
.pre-inc .mv_section01,.pre-inc .mv_section02{
	position: absolute;
	top: 0;
}
.pre-inc .mv_section02{
	z-index: 4;
	opacity: 0;
	transition: 2s;
}
.pre-inc .mv_section02.on{
	opacity: 1;
}
.pre-inc .mv_panel{
	position: absolute;
	top: 0;
}
.pre-inc .copytext{
	color: #4f6486;
	font-family: "Zen Old Mincho", serif;
	font-size: 2.4em;
	letter-spacing: 0.16em;
	width: 100%;
	height: 100%;
	padding: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: 1.5s;
}
.pre-inc .copytext.on{
	opacity: 1;
}
.pre-inc .photo_panel{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	z-index: 2;
}
.pre-inc .photoimage{
	position: absolute;
	z-index: 2;
}
.pre-inc .mv_section01 .photo01 .photoimage{
	width: 12.39583333333333%;
	right: 38.54166666666667%;
	top: 34.49275362318841%;
}
.pre-inc .mv_section01 .photo02 .photoimage{
	width: 19.79166666666667%;
	left: 19.42708333333333%;
	top: 28.98550724637681%;
}
.pre-inc .mv_section01 .photo03 .photoimage{
	width: 19.16666666666667%;
	left: 33.33333333333333%;
	top: 47.2463768115942%;
}
.pre-inc .mv_section01 .photo04 .photoimage{
	width: 19.47916666666667%;
	right: 20.3125%;
	bottom: 27.53623188405797%;
}
.pre-inc .mv_section01 .photo05 .photoimage{
	width: 27.8125%;
	right: 5.729166666666667%;
	bottom: 12.31884057971014%;
}
.pre-inc .mv_section01 .photo06 .photoimage{
	width: 27.8125%;
	right: 8.854166666666667%;
	top: 12.02898550724638%;
}
.pre-inc .mv_section01 .photo07 .photoimage{
	width: 25.78125%;
	left: 8.4375%;
	bottom: 12.31884057971014%;
}
.pre-inc .mv_section01 .photo08 .photoimage{
	width: 22.91666666666667%;
	left: 3.385416666666667%;
	top: 14.20289855072464%;
}
.pre-inc .mv_section01 .photo01{
	transform: scale(2.1);
	opacity: 0;
}
.pre-inc .mv_section01 .photo01.on{
	animation: photo01anime 2.2s ease-out forwards;
	animation-delay: 0.2s;
}
.pre-inc .mv_section01 .photo02{
	transform: scale(2.3);
	opacity: 0;
}
.pre-inc .mv_section01 .photo02.on{
	animation: photo02anime 2.2s ease-out forwards;
	animation-delay: 0.4s;
}
.pre-inc .mv_section01 .photo03{
	transform: scale(2.1);
	opacity: 0;
}
.pre-inc .mv_section01 .photo03.on{
	animation: photo03anime 2.2s ease-out forwards;
	animation-delay: 0.55s;
}
.pre-inc .mv_section01 .photo04{
	transform: scale(2.3);
	opacity: 0;
}
.pre-inc .mv_section01 .photo04.on{
	animation: photo04anime 2.2s ease-out forwards;
	animation-delay: 0.75s;
}
.pre-inc .mv_section01 .photo05{
	transform: scale(2);
	opacity: 0;
}
.pre-inc .mv_section01 .photo05.on{
	animation: photo05anime 2.2s ease-out forwards;
	animation-delay: 2.1s;
}
.pre-inc .mv_section01 .photo06{
	transform: scale(2);
	opacity: 0;
}
.pre-inc .mv_section01 .photo06.on{
	animation: photo06anime 2.1s ease-out forwards;
	animation-delay: 1.7s;
}
.pre-inc .mv_section01 .photo07{
	transform: scale(1.9);
	opacity: 0;
}
.pre-inc .mv_section01 .photo07.on{
	animation: photo07anime 2s ease-out forwards;
	animation-delay: 1.4s;
}
.pre-inc .mv_section01 .photo08{
	transform: scale(1.7);
	opacity: 0;
}
.pre-inc .mv_section01 .photo08.on{
	animation: photo08anime 2s ease-out forwards;
	animation-delay: 2.3s;
}

@keyframes photo01anime{
  from{transform: scale(2.1);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo02anime{
  from{transform: scale(2.3);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo03anime{
  from{transform: scale(2.1);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo04anime{
  from{transform: scale(2.3);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo05anime{
  from{transform: scale(2);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo06anime{
  from{transform: scale(2);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo07anime{
  from{transform: scale(1.9);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
@keyframes photo08anime{
  from{transform: scale(1.7);opacity: 0;}
  to{transform: scale(1);opacity: 1;}
}
.pre-inc .mv_section02 .mv_logo,.pre-inc .mv_section02 .mv_logo_lead{
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	transition: 2s;
	z-index: 6;
}
.pre-inc .mv_section02 .mv_logo img,.pre-inc .mv_section02 .mv_logo_lead img{
	width: 53.38541666666667%;
	max-width: 1025px;
}
.pre-inc .mv_section02 .mv_logo.on,.pre-inc .mv_section02 .mv_logo_lead.on{
	opacity: 1;
}
.pre-inc .mv_section02 .mv_logo.on.pan,.pre-inc .mv_section02 .mv_logo_lead.on.pan{
	animation: pandown_logo 3s ease-in-out forwards;
}

.pre-inc .mv_section02 .mv_logo img,.pre-inc .mv_section02 .mv_logo_lead img{
	max-width: 1025px;
}
.pre-inc .mv_section02 .areaimg{
	z-index: 4;
	top: 0;
  width:100%;
  height:auto;
	transform: translateY(0);
	opacity: 0;
}
.pre-inc .mv_section02 .areaimg.on{
  animation: fadeIn 1s ease forwards,pandown 3s ease-in-out forwards;
}
.pre-inc .mv_section02 .areaimg_plot{
	z-index: 4;
	bottom: 0;
  width:100%;
  height:100%;
	transform-origin: center bottom;
	overflow: hidden;
}
.pre-inc .mv_section02 .areaimg_plot img{
	transform: translateY(var(--panY, 0px));
	clip-path: inset(100% 0 0 0);
  transition: clip-path 2s ease;
}
.pre-inc .mv_section02 .areaimg_plot.on img{
	clip-path: inset(0 0 0 0);
}
.pre-inc .mv_section02 .cap_wb{
	display: none;
	z-index: 5;
}
.pre-inc .mv_section02 .areaimg-fix{
	z-index: 5;
	top: 0;
  width:100%;
  height:auto;
	transform: translateY(var(--panY, 0px));
	opacity: 0;
	transition: 2s;
}
.pre-inc .mv_section02 .areaimg-fix.on{
	opacity: 1;
}
.pre-inc .cap-areafix{
	opacity: 0;
	transition: 2s;
}
.pre-inc .cap-areafix.on{
	opacity: 1;
}

@keyframes fadeIn{
  from{ opacity: 0; }
  to{ opacity: 1; }
}
@keyframes pandown{
  to{ transform: translateY(var(--panY, 0px)); }
}
@keyframes pandown_logo{
  to{ transform: translateY(var(--panYl, 0px)); }
}

/* koudou */
.pre-inc section#koudou {
	font-family: YakuHanMP, "Noto Serif JP", serif;
	overflow: hidden;
	background: #f7f7f7;
	padding: 60px 0 50px;
}
.pre-inc .koudou_lead{
	border-bottom: 1px solid #4f6486;
	text-align: center;
	padding-bottom: 35px;
}
.pre-inc .koudou_lead p{
	color: #4f6486;
	font-size: clamp(20px,3.2vw,32px);
	letter-spacing: 0.16em;
}
.pre-inc .koudou_lead p span{
	font-size: clamp(38px,5vw,50px);
	letter-spacing: 0.16em;
}
.pre-inc .koudou_lead p strong{
	color: #333;
	display: block;
	font-size: clamp(40px,5.6vw,56px);
	text-align: center;
	letter-spacing: 0.08em;
}
.pre-inc .koudou_entry{
	padding-top: 35px;
	text-align: center;
}
.pre-inc .koudou_entry p{
	font-size: clamp(38px,5vw,50px);
	letter-spacing: 0.1em;
	margin-bottom: 40px;
	font-family: YakuHanMP, "EB Garamond", "Noto Serif JP", serif;
}
.pre-inc .koudou_entry p small{
	font-size: clamp(14px,3vw,32px);
	letter-spacing: 0;
}
.pre-inc .entry_btn{
	text-align: center;
}
.pre-inc .entry_btn a{
	background-image: linear-gradient(0deg, #1e3d70, #4f6486);
	color: #FFF;
	font-family: "EB Garamond", serif;
	font-size: clamp(20px,3.2vw,32px);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 360px;
	height: 60px;
	position: relative;
}
.pre-inc .entry_btn a::after{
	background: url("../common/img/btn_arw_r.svg") no-repeat;
	background-size: 100% auto;
	aspect-ratio: 41 / 5;
	content: "";
	display: block;
	width: 22.77777777777778%;
	position: absolute;
	right: 11.11%;
	bottom: 33.33%;
	transition: 0.5s;
}
.pre-inc .entry_btn a:hover::after{
	right: 5.6%;
}
.pre-inc .reserve_btn a{
	background-image: linear-gradient(0deg, #7a6328, #9b813f);
	color: #FFF;
	font-family: "EB Garamond", serif;
	font-size: clamp(20px,3.2vw,32px);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 360px;
	height: 60px;
	position: relative;
}
.pre-inc .reserve_btn a::after{
	background: url("../common/img/btn_arw_r.svg") no-repeat;
	background-size: 100% auto;
	aspect-ratio: 41 / 5;
	content: "";
	display: block;
	width: 22.77777777777778%;
	position: absolute;
	right: 11.11%;
	bottom: 33.33%;
	transition: 0.5s;
}
.pre-inc .reserve_btn a:hover::after{
	right: 5.6%;
}

/* areainfo */
.pre-inc section#areainfo{
	background: #f0efed;
	padding: 60px 0 70px;
	margin-bottom: 80px;
}
.pre-inc .station_flex{
	display: flex;
	justify-content: center;
	align-items: center;
}
.pre-inc .station_flexitem{
	width: 50%;
	text-align: center;
}
.pre-inc .station_flexitem .stationinfo{
	text-align: left;
	display: inline-block;
	letter-spacing: 0.05em;
}
.pre-inc .station_flexitem .station{
	font-size: clamp(30px,3.6vw,36px);
	line-height: 1;
	margin-top: -0.75em;
}
.pre-inc .station_flexitem .station strong{
	color: #4f6486;
	font-family: "EB Garamond", serif;
	font-size: clamp(64px,8vw,80px);
}
.pre-inc .station_flexitem .stationinfo p{
	font-size: clamp(11px,1.4vw,14px);
}
.pre-inc .station_flexitem .stationinfo p.station_note{
	text-align: right;
	font-size: clamp(11px,1.4vw,14px);
}
.pre-inc .article_flex{
	display: flex;
	justify-content:space-between;
	margin-top: 20px;
	align-items: flex-end;
}
.pre-inc .article_flexitem{
	width: 50%;
	text-align: center;
}
.pre-inc .article_flexitem .articleinfo{
	display: inline-block;
	letter-spacing: 0.05em;
}
.pre-inc .article_flexitem .articleinfo .articlelabel{
	font-size: clamp(20px,3.6vw,36px);
	line-height: 100%;
}
.pre-inc .article_flexitem .articleinfo p{
	font-size: clamp(11px,1.4vw,14px);
	text-align: right;
}

/* activecomfort */
.pre-inc .activecomfort{ 
	position: relative;
	width: 100%;
	overflow: hidden;
}
.pre-inc .activecomfort .split_image{
  height: 100vh;
  overflow: hidden;
}
.pre-inc .activecomfort .activecomfort_label{
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 5;
	animation-delay: 1s;
}
.pre-inc .activecomfort .panel{
  position: relative;
  height: 50vh;
  overflow: hidden;
}
.pre-inc .activecomfort .layer{
  position: absolute;
  inset: 0;
}
.pre-inc .activecomfort .layer img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.pre-inc .activecomfort .layer_base{
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 32px;
  font-weight: 700;
  color:#fff;
}
.pre-inc .activecomfort .layer_in{ display:flex; align-items:center; justify-content:center; font-size:32px; font-weight:700; color:#fff; }
.pre-inc .activecomfort .layer_base{ z-index: 1; }
.pre-inc .activecomfort .layer_inTop1, .pre-inc .activecomfort .layer_inBottom1{ z-index: 2; }
.pre-inc .activecomfort .layer_inTop2, .pre-inc .activecomfort .layer_inBottom2{ z-index: 3; }
.pre-inc .activecomfort .layer_inTop1{ transform: translateX(-100%); }
.pre-inc .activecomfort .layer_inBottom1{ transform: translateX(100%); }
.pre-inc .activecomfort .layer_inTop2{ transform: translateX(-100%); }
.pre-inc .activecomfort .layer_inBottom2{ transform: translateX(100%); }
.pre-inc .activecomfort .layer .cap_wb{
	font-size: clamp(10px,1.3vw,13px);
}

/* active_area */
.pre-inc .titlehead h2{
	position: relative;
}
.pre-inc .titlehead p{
	color: #4f6486;
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(22px,3.6vw,36px);
	letter-spacing: 0.05em;
	margin: 20px 0 30px;
}
.pre-inc #active_area{
	background: #f0efed;
	padding: 80px 0;
	margin-top: 90px;
}
.pre-inc #active_area .titlehead h2::after{
	background: #333333;
	content: "";
	display: block;
	height: 1px;
	width: 100%;
	max-width: 900px;
	position: absolute;
	bottom: 1px;
	left: 0;
}
.pre-inc #active_area .areamain{
	background: url("../img/top/routemap_tennoji.svg") no-repeat;
	background-size: 55.6640625% auto;
	background-position: right 0 top 20px;
	display: flex;
	margin-bottom: 50px;
}
.pre-inc #active_area .areamain .areamain_info{
	width: 100%;
}
.pre-inc #active_area .areamain .areamain_info p{
	font-size: clamp(13px,1.6vw,16px);
	line-height: 220%;
	margin-bottom: 20px;
}
.pre-inc #active_area .areamain .areamain_info p sup{
	font-size: 0.6em;
}
.pre-inc #active_area .areamain .areamain_image{
	width: 68.359375%;
	transform: translateX(-13.8%);
}
.pre-inc #active_area .areamain .areamain_image .cap_wb{
	left: 0.5em;
	right: auto;
}
.pre-inc .loaction_list {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 24px;
}
.pre-inc .loaction_list .location01{
  grid-column: 1;
  grid-row: 1 / span 2;
}
.pre-inc .loaction_list .location02{
  grid-column: 2;
  grid-row: 1;
}
.pre-inc .loaction_list .location03{
  grid-column: 2;
  grid-row: 2;
}
.pre-inc .loaction_list  figure{
  display: flex;
  flex-direction: column;
}
.pre-inc .loaction_list  figure img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  flex: 1;
  display: block;
}
.pre-inc .loaction_list  figcaption{
  margin-top: 8px;
}
.pre-inc .loaction_list img{
  width: 100%;
  height: auto;
  display: block;
}
.pre-inc .loaction_list  figcaption{
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.6;
}

/* comfort_area */
.pre-inc #comfort_area .titlehead h2{
	position: relative;
	text-align: right;
}
.pre-inc #comfort_area .titlehead p{
	color: #4f6486;
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(22px,3.6vw,36px);
	letter-spacing: 0.05em;
	margin: 20px 0 30px;
	text-align: right;
}
.pre-inc #comfort_area{
	background: #fff;
	padding: 80px 0;
	margin-top: 90px;
	overflow: hidden;
}
.pre-inc #comfort_area .titlehead h2::after{
	background: #333333;
	content: "";
	display: block;
	height: 1px;
	width: 100%;
	max-width: 900px;
	position: absolute;
	bottom: 1px;
	right: 0;
}
.pre-inc #comfort_area .areamain{
	background: url("../img/top/routemap_teradamachi.svg") no-repeat;
	background-size: 39.0625% auto;
	background-position: left 0 top 50px;
	display: flex;
	margin-bottom: 50px;
}
.pre-inc #comfort_area .areamain .areamain_info{
	width: 100%;
	text-align: right;
}
.pre-inc #comfort_area .areamain .areamain_info p{
	font-size: clamp(13px,1.6vw,16px);
	line-height: 220%;
	margin-bottom: 20px;
	text-align: right;
}
.pre-inc #comfort_area .areamain .areamain_image{
	width: 68.359375%;
	transform: translateX(13.8%);
	display: inline-block;
}
.pre-inc #comfort_area .areamain .areamain_image .cap_wb{
	right: 0.5em;
	left: auto;
}
.pre-inc #comfort_area .loaction_list{
	margin-bottom: 50px;
}
.pre-inc #comfort_area .comfort_family{
	background: #fef6ec;
	border: 2px solid #4f6486;
	padding: 4px;
}
.pre-inc #comfort_area .comfort_family .flexcontents{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	border: 1px solid #4f6486;
	padding: 35px 45px 10px;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left{
	flex: 1;
	margin-right: 30px;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left .comfort_family_ttl{
	color: #4f6486;
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(18px,2.4vw,24px);
	margin-bottom: 20px;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left .comfort_family_illust{
	margin-top: 10px;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left .comfort_family_illust figure{
	max-width: 328px;
	display: inline-block;
	position: relative;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left .comfort_family_illust figure figcaption{
	position: absolute;
	right: 0.5em;
	bottom: 0;
    font-size: 14px;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left p sup{
	font-size: 0.6em;
}

.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_right{
	width: 45.6%;
}
.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_right figcaption{
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.6;
}

/* access */
.pre-inc section#access{
	background: #f0efed;
	margin-bottom: 80px;
}
.pre-inc .access_main{
	background: url("../img/top/access_mainimg.webp") no-repeat center center;
	background-size: cover;
	width: 100%;
	min-height: 460px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 80px;
}
.pre-inc .access_head{
	text-align: center;
}
.pre-inc .access_head h3{
	color: #4f6486;
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(24px,3.6vw,36px);
	margin-bottom: 20px;
}
.pre-inc .access_head p{
	line-height: 220%;
}
.pre-inc .access_head p sup{
	font-size:0.6em;
}
.pre-inc .route_container{}
.pre-inc .route_container .center_routeimg{
	text-align: center;
	margin: 30px 0 80px;
}
.pre-inc .route_container h3{
	margin-bottom: 50px;
	text-align: center;
	letter-spacing: 0.05em;
}
.pre-inc .route_container h3 .route_centerttl{
	border-bottom: 1px solid #333333;
	font-size: clamp(24px,3.6vw,36px);
	display: inline-block;
	padding: 0 5px;
}
.pre-inc .route_container h3 span{
	color: #4f6486;
	font-family: "EB Garamond", serif;
	font-size: clamp(56px,8vw,80px);
	letter-spacing: 0.05em;
}
.pre-inc .route_container h3 .route_centerttl sub{
	font-size: clamp(10px,1.3vw,13px);
}
.pre-inc .routeflex{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.pre-inc .routeflex .station{
	font-size: clamp(24px,3.6vw,36px);
	line-height: 1;
	margin-top: -0.85em;
}
.pre-inc .routeflex .station strong{
	color: #4f6486;
	font-family: "EB Garamond", serif;
	font-size: clamp(56px,8vw,80px);
}
.pre-inc .routeflex .stationinfo p{
	font-size: clamp(11px,1.4vw,14px);
	line-height: 120%;
	margin-bottom: -5px;
}
.pre-inc .routeflex .stationinfo p.station_note{
	text-align: right;
	font-size: clamp(11px,1.4vw,14px);
}
.pre-inc .routeflex .routeflex_left{
	width: 48%;
}
.pre-inc .routeflex .routeflex_left .routeline{
	margin-bottom: 20px;
}
.pre-inc .routeflex .routeflex_left .routeline .stationinfo{
	display: inline-block;
}
.pre-inc .routeflex .routeflex_right{
	width: 51%;
}
.pre-inc .routeflex .routeflex_right .station{
	font-size: clamp(20px,2.8vw,28px);
	line-height: 1;
	letter-spacing: 0.05em;
	margin-top: -0.85em;
	margin-bottom: 30px;
}
.pre-inc .routeflex .routeflex_right .station span{
	font-size: clamp(22px,3.2vw,32px);
	letter-spacing: 0.05em;
}
.pre-inc .routeflex .routeflex_right .station strong{
	color: #4f6486;
	font-family: "EB Garamond", serif;
	font-size: clamp(42px,6.8vw,68px);
	letter-spacing: 0.05em;
}
.pre-inc .routeflex .routeflex_right .station .station_note{
	display: inline;
}
.pre-inc .routeflex:last-child .routeflex_right .station{
	margin-top: -0.5em;
}
.pre-inc .stations{
	display: flex;
	justify-content: center;
	margin-top: 30px;
}
.pre-inc .stations .station_contents{
	width: 33.333333%;
	position: relative;
}
.pre-inc .stations .station_contents .station_name{
	color: #FFF;
	font-family: "EB Garamond", serif;
	font-size: clamp(56px,5vw,80px);
	line-height: 80%;
	letter-spacing: 0.05em;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 5;
}
.pre-inc .stations .station_contents .time{
	color: #FFF;
	font-family: "EB Garamond", serif;
	font-size: clamp(34px,5vw,40px);
	letter-spacing: 0.05em;
	position: absolute;
	bottom: 20px;
	right: 10px;
	z-index: 5;
}
.pre-inc .stations .station_contents .time strong{
	font-size: clamp(56px,8vw,80px);
	line-height: 1;
}
.pre-inc .stations .station_contents figcaption{
	left: 0.5em;
	right: auto;
}
/* style */
.pre-inc section#style{
	background: #ebe3d9;
	padding-bottom: 80px;
}
.pre-inc .style_main{
	background: url("../img/top/style_mainimg.webp") no-repeat center center;
	background-size: cover;
	width: 100%;
	min-height: 460px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.pre-inc .style_lead{
	text-align: center;
	padding: 80px 20px 50px;
}
.pre-inc .style_lead p{
	color: #4f6486;
	font-family: "Noto Sans JP", sans-serif;
	font-size: clamp(24px,3.6vw,36px);
}

/* 斜め角度 */
:root{ --skew: 90px; }
.pre-inc .style_list{
  display: flex;
  height: 600px;
  overflow: hidden;
  gap: 0;
}
.pre-inc .style_list .styledetail{
  position: relative;
  overflow: hidden;
  flex: 1 1 calc(33.333% + var(--skew));
  margin-right: calc(var(--skew) * -1);
}
.pre-inc .style_list .styledetail_right{
  margin-right: 0;
  flex: 1 1 33.333%;
}
.pre-inc .style_list .styledetail_left{ z-index: 1;margin-left: -60px;}
.pre-inc .style_list .styledetail_center{ z-index: 2;margin-left: -60px;}
.pre-inc .style_list .styledetail_right{ z-index: 3;}
.pre-inc .style_list .styledetail a{
	font-size: clamp(48px,7vw,70px);
	letter-spacing: 0.08em;
	line-height: 140%;
  position: relative;
  display: block;
  height: 100%;
}
.pre-inc .style_list .styledetail a img{
	transition: 0.5s;
}
.pre-inc .style_list .styledetail a:hover img{
	transform: scale(1.05);
}
.pre-inc .style_list .styledetail_img{
  display: block;
  height: 100%;
  overflow: hidden;
}
.pre-inc .style_list .styledetail a .styledetail_ttl{
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 6;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #FFF;
  text-align: center;
}
.pre-inc .style_list .styledetail a .styledetail_ttl h3::after{
	background: url("../common/img/circlearrow_r.svg") no-repeat center center;
	background-size: 50px 50px;
	content: "";
	height: 50px;
	width: 100%;
	display: block;
	margin-bottom: -50px;
}
.pre-inc .style_list .styledetail a .cap_wb{
  position: absolute;
  bottom: 0.5em;
  left: 1em;
  text-align: left;
  z-index: 6;
}
.pre-inc .style_list .styledetail.styledetail_left a .cap_wb{
	left: calc(1em + 60px);
}
.pre-inc .style_list .styledetail.styledetail_right a .cap_wb{
	left: auto;
	right: 1em;
}
.pre-inc .style_list .styledetail_img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pre-inc .style_list .styledetail_left .styledetail_img{
  /*clip-path: polygon(0 0, calc(100% - var(--skew)) 0, 100% 100%, 0 100%);*/
}
.pre-inc .style_list .styledetail_center .styledetail_img{
  clip-path: polygon(var(--skew) 0, 100%  0, 100% 100%, 0 100%);
}
.pre-inc .style_list .styledetail_right .styledetail_img{
  clip-path: polygon(var(--skew) 0, 100% 0, 100% 100%, 0 100%);
}



@media screen and (max-width: 1400px) {
	.pre-inc .mv_section02 .mv_logo.on.pan,.pre-inc .mv_section02 .mv_logo_lead.on.pan{
		animation: pandown 3s ease-in-out forwards;
	}
}
@media screen and (max-width: 768px) {
  .pre-inc article {
    margin-top: 0;
  }
	
	/* mainvisual */
	.pre-inc .mainvisual {
		aspect-ratio: 64 / 75;
	}
	.pre-inc .mv_section02 .mv_logo img, .pre-inc .mv_section02 .mv_logo_lead img {
		width: 80%;
	}
	.pre-inc .copytext{
		font-size: clamp(18px,2.8vw,28px);
		letter-spacing: 0.16em;
		text-align: center;
	}
	.pre-inc .mv_section01 .photo01 .photoimage{
		width: 28.396%;
    right: 25.542%;
    top: 12.493%;
	}
	.pre-inc .mv_section01 .photo02 .photoimage{
		width: 38.792%;
    left: 3.427%;
    top: 24.986%;
	}
	.pre-inc .mv_section01 .photo03 .photoimage{
		width: 35.167%;
    left: 19.333%;
    top: 52.246%;
	}
	.pre-inc .mv_section01 .photo04 .photoimage{
		width: 37.479%;
    right: 0.313%;
    bottom: 24.536%;
	}
	.pre-inc .mv_section01 .photo05 .photoimage{
		width: 47.813%;
    right: 1.729%;
    bottom: -1.681%;
	}
	.pre-inc .mv_section01 .photo06 .photoimage{
		width: 41.813%;
    right: -9.146%;
    top: 6.029%;
	}
	.pre-inc .mv_section01 .photo07 .photoimage{
		width: 43%;
    left: -1.562%;
    bottom: 0;
	}
	.pre-inc .mv_section01 .photo08 .photoimage{
		width: 35.917%;
    left: -0.615%;
    top: 0.203%;
	}
	.pre-inc .mv_panel{
		top: 2em;
	}
	/* koudou */
	.pre-inc section#koudou {
		padding: 30px 10px;
	}
	.pre-inc .koudou_lead p strong {
		font-size: clamp(18px,2.8vw,28px);
		margin-top: 10px;
	}
	.pre-inc .koudou_entry p {
		font-size: clamp(18px,2.4vw,24px);
		letter-spacing: 0.16em;
		margin-bottom: 20px;
	}
	
	/* areainfo */
	.pre-inc section#areainfo {
		padding: 30px 10px;
		margin-bottom: 40px;
	}
	.pre-inc .station_flex{
		display: block;
	}
	.pre-inc .station_flexitem {
		width: 100%;
	}
	
	/* activecomfort  */
	.pre-inc .activecomfort .panel_top .layer .cap_wb {
		bottom: auto;
		top: 0.5em;
	}
	.pre-inc .titlehead h2 img {
		height: 38px;
		width: auto;
	}
	.pre-inc .activecomfort .activecomfort_label img{
		margin: 0 auto;
		width: 90%;
	}
	.pre-inc .titlehead p,.pre-inc #comfort_area .titlehead p {
		font-size: clamp(18px,3.6vw,36px);
	}
	.pre-inc #active_area .areamain .areamain_image {
		width: 100%;
		transform: translateX(0%);
	}
	.pre-inc .areamain_route{
		width: 80%;
		margin: 20px auto;
	}
	.pre-inc #active_area .areamain,.pre-inc #comfort_area .areamain{
		background: none;
		margin-bottom: 30px;
	}
	.pre-inc #active_area {
		background: #f0efed;
		padding: 40px 0;
		margin-top: 40px;
	}
	.pre-inc .loaction_list {
    display: block;
  }
  .pre-inc .loaction_list .location01,.pre-inc .loaction_list .location02{
		margin-bottom: 15px;
  }
	.pre-inc #comfort_area{
		padding: 40px 0;
		margin-top: 40px;
	}
	.pre-inc #comfort_area .areamain .areamain_image {
		width: 100%;
		transform: translateX(0%);
		display: block;
	}
	.pre-inc #comfort_area .comfort_family .flexcontents{
		padding: 15px;
		display: block;
	}
	.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_left{
		margin-right: 0;
		margin-bottom: 15px;
	}
	.pre-inc #comfort_area .comfort_family .flexcontents .flexitem_right {
		width: 100%;
	}
	/* access */
	.pre-inc .access_main {
		min-height: 230px;
		margin-bottom: 40px;
	}
	.pre-inc .access_main h2{
		margin: 0 15px;
	}
	.pre-inc .access_main h2 img{
		height: 37px;
		width: auto;
	}
	.pre-inc .route_container .center_routeimg {
		margin: 20px 0 40px;
	}
	/* style */
	.pre-inc section#style {
		padding-bottom: 40px;
	}
	.pre-inc .style_main {
		min-height: 230px;
		margin-bottom: 0px;
	}
	.pre-inc .style_main h2{
		margin: 0 15px;
	}
	.pre-inc .style_main h2 img{
		height: 150px;
		width: auto;
	}
	.pre-inc .route_container h3{
		margin-bottom: 20px;
	}
	.pre-inc .route_container h3 .route_centerttl {
		font-size: clamp(22px,3vw,30px);
	}
	.pre-inc .route_container h3 span{
		font-size: clamp(42px,6vw,60px);
	}
	.pre-inc .routeflex {
		display: block;
	}
	.pre-inc .routeflex .stationinfo p {
		margin-bottom: -5px;
		text-align: left;
	}
	.pre-inc .routeflex .routeflex_left,.pre-inc .routeflex .routeflex_right{
		width: 100%;
	}
	.pre-inc .routeflex .routeflex_left .routeline {
		margin-bottom: 20px;
		text-align: center;
	}
	.pre-inc .routeflex .routeflex_right p{
		text-align: center;
	}
	.pre-inc .routeflex .routeflex_right .station {
		text-align: center;
		margin-top: 0;
		margin-bottom: 20px;
	}
	.pre-inc .routeflex .routeflex_right .station .station_note {
		display: block;
		text-align: center;
	}
	.pre-inc .stations {
	  display: block;
	}
	.pre-inc .stations .station_contents {
		width: 100%;
		position: relative;
	}
	.pre-inc .style_lead {
		text-align: center;
		padding: 30px 10px;
	}
	.pre-inc .style_list{
		display: block;
		height: auto;
		overflow: hidden;
		gap: 0;
	}
	.pre-inc .style_list .styledetail{
		display: block;
		width: 100%;
	}
	.pre-inc .style_list .styledetail_right{
		margin-right: 0;
	}
	.pre-inc .style_list .styledetail_left{ z-index: 1;margin-left:0}
	.pre-inc .style_list .styledetail_center{ z-index: 2;margin-left:0;}
	.pre-inc .style_list .styledetail a{
		font-size: clamp(36px,6vw,60px);
	}
	.pre-inc .style_list .styledetail a .cap_wb{
		position: absolute;
		bottom: 0.5em;
		left: 1em;
		text-align: left;
		z-index: 6;
	}
	.pre-inc .style_list .styledetail.styledetail_left a .cap_wb,.pre-inc .style_list .styledetail.styledetail_right a .cap_wb{
		left: 0.5em;
		right: auto;
	}
	.pre-inc .style_list .styledetail_center .styledetail_img,.pre-inc .style_list .styledetail_right .styledetail_img{
		clip-path:none;
	}
}

/* キャンペーンバナー */
.cp_modal_bk {
  background: rgba(0, 0, 0, 0.6);
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 10000000;
  cursor: pointer;
}
.cp_modal_wrap {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 11000000;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
  padding: 0 20px;
}
.cp_modal_btn {
  pointer-events: painted;
	position: relative;
}
.cp_modal_btn a {
  overflow: hidden;
  display: inline-block;
}
.cp_modal_btn a img {
  transition: 0.5s all;
  max-height: 90vh;
}
.cp_modal_close_btn {
  font-size: 40px;
  color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  line-height: 1;
  cursor: pointer;
  transition: 0.5s all;
  background: #000;
  z-index: 1000;
}
@media screen and (min-width: 769px) {
  .cp_modal_close_btn:hover {
    opacity: 0.6;
  }
  .cp_modal_btn a:hover img {
    transform: scale(1.02);
  }
}
@media screen and (min-width: 769px) and (max-height: 809px) {
  .cp_modal_btn {
    height: 90%;
  }
  .cp_modal_btn a {
    height: 100%;
  }
  .cp_modal_btn a img {
    height: 100%;
    max-width: none;
  }
}
@media screen and (max-width: 768px) {
  .cp_modal_wrap {
    padding: 0 15px;
		box-sizing: border-box;
  }
  .cp_modal_close_btn {
    font-size: 30px;
    top: 0;
    right: 0;
  }
	.cp_modal_btn a img {
    max-width: 100%;
		vertical-align: bottom;
		backface-visibility: hidden;
		image-rendering: crisp-edges;
  }
}

@media screen and (max-width: 768px) {
  .cp_modal_btn .pc {
    display: none !important;
  }
}
@media screen and (min-width: 769px) {
  .cp_modal_btn .sp {
    display: none !important;
  }
}

