/*---------------
mv
---------------*/
#floor-dt{
	position: relative;
	margin-bottom: 150px;
	height: calc(50vh + 49px);
}
.floor-dt-mv-wrap{
	margin-top: 150px;
	width: 100%;
	display: flex;
	display: -webkit-flex;
}
.floor-dt-mv {
  position: relative;
  overflow: hidden;
	height: calc(50vw - 150px);
	width: 100%;
	display: flex;
	display: -webkit-flex;
}
.floor-dt-mv img{
	height: calc(50vw - 150px);
	width: 100%;
	object-fit: cover;
}
#floor-dt .set_cnts_line{
	height: 85px;
	max-width: 88%;
	display: flex;
	align-items: flex-start;
	position: relative;
	bottom: 37px;
}
#floor-dt .set_cnts_line h1{
	font-size: 11.35vw;
	letter-spacing: -0.05em;
	position: absolute;
	bottom: 0;
	right: calc(12.2vw - 12%);
	color: #fff; 
	-webkit-text-stroke: 2px #071715;
	text-stroke: 2px #071715;
	height: 12.5vw;
}
#floor-dt .set_cnts_line-horizontal1 {
	position: absolute;
	width: 70%;
	height: 2px;
	background: #000;
	top: 0;
	left: 0;
}
#floor-dt .set_cnts_line-vertical {
	position: absolute;
	width: 2px;
	height: 85px;
	background: #000;
	top: 0;
	left: 70%;
}
#floor-dt .set_cnts_line-horizontal2 {
	position: absolute;
	width: calc(100% - 70%);
	height: 2px;
	background: #000;
	top: 85px;
	left: 70%;
}
@media screen and (max-width: 768px) {
	#floor-dt{
		margin-bottom: 100px;
		height: calc(100vw + 15px);
	}
	.floor-dt-mv-wrap{
		margin-top: 80px;
		height: calc(100vw + 15px);
		display: block;
	}
	.floor-dt-mv{
		height: 100vw;
		width: 100%;
	}
	.floor-dt-mv img{
		height: 100vw;
	}
	#floor-dt .set_cnts_line{
		height: 60px;
		max-width: calc(100% - 20px);
		bottom: 37px;
	}
	#floor-dt .set_cnts_line h1{
		font-size: 27.6vw;
		bottom: 0;
		right: 0;
		height: 130px;
	}
	#floor-dt .set_cnts_line-horizontal1 {
		position: absolute;
		width: 53%;
	}
	#floor-dt .set_cnts_line-vertical {
		position: absolute;
		height: 60px;
		left: 53%;
	}
	#floor-dt .set_cnts_line-horizontal2 {
		position: absolute;
		width: calc(100% - 53%);
		top: 60px;
		left: 53%;
	}
}
/*---------------
floor-lead
---------------*/
#floor-lead{
	width: 100%;
	max-width: 1200px;
	margin: 0 auto 150px;
}
.floor-lead{
	width: 100%;
	max-width: 1200px;
	margin: 0 auto 125px;
}
.floor-lead h2{
	font-size: 28px;
	font-weight: bold;
	letter-spacing: 0.15em;
	margin-bottom: 25px;
	opacity: 0.23;
}
.floor-lead h3{
	font-size: 50px;
	font-weight: bold;
	letter-spacing: 0.1em;
	margin-bottom: 45px;
}
.floor-lead p{
	font-size: 21px;
	font-weight: 500;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
	#floor-lead{
		width: calc(100% - 40px);
		max-width: initial;
		margin: 0 auto 100px;
	}
	.floor-lead{
		width: 100%;
		max-width: initial;
		margin: 0 auto 45px;
	}
	.floor-lead h2{
		font-size: 18px;
		margin-bottom: 15px;
	}
	.floor-lead h3{
		font-size: 30px;
		line-height: 42px;
		margin-bottom: 34px;
	}
	.floor-lead p{
		font-size: 14px;
	}
}
/*---------------
floor-photo
---------------*/
#floor-photo{
	max-width: 1200px;
	margin: 0 auto 150px;
}
.floor-photo-wrap{
	max-width: 1200px;
}
.floor-photo-title{
	height: 78px;
	width: 100%;
	display: flex;
	align-items: flex-start;
	position: relative;
	margin-bottom: 50px;
}
.floor-photo-line-wrap {
	display: flex;
	align-items: flex-start;
	position: absolute;
	height: 78px;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	}
