

/* ****************************
  サロンメイン
***************************** */

/* ヘッダーテキスト */
.main_text {
  font-size: 1.3rem;
  line-height: 2.3rem;
}
.main_title {
  line-height: 2.3rem;
}
.online_salon_header {
  background-position: center;
  background-size: cover;
}

/* 各コンテンツの見出し */
.heading07 {
	position: relative;
	padding-top: 50px;
}
.heading07::before {
	content: attr(data-en);
	position: absolute;
	transform: rotate(-5deg);
	top: -20px;
	color: rgba(215,217,242,0.6);
  font-size: 3.2em;
	font-weight: 400;
	font-family: luxus-brut, cursive;
	font-style: italic;
  z-index: -1;
}
.introduction_area {
  max-width: 48rem;
  margin: auto;
}
@media screen and (max-width:768px){
  .main_text {
    font-size: 1.3rem;
    line-height: inherit;
  }
  .main_title {
    line-height: inherit;
  }
  .heading07 {
    padding-top: 25px;
  }
  .heading07::before {
    font-size: 2em;
  }
  .introduction_area {
    max-width: 48rem;
    margin: auto;
  }
}

.header-video {
  position: relative;
  overflow: hidden;
  height: 100%;
}
.header-video video {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  object-fit: cover;
}

.header-video__play-trigger {
  z-index: 5;
  position: absolute;
  background: rgba(0,0,0,.3);
  text-align: center;
  color: white;
  text-decoration: none;
  padding: 1.5em 3em;
  z-index: 5;
  left: 50%;
  top: 50%;
  border-radius: 10px;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: background .5s;
  -moz-transition: background .5s;
  transition: background .5s;
}
.header-video__play-trigger:hover {
  background: rgba(0,0,0,.5);
}
.header-video__close-trigger {
  z-index: 99;
  position: absolute;
  background: #A61212;
  text-align: center;
  color: white;
  text-decoration: none;
  padding: 2em 3em;
  border-radius: 10px;
  right: 30px;
  top: 30px;
  -webkit-transition: background .3s;
  -moz-transition: background .3s;
  transition: background .3s;  
  border: none;
}
.header-video__close-trigger:hover {
  background: #363636;
  cursor: pointer;
}

/* *********************************************
 スライダー 
********************************************** */
.swiper-container {
  background-image: url(/public/img/online-salon-header.jpg) !important;
  background-size: cover;
  background-position: center;
}
/* 全体のスタイル */
.swiper-wrapper {
	width: 100%;
  max-height: 500px;
  min-height: 500px;
}
/* 全スライド共通スタイル */
.swiper-slide {
	color: #333;
	width: 100%;
	height: 100%;
}
.swiper-slide a {
  color: #333;
}
/* スライダーの画像 */
.slide_card_item,
.slide_card_item img {
  border-radius: 1.8rem;
  max-height: 350px;
  min-height: 350px;
  object-fit: cover;
}
.salon_contents_slider {
  vertical-align: middle;
  align-items: center;
  padding: 40px;
  min-height: 500px;
  max-height: 500px;
}
.salon_contents_slider p {
  font-size: 1.1rem;
}
.swiper-button-prev {
  background-image: url(../img/swiper-button-prev.png);
  filter: drop-shadow(0px 0px 5px rgba(0,0,0,0.2));
}
.swiper-button-next {
  background-image: url(../img/swiper-button-next.png);
  filter: drop-shadow(0px 0px 5px rgba(0,0,0,0.2));
}
.swiper-pagination-bullet-active {
  background: #997578;
}

@media screen and (max-width:768px){
  /* 全体のスタイル */
  .swiper-wrapper, .salon_contents_slider {
    min-height: 300px;
    max-height: 300px;
  }
  .salon_contents_slider {
    padding: 10px;
  }
  .swiper-slide,
  .swiper-slide_bg {
    height: 100% !important;
  }
  /* スライダーの画像 */
  .slide_card_item,
  .slide_card_item img {
    border-radius: .5rem;
    max-height: 200px;
    min-height: 200px;
  }
}


/* *********************************************
 サロン一覧
********************************************** */

.salon_image {
  border-radius: .25rem .25rem 0 0;
  max-height: 225px;
  min-height: 225px;
  object-fit: cover;
}


/* *********************************************
 サロン詳細
********************************************** */
.left-wrap {
  overflow: auto;
  height: 100vh;
}

.left_salon_title {
  min-height: 2em;
}
.left_salon_list {
  overflow-y: auto;
  height: 85%;
  padding-bottom: 3em;
  word-break: break-all;
}
.deitails_list_thumbnail {
  min-height: 150px;
  max-height: 150px;
  object-fit: cover;
}

.video_player {
  background-size: cover;
  background-position: center;
  padding: 150px 0;
}

.video-play-button {
/* position: absolute; */
z-index: 10;
top: 50%;
left: 50%;
transform: translateX(0%) translateY(0);
box-sizing: content-box;
display: block;
width: 32px;
height: 44px;
/* background: #fa183d; */
border-radius: 50%;
padding: 18px 20px 18px 28px;
}

.video-play-button:before {
content: "";
position: absolute;
z-index: 0;
left: 50%;
top: 50%;
transform: translateX(-50%) translateY(-50%);
display: block;
width: 80px;
height: 80px;
background: #ba1f24;
border-radius: 50%;
animation: pulse-border 1500ms ease-out infinite;
}

.video-play-button:after {
content: "";
position: absolute;
z-index: 1;
left: 50%;
top: 50%;
transform: translateX(-50%) translateY(-50%);
display: block;
width: 80px;
height: 80px;
background: #fa183d;
border-radius: 50%;
transition: all 200ms;
}

.video-play-button:hover:after {
background-color: darken(#fa183d, 10%);
}

.video-play-button img {
position: relative;
z-index: 3;
max-width: 100%;
width: auto;
height: auto;
}

.video-play-button span {
display: block;
position: relative;
z-index: 3;
width: 0;
height: 0;
border-left: 32px solid #fff;
border-top: 22px solid transparent;
border-bottom: 22px solid transparent;
}

@keyframes pulse-border {
0% {
transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
opacity: 1;
}
100% {
transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
opacity: 0;
}
}

.video-overlay {
position: fixed;
z-index: -1;
top: 0;
bottom: 0;
left: 0;
right: 0;
background: rgba(0,0,0,0.80);
opacity: 0;
transition: all ease 500ms;
}

.video-overlay.open {
position: fixed;
z-index: 1000;
opacity: 1;
}

.video-overlay-close {
position: absolute;
z-index: 1000;
top: 15px;
right: 20px;
font-size: 36px;
line-height: 1;
font-weight: 400;
color: #fff;
text-decoration: none;
cursor: pointer;
transition: all 200ms;
}

.video-overlay-close:hover {
color: #fa183d;
}

.video-overlay video {
position: absolute;
top: 50%;
left: 50%;
transform: translateX(-50%) translateY(-50%);
/* width: 90%; */
/* height: auto; */
box-shadow: 0 0 15px rgba(0,0,0,0.75);
}

@media screen and (max-width:768px) {
  .video_player {
    padding: 40px 0;
  }
}