@charset "utf-8";

:where(*){
  margin: 0;
  padding: 0;
  line-height: 1.6;
  box-sizing: border-box;
}

:where(a){
  text-decoration: none;
  color: #000;
  transition: .3s;
}

:where(a):hover{
  opacity: .8;
  transition: .3s;
}

:where(img){
  max-width: 100%;
  width: 100%;
  line-height: 0;
}

ul li{
  list-style: none;
}

:where(main, section, picture, figure){
  display: block;
}

html { font-size: 62.5%;}
body { font-size: 1.4rem; }
h2 { font-size: 1.8rem; }
h3 { font-size: 1.6rem; }
h4 { font-size: 1.4rem; }

/*ヘッダーCSS  */

header{
    background: #6B1685;
 }


 .header_up{
  position: fixed; /* ウィンドウを基準に画面に固定 */
  width: 100%; /* 幅いっぱいを指定 */
  height: 60px; /* 高さを60pxに指定 */
  background: #6B1685; /* 背景色にグレーを指定 */
  padding:0;/* ヘッダーに上下左右それぞれ余白を指定 */
  /* box-sizing: border-box;  padding分を含んで幅を100%にするため   */
  top: 0; /* 上下の固定位置を上から0pxにする */
  left: 0; /* 左右の固定位置を左から0pxにする */
  display: flex; /* 中の要素を横並びにする */
  align-items: center; /* 中の要素を上下中央に並べる */
  z-index:99999; /*中の要素が一番前に表記、数字の大き程前に表記する*/
 }
 

 
.header_word{
  position: sticky;
  color:white;
  font-size:20px;
  left:20%;
  display: flex;
}


@media screen and (max-width: 768px) {
 .header_word{
  font-size:13px;
  }   
}


@media screen and (min-width: 768px){
.br-sp {display: none; }
}
/* 文字の行替えを画面幅768px以下の場合実行せず   */

.header_logo{
  width: 90px;
  background: #fff;
  padding: 5px 5px 0px;
  margin-left: 5px;
  margin-right: 100px;
  justify-content: left;
  display: block;
}

@media screen and (max-width: 768px) {
  .header_logo{
   margin-right: 5px;
  }
}

/*  END　ヘッダーCSS  */
 

h1{
  width: 100px;
  background: #fff;
  margin: 10px;
  padding: 10px;
  line-height: 0;
}



h2, h3, h4 {
  margin-top: 10px;
  margin-bottom: 10px;
}

main{
  width: min(100% - 2rem, 1150px);
  margin: auto;
}

.c-box{
  display: flex;
  justify-content: center;
  align-items: center;
}




.mt01{
  margin-top: 1em!important;
}
.mt02{
  margin-top: 2em!important;
}
.mt03{
  margin-top: 3em!important;
}
.mt04{
  margin-top: 4em!important;
}

.mb01{
  margin-bottom: 1em!important;
}
.mb02{
  margin-bottom: 2em!important;
}
.mb03{
  margin-bottom: 3em!important;
}
.mb04{
  margin-bottom: 4em!important;
}
.sale{
  font-weight: bolder;
}
.text-c{
  text-align: center!important;
}

.main_visual{
  padding: 5px;
}