h3.floor-photo-link {
	font-size: 35px;
	line-height: 78px;
	font-weight: bold;
	letter-spacing: 0.1em;
	top: 0;
	left: 0;
	text-align: center;
	width: 400px;
}
h3.floor-photo-link2 {
	position: absolute;
	bottom: -11px;
	font-size: 60px;
	font-weight: bold;
	letter-spacing: 0.1em;
	right: 20px;
	opacity: 0.23;
}
.floor-photo-line-horizontal1 {
	position: absolute;
	width: 400px;
	height: 2px;
	background: #000;
	top: 0;
	left: 0;
}
.floor-photo-line-vertical {
	position: absolute;
	width: 2px;
	height: 78px;
	background: #000;
	top: 0px;
	left: 400px;
}
.floor-photo-line-horizontal2 {
	position: absolute;
	width: calc(100% - 400px);
	height: 2px;
	background: #000;
	bottom: 0;
	left: 400px;
}
.floor-photo_block{
	max-width: 1200px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}
.photo-carousel {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.photo-slide {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(2, 1fr);
	gap: 10px;
	width: 100%;
	min-height: 300px;
	box-sizing: border-box;
	/* スライド用 */
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.4s;
}

.photo-slide.active {
	opacity: 1;
	pointer-events: auto;
	position: relative;
}

.photo-slide img {
	width: 100%;
	height: auto;
	object-fit: cover;
	display: block;
}

.photo-prev,
.photo-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: none;
  border: none;
  width: 40px;
  height: 60px;
  padding: 0;
  cursor: pointer;
  background-color: rgba(255, 255, 255, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
}
.photo-prev {
	left: -50px;
}
.photo-next {
	right: -50px;
}
.photo-prev img,
.photo-next img {
  width: 24px;
  display: block;
}

@media screen and (max-width: 768px) {
	#floor-photo{
		max-width: initial;
		margin: 0 auto 100px;
	}
	.floor-photo-wrap{
		max-width: initial;
		margin-bottom: 0;
	}
	.floor-photo-title{
		height: 54px;
		margin-bottom: 45px;
	}
	.floor-photo-line-wrap {
		position: absolute;
		height: 54px;
		max-width: initial;
	}
	h3.floor-photo-link {
		font-size: 21px;
		line-height: 54px;
		margin-left: 20px;
		width: auto;
	}
	h3.floor-photo-link2 {
		position: absolute;
		bottom: -5px;
		font-size: 8vw;
		right: 20px;
	}
	.floor-photo-line-horizontal1 {
		width: 45%
	}
	.floor-photo-line-vertical {
		position: absolute;
		height: 54px;
		top: 0px;
		left: 45%;
	}
	.floor-photo-line-horizontal2 {
		position: absolute;
		width: calc(100% - 45%);
		left: 45%;
	}
	.floor-photo_block{
		max-width: initial;
		width:calc(100% - 14px);
		margin: 0 7px;
	}
	.photo-carousel {
	}
	.photo-slide {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(2, 1fr);
		gap: 7px;
		width: 100%;
		min-height: 200px;
	}
	.photo-slide.active {
	}
	.photo-slide img {
	}
	.photo-prev,
	.photo-next {
	}
	.photo-prev {
		left: 0; 
	}
	.photo-next {
		right: 0; 
	}
}
/*---------------
floor-guide
---------------*/
#floor-guide{
	max-width: 1200px;
	margin: 0 auto 150px;
}
.floor-guide-wrap{
	max-width: 1200px;
}
.floor-guide-title{
	height: 78px;
	width: 100%;
	display: flex;
	align-items: flex-start;
	position: relative;
	margin-bottom: 68px;
}
.floor-guide-line-wrap {
	display: flex;
	align-items: flex-start;
	position: absolute;
	height: 78px;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	}
h3.floor-guide-link {
	font-size: 35px;
	line-height: 78px;
	font-weight: bold;
	letter-spacing: 0.1em;
	top: 0;
	left: 0;
	text-align: center;
	width: 400px;
}
h3.floor-guide-link2 {
	position: absolute;
	bottom: -11px;
	font-size: 60px;
	font-weight: bold;
	letter-spacing: 0.1em;
	right: 20px;
	opacity: 0.23;
}
.floor-guide-line-horizontal1 {
	position: absolute;
	width: 400px;
	height: 2px;
	background: #000;
	top: 0;
	left: 0;
}
.floor-guide-line-vertical {
	position: absolute;
	width: 2px;
	height: 78px;
	background: #000;
	top: 0px;
	left: 400px;
}
.floor-guide-line-horizontal2 {
	position: absolute;
	width: calc(100% - 400px);
	height: 2px;
	background: #000;
	bottom: 0;
	left: 400px;
}
.floor-guide{
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	width: calc(100% - 40px);
	border: 1px solid #000;
}
.floor-guide img{
	width: 100%;
	object-fit: cover;
}
.floor-guide .floor-guide-bg{
	position: absolute;
	top: 20px;
	left: 20px;
	z-index: -1;
	height: 586px;
	width: 100%;
	background-color: #EBEBEB;
}
@media screen and (max-width: 768px) {
  #floor-guide{
		max-width: initial;
		margin: 0 auto 100px;
	}
	.floor-guide-wrap{
		max-width: initial;
		margin-bottom: 0;
	}
	.floor-guide-title{
		height: 54px;
		margin-bottom: 40px;
	}
	.floor-guide-line-wrap {
		position: absolute;
		height: 54px;
		max-width: initial;
		}
	h3.floor-guide-link {
		font-size: 4.6vw;
		line-height: 54px;
		margin-left: 20px;
		width: auto;
	}
	h3.floor-guide-link2 {
		position: absolute;
		bottom: -5px;
		font-size: 8vw;
		right: 20px;
	}
	.floor-guide-line-horizontal1 {
		width: 50%
	}
	.floor-guide-line-vertical {
		position: absolute;
		height: 54px;
		top: 0px;
		left: 50%;
	}
	.floor-guide-line-horizontal2 {
		position: absolute;
		width: calc(100% - 50%);
		left: 50%;
	}
	.floor-guide{
		max-width: initial;
	}
	.floor-guide img{
	}
	.floor-guide .floor-guide-bg{
		position: absolute;
		top: 8px;
		left: 8px;
		height: 100%;
		width: 100%;
	}
}

/*---------------
floor-service
---------------*/
#floor-service{
	max-width: 1200px;
	margin: 0 auto 150px;
}
.floor-service-wrap{
	max-width: 1200px;
}
.floor-service-title{
	height: 78px;
	width: 100%;
	display: flex;
	align-items: flex-start;
	position: relative;
	margin-bottom: 68px;
}
.floor-service-line-wrap {
	display: flex;
	align-items: flex-start;
	position: absolute;
	height: 78px;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	}
