@charset "UTF-8";

.cover {
  display: table;
  width: 100vw;
  height: 100vh;
}
.cover-img {
  background-position: center center;
  background-repeat: no-repeat;
  background-size:cover;
}
.cover-bg1 {
  background-image:url("../img/index/cover1.png");
}

.cover-text-box {
  display: table-cell;
  vertical-align:top;
  text-align:center;
}

.cover p {
	margin:30px 0 20px 0;
	padding: 0;
	font-size: 2.8rem;
	color: #F072B6;
	font-weight: bold;
text-shadow: 1px 2px 4px #fff;
}
h2.catch {
margin: 0;
padding: 0;
letter-spacing: 0.05em;
text-shadow: 1px 2px 4px #fff;
color:#FD6585;
font-weight: bold;
font-size: 6.0rem;
}
p.sub-catch {
margin: 0;
	padding: 0;
font-size:3.6rem;
color: #fff;
letter-spacing: 0.05em;
line-height: 1.2;
font-weight: bold;
text-shadow: 1px 2px 4px #666;
}
img.cara {
	width: 200px;
	height: auto;
}


@media screen and (max-width: 768px){
.cover-img {
  background-position: center top;
  background-size: auto 300px;
}
.cover-bg1 {
  background-image:url("../img/index/cover1-sp.png");
}
.cover-text-box {
  display: table-cell;
  vertical-align:top;
  text-align: center;
	padding:100px 0 0 0;
}
.cover p {
margin:30px 0;
font-size:2.4rem;
	color: #F072B6;
}
p.catch {
font-size:8.0rem;
color:#fff;
text-shadow: 1px 2px 4px #ccc;
}
p.sub-catch {
font-size:2.4rem;
color:#fff;
text-shadow: 2px 1px 10px #666;
}

}

.slide-in {
opacity:0;
filter: blur(8px);
animation:text_anime_on 0.1s ease-out forwards;
animation-name: blur;
animation-duration: 1.5s;
}

@keyframes slideIn {
  0% {
    transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}


/*---*/



@keyframes blur {
0% {
opacity: 0;
filter: blur(10px);
}
100% {
opacity: 1;
filter: blur(0);
}
}


p.catch {
font-size:3.6rem;
color:#fff;
text-shadow: 2px 1px 10px #fff;
}



@media screen and (max-width: 768px){
p.catch {
font-size:2.4rem;
color:#FD6585;
text-shadow: 2px 1px 10px #fff;
	}
}
/* 円画像４つ並び
----------*/	
.circle-container {
    display: flex;
    flex-wrap: wrap;
}

.circle-item {
    flex: 1 0 25%; 
    text-align: center;
    text-align: center;
    margin: 10px 40px;
}	 
.saiyou .circle-item {
	background: #fff;
	border-radius: 25px;
	padding: 2.0rem;
}


.circle-item h3 {
font-size: 2.4rem;
}
.circle-item p {
	text-align: left;
}
img.circle-image {
	border-radius:10px;
    max-width: 50%;
    height: auto;
    object-fit: cover;
}

@media screen and (max-width: 768px) {
.circle-item {
    flex: 1 0 50%;
    margin: 10px 10px;
    }
 
.saiyou .circle-item {
	padding: 1.0rem;
}
	
img.circle-image {
    max-width:100%;
}
}	


/* こんな方におすすめ
----------*/	
.osusume {
	padding: 20px 0;
	overflow: hidden;
}

.osusume h3 {
	font-size: 3.6rem;
}
.osusume .circle-item {
	padding: 10px;
	background: #ececec;
	border-radius: 5px;
}
.osusume h4 {
	font-size: 2.4rem;
}


/* 利用者
----------*/	
.riyousya {
	padding: 20px 0;
	overflow: hidden;
}
.riyousya p.read {
	font-size:1.8rem;
	color:#C346C2;
	line-height:1.25;
}
.riyousya h3 {
	font-size: 3.6rem;
}
.riyousya h4 {
	text-align: center;
	font-size: 2.4rem;
	line-height: 1.0;
}

.riyousya-item:nth-child(odd) {
  flex-direction: row-reverse;
	background:#FAF8FA;
	border-radius: 10px;
	padding: 4rem 2rem;
	overflow: hidden;
}
@media (min-width:769px) {
.riyousya h3 {
	font-size: 3.6rem;
}
.riyousya h4 {
	text-align: center;
	font-size: 2.4rem;
	line-height: 1.0;
}
.riyousya-list {
	overflow: hidden;
}

.riyousya-item {
  display: flex;
  margin: 20px auto;

}

.riyousya-item:nth-child(odd) {
  flex-direction: row-reverse;
	background:#FAF8FA;
	border-radius: 10px;
	padding: 4rem;
	overflow: hidden;
}

img.riyousya-item-img {
max-width: 30%;
height: auto;
}

}


/* 施設紹介
----------*/
.bg-container {
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.bg-gray-stripe1 {
  background:#fff;
}
.bg-gray-stripe1::before {
  content: "";
  width: 0;
  height: 0;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
  border-style: solid;
  border-width: 60px 0 0 100vw;
  border-color: transparent transparent transparent #72EDF2;
}
.bg-gray-stripe2 {
background-image: linear-gradient( 180deg, #72EDF2 10%, #5151E5 100%);
}
.bg-gray-stripe1 .bg-gray-stripe-container {
  padding:40px 0;
}
.bg-gray-stripe2 .bg-gray-stripe-container {
  padding:0px 0 0 0;
}

@media screen and (max-width: 768px) {
.bg-gray-stripe1::before {
  border-width: 48px 0 0 100vw;
}
.bg-gray-stripe-container {
  padding: 30px 0 0 0;
}
}




/*施設紹介のブロック
----------*/		  

.shisetsu-container {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.shisetsu-block {
    background-color: white;
    border-radius: 10px;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
    padding: 0rem;
    margin-bottom: 20px;
    width: calc(33.3% - 20px); 
}

@media screen and (max-width: 768px) {
.shisetsu-container {
        flex-direction: column;
    }

.shisetsu-block {
        width: calc(100% - 10px); /* Full width on mobile */
        margin-right: 5px;
        margin-left: 5px;
        text-align: center; /* Center-align on mobile */
        padding: 1rem; /* Reduce padding on mobile */
    }
}

.shisetsu-block img {
    width: 100%;
    border-radius:10px 10px 0 0;
}

.shisetsu-block h4 {
    text-align: center;
    margin:0 4px;
  color:#333;
  text-shadow: 0 0 5px white;
  padding: 0.3em 0.5em;
  background: -webkit-repeating-linear-gradient(-45deg, #ececec, #ececec 3px,#fff 3px, #fff 7px);
  background: repeating-linear-gradient(-45deg, #ececec, #ececec 3px,#fff 3px, #fff 7px);
}

.shisetsu-block p {
    text-align: left;
	margin:10px 10px 10px 10px;

}
p.address {
	text-align: center;
	font-size: 1.4rem;
	color: #666;
}
@media screen and (max-width: 768px) {
.shisetsu-block h4, .shisetsu-block p {
        margin-top: 0rem; /* Reduced space on mobile */
        margin-bottom: 1rem; /* Reduced space on mobile */
    }
}
/* 採用
----------*/	
.syokusyu {
	padding: 20px 0;
	overflow: hidden;
}

.syokusyu h2 {
	font-size: 2.1rem;
}
p.catch-saiyou-sabikan {
	font-size: 2.0rem;
	line-height: 1.5;
	color:#F18E90;
}
p.catch-saiyou-seikatsu {
	font-size: 2.0rem;
	line-height: 1.5;
	color:#F3BE33;
}



ul.hanrei {
	width: 95%;
	margin: 0 auto;	
	list-style: none;
}

@media (min-width:769px) {
ul.hanrei {
	display: none;
}
}
.dli-arrow-down {
  display: inline-block;
  vertical-align: middle;
  color:#00C7D5;
  line-height: 1;
  position: relative;
  width: 0.2rem;
  height: 4rem;
  background: currentColor;
}

.dli-arrow-down::before {
  content: '';
  width: 2.6rem;
  height: 2.6rem;
  border: 0.2rem solid currentColor;
  border-top: 0;
  border-right: 0;
  transform: rotate(-45deg);
  transform-origin: bottom left;
  position: absolute;
  left: 50%;
  bottom: -0.05em;
  box-sizing: border-box;
}

/* occupation */

.occupation {
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
  max-width:100%;
  border-radius: 20px;
  overflow: hidden;
  text-align: center;
}
.occupation tr {
  background-color: #e6f1f6;
}
.occupation tr:nth-child(even) {
  background-color: #fff;
}
.occupation th, .occupation td {
  padding: 1em;
}
.occupation thead th {
  background-color: #4d9bc1;
  font-size: 2.0rem;
  font-weight: bold;
  text-align: center;
	color:#fff;
}
.occupation thead th.text-pink-saiyou {
	color:#FD6585;
 -webkit-text-stroke: 1px #FFF;
  text-stroke: 1px #FFF;
}

.occupation thead th.text-orange-saiyou p {
	color:#F90;
-webkit-text-fill-color:#F90;
 -webkit-text-stroke: 1px #FFF;
  text-stroke: 1px #FFF;
}




.occupation tbody th {
  color: #4d9bc1;
}
@media screen and (max-width: 768px) {
  .occupation {
    border-radius: 0;
    text-align: left;
  }
  .occupation thead {
    display:none;
  }
  .occupation tr {
    background-color: unset;
  }
  .occupation th, .occupation td {
    display: block;
    border: 0;
    border-bottom: 1px solid #4d9bc1;
  }
  .occupation tbody th{
    background: #4d9bc1;
    color:#fff;
    text-align: center;
  }
  .occupation td::before{
    content: attr(data-label);
    background-color: #e6f1f6;
    font-weight: bold;
    display: inline-block;
    width: 20%;
    min-width: 4em;
    text-align: center;
    margin-right: 0.5em;
    padding: 4px;
    border-radius: 100vh;
  }
}


ul.saiyou-icon {
	margin:1rem 0;
	padding: 0;
	list-style: none;
	overflow: hidden;
}
ul.saiyou-icon li {
	float: left;
	background:#EAD8D8;
	color: #9C6869;
	padding: 0.2rem 0.5rem;
	margin:0.1rem 0.2rem 0.1rem 0;
	border-radius: 0.5rem;
	display: block;
}


/* FAQ
----------*/

.faq-container {
    max-width: 80%;
    margin:0 auto 25px;
    border: none;
    border-radius: 50px;
    box-shadow: 0 4px 4px rgb(0 0 0 / 2%), 0 2px 3px -2px rgba(0 0 0 / 5%);
    background-color: #fff;
}
.faq-container[open] {
    border-radius: 25px;
}



@media (max-width:769px) {
.faq-container {
    max-width: 100%;

	}
}
.faq-container summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em 1em 3em;
    color: #333333;
    font-weight: 600;
    cursor: pointer;
}

.faq-container summary::before,
.faq-container p::before {
    position: absolute;
    left: 1em;
    font-weight: 600;
    font-size: 1.3em;
}

.faq-container summary::before {
    color: #75bbff;
    content: "Q";
}

.faq-container summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 1.4rem;
    height: 1.4rem;
    margin-left: 10px;
    border-bottom: 3px solid #333333b3;
    border-right: 3px solid #333333b3;
    content: '　　';
    transition: transform 0.5s;
}

.faq-container[open] summary::after {
    transform: rotate(225deg);
}

.faq-container p {
    position: relative;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: .3em 3em 1.5em;
    color: #333;
    transition: transform 0.0s, opacity 0.5s;
}

.faq-container[open] p {
    transform: none;
    opacity: 1;
}

.faq-container p::before {
    color: #ff8d8d;
    line-height: 1.2;
    content: "A";
}
.shisetu-name {
	color: #9C6E6F;
}

/* about.html
------------------------------------------*/
#about .inner h1 {
	font-size: 3.6rem;
	color:#003D2F;
}
#guide .circle-item {
	text-align: left;	
}
#naiyou .bg-white , h3 ,h4 {
	border-radius: 10px;	
}
#naiyou .section-container {
	margin: 0 0 20px 0;
}
@media screen and (max-width: 768px) {
#naiyou img {
	width: 50%;
}
}