.xscore_area1{
  background: linear-gradient(#e7d9ce,#f8f4f1);
  padding: 20px 0;
}

.title{
  border-bottom: solid 2px #ff0000;
  display: inline-block;
  text-align: center;
}

.btn{
  width: 300px;
  margin: 1em auto;
}

.btn_og{
  background-color: #ff4500;
  width: 300px;
  height: 100px;
  border-radius: 20px;
  color: #fff;
  font-weight: bold;
  text-align: center;
}

.btn_og b{
  display: inline-block;
}

.xscore_kaisai {
  border: #4e3121 5px double;
  background-color: #c29765;
  width: min(100% - 2rem, 800px);
  padding: 2rem;
  margin: 2rem auto;
  line-height: 1.8;
}


.xscore_area2{
  background: #ffff91;
  padding-bottom: 3rem;
  margin-bottom: 3rem;
}

.xscore_area3{
border-bottom: solid 1px #ccc;
margin-bottom: 4rem;
}

.flex_jc_bw_wrap{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}



@media screen and (max-width: 768px) {
  .flex_jc_bw_wp{
    display: block;
  }
}

.info_box{
  width: 49%;
  padding: 10px;
  box-shadow: 0 2px 2px #d8d5d4; /*  枠の */
  margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
  .info_box{
    width: 100%;

  }
}

.xscore_area4{
  border-bottom: solid 1px #ccc;
  margin-bottom: 4rem;
}


.xscore_area6{

}

.title_pu{
  background-color: #7d0d89;
  padding: 3px;
  color: #fff;
  text-align: center;
}

.title_ft{
  padding: 5px; 
  background-color: #ffffff; 
  box-shadow: #cd853f 0px 0px 50px inset, #cecece 5px 5px 0px; font-size: 90%;  
  text-align: center;
  font-weight: bold;
  font-size: large;
}

.word{
  background-color: #221814;
  padding: 3px;
  color: #fff;
  text-align: center;
}


.icon{
  display: inline-block;
    background: #7d0d89;
    padding: 2px;
    border-radius: 2px;
    word-break: break-all;
    color: #fff;
}

footer {
  color: #ffffff;
}

footer p{
  font-size: 1.2rem;
}

footer a {
  color: #ffffff;
  text-decoration: underline;
}

footer a:hover {
  color: #ffffff;
  text-decoration: none;
}

.footer_up{
  background: #6B1685;
    padding: 25px;
    display: flex;
    justify-content: center; /*  横　中央揃い  */
    align-items: center;　　/*  縦　中央揃い  */
}
@media screen and (max-width: 768px) {
.footer_up{
  display: block;
}
}

.footer_logo{
  width: 150px;
  background: #fff;
  padding: 5px 10px;
  margin-right: 10px;
  display: block;
}
@media screen and (max-width: 768px) {
  .footer_logo{
    margin-bottom: 1em;
  }
}




.footer_under{
  padding: 15px;
  background-color: #4e0f74;
}

.site_map {
  display: flex;
  justify-content: space-around;
  color: #ffffff;
  width: min(100% - 2rem, 300px);
  margin: auto;
}

/*固定申込ボタン*/
.fix_bt{
    position: fixed;
    bottom: 0;
    z-index: 1000;
	text-align:center;
	right:0px;
}


/*表組*/

.tr{
	width:100%;
	display:table;
	margin-bottom:2px;
	clear:both;
	}
	
.table .th{
	width:25%;
	padding:5px;
	text-align:left;
	background:#e9e9e9;
	display:table-cell;
	}
.table .td{
	width:75%;
	padding:5px;
	background:#f8f8f8;
	display:table-cell;	
	vertical-align: middle;
	}

.table{
	margin-bottom:20px;
	display:table;
	clear:both;
	width:100%;
	}
	


.table-1 {
    margin-left: auto;
    margin-right: auto;
}

.table-img{
    width:170px
}
	
	
/*トップに戻るスロー*/		
	
	html{
  scroll-behavior: smooth;
}



/*-----------------------------------------------
住吉ベッドアコーディオン用
-----------------------------------------------*/

/*アコーディオン*/		
/*ベース*/
.toggle {
	display: none;
}
.Label {		/*タイトル*/
	padding: 1em;
	display: block;
	color: #ffffff;
	background:#000080;
}
.Label::before{		/*タイトル横の矢印*/
	content:"";
	width: 6px;
	height: 6px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 20px;
	transform: rotate(135deg);
}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0 20px;
	overflow: hidden;
}
.toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	padding:20px ;
	transition: all .3s;
}
.toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}

/*-----------------------------------------------
住吉表組よこ用
-----------------------------------------------*/
@media screen and (max-width: 767px) {
.table .th{
	width:100%;
	padding:5px;
	background:#e9e9e9;
	display:block;
	}
	
	.table .td{
	width:auto;
	padding:5px;
	background:#f8f8f8;
	display:block;	
	vertical-align: middle;
	}
}


/*-----------------------------------------------
住吉キラキラ
-----------------------------------------------*/
.reflection{
display:inline-block;
position:relative;
overflow:hidden;
}
 
.reflection:after {
content:"";
height:100%;
width:30px;
position:absolute;
top:-180px;
left:0;
background-color: #fff;
opacity:0;
-webkit-transform: rotate(45deg);
-webkit-animation: reflection 2s ease-in-out infinite;
}
 
@keyframes reflection {
0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}


/* コードグラデーション上下住吉 */
.box_sssn {
  background: linear-gradient(#001e43,#001e43);
   border-radius: 10px 10px 10px 10px / 10px 10px 10px 10px;
  
}