h3.floor-service-link {
	font-size: 35px;
	line-height: 78px;
	font-weight: bold;
	letter-spacing: 0.1em;
	top: 0;
	left: 0;
	text-align: center;
	width: 400px;
}
h3.floor-service-link2 {
	position: absolute;
	bottom: -11px;
	font-size: 60px;
	font-weight: bold;
	letter-spacing: 0.1em;
	right: 20px;
	opacity: 0.23;
}
.floor-service-line-horizontal1 {
	position: absolute;
	width: 400px;
	height: 2px;
	background: #000;
	top: 0;
	left: 0;
}
.floor-service-line-vertical {
	position: absolute;
	width: 2px;
	height: 78px;
	background: #000;
	top: 0px;
	left: 400px;
}
.floor-service-line-horizontal2 {
	position: absolute;
	width: calc(100% - 400px);
	height: 2px;
	background: #000;
	bottom: 0;
	left: 400px;
}
.icon-wrap{
	display: flex;
	display: -webkit-flex;
	margin: 0 auto 100px;
	width: 848px;
}
.icon-block{
	width: 108px;
	margin-right: 40px;
}
.icon-block:last-child{
	margin-right: 0;
}
.icon-block.no-service{
	opacity: 0.16;
}
.icon-box{
	height: 108px;
	width: 108px;
	margin-bottom: 15px;
	border-radius: 17px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #000;
	box-shadow: inset 0px 2px 11px rgba(114,114,114,0.15);

}
.icon-box img{
	height: 72px;
	width: 72px;
}
.icon-block p{
	font-size: 18px;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-align: center;
}
.icon-block span{
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-align: center;
}
.studio-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  table-layout: fixed;
}
.studio-table th,
.studio-table td {
  border: 1px solid #eee;
  padding: 18px 16px;
  font-size: 16px;
  vertical-align: top;
  text-align: left;
}
.studio-table th {
  background: #fafafa;
  font-weight: bold;
  width: 300px;
  min-width: 120px;
}
.studio-table td {
  background: #fff;
  word-break: break-all;
}
.photo-row {
  display: flex;
  gap: 20px;
  margin-bottom: 10px;
}
.photo-item {
  width: 28%;
  min-width: 120px;
  text-align: center;
}
.photo-item img {
  width: 100%;
  height: auto;
  border: 1px solid #ddd;
  background: #fafafa;
  object-fit: cover;
  aspect-ratio: 1 / 1;
}
.photo-caption {
  margin-top: 8px;
  font-size: 14px;
  color: #333;
}
@media screen and (max-width: 768px) {
  #floor-service{
		max-width: initial;
		margin: 0 auto 100px;
	}
	.floor-service-wrap{
		max-width: initial;
		margin-bottom: 0;
	}
	.floor-service-title{
		height: 54px;
		margin-bottom: 40px;
	}
	.floor-service-line-wrap {
		position: absolute;
		height: 54px;
		max-width: initial;
		}
	h3.floor-service-link {
		font-size: 4.6vw;
		line-height: 54px;
		margin-left: 20px;
		width: auto;
	}
	h3.floor-service-link2 {
		position: absolute;
		bottom: -5px;
		font-size: 8vw;
		right: 20px;
	}
	.floor-service-line-horizontal1 {
		width: 50%
	}
	.floor-service-line-vertical {
		position: absolute;
		height: 54px;
		top: 0px;
		left: 50%;
	}
	.floor-service-line-horizontal2 {
		position: absolute;
		width: calc(100% - 50%);
		left: 50%;
	}
	.icon-wrap{
		margin: 0 36px 65px;
		width: calc(100% - 72px);
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.icon-block{
		width: 100px;
		padding: 0;
		margin: 0 0 28px;
	}
	.icon-block:last-child{
		margin-right: 0;
	}
	.icon-box{
		height: 70px;
		width: 70px;
		border-radius: 8px;
		margin: 0 15px 8px;
	}
	.icon-box img{
		height: 48px;
		width: 48px;
	}
	.icon-block p{
		font-size: 15px;
	}
	.icon-block span{
		font-size: 2.5vw;
	}
	.studio-table {
	  width: calc(100% - 40px);
	  margin: 0 20px;
	}
	.studio-table th,
	.studio-table td {
	  padding: 15px;
	  font-size: 15px;
	}
	.studio-table th {
	  width: 30%;
	  min-width: initial;
	}
	.studio-table td {
	}
	.photo-row {
	  display: flex;
	  gap: 20px;
	  margin-bottom: 10px;
	}
	.photo-item {
	  width: 28%;
	  min-width: 120px;
	  text-align: center;
	}
	.photo-item img {
	  width: 100%;
	  height: auto;
	  border: 1px solid #ddd;
	  background: #fafafa;
	  object-fit: cover;
	  aspect-ratio: 1 / 1;
	}
	.photo-caption {
	  margin-top: 8px;
	  font-size: 14px;
	  color: #333;
	}
}

/*---------------
floor-point
---------------*/
#floor-point{
	max-width: 1200px;
	margin: 0 auto 90px;
}
.floor-point-wrap{
	max-width: 1200px;
}
.floor-point-title{
	height: 78px;
	width: 100%;
	display: flex;
	align-items: flex-start;
	position: relative;
	margin-bottom: 68px;
}
.floor-point-line-wrap {
	display: flex;
	align-items: flex-start;
	position: absolute;
	height: 78px;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	color: #333;
	}
h3.floor-point-link {
	font-size: 35px;
	line-height: 78px;
	font-weight: bold;
	letter-spacing: 0.1em;
	top: 0;
	left: 0;
	text-align: center;
	width: 400px;
}
h3.floor-point-link2 {
	position: absolute;
	bottom: -11px;
	font-size: 60px;
	font-weight: bold;
	letter-spacing: 0.1em;
	right: 20px;
	opacity: 0.23;
}
.floor-point-line-horizontal1 {
	position: absolute;
	width: 400px;
	height: 2px;
	background: #000;
	top: 0;
	left: 0;
}
.floor-point-line-vertical {
	position: absolute;
	width: 2px;
	height: 78px;
	background: #000;
	top: 0px;
	left: 400px;
}
.floor-point-line-horizontal2 {
	position: absolute;
	width: calc(100% - 400px);
	height: 2px;
	background: #000;
	bottom: 0;
	left: 400px;
}
.point-block {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	width: 100%;
	min-height: 400px;
	box-sizing: border-box;
	position: relative;
	margin-bottom: 50px;
}
.point-text {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-left: 35px;
}
.point-number {
	position: relative;
	display: flex;
	align-items: flex-end;
	font-weight: bold;
	margin-bottom: 10px;
	line-height: 1;
}
.point-number .num {
	font-size: 49px;
	font-weight: bold;
}
.point-number .slash {
	position: absolute;
	bottom: -20px;
	left: 55px;
	font-size: 50px;
	font-weight: normal;
}
.point-desc {
	font-size: 28px;
	letter-spacing: 0.1em;
	line-height: 32px;
	margin: 0 35px 0 80px;
}
.point-image {
	flex: 1 1 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50%;
}
.point-image img {
	max-width: 100%;
	width: auto;
	height: auto;
	display: block;
	box-shadow: 0 2px 16px rgba(0,0,0,0.08);
}
@media screen and (max-width: 768px) {
	#floor-point{
		max-width: initial;
		margin: 0 auto 70px;
	}
	.floor-point-wrap{
		max-width: initial;
		margin-bottom: 0;
	}
	.floor-point-title{
		height: 54px;
		margin-bottom: 40px;
	}
	.floor-point-line-wrap {
		position: absolute;
		height: 54px;
		max-width: initial;
		}
	h3.floor-point-link {
		font-size: 5.6vw;
		line-height: 54px;
		margin-left: 20px;
		width: auto;
	}
	h3.floor-point-link2 {
		position: absolute;
		bottom: -5px;
		font-size: 8vw;
		right: 20px;
	}
	.floor-point-line-horizontal1 {
		width: 55%
	}
	.floor-point-line-vertical {
		position: absolute;
		height: 54px;
		top: 0px;
		left: 55%;
	}
	.floor-point-line-horizontal2 {
		position: absolute;
		width: calc(100% - 55%);
		left: 55%;
	}
	.point-block {
		position: relative;
		display: block;
		min-height: 350px;
		margin-bottom: 45px;
	}
	.point-text {
		position: absolute;
		top: 0;
		left: 0;
		padding-left: 20px;
		margin-right: 20px;
		width: calc(100% - 20px);
	}
	.point-number {
		margin-bottom: 0px;
		line-height: 1;
	}
	.point-number .num {
		font-size: 28px;
		font-weight: bold;
	}
	.point-number .slash {
		position: absolute;
		bottom: -15px;
		left: 25px;
		font-size: 29px;
		font-weight: normal;
	}
	.point-desc {
		font-size: 14px;
		line-height: 17px;
		margin-left: 50px;
	}
	.point-image {
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		width: calc(100% - 40px);
		margin: 0 auto;
	}
	.point-image img {
	}
}
/*---------------
floor-alert
---------------*/
#floor-alert{
	max-width: 1200px;
	margin: 0 auto 150px;
}
.floor-alert-block{
	position: relative;
	padding: 75px 100px 60px;
	width: 100%;
	background: linear-gradient(to bottom, rgba(2,7,6,0.03), rgba(202,202,202,0.03));
	border-radius: 5px;
}
.floor-alert-block .floor-alert-title{
	position: absolute;
	top: -30px;
	left: 0;
	right: 0;
	width: 66.6%;
	font-weight: bold;
	font-size: 35px;
	letter-spacing: 0.1em;
	z-index: 5;
	margin: 0 auto;
	text-align: center;
}
.floor-alert-block p{
	font-weight: 500;
	font-size: 18px;
	line-height: 27px;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
	#floor-alert{
		max-width: initial;
		margin: 0 auto 100px;
	}
	.floor-alert-block{
		padding: 65px 20px 20px;
		width: 100%;
	}
	.floor-alert-block .floor-alert-title{
		position: absolute;
		top: -20px;
		left: 0;
		right: 0;
		width: 80%;
		font-size: 21px;
	}
	.floor-alert-block p{
		font-size: 14px;
	}
}

/*---------------
floor-price
---------------*/
#floor-price{
	margin: 0 auto 100px;
	width: 100%;
	max-width: 1200px;
}
