@charset "utf-8";

/* -----------------------------------------------------------
        reset
-------------------------------------------------------------- */
html {
  overflow-x: auto;
  overflow-y: scroll;
  font-size: 62.5%;
}

:root {
    --main-color:var(--blue);
    --cv-color:var(--sample);
    --sub-color:var(--lightblue);
    --bg-color:var(--pastelblue);


    /*color*/
    --navy: #073972;
    --grayblue:#ADBEC8;
    --blue:#3972B7;
    --lightblue: #009fe7;
    --pastelblue:#F3F7FB;
    --softblue:#B7C6DB;
    --white:#fff;
    --black:#333;


    --darkgray: #49565E;
    --gr: linear-gradient(90deg, #99bcdb, #7da4cb, #648cbc, #4d74ac, #375c9b, #244589, #132e77, #021763);
    --cv: #223F53;

    /* font */
    --awesome: 'Font Awesome 5 Free';
    --font-jp: "Noto Sans JP", sans-serif;
    --font-en: "Montserrat", sans-serif;
    --lato: 'Lato', sans-serif;
}

.lecture{
    --servicecolor: #009FE8;
}
.csr{
    --servicecolor: #89CC13;
}
.future{
    --servicecolor: #E72A62;
}
.healthtable365{
    --servicecolor: #F0D700;
}
.electrictherapy{
    --servicecolor: #1558A7;
}
.cosmolab{
    --servicecolor: #E96C29;
}
.bodyful{
    --servicecolor: #3FBF8E;
}
.project{
    --servicecolor: #a799fc;
}
.yobo{
    --servicecolor: #15a764;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

h1,h2,h3,h4,h5,h6,
p,ul,ol,li,div,dl,dt,dd,
form,img,hr,table,tr,td,
br,em,figure {
  margin: 0px;
  padding: 0px;
  border: none;
  font-style: normal;
}

h1,h2,h3,h4,h5,h6 {
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 1.8;
}

ul,ol,dl {
  list-style: none;
}

img {
	vertical-align: bottom;
}

@media screen and (max-width: 768px) {

  img {
	height: auto;
	margin: 0 auto;
  }

}

/* -----------------------------------------------------------
        body
-------------------------------------------------------------- */
body {
	margin: 0 auto;
	padding: 0;
	line-height: 1;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	color: #444;
	font-family: 'Montserrat', 'Noto Sans JP', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	background: #fff;
	-webkit-text-size-adjust: 100%;
	word-break: break-all;
	min-width: 1300px;
    font-feature-settings: "palt";
}

#wrapper {
	width: 100%;
	height: 100%;
	margin: 0 auto;
	overflow: hidden;
	background: url() no-repeat;
	background-position: center 250px;
	background-size: auto;
}

#wrapper.no_bg {
	background: none;
}

#wrapper.form_page {
	background-position: center 200px;
}

p {
	font-size: 1.6rem;
	line-height: 1.8;
}
p.txt{
    font-size: 1.6rem;
    line-height: 1.8;
}

#wrapper {
	width: 100%;
	height: 100%;
	min-width: 1200px;
	margin: 0 auto;
	overflow: hidden;
}

#main {
	display: block;
}

@media screen and (max-width: 768px) {

	body {
		min-width: inherit;
	}
	#wrapper {
		min-width: 100%;
		background-position: center 140px;
		background-size: 100% auto;
	}

	#wrapper.form_page {
		background-position: center 130px;
	}

	*:focus {
		outline: none !important;
	}



	/* iOSでのデフォルトスタイルをリセット */
	input[type="submit"],
	input[type="button"] {
		border-radius: 0;
		-webkit-box-sizing: content-box;
		-webkit-appearance: button;
		appearance: button;
		border: none;
		box-sizing: border-box;
		cursor: pointer;
	}

	input[type="submit"]::-webkit-search-decoration,
	input[type="button"]::-webkit-search-decoration {
		display: none;
	}

	input[type="submit"]::focus,
	input[type="button"]::focus {
		outline-offset: -2px;
	}

}

/* -----------------------------------------------------------
        link
-------------------------------------------------------------- */
a:link,
a:visited {
	color: #333;
	text-decoration: none;
	transition: 0.5s;
}

a
a:hover {
	transition: 0.3s;
}

a.anchor {
	margin-top: -132px;
	padding-top: 132px;
	display: block;
}

::-moz-selection {
	color: #fff;
	background: #656f72;
}

/* 電話リンク PC:OFF */
a[href^="tel:"] {
	pointer-events: none;
}

@media screen and (max-width: 768px) {
	a:link,
	a:visited {
		transition: 0;
	}

	/* 電話リンク SP:ON */
	a[href^="tel:"] {
		pointer-events: inherit;
	}

    a.anchor {
		margin-top: -60px;
		padding-top: 60px;
	}
}

/* -----------------------------------------------------------
        clear
-------------------------------------------------------------- */
.clear {
	height: 0px;
	margin: 0px;
	padding: 0px;
	line-height: 0px;
	clear: both;
	font-size: 0px;
}

.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.clearfix {
	display: inline-block;
}

/* Hides from IE-mac \*/
* html .clearfix {
	zoom: 1;
}
.clearfix {
	display: block;
}
/* End hide from IE-mac */

/* -----------------------------------------------------------
        Frame
-------------------------------------------------------------- */

.inner {
	margin: 0 auto;
	max-width: 1200px;
	min-width: 1200px;
	width: calc(100% - 200px);
    height: inherit;
}

.inner1000 {
	margin: 0 auto;
	max-width: 1000px;
	min-width: 1000px;
	width: calc(100% - 100px);
    height: inherit;
}

.inner1100 {
    margin: 0 auto;
	max-width: 1100px;
	min-width: 1100px;
	width: calc(100% - 250px);
    height: inherit;
}

.inner1300 {
    margin: 0 auto;
	max-width: 1300px;
	min-width: 1300px;
	width: calc(100% - 150px);
    height: inherit;
}

/*	 template     */
.contents {
	padding: 100px 0;
}

.contents-left {
  float: left;
}

.contents-right {
  float: right;
}

@media screen and (max-width: 768px) {

	.inner,
    .inner1000,
    .inner1100,
    .inner1200,
    .inner1300{
		max-width: 100%;
		min-width: 100%;
		width: 100%;
	}

	.contents {
		padding: 0;
	}

	.wrap10 {
		padding: 0 10px;
	}

	.wrap15 {
		padding: 0 15px;
	}

	.wrap20 {
		padding: 0 20px;
	}

	.wrap30 {
		padding: 0 30px;
	}

	.contents-left {
		float: none;
	}

	.contents-right {
		float: none;
	}

}

/* -----------------------------------------------------------
        responsive
-------------------------------------------------------------- */

.sp-display {
	display: none;
}

.sp-display-b {
	display: none;
}

br.pc-br {
	display: inline;
}

br.sp-br {
	display: none;
}

@media screen and (max-width: 768px) {

	.pc-display {
		display: none;
	}

	.pc-display-b {
		display: none;
	}

	.sp-display {
		display: inline;
	}

	.sp-display-b {
		display: block;
	}

	br.pc-br {
		display: none;
	}

	br.sp-br {
		display: inline;
	}

}

/* -----------------------------------------------------------
        マーカー
-------------------------------------------------------------- */
.yellow-line {
    background: linear-gradient(transparent 70%, #FCEC7E 70%);
}


/* -----------------------------------------------------------
        CVボタン
-------------------------------------------------------------- */
/* .cv-btn {
    padding: 10px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    min-height: 60px;
    background-position: 100%!important;
    background-size: 200% auto!important;
    background-color: var(--cv);
    transition: background 1s cubic-bezier(0.19, 1, 0.22, 1)!important;
    position: relative;
    overflow: hidden;
} */

/* .cv-btn::after {
    content: '';
    position: absolute;
    top: -100px;
    left: -100px;
    width: 50px;
    height: 50px;
    background-image: linear-gradient(100deg,  rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%, rgba(255, 255, 255, 0) 0%);

    アニメーション
    animation-name: shiny;
    animation-duration: 7s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
} */

@keyframes shiny {
    0% {
        transform: scale(0) rotate(25deg);
        opacity: 0;
    }

    50% {
        transform: scale(1) rotate(25deg);
        opacity: .6;
    }

    100% {
        transform: scale(50) rotate(25deg);
        opacity: 0;
    }
}

.cv-btn:hover {
    background-position: 0!important;
}

.cv-btn .btn-txt {
    font-weight: bold;
    color: #fff;
    font-size: 1.6rem;
    /*display: inline-block;*/
    width: 100%;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0 3px;
}

.cv-btn .btn-txt .icon-wrap {
    /*display: block;*/
    /*width: 100%;*/
    display: inline-block;
    text-align: center;
    /*margin: 0 0 5px;*/
    margin: 0;
}


@media screen and (max-width: 768px) {

    .cv-btn {
        padding: 6px 5px 8px;
        width: 100%;
        min-height: initial;
    }

    .cv-btn .btn-txt {
        font-size: 1.4rem;
    }

    .cv-btn img {
        margin: 0;
    }
}

/* -----------------------------------------------------------
        矢印付きテキストリンク
-------------------------------------------------------------- */

.back-link {
	clear: both;
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	margin: 15px auto 30px;
	text-align: left;
}

.back-link a {
	padding: 5px 5px 5px 15px;
    display: inline-block;
    position: relative;
}

.back-link a:hover {
	color: #009fe7;
}

.back-link a::before {
    content: "\f104";
	display: inline-block;
	margin: 0 8px 0 0;
	font-family: FontAwesome;
	font-size: 1.6rem;
	color: var(--main-color);
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.next-link {
	font-size: 1.6rem;
	text-align: right;
}

.next-link a {
	display: inline-block;
	padding: 5px;
}

.next-link a:hover {
	color: #1c5896;
}
.next-link a::before {
	display: inline-block;
	margin: 0 8px 0 0;
	content: "\f105";
	font-family: FontAwesome;
	font-size: 1.6rem;
	color: #1c5896;
}

@media screen and (max-width: 768px) {

	.back-link {
		width: 100%;
		margin: 15px auto 0;
	}

}

/* -----------------------------------------------------------
        breadcrumbs
-------------------------------------------------------------- */
.breadcrumbs {
	position: absolute;
	width: 100%;
	padding: 10px 0 10px;
	font-size: 1.2rem;
	background: transparent;
    z-index: 100;
    right: 0;
    left: 0;
    /* bottom: 243px; */
    /* top: 633px; */
    bottom: 0;
    bottom: 25px;
    color: var(--white);
}
.breadcrumbs.inner{
    height: auto !important;
}
.breadcrumbs.type02{
    bottom: auto;
    top: auto;
}
.breadcrumbs a {
	font-size: 1.2rem;
	letter-spacing: 0.2rem;
    color: var(--white);
    color: var(--darkgray);
}
.breadcrumbs a:hover {
    opacity: .7;
}
.breadcrumbs p {
	font-size: 1.2rem;
	position: relative;
	z-index: 5;
    color: var(--darkgray);
}
.breadcrumbs .fa {
	color: var(--main-color);
	margin: 0 5px;
	font-size: 1.4rem;
    vertical-align: middle;
}

@media screen and (max-width: 768px) {

	/* breadcrumbs */
	.breadcrumbs {
		display: none;
	}
}

/* -----------------------------------------------------------
        h1
-------------------------------------------------------------- */

.h1-area {
	position: absolute;
	/* left: 0; */
	right: 5%;
    text-align: right;
    top: 370px;
    top: 345px;
    z-index: 0;
    color: var(--white);
    color: var(--darkgray);
}
.h1-area.type02{
    top: 439px;
}
.h1-area h1 {
	font-size: 1.2rem;
	line-height: 1.7;
	font-weight: 400;
}

@media screen and (max-width: 768px) {

	.h1-area {
        color: #fff;
		/* position: absolute; */
        position: relative;
		width: 100%;
		padding: 5px 5px 5px 10px;
		/* margin: 0 auto;
		top: -27px;
		left: 0; */
        top: auto;
        right: auto;
        text-align: left;
        text-align: center;
		z-index: 0;
        position: absolute;

        /* background: radial-gradient(circle at 10%, #F3F7FB, #009fe7);
        background-size: 200% 200%;
        animation: bggradient 20s ease infinite; */
	}

	.h1-area h1 {
		font-size: 1.0rem;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
        color: #333;
	}
    .h1-area.type02{
        position: relative;
        top: 55px;

    }
}


/* -----------------------------------------------------------
        pager-area
-------------------------------------------------------------- */

.pager-area {
	font-size: 1.6rem;
	margin: 30px 0 50px 0;
	text-align: center;
}

.pager-area a {
    font-family: var(--font-en);
    /* font-weight: bold; */
	border: 1px solid var(--main-color);
	color: var(--main-color);
	display: inline-block;
	margin: 0 3px;
    text-align: center;
    line-height: 36px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
}

.pager-area a:hover {
	background: var(--main-color);
	border: 1px solid var(--main-color);
	color: #fff;
}

.pager-area .current {
    font-family: var(--font-en);
    /* font-weight: bold; */
	background: var(--main-color);
	border: 1px solid var(--main-color);
	color: #fff;
	display: inline-block;
	margin: 0 3px;
    text-align: center;
    line-height: 36px;
	transition: 0.5s;
    width: 38px;
    height: 38px;
    border-radius: 50%;
}

.pager-area .current:hover {
	pointer-events: none;
}

.pager-area .back,
.pager-area .next {
    font-family: var(--font-en);
    /* font-weight: bold; */
	color: var(--main-color);
	/* width: auto; */
}

.pager-area .back a,
.pager-area .next a {
	border: none;
	border: 1px solid #e6e6e6;
	margin: 0;
	padding: 10px 15px 10px;
}

.pager-area .back .fa {
	margin: 0 10px 0 0;
}

.pager-area .next .fa {
	margin: 0 0 0 0px;
}

.pager-area .back .fa,
.pager-area .next .fa {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
}

.pager-area .back:hover .fa,
.pager-area .next:hover .fa {
	color: #fff;
}

@media screen and (max-width: 768px) {

	.pager-area {
		margin: 20px 0 40px;
	}

	/* .pager-area a,
	.pager-area b {
		
	} */

	.pager-area .current {
		margin: 0 1px;
		/* padding: 10px; */
	}

	.pager-area .back,
	.pager-area .next {
		margin: 0 1px;
		/* padding: 10px; */
	}

}

/* -----------------------------------------------------------
        page-top
-------------------------------------------------------------- */

#page-top {
	position: fixed;
	bottom: 10px;
	right: 10px;
	z-index: 60;
	line-height: 1;
}

#page-top a {
	display: flex;
	width: 50px;
	height: 50px;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	background: #7C7C84;
	color: #fff;
    /* border: 2px solid #00286A; */
}

#page-top a:hover {
    opacity: 0.8;
}

#page-top a i {
	font-size: 2rem;
}

@media screen and (max-width: 768px) {

	#page-top {
		bottom: 10px;
	}


}

/* -----------------------------------------------------------
        404
-------------------------------------------------------------- */

#not .not-box {
	text-align: center;
}

#not .section_txt {
	margin: 70px 0 60px;
}

#not .toplink {
	margin: 0 0 60px;
}

@media screen and (max-width: 768px) {

	#not .section_txt {
		margin: 25px 0 50px;
	}

	#not .toplink {
		margin: 0 0 40px;
	}

}

/* -----------------------------
	記事パーツ
-------------------------------- */

.cate-area .cate-title,
.archive-area .archive-title {
	padding: 0 0 15px;
    line-height: 1.7;
	letter-spacing: 0.05em;
	font-size: 2.2rem;
	font-family: var(--font-en);
	font-weight: 600;
	text-align: center;
	color: var(--main-color);
}
.archive-area.popular .archive-title{
    font-size: 2.0rem;
    font-family: "Noto Sans JP", 游ゴシック, YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}
.cate-area .cate-list,
.archive-area .archive-list {
	border-top: 1px solid #e6e6e6;
	padding: 0 0 40px;
	text-align: center;
}

.cate-area .cate-list li,
.archive-area .archive-list li {
	border-bottom: 1px solid #e6e6e6;
	line-height: 1.4;
	font-size: 1.5rem;
}

.cate-area .cate-list li a,
.archive-area .archive-list li a {
	color: #333;
	padding: 20px 0;
	display: block;
}

.cate-area .cate-list li a:hover,
.archive-area .archive-list li a:hover {
	opacity: 0.8;
}

@media screen and (max-width: 768px) {

	.cate-area .cate-title,
	.archive-area .archive-title {
		padding: 0 0 15px;
		border-top: none;
	}

	.cate-area .cate-list,
	.archive-area .archive-list {
		padding: 0 0 30px;
	}

	.cate-area .cate-list li a,
	.archive-area .archive-list li a {
		padding: 15px 0;
	}

}

/* -----------------------------
	ページパーツ（　tag-area　）
-------------------------------- */

.tag-area {
	padding: 0 0 40px 0;
}

.tag-area .tag-title {
	padding: 0 0 15px;
	letter-spacing: 0.05em;
	font-size: 2.2rem;
	font-family: var(--font-en);
	font-weight: 600;
	text-align: center;
	color: var(--main-color);
}

.tag-area .tag-list {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
    gap: 10px;
}

.tag-area .tag-list li {
	text-align: center;
	/*margin: 0 10px 10px 0;*/
	line-height: 1.2;
    width: calc( (100% - 10px) / 2);
}

.tag-area .tag-list li a {
	display: block;
	padding: 6px 15px;
	font-size: 1.2rem;
	background: #fff;
	border: #ccc solid 1px;
	color: #333;
}

.tag-area .tag-list li a:hover {
	opacity: 1;
	background: var(--main-color);
    border-color: var(--main-color);
	color: #fff;
}

@media screen and (max-width: 768px) {

	.tag-area {
		margin: 20px 0;
		padding: 0;
	}

	.tag-area .tag-title {
		width: auto;
	}

	.tag-area .tag-list {
		width: auto;
	}

	/* .tag-area .tag-list li {
		margin: 0 8px 8px 0;
	} */

	.tag-area .tag-list li a {
		padding: 4px 10px;
	}

}
/* -----------------------------------------------------------
        layout
-------------------------------------------------------------- */

.f-fs {
	display: flex;
	justify-content: flex-start;
}

.f-sb {
	display: flex;
	justify-content: space-between;
}

.f-fe {
	display: flex;
	justify-content: flex-end;
}

.f-c {
	display: flex;
	justify-content: center;
}

@media screen and (max-width: 768px) {

	.f-fs {
		display: block;
		justify-content: flex-start;
	}

	.f-sb {
		display: block;
		justify-content: flex-start;
	}

	.f-fe {
		display: block;
		justify-content: flex-start;
	}

}

/* -----------------------------------------------------------
        btn
-------------------------------------------------------------- */
.btn-area {
    width: 100%;
    text-align: center;
}

.btn-area .more-btn {
    /* padding: 15px 20px; */
    min-width: 280px;
    min-height: 60px;
    line-height: 60px;
    display: inline-block;
    text-align: center;
    color: #fff;
    border-radius: 30px;
    background-image: linear-gradient(to right, #3972B7 0%, #009FE8 51%, #3972B7 100%);
    background-position: 100%;
    background-size: 200% auto;
    transition: background 1s cubic-bezier(0.19, 1, 0.22, 1);
    position: relative;
    /*box-shadow: 0px 0px 15px -5px #777;*/
    transition: all .4s ease-out;
}
.btn-area .more-btn.white{
    background: #fff;
    color: var(--blue);
    font-weight: bold;
    overflow: hidden;
}
.btn-area .more-btn.white::after{
    background-color: var(--blue);
}
.btn-area .more-btn:hover {
    background-position: 0;
}

.btn-area .more-btn::after {
    content: "";
    display: inline-block;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    /* background: url("../img/icon-btn-arrow-navy.svg") center/cover, no-repeat; */
    background-color: #fff;
    /* width: 45px;
    height: 1px; */
    width: 8px;
    height: 8px;
    border-radius: 10px;
    transition: all .4s ease-out;
}
.btn-area .more-btn.white::before {
    background: var(--blue);
    border-radius: 50%;
    content: "";
    display: block;
    margin: auto;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    width: 100%;
    padding-top: 100%;
    height: 0;
    z-index: -1;
    transform: translateY(-50%) scale(0.1);
    transition: opacity .5s, transform 0s;
    transition-delay: 0s, .4s;
}
.btn-area .more-btn.white:hover{
    background: transparent;
    color: var(--white);
}
.btn-area .more-btn.white:hover::before{
    opacity: 1;
  transform: translateY(-50%) scale(1.1);
  transition-delay: 0s;
  transition: opacity .8s, transform .6s ease-in-out;
}
.btn-area .more-btn.white:hover::after{
    background-color: var(--white);
}
/* .btn-area .more-btn:hover::after {
    right: -30px;
} */
.btn-area .more-btn::before{

}
@media screen and (max-width: 768px) {
    .btn-area .more-btn.w100 {
        width: 100%;
    }
}

/* -----------------------------------------------------------
        header
-------------------------------------------------------------- */
.header-fixed {
	min-width: 1200px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 100;
}
.header-fixed.active .header-area{
    background-color: #fff;
    box-shadow: 0px 20px 20px 0px rgba(0, 0, 0, 0.05);
}
.header-fixed.active #main-nav{
    width: 100%;
}
.header-fixed.active .sub-nav li a{
    color: #333 !important;
}
.header-nofixed{
    position: absolute;
	z-index: 30;
	width: 100%;
    min-width: 1200px;
}

/* スクロールメニュー */
/* #header.header-fixed.scroll-nav {
	background: #fff;
	box-shadow: 0px 20px 20#pc-header .nav .sub-nav li apx 0px rgba(0, 0, 0, 0.05);
} */

.header-area {
	transition: 0.5s;
	/* overflow: hidden; */
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 0 auto;
}
#header .header-area .inner{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
	transition: all .2s;
}
#header.header-fixed.active .header-area .inner{
    padding: 5px 0;
    padding: 0;
}
/* ロゴ */
.header-area .h-logo {
    /*width: 13.8%;*/
	transition: 0.5s;
    max-width: 222px;
    line-height: 0;
	height: 50px;
    /* width: 199px; */
	align-items: center;
}
.header-area .h-logo a {
	display: block;
}
.header-area .h-logo a img {
	width: 100%;
    height: 50px;
    transition: all .5s;
}

/* #header.header-fixed.scroll-nav .header-area .h-logo {
	padding: 0 0 0 30px;
}

#header.header-fixed.scroll-nav .header-area .h-logo a img {
    transform: scale(90%);
} */

/* ナビゲーション（上段） */
#header .header-area #pc-header {
	/*float: right;*/
	display: flex;
    width: calc(100% - 295px);
    /*flex-wrap: wrap;*/
	/* padding: 0 35px 0 0; */
    transition: all .2s;
}
#pc-header .nav {
    display: flex;
    /* flex-wrap: wrap; */
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    /*width: initial;*/
    gap:20px;
}
/* #header.header-fixed.scroll-nav .header-area #pc-header {
	padding: 0 35px 0 0;
} */

#pc-header .nav .sub-nav {
    display: flex;
    transition: 0.2s;
    /*flex-wrap: wrap;*/
    /* width: 100%; */
    justify-content: flex-end;
}
#pc-header .nav .sub-nav li a {
    padding: 20px;
    display: block;
    color: #333;
    /* color: var(--white); */
    font-size: 1.6rem;
    line-height: 1;
    transition: all .2s ease-in;
    text-align: center;
    position: relative;
    z-index: 1;
	font-weight: 500;
}
#pc-header .nav .sub-nav li a.main::before{
    content: '';
    /*絶対配置で線の位置を決める*/
    position: absolute;
    bottom: 0;
    left: 10%;
    /*線の形状*/
    width: 80%;
    height: 1px;
    background:var(--main-color);
    /*アニメーションの指定*/
    transition: all .3s;
    transform: scale(0, 1);/*X方向0、Y方向1*/
    transform-origin: center top;/*上部中央基点*/
}
#pc-header .nav .sub-nav li a.main:hover {
    color: var(--main-color);
}
#pc-header .nav .sub-nav li a.main:hover::before{
    transform: scale(1, 1);/*X方向にスケール拡大*/
}

.a.no-link{
    pointer-events: none;
}

/* メガメニュー内 */
#pc-header .nav li .menu{
    width: 1300px;
	max-height: 0;
	background-color: var(--rightgray);
	background-color: var(--navy);

	transition: all .2s ease-in;
	opacity: 0;
	overflow: hidden;
	position: absolute;
    top: 70px;
    margin: 0px auto;
    left: 0px;
    right: 0px;
}
.header-fixed.active #pc-header .nav li .menu{
    top: 55px;
}
#pc-header .nav li .menu .menu-container{
    padding: 30px 0;
    /* display: flex;
    gap: 50px;
    justify-content: space-between; */
    margin: 0 auto;
    width: 1200px;
	/*
    height: 300px;
	*/
}
/* サービスメガメニュ */
#pc-header .nav li .menu .menu-container ul{
    display: flex;
    flex-wrap: wrap;
    /* justify-content: space-between; */
    margin: 0 auto;
    gap: 20px;
    padding: 0;
}
#pc-header .nav li .menu .menu-container ul li{
    width: calc( (100% - 60px) / 4 );
    background-color: #fff;
    height: 100%;
    box-shadow: none;
    position: relative;
    top: 0px;
    transition: 0.5s;
}
#pc-header .nav li .menu .menu-container ul li::after{
    position: absolute;
    content: "\f061";
    font-family: "Font Awesome 6 Free";
    right: 10px;
    bottom: 10px;
    color: var(--servicecolor);
    z-index: 1;
}
#pc-header .nav li .menu .menu-container ul li:hover::after{
    color: #fff;
}
#pc-header .nav li .menu .menu-container ul li a{
    display: flex;
    align-items: center;
    gap: 10px;
}
#pc-header .nav li .menu .menu-container ul li a img{
    width: 90px;
}
#pc-header .nav li .menu .menu-container ul li a .txt{
    text-align: left;
    line-height: 1.4;
	font-size: 1.7rem;
}
#pc-header .nav li .menu .menu-container ul li a .txt span{
    display: block;
    font-size: 1.2rem;
    color: var(--servicecolor);
	margin: 2px 0 0;
}
#pc-header .nav li .menu .menu-container ul li.electrictherapy a .txt span{
    font-size: 1.0rem;
}
#pc-header .nav li .menu .menu-container ul li:hover .txt span{
    color: #fff;
    transition: .5s;
}
#pc-header .nav li .menu .menu-container ul li:hover{
    top: 0px;
    transition: 0.5s;
}
#pc-header .nav li:hover .menu {
	max-height: 9999px;
	opacity: 1;
	z-index: 100;
}
#pc-header .hover-bg::before{
    background: var(--servicecolor);
    opacity: 0.7;
}

/* 会社概要メガメニュ */
#pc-header .nav li .menu .menu-container.company ul li{
    /*width: calc( (100% - 40px) / 3 );*/
	
	width: calc( (100% - 100px) / 5 );
    overflow: hidden;
	background: none;
}
#pc-header .nav li .menu .menu-container.company ul li::after{
    color: #fff;
}
#pc-header .nav li .menu .menu-container.company  ul li a{
    display: block;
    padding: 0;
	position: relative;
}
#pc-header .nav li .menu .menu-container.company  ul li a:hover{
    border-radius: 10px;
}
#pc-header .nav li .menu .menu-container.company ul li a img{
    width: 100%;
    height: 100%;
	height: 280px;
    object-fit: cover;
	object-position: center top;
    transition: all 0.3s ease;
}
#pc-header .nav li .menu .menu-container.company ul li:hover img{
    /*transform: scale(1.1);
	transition-duration: 0.3s;*/
	border-radius: 15px;
}
#pc-header .nav li .menu .menu-container.company ul li a .txt{
    position: absolute;
    /*top: 50%;
    transform: translateY(-50%);*/
	top: auto;
	bottom: 20px;
    left: 20px;
	color: #fff;
	transition: all 0.3s ease;
}
#pc-header .nav li .menu .menu-container.company ul li a .txt {
    font-size: 1.8rem;
    font-weight: 600;
}
#pc-header .nav li .menu .menu-container.company  ul li a:hover .txt{
    bottom: 30px;
}

#pc-header .nav li .menu .menu-container.company ul li a .txt span{
    font-size: 1.4rem;
}
@media screen and (max-width: 768px){

	.header-fixed,
    .header-nofixed{
		min-width: 100%;
		position: absolute;
	}

	#header .header-area #pc-header {
		display: none;
	}

	/* スクロールメニュー */
	#header .header-area {
		padding: 10px;
        background: transparent;
        transition: none;
        align-items: center;
        height: auto;
	}
    #header.header-fixed.active .header-area{
        /*background-color: #fff;*/
		background: none;
		box-shadow: none;
    }
    #header .header-area .inner{
        display: unset;
        padding: 0;
        height: 100%;
    }
    #header .header-area .h-num {
        font-size: 1.0rem;
        font-weight: 500;
        width: 100%;
        line-height: 1;
        padding: 5px 0 0;
        display: inline-block;
    }

    #header.top-header .header-area .h-num {
        color: #fff;
    }

    #header.open .h-num  {
        color: #fff;
        position: fixed;
        top: 70px;
        display: none;
    }

    #header .h-logo {
        transition-property: background;
        transition-duration: 0s;
    }

    #header.open .h-logo {
        position: fixed;
        /* top: 0;
        left: 0;
        padding: 10px 15px; */
        /* background-color: #fff; */
        /* width: 100%;
        height: 55px; */
        transition-property: background;
        transition-duration: 1.2s;
    }

	#header.header-fixed.scroll-nav .header-area {
		/*margin: 9px 10px;*/
	}

	/* ロゴ */
	.header-area .h-logo {
		display: inline-block;
		max-width: 100%;
		/*width: initial;
		height: 48px;
        aspect-ratio: 500 / 151;*/
		float: none;
		padding: 0;
        z-index: 9999; /*SPメニューより前面*/
		height: 46px;
	}

	.header-area .h-logo a {
		display: block;
        height: 100%;
	}

	/* .header-area .h-logo a img {
		width: 167px;
	} */

	/*#header.header-fixed.scroll-nav .header-area .h-logo {
		height: 40px;
		padding: 0;
	}*/
    .header-area .h-logo a img{
		width: auto;
        height: 100%;
    }
}

/* -----------------------------------------------------------
        footer
-------------------------------------------------------------- */
#footer{
    position: relative;
    z-index: 3;
}

#footer .ft-contact-area {
    padding: 90px 0 60px;
    padding: 90px 0 157px;
    background-color: var(--navy);
    border-radius: 60px 60px 0 0;
    position: relative;
}
#footer .ft-contact-area::before{
    position: absolute;
    content: "";
    background-color: var(--white);
    width: 100%;
    height: 60px;
    top: 0px;
    left: 0;
    z-index: -1;
}
#footer .ft-contact-area .inner .info-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    color: var(--white);
}
#footer .ft-contact-area .inner .ft-txt-block{
    position: relative;
    padding: 0 110px 0 0;
    border-right: solid 2px var(--white);
}
#footer .ft-contact-area .inner .info-box .en{
    font-size: 4.0rem;
}
#footer .ft-contact-area .inner .ft-txt-block .txt{
    font-size: 1.8rem;
    margin: 15px 0 0;
}
#footer .ft-contact-area .cv-box{
    display: flex;
    align-items: end;
    gap: 70px;
}

/* 電話 */
#footer .ft-contact-area .tel-box{
    /* text-align: right; */
    color: #fff;
}
#footer .ft-contact-area .tel-box h3{
    font-size: 1.8rem;
    letter-spacing: 0.15em;
    font-weight: 500;
    line-height: 1;
    margin: 0 0 5px;
}
#footer .ft-contact-area .tel-box .tel a{
    font-family: var(--lato);
    font-size: 3.0rem;
    font-weight: bold;
    color: #fff;
    line-height: 1;
    letter-spacing: 0.05em;
}
#footer .ft-contact-area .tel-box .tel a i{
    font-size: 2.5rem;
    margin: 0 15px 0 0;
}
#footer .ft-contact-area .tel-box .txt{
    font-size: 1.2rem;
    /* letter-spacing: .1em; */
}

/* お問い合わせ */
#footer .ft-contact-area .cv-btn {
    width: 260px;
    height: 60px;
    align-content: center;
    padding: 0;
    overflow: hidden;
}
#footer .ft-contact-area .cv-btn a{
    width: 260px;
    height: 60px;
    font-size: 1.6rem;
    line-height: 60px;
    display: inline-block;
    color: #fff;
    border: solid 1px #fff;
    position: relative;
    text-align: center;
    transition: .5s;
}
#footer .ft-contact-area .cv-btn a::before{
    background: var(--white);
    border-radius: 50%;
    content: "";
    display: block;
    margin: auto;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    width: 100%;
    padding-top: 100%;
    height: 0;
    z-index: -1;
    transform: translateY(-50%) scale(0.1);
    transition: opacity .5s, transform 0s;
    transition-delay: 0s, .4s;
}
#footer .ft-contact-area .cv-btn a:hover{
    color: var(--navy) !important;
    z-index: 1;
}
#footer .ft-contact-area .cv-btn a:hover::before{
    opacity: 1;
    transform: translateY(-50%) scale(1.1);
    transition-delay: 0s;
    transition: opacity .8s, transform .6s ease-in-out;
}
#footer .ft-contact-area .cv-btn a i{
    margin: 0 10px 0 0;
}

/* 注意事項エリア */
#footer .ft-contact-area .notice-box{
    display: flex;
    color: var(--grayblue);
    margin: 95px  auto 0;
    gap: 30px;
}
#footer .ft-contact-area .notice-box div{
    width: calc((100% - 30px) /2 );
}
#footer .ft-contact-area .notice-box div .notice-list li{
    position: relative;
    padding: 0 0 0 15px;
    line-height: 1.4;
    margin: 0 0 5px;
    font-size: 1.4rem;
}
#footer .ft-contact-area .notice-box div .notice-list li::before{
    position: absolute;
    left: -3px;
    top: 0;
    content: '・';
}

/* 下段 */
#footer .img.parts img{
    width: 100%;
    height: auto;
}
#footer .ft-area {
    margin: -50px auto 0;
}
#footer .ft-area .inner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}
#footer .ft-l-area {
    display: inline-block;
    width: initial;
    text-align: center;

}
#footer .ft-l-area .logo {
    margin: 0 0 20px;
    width: 217px;
    height: 100px;
}
#footer .ft-l-area .logo a {
    width: 100%;
    display: inline-block;
}
#footer .ft-l-area .logo a img {
    vertical-align: middle;
    /* width: 100%; */
    height: 100px;
    object-fit: contain;
}
#footer .ft-l-area .add{
    font-size: 1.5rem;
}
#footer .ft-l-area .acc{
    margin: 15px 0 0;
}
#footer .ft-l-area .acc i{
    font-size: 1.6rem;
    color: var(--main-color);
}
i{
    margin: 0 8px 0 0;
}
#footer .ft-l-area .sns-list{
    display: flex;
    gap: 15px;
    justify-content: center;
    margin: 15px 0 0;
}
#footer .ft-l-area .sns-list img{
    width: 30px;
}
#footer .ft-r-area {
    display: flex;
    justify-content: space-between;
    gap: 0 50px;
}
#footer .ft-r-area .ft-sitemap-list.subonly{
    margin: 30px 0 0 -25px;
}
#footer .ft-r-area .ft-sitemap-list li a {
    display: block;
    font-size: 1.4rem;
    line-height: 1.7;
    padding: 5px 0;
    color: #666;
}
#footer .ft-r-area .ft-sitemap-list li.sub{
    padding: 0 0 0 20px;
    position: relative;
}
#footer .ft-r-area .ft-sitemap-list li.sub::before{
    position: absolute;
    content: "-";
    color: #666;
    top: 10px;
    top: 2px;
    left: 5px;
}

#footer .ft-copy-area {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 60px 0 60px;
}
#footer .ft-copy-area .ft-copy-r-area {
    display: inline-block;
}
#footer .ft-copy-area .ft-copy-l-area .copy {
    font-size: 1.2rem;
    color: #888;
}
#footer .ft-copy-area .ft-copy-r-area .privacy,
#footer .ft-copy-area .ft-copy-r-area .sitemap {
    font-size: 1.2rem;
    display: inline-block;
}
#footer .ft-copy-area .ft-copy-r-area .privacy a {
    padding-right: 10px;
}
#footer .ft-copy-area .ft-copy-r-area .sitemap a {
    padding-left: 10px;
}

#footer .ft-copy-area .ft-copy-r-area .privacy a,
#footer .ft-copy-area .ft-copy-r-area .sitemap a {
    color: #888;
}


@media screen and (max-width: 768px) {
    #footer .ft-contact-area .inner .info-box .en,
    #footer .ft-contact-area .inner .info-box .jp{
        justify-content: center;
    }

    #footer .ft-l-area {
        width: 100%;
        text-align: center;
    }

    #footer .ft-l-area .logo {
        margin: 0 0 20px;
        width: 100%;
        text-align: center;
    }

    #footer .ft-l-area .logo a {
        display: inline-block;
    }

    #footer .ft-l-area .logo a img {
        width: auto;
		height: 80px;
    }

    #footer .ft-l-area .sns {
        justify-content: center;
    }

    #footer .ft-r-area {
        display: none;
    }

    #footer .ft-copy-area .ft-copy-r-area {
        display: none;
    }

    #footer .ft-copy-area .ft-copy-l-area {
        text-align: center;
        width: 100%;
    }

    #footer .ft-copy-area {
        padding: 40px 0px 40px;
    }

    #footer .ft-contact-area {
        padding: 80px 20px 60px;
        min-height: initial;
		margin: 0;
    }
    #footer .ft-contact-area .inner{
        display: block;
    }
    #footer .ft-contact-area .inner .ft-txt-block{
        width: 100%;
        text-align: center;
        border-right: none;
        padding: 0;
    }
    #footer .ft-contact-area .inner .ft-txt-block .catch-en{
        font-size: 6.5rem;
        /* white-space: unset; */
        /* left: -20px; */
        left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    }
    #footer .ft-contact-area .ft-txt-block .ft-catch{
        margin: 0 0 15px;
    }
    #footer .ft-contact-area .cv-box{
        border-radius: 15px;
        background-color: #062950;
        padding: 40px 15px;
        width: 100%;
        margin: 40px auto 0;
        flex-wrap: wrap;
        gap: 30px;
    }
    #footer .ft-contact-area .tel-box{
        text-align: center;
        width: 100%;
    }
    #footer .ft-contact-area .tel-box h3{
        font-size: 1.6rem;
        margin: 0 0 15px;
    }
    #footer .ft-contact-area .tel-box .tel{
        margin: 0 0 5px;
    }
    #footer .ft-contact-area .cv-btn.line img {
        vertical-align: middle;
        width: 35px;
    }

    #footer .ft-contact-area .ft-catch {
        font-size: 1.8rem;
        margin: 0 0 30px;
    }

    #footer .ft-contact-area .ft-contact-list .ft-tel-catch {
        margin: 0 0 5px;
    }

    #footer .ft-contact-area .cv-btn {
        min-width: initial;
        width: 280px;
        margin: 0px auto 0;
        min-height: 60px;
    }
    #footer .ft-contact-area .cv-btn a{
        width: 280px;
    }
    #footer.partnership .ft-contact-area .cv-btn.partner,
    #footer.partnership .ft-contact-area .cv-btn.partner a{
        width: 280px;
    }
    #footer .ft-contact-area .ft-txt-block .ft-txt{
        letter-spacing: 0;
    }
    #footer .ft-contact-area .cv-btn.line {
        min-height: 66px;
    }

    /* #footer .ft-contact-area .cv-btn img {
        margin-right: 8px;
    } */

    #footer .ft-contact-area .ft-contact-list {
        gap: 20px;
    }

    #footer .ft-contact-area .ft-contact-list li {
        width: 100%;
    }

    #footer .ft-contact-area .ft-contact-list li.tel-block {
        margin: 0 0 20px;
    }

    #footer .ft-area {
        padding: 40px 0 0px;
        /* background: #fff; */
    }

    #footer .ft-l-area .num {
        color: #002B40;
    }

    #footer .ft-copy-area .ft-copy-l-area .copy {
        color: #424F56;
    }

    #footer .ft-contact-area .ft-contact-list .ft-tel-num {
        font-size: 3.2rem;
    }

    #footer .ft-contact-area .ft-contact-list .ft-tel-num .fa-phone {
        font-size: 2.2rem;
        margin: 0 0 5px;
    }

    #footer .ft-contact-area .notice-box{
        margin: 40px auto 0;
        flex-wrap: wrap;
    }
    #footer .ft-contact-area .notice-box div{
        width: 100%;
    }

}

/* -----------------------------------------------------------
        .pagetitle-area
-------------------------------------------------------------- */

/*.page-title-area {
	height: 400px;
    position: relative;
    background:  #F3F7FB;
	z-index: 3;
    background: radial-gradient(circle at 10%, #F3F7FB, #009FE8);
    border-bottom-left-radius: 100% 20%;
    border-bottom-right-radius: 100% 20%;
	background-size: 200% 200%;
	animation: bggradient 20s ease infinite;
}
@keyframes bggradient{
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}*/

.page-title-area{
	position: relative;
	z-index: 3;
	/*background: url("../img/blue-titlebg.png") #fff no-repeat left bottom / cover;*/
	width: 100%;
	height: 400px;
	/*aspect-ratio: 3200 / 450;
	-moz-animation: titlebg_loop 20s linear infinite;
	animation: titlebg_loop 20s linear infinite;*/
}
.page-title-area::after{
    position: absolute;
	top: 0;
	left: 0;
    content: "";
    background-color: rgba(255,255,255,.3);
    width: 100%;
    height: 100%;
	z-index: 1;
}
/*@keyframes titlebg_loop {
	0% {
		background-position: 0 0;
	}

	100% {
		background-position: -2844px 0;
	}
}*/

.page-title-area.bg-none {
    background: none;
}

.page-title-area video{
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center center;
    /*border-bottom-left-radius: 100% 20%;
    border-bottom-right-radius: 100% 20%;*/
	border-radius: 0 0 80px 80px;
}
.page-title-area.type02{
    height: 300px;
}
/* .page-title-area::after {
	content: "";
	display: inline-block;
	background-position: top;
	background-repeat: no-repeat;
	background-size: cover;
	width: 50%;
	min-width: 800px;
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	z-index: -1;
} */


.page-title-area .inner {
    height: 100%;
    /*position: relative;*/
}
/* .page-title-area .inner::before{
    position: absolute;
    content: "";
    background-image: url(../img/bg-logo-wht.png);
    background-size: cover;
	background-position: left center;
    width: 770px;
    height: 620px;
    left: 0px;
    z-index: -1;
} */
.page-title-area.type02 .inner::before{
    width: 550px;
    height: 300px;
    right: 160px;
    left: auto;
}
.page-title-area .section-title {
    font-weight: bold;
    line-height: 1.5;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.page-title-area .section-title .en {
    font-family: var(--opensans);
    display: block;
	font-size: 7.0rem;
	font-weight: 400;
    color: var(--darkgray);
}

.page-title-area .section-title .ja {
    display: block;
    font-size: 2.0rem;
	margin-top: 20px;
	position: relative;
	color: var(--darkgray);
}


.page-title-area .section-title .cate-l-name,
.page-title-area .section-title .cate-m-name{
    display: inline-block;
    padding: 5px 8px;
    font-size: 1.5rem;
    font-weight: bold;
    /*background-color: var(--blue-bg);*/
    color: var(--blue-bg);
    border: 1px solid var(--blue-bg);
    margin: 0 0 15px;
}

.page-title-area .section-title .cate-l {
    margin-right: 10px;
}


/*title-video*/
.title-movie{
	width: 100%;
	position: absolute;
	top: 0;
	z-index: 1;
	background: #fff;
}
.title-movie video{
    height: 600px;
    width: 100%;
    object-fit: cover;
    object-position: center bottom;
	opacity: .4;
}
.title-movie-index{
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 768px) {

    .page-title-area .inner::before{
        display: none;
    }
	.page-title-area.type02 .inner::before{
		width: 200px;
		height: 200px;
		right: 0;
		left: auto;
		top: -30px;
		display: block;
	}

    .page-title-area.type02{
        margin: 55px 0 0;
        padding: 40px 20px;
		min-height: 130px;
		height: auto;
    }
    .page-title-area.type02 .section-title{
        top: auto;
        left: auto;
		background: none;
		padding: 0;
    }

	.page-title-area::after {
		width: 100%;
		height: 100%;
		min-width: initial;
	}

	#saikouchiku .page-title-area::after {
		background-image: url("../img/pagetitle-saikouchiku.jpg");
	}

    .page-title-area .section-title {
        line-height: 1.5;
        left: 0px;
        top: 140px;
        background-color: #fff;
        padding: 15px 20px;
    }

    .page-title-area .section-title .en {
        font-size: 2.8rem;
		text-shadow: 0 0 3px var(--rightblue), 0 0 6px var(--rightblue), 0 0 9px var(--rightblue), 0 0 12px var(--rightblue);
    }

    .page-title-area .section-title .en.long {
        font-size: 2.7rem;
    }

    .page-title-area .section-title .ja {
        display: block;
        font-size: 1.4rem;
		margin-top: 10px;
		font-weight: 500;
		text-shadow: 0 0 3px var(--rightblue), 0 0 6px var(--rightblue), 0 0 9px var(--rightblue), 0 0 12px var(--rightblue);
    }
    .page-title-area .section-title .ja::before{
        top: 0px;
    }
	
	
	/*title-video*/
	.title-movie{
		top: 0;
		right: 0;
		width: 130%;
	}
	.title-movie video{
		height: 230px;
		opacity: .6;
		object-position: right bottom;
	}

}


/* -----------------------------------------------------------
        ttl
-------------------------------------------------------------- */

/*共通*/
.en{
    font-family: var(--font-en);
    font-size: 4.4rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    margin: 0 0 5px;
    display: flex;
}
.jp{
    font-size: 1.8rem;
    font-family: var(--font-jp);
    font-weight: bold;
    line-height: 1.2;
    letter-spacing: 0.05em;
    position: relative;
    display: flex;
}
.catch{
    font-size: 3.6rem;
    line-height: 1.5;
    font-weight: 500;
    letter-spacing: 0.05em;
}
p.img{
    line-height: 1;
}

/*L*/
.ttl-l{
    margin: 0 0 30px;
}
.ttl-l .en {
	font-size: 10.0rem;
	padding: 0 0 20px;
}


/*M*/
.ttl-m .en {
	font-size: 5.6rem;
	line-height: 1.1;
}


/*S*/
.ttl-s{
    margin: 0 0 20px;
}
.ttl-s .en {
	font-size: 3.0rem;
	line-height: 1.2;
}


@media screen and (max-width: 768px) {
	
	/*共通*/
	.en{
		font-size: 4rem;
	}
	
    .en-ttl{
        font-size: 4.0rem;
    }

    .catch{
        font-size: 2.4rem;
        font-weight: 500;
    }
    /* p.img img{
        width: 100%;
    } */
	/*L*/
	.ttl-l .en {
		font-size: 5.2rem;
		padding: 0 0 10px;
	}

	.page-title-area .ttl-l .en {
		font-size: 5.4rem;
	}

	.ttl-l .jp {
		font-size: 1.6rem;
	}

	/*M*/
	.ttl-m .en {
		font-size: 4rem;
	}

	.ttl-m .jp {
		font-size: 1.4rem;
	}

	/*S*/
	.ttl-s .en {
		font-size: 3rem;
	}

	.ttl-s .jp {
		font-size: 1.4rem;
	}
}

/* -----------------------------------------------------------
        FontAwesome
-------------------------------------------------------------- */

a::after,
a::before,
::after,
::before {
	font-family: "Font Awesome 6 Free";
	font-style: normal;
	font-weight: 900;
}

a::after,
a::before{
	display: block;
	position: absolute;
	line-height: 1;
}

/* -----------------------------------------------------------
        アコーディオン
-------------------------------------------------------------- */

.accordion-more{
	display: none;
}

.accordion-btn{
	display: block;
	width: 280px;
	height: 65px;
	line-height: 65px;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	position: relative;
	text-align: center;
	color: #333;
	border: 1px solid #333;
	cursor: pointer;
	-webkit-transition: 0.5s;
    transition: 0.5s;
}

.accordion-btn::after {
	content: '\f054';
	font-family: 'Font Awesome 5 Free';
	font-weight: bold;
	font-size: 1rem;
	position: absolute;
	right: 20px;
}
.accordion-btn:hover {
	background: #BC9E62;
	opacity: 1;
}
.accordion-btn::after:hover {
	content: '\f054';
}

.accordion-icon{
	display: block;
	position: absolute;
	right: 15px;
	top: 50%;
    transform: translateY(-50%);
    /*-webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);*/
	width: 40px;
	height: 40px;
	margin: 0 0 0 auto;
}
.accordion-icon span {
	width: 50%;
	position: absolute;
	left: 5px;
	height: 2px;
	background-color: var(--main-color);
	border-radius: 0;
	transition: all .4s;
	box-sizing: border-box;
}
.accordion-icon span:nth-of-type(1) {
	top: 20px;
	-webkit-transform: rotate(0deg);
	transform: rotate(0deg);
}
.active .accordion-icon span:nth-of-type(1){
	display: none;
}
.accordion-icon span:nth-of-type(2) {
	top: 20px;
	-webkit-transform: rotate(90deg);
	transform: rotate(90deg);
}
.active .accordion-icon span:nth-of-type(2){
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}


@media screen and (max-width: 768px){

	.accordion-btn{
		display: block;
		padding: 15px 15px;
		margin: 20px auto 0 auto;
	}

	.accordion-icon{
		width: 24px;
		height: 24px;
	}

	.accordion-icon span:nth-of-type(1) {
		top: 12px;
	}
	.accordion-icon span:nth-of-type(2) {
		top: 12px;
	}

}

/* -----------------------------------------------------------
        .sp-scroll-wrap
-------------------------------------------------------------- */
.sp-scroll-wrap {
    display: contents;
}

@media screen and (max-width: 768px){
.sp-scroll-wrap {
    display: block;
    width: 100%;
    overflow-x: scroll;
    overflow-y: hidden;
    padding-bottom: 20px;
}
}

/* -----------------------------------------------------------
        .img-animation
-------------------------------------------------------------- */
.img-wrap {
    overflow: hidden;
    position: relative;
}

.tb-area.img-wrap {
    /*overflow: initial;*/
    overflow: inherit;
}

.img-animation {
    animation: img-opacity 1.5s cubic-bezier(.7, 0, .2, 1);
}

.img-animation:before {
    animation: img-animation 1.5s cubic-bezier(.7, 0, .2, 1) forwards;
    background: var(--main-color);
    bottom: 0;
    content: '';
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 3;
}

@keyframes img-opacity {
	0% {
		opacity: 0;
	}
}

@keyframes img-animation {
	100% {
		transform: translatex(100%);
	}
}


/* hover 背景 */
.hover-bg{
    position: relative;
}
.hover-bg::before{
	position: absolute;
	content: "";
	width: 0;
	height: 100%;
	top: 0;
	right: 0;
	z-index: 0;
	transition: all 0.4s ease;
	/* background: #003988; */
    background: var(--main-color);
}
.hover-bg:hover::before{
    left: 0;
	width: 100%;
}

/* -----------------------------------------------------------
    ラインアニメーション
-------------------------------------------------------------- */

span.ani-line {
    /*background-image: linear-gradient(to right, #FCF192 0%, #FCF192 50%, transparent 50%);*/
    background-image: linear-gradient(to right, #FFC1C1 0%, #FFC1C1 50%, transparent 50%);
    background-repeat: no-repeat;
    background-position: 100% 100%;
	background-size: 200% 10px;
	margin: 0 2px 0 0;
	padding: 0 0 0 2px;
	transition: background-position 3s;
    /*
	letter-spacing: 0.025!important;
    */
}
span.ani-line.s-txt {
	font-weight: 500!important;
	background-size: 200% 5px;
}
span.ani-line.is-animation{
	background-position: 0% 90%;
}

span.ani-line.about-col.col01 {
    background-image: linear-gradient(to right, #FCE0CF 0%, #FCE0CF 50%, transparent 50%);
}



@media screen and (max-width: 767px) {
	span.ani-line {
		background-size: 200% 8px;
	}
}

/* -----------------------------
    テーブル(デフォルト)
-------------------------------- */
.table {
	border-top: #ccc solid 1px;
    border-collapse: collapse;
    box-sizing: border-box;
	margin: 0px auto;
    width: 100%;
}

.table tr {
	border-bottom: #ccc solid 1px;
}

.table tr th {
	line-height: 1.5;
	padding: 30px 0 25px 65px;
	text-align: left;
	vertical-align: top;
    width: 300px;
}

.table tr td {
	line-height: 1.5;
	padding: 30px 0 25px 65px;
}


.table tr td ul li {
	line-height: 1.5;
	font-size: 1.6rem;
	padding: 0 0 5px;
}

.table tr td .att {
	font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
    .table {
        border: none;
        width: 100%;
    }

    .table tr {
        border-bottom: none;
    }

    .table tr th {
        background: var(--main-color);
        color: #fff;
        display: block;
        padding: 5px 10px 3px;
        width: 100%;
    }

    .table tr td {
        display: block;
        padding: 10px 0 12px;
        width: 100%;
    }

    .table tr td ul li {
        font-size: 1.5rem;
    }
}
/* -----------------------------
    テーブル(小)
-------------------------------- */
.table.small-type{
    border-left: solid 1px #ccc;
}
.table.small-type tr th{
    padding: 10px 0;
    text-align: center;
    border-right: solid 1px #ccc ;
    background-color: #F3F7FB;
}
.table.small-type tr td{
    padding: 10px 0;
    text-align: center;
    border-right: solid 1px #ccc;
}
/* -----------------------------
    活動報告
-------------------------------- */
.report-area{
    margin: 0 auto;
    padding: 120px 0 125px;
    background-color: var(--pastelblue);
    position: relative;
}
.report-area .top-box{
    margin: 0 0 60px;
    text-align: center;
}
.report-area .catch{
    margin: 0 0 30px;
}
.report-area .top-box video{
    width: 100%;
    margin: 30px 0 0;
    display: none;
}
.report-area .grid-box{
    display: flex;
    gap: 30px;
}
#top .report-area .grid-box{
    flex-wrap: wrap;
    width: calc(100% - 50px);
    margin: 0 auto;
}
.report-area .article-box{
    text-align: center;
    margin: 0 30px 0 0;
}
#top .report-area .article-box{
    width: calc((100% - 90px) / 4);
}
.report-area .article-box{
    width: 340px;
}
#top .report-area .article-box{
    margin: 0;
}
.report-area .article-box a{
    display: block;
    width: 100%;
    height: 100%;
}
.report-area .article-box .img{
    /* min-height: 340px; */
    aspect-ratio: 1 / 1;
}
.report-area .article-box img{
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    /* min-height: 340px; */
    object-fit: cover;
	transition-duration: 0.3s;
}
.report-area .article-box:hover img{
    transform: scale(1.1);
	transition-duration: 0.3s;
}
.report-area .article-box .txt-box{
    padding: 15px 20px 0;
    font-weight: 400 !important;
}
.report-area .article-box .txt-box .cate,
.report-area .article-box .txt-box .date{
    font-size: 1.2rem;
}
.report-area .article-box .txt-box .article-title{
    white-space: normal;
}
.report-area .article-box .txt-box .article-ttl{
    font-weight: 400;
}
.report-area .btn-area{
    margin: 90px auto 0;
}
.report-area .top-box video{
    width: 100%;
    margin: 30px 0 0;
    display: block;
}
.report-area .top-box iframe{
    width: 1200px;
    height: 540px;
    height: 650px;
    margin: 30px 0 0;
}
@media screen and (max-width: 767px) {
    .report-area{
        padding: 40px 0 90px;
    }
    .report-area .top-box{
        padding: 0 20px;
        margin: 0 0 50px;
    }
    .report-area .top-box{
        margin: 0px auto 0;
    }
    .report-area .catch{
        font-size: 2.0rem;
        font-weight: bold;
        /* margin: 0 0 50px; */
    }
    .report-area .txt{
        text-align: left;
        margin: 0 0 30px;
    }
    #top .report-area .scroll-wrap{
        overflow-x: scroll;
        white-space: nowrap;
    }
    .report-area .grid-box{
        flex-wrap: nowrap !important;
        width: 100%;
        gap: 20px;
    }
    .report-area .article-box{
        /* width: 340px; */
        min-width: 327px;
        margin: 0;
    }
    .report-area .article-box .txt-box{
        padding: 10px 20px 20px;
    }
    .report-area .btn-area{
        margin: 20px auto 0;
    }
    .report-area .top-box video{
        margin: 30px auto ;
    }
    .report-area .top-box iframe{
        width: 100%;
        height: 280px;
        margin: 0 0 30px;
    }
}
/* -----------------------------
    サービス導線
-------------------------------- */
.ser-link-area{
    background-color: var(--main-color);
    padding: 100px 0 120px;
    position: relative;
    /* margin: 0 0 150px; */
}
.ser-link-area::after{
    position: absolute;
    content: "";
    width: 100%;
    height: 210px;
    background-color: #00000000;
    background-color:var(--main-color);
    bottom: 0;
    z-index: 0;
}
.ser-link-area .inner{
    display: flex;
    justify-content: space-between;
}
.ser-link-area .catch-box{
    width: 700px;
}
.ser-link-area .section-title,
.ser-link-area .catch-box .catch,
.ser-link-area .catch-box .txt{
    color: #fff;
}
.ser-link-area .inner .catch{
    margin: 0 0 25px;
}
.ser-link-area .ser-list{
    display: flex;
    flex-wrap: wrap;
    margin: 50px auto 0;
}
.ser-link-area .ser-list .ser-item{
    width: calc(100% / 4);
   background-color: #fff;
   position: relative;
   z-index: 1;
}
.ser-link-area .ser-list .ser-item::after{
    position: absolute;
    content: "\f061";
    font-family: "Font Awesome 6 Free";
    right: 10px;
    bottom: 10px;
    color: var(--bgc);
    z-index: 1;
}
.ser-link-area .ser-list .ser-item:hover::after{
    color: var(--white);
}
/* .ser-link-area .ser-list .ser-item::after{
    position: absolute;
		content: "";
		top: 100px;
		right: 0;
		left: -20px;
		bottom: auto;
		margin: auto;
		display: block;
		background-color: var(--bgc);
		z-index: 0;
		mix-blend-mode: color;
		width: calc(100% + 600px);
		height: calc(100% - 60px);
		border-radius: 8px;
		transform: translate(-25%, 25%);
		transition: opacity 0.4s cubic-bezier(.65,.05,.36,1);
		opacity: 0.5;
		filter: blur(128px);
		border-radius: 100%;
} */
.ser-link-area .ser-list .ser-item a{
    position: relative;
    padding: 40px 20px 30px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	background-color: rgba(255,255,255,1);
	overflow: hidden;
}
.ser-link-area .ser-list .ser-item{
    border-right: solid 1px #009fe7;
    border-bottom: solid 1px #009fe7;
}
.ser-link-area .ser-list .ser-item:nth-child(4n){
    border-right: none;
}
.ser-link-area .ser-list .ser-item:nth-child(n + 5){
    border-bottom: none;
}
.ser-link-area .ser-list .ser-item a{
    display: block;
    width: 100%;
    height: 100%;
}
.ser-link-area .ser-list .ser-item a .img{
    text-align: center;
    margin: 0 auto 10px;
}
.ser-link-area .ser-list .ser-item a .img img{
    width: 170px;
}
.ser-link-area .ser-list .ser-item a .ser-ttl{
    text-align: center;
    font-size: 2.0rem;
    font-weight: bold;
}
.ser-link-area .ser-list .ser-item a .ser-ttl.en{
    font-size: 1.2rem;
    justify-content: center;
    color: var(--bgc);
}
.ser-link-area .ser-list .ser-item a .ser-catch{
    font-size: 2.0rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.5;
    margin: 24px auto;
}

.mainContents__hoverelm {
    position: absolute;
    inset: 0 -100%;
    display: block;
    width: calc(800.3280038511986 * 1px);
    height: calc(800.3280038511986 * 1px);
    margin: auto;
    z-index: 1;
    mix-blend-mode: multiply;
}

.mainContents__hoverelm::before,
.mainContents__hoverelm::after {
    position: absolute;
    inset: 0;
    margin: auto;
    display: block;
    background-color: var(--bgc);
    width: 0;
    height: 0;
    border-radius: 100%;
    transition: 0.4s cubic-bezier(.77,0,.18,1);
    transition-property: opacity, translate, width, height;
    z-index: 2;
    opacity: 0;
    content: "";
}

.ser-item:hover .mainContents__hoverelm::before,
.ser-item:hover .mainContents__hoverelm::after {
    width: calc(800.3280038511986 * 1px);
    height: calc(800.3280038511986 * 1px);
    transition-duration: 0.4s;
    transition-timing-function: cubic-bezier(.19,1,.22,1);
    translate: 0 0;
}

.ser-item:hover .mainContents__hoverelm::before {
    opacity: 0.5;
}

.ser-item:hover .mainContents__hoverelm::after {
    opacity: 0.8;
    transition-duration: 0.8s;
    transition-delay: 0.2s;
}
.ser-item:hover .img{
    position: relative;
    z-index: 5;
}
/* .ser-item:hover .img::before{
    background-color: #fff;
		transition-delay: 0.4s;
} */
/* .ser-item.ambulatory{
    --bgc: #77bd31;
}
.ser-item.hospitalization{
    --bgc: #6fbdde;
}
.ser-item.check-up{
    --bgc: #a799fc;
}
.ser-item.rehabilitation{
    --bgc: #fb8c96;
}
.ser-item.service{
    --bgc: #fba64a;
} */


.ser-item.lecture{
    --bgc: #009FE8;
}
.ser-item.csr{
    --bgc: #89CC13;
}
.ser-item.future{
    --bgc: #E72A62;
}
.ser-item.healthtable365{
    --bgc: #F0D700;
}
.ser-item.lectrictherapy{
    --bgc: #1558A7;
}
.ser-item.cosmolab{
    --bgc: #E96C29;
}
.ser-item.bodyful{
    --bgc: #3FBF8E;
}
.ser-item.project{
    --bgc: #a799fc;
}
.ser-item.yobo{
    --bgc: #15a764;
}

.ser-link-area .btn-area{
    margin: 50px auto 0;
    position: relative;
    z-index: 1;
}
@media screen and (max-width: 767px) {
    .ser-link-area{
        padding: 100px 20px;
        padding: 60px 20px;
    }
    .ser-link-area .inner{
        display: block;
    }
    .ser-link-area .catch-box{
        width: 100%;
    }
    .ser-link-area .inner .catch{
        margin: 25px 0 ;
    }
    .ser-link-area .ser-list{
        gap: 20px;
    }
    .ser-link-area .ser-list .ser-item{
        width: 100%;
        border: none;
    }
    .ser-link-area .ser-list .ser-item a{
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 20px 15px;
    }
    .ser-link-area .ser-list .ser-item a .img{
        margin: 0;
    }
    .ser-link-area .ser-list .ser-item a .img img{
        width: 110px;
    }
    .ser-link-area .ser-list .ser-item a .txt-box{
        width: calc(100% - 130px);
    }
    .ser-link-area .ser-list .ser-item a .ser-ttl{
        text-align: left;
        line-height: 1.3;
        margin: 0 0 5px;
    }
    .ser-link-area .ser-list .ser-item a .ser-ttl.en{
        margin: 0 0 10px;
        justify-content: flex-start;
    }
    .ser-link-area .ser-list .ser-item a .ser-catch{
        font-size: 1.4rem;
        font-weight: 500;
        text-align: left;
        margin: 0;
    }
}
/* -----------------------------
	report-area
-------------------------------- */
.slide-box{
    position: relative;
    padding: 150px 0 0;
    background-color: var(--white);
}
.slide-box .slick{
    position: relative;
    z-index: 1;
    height: 615px;
    width: 100%;
}

.slick-item.img01{
    background: url(../img/report-slide01.png);
}
.slick-item.img02{
    background: url(../img/report-slide02.png);
}
.slick-item.img03{
    background: url(../img/report-slide03.png);
}
.slick-item{
    width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
    height:100%;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
    min-height: 615px !important;
    background-repeat: no-repeat;/*背景画像をリピートしない*/
    background-position: top !important;/*背景画像の位置を中央に*/
    background-size: cover !important;/*背景画像が.slider-item全体を覆い表示*/
}
.slide-box .slick-dots{
    bottom: 5px;
}
.slick-dotted.slick-slider{
    margin: 0 !important;
}
.en-ttl.big{
    font-family: var(--font-en);
    color: #fff;
    font-size: 12.0rem !important;
    font-weight: 500;
    position: absolute;
    /* bottom: 0; */
    z-index: 1;
    right: 0;
    left: 0;
    text-align: center;
    margin: auto;
    line-height: 1;
    bottom: 40px;
    opacity: 70%;
    /* transform: translateY(-50%); */
}

@media screen and (max-width: 767px) {
    .slide-box{
        padding: 0px 0 0;
    }
    .slide-box .slick{
        height: 250px;
    }
    .slick-item{
        min-height: 250px !important;
    }
    .en-ttl.big{
        font-size: 4.0rem !important;
        opacity: 100%;
        letter-spacing: 0.1em;
        line-height: 1.2;
    }
    .slick-item.img01{
        background: url(../img/report-slide01-sp.png);
    }
    .slick-item.img02{
        background: url(../img/report-slide02-sp.png);
    }
    .slick-item.img03{
        background: url(../img/report-slide03-sp.png);
    }
}
/* -----------------------------
    見出しタイトル
-------------------------------- */
.page-ttl-box{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
}
.page-ttl-box .ttl-en{
    font-size: 7rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.2;
    display: flex;
}
.page-ttl-box .ttl-jp{
    font-size: 2.0rem;
    letter-spacing: 0.1em;
    line-height: 1;
    /* margin: 10px 0 0; */
    display: flex;
}
.sec-ttl-box .ttl-en{
    /*font-size: 8.4rem;*/
	font-size: 6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1;
    display: flex;
    margin: 0 0 10px;
}
.sec-ttl-box .ttl-jp{
    font-size: 2.0rem;
    letter-spacing: 0.1em;
    line-height: 1;
    /* margin: 10px 0 0; */
    display: flex;
}
/* 点滅と下から出てくる*/
.blink,
.blink-wh,
.blink-mv{
	position: relative;
	overflow: hidden;
}
.blink span,
.blink-wh span{
	transform: translateY(110%); /*下（範囲外）に隠しておく*/
	display: block; /*ブロック要素に変更*/
}

/* .blink.active{
	opacity: 1;
	overflow: hidden;
} */
.blink-wh{
	position: relative;
	overflow: hidden;
}
.blink.active span{
	/* animation: blinking 1s ease-in-out infinite alternate; */
	/* transition: opacity 0.8s cubic-bezier(0.26, 0.06, 0, 1),transform 1.2s cubic-bezier(0.36, 0.14, 0, 1);
	transform: rotate(0deg) translate(0, 0%); */
	transform: translateY(110%); /*下（範囲外）に隠しておく*/
	animation: blinking 3.8s both cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite,
				.8s updown-anim cubic-bezier(.9,0,.1,1) forwards;
	/* animation-name: blinking;
	animation-duration: 3.8s;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
	animation-iteration-count: infinite; */
}

.blink-mv span{
	transform: translateY(110%); /*下（範囲外）に隠しておく*/
	animation: blinking-gray 3.8s both cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite,
				.8s updown-anim cubic-bezier(.9,0,.1,1) forwards;
}

.blink-wh.active span{

	/* animation: blinking 1s ease-in-out infinite alternate; */
	/* transition: opacity 0.8s cubic-bezier(0.26, 0.06, 0, 1),transform 1.2s cubic-bezier(0.36, 0.14, 0, 1);
	transform: rotate(0deg) translate(0, 0%); */
	transform: translateY(110%);
	animation: blinking-wh 3.8s both cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite,
				.8s updown-anim cubic-bezier(.9,0,.1,1) forwards;
	/* animation-name: blinking-wh;
	animation-duration: 3.8s;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
	animation-iteration-count: infinite; */
}

@keyframes blinking {
	/* 0% {opacity: 0;}
	100% {opacity: 1;} */
	0% {
        color: #333
    }

    12.5% {
        color: var(--sub-color)
    }

    25% {
        color: #333
    }

    100% {
        color: #333
    }
}
@keyframes blinking-wh {
	/* 0% {opacity: 0;}
	100% {opacity: 1;} */
	0% {
        color: #fff
    }

    12.5% {
        color: var(--sub-color)
    }

    25% {
        color: #fff
    }

    100% {
        color: #fff
    }
}
@keyframes blinking-gray {
	/* 0% {opacity: 0;}
	100% {opacity: 1;} */
	0% {
        /*color: var(--darkgray)*/
		color: #444;
    }

    12.5% {
        color: var(--sub-color)
    }

    25% {
        /*color: var(--darkgray)*/
		color: #444;
    }

    100% {
        /*color: var(--darkgray)*/
		color: #444;
    }
}
@keyframes updown-anim{
	0%{
		transform: translateY(110%); /*表示範囲外から*/
	}
	100%{
		transform: translateY(0); /*通常の位置へ*/
	}
}

.blink span:nth-child(1),
.blink-wh span:nth-child(1),
.blink-mv span:nth-child(1){
	transition-delay: 0ms;
	animation-delay: 300ms;
}
.blink span:nth-child(2),
.blink-wh span:nth-child(2),
.blink-mv span:nth-child(2){
	transition-delay: 80ms;
	animation-delay: 340ms;
}
.blink span:nth-child(3),
.blink-wh span:nth-child(3),
.blink-mv span:nth-child(3){
	transition-delay: 160ms;
	animation-delay: 380ms;
}
.blink span:nth-child(4),
.blink-wh span:nth-child(4),
.blink-mv span:nth-child(4){
	transition-delay: 240ms;
	animation-delay: 420ms;
}
.blink span:nth-child(5),
.blink-wh span:nth-child(5),
.blink-mv span:nth-child(5){
	transition-delay: 320ms;
	animation-delay: 460ms;
}
.blink span:nth-child(6),
.blink-wh span:nth-child(6),
.blink-mv span:nth-child(6){
	transition-delay: 400ms;
	animation-delay: 520ms;
}
.blink span:nth-child(7),
.blink-wh span:nth-child(7),
.blink-mv span:nth-child(7){
	transition-delay: 480ms;
	animation-delay: 560ms;
}
.blink span:nth-child(8),
.blink-wh span:nth-child(8),
.blink-mv span:nth-child(8){
	transition-delay: 560ms;
	animation-delay: 620ms;
}
.blink span:nth-child(9),
.blink-wh span:nth-child(9),
.blink-mv span:nth-child(9){
	transition-delay: 640ms;
	animation-delay: 660ms;
}
.blink span:nth-child(10),
.blink-wh span:nth-child(10),
.blink-mv span:nth-child(10){
	transition-delay: 720ms;
	animation-delay: 700ms;
}
.blink span:nth-child(11),
.blink-wh span:nth-child(11),
.blink-mv span:nth-child(11){
	transition-delay: 800ms;
	animation-delay: 740ms;
}
.blink span:nth-child(12),
.blink-wh span:nth-child(12),
.blink-mv span:nth-child(12){
	transition-delay: 880ms;
	animation-delay: 780ms;
}
.blink span:nth-child(13),
.blink-wh span:nth-child(13),
.blink-mv span:nth-child(13){
	transition-delay: 960ms;
	animation-delay: 820ms;
}
.blink span:nth-child(14),
.blink-wh span:nth-child(14),
.blink-mv span:nth-child(14){
	transition-delay: 1040ms;
	animation-delay: 860ms;
}
.blink span:nth-child(15),
.blink-wh span:nth-child(15),
.blink-mv span:nth-child(15){
	transition-delay: 1120ms;
	animation-delay: 900ms;
}
.blink span:nth-child(16),
.blink-wh span:nth-child(16),
.blink-mv span:nth-child(16){
	transition-delay: 1200ms;
	animation-delay: 940ms;
}

.blink span:nth-child(17),
.blink-wh span:nth-child(17),
.blink-mv span:nth-child(17){
	transition-delay: 1280ms;
	animation-delay: 980ms;
}
.blink span:nth-child(18),
.blink-wh span:nth-child(18),
.blink-mv span:nth-child(18){
	transition-delay: 1360ms;
	animation-delay: 1020ms;
}
.blink span:nth-child(19),
.blink-wh span:nth-child(19),
.blink-mv span:nth-child(19){
	transition-delay: 1440ms;
	animation-delay: 1060ms;
}
.blink span:nth-child(20),
.blink-wh span:nth-child(20),
.blink-mv span:nth-child(20){
	transition-delay: 1520ms;
	animation-delay: 1100ms;
}
.blink span:nth-child(21),
.blink-wh span:nth-child(21),
.blink-mv span:nth-child(21){
	transition-delay: 1600ms;
	animation-delay: 1140ms;
}
.blink span:nth-child(22),
.blink-wh span:nth-child(22),
.blink-mv span:nth-child(22){
	transition-delay: 1680ms;
	animation-delay: 1180ms;
}
@media screen and (max-width: 767px) {
    .page-title-area{
        width: 100%;
        height: auto;
        min-height: auto;
        padding: 70px 20px 20px;
        padding: 60px 20px 60px;
        margin: 0;
		border-radius: 0 0 40px 40px;
		background: url("../img/blue-titlebg-sp.png") no-repeat left bottom / cover;
    }
    .page-title-area .page-ttl-box{
        position: relative;
        margin: 0px 0 0;
        top: auto;
        transform: none;
    }
    .page-title-area video{
        position: absolute !important;
        top: 0px;
        left: 0;
		border-radius: 0 0 40px 40px;
    }
    .page-ttl-box .ttl-en{
        font-size: 3.6rem;
		text-align: center;
		display: block;
    }
    .overview .page-ttl-box .ttl-en,
    .lecture .page-ttl-box .ttl-en,
    .futurestrategy .page-ttl-box .ttl-en,
    .healthtable .page-ttl-box .ttl-en,
    .project .page-ttl-box .ttl-en,
	.yobo .page-ttl-box .ttl-en{
        font-size: 3.0rem;
    }
    .page-ttl-box .ttl-jp{
        font-size: 1.6rem;
		text-align: center;
		display: block;
		font-weight: 500;
		margin: 5px 0 0;
    }

    .sec-ttl-box .ttl-en{
        font-size: 4rem;
    }
    .sec-ttl-box .ttl-jp{
        font-size: 1.6rem;
    }
	
}
/* -----------------------------------------------------------
    下から登場するアニメーション
-------------------------------------------------------------- */
@keyframes updown-anim{
	0%{
		transform: translateY(110%); /*表示範囲外から*/
	}
	100%{
		transform: translateY(0); /*通常の位置へ*/
	}
}

/*** アニメーションさせる要素 ***/
.updown,
.updown-mv{
	display: flex;
	overflow: hidden;
}
.updown span{
	transform: translateY(110%); /*下（範囲外）に隠しておく*/
	display: block; /*ブロック要素に変更*/
}

/*** スクロールで画面に入った場合 ***/
.updown.active span{
	animation: .8s updown-anim cubic-bezier(.9,0,.1,1) forwards; /*一度だけのアニメーション（終了時点で固定）*/
}

/*** 各文字のアニメーション遅延時間 ***/
.updown span:nth-child(1),
.updown-mv span:nth-child(1){
	animation-delay: 0s;
}
.updown span:nth-child(2),
.updown-mv span:nth-child(2){
	animation-delay: 0.05s;
}
.updown span:nth-child(3),
.updown-mv span:nth-child(3){
	animation-delay: 0.1s;
}
.updown span:nth-child(4),
.updown-mv span:nth-child(4){
	animation-delay: 0.15s;
}
.updown span:nth-child(5),
.updown-mv span:nth-child(5){
	animation-delay: 0.2s;
}
.updown span:nth-child(6),
.updown-mv span:nth-child(6){
	animation-delay: 0.25s;
}
.updown span:nth-child(7),
.updown-mv span:nth-child(7){
	animation-delay: 0.3s;
}
.updown span:nth-child(8),
.updown-mv span:nth-child(8) {
	animation-delay: 0.35s;
}
.updown span:nth-child(9),
.updown-mv span:nth-child(9) {
	animation-delay: 0.4s;
}
.updown span:nth-child(10),
.updown-mv span:nth-child(10) {
	animation-delay: 0.45s;
}
.updown span:nth-child(11),
.updown-mv span:nth-child(11) {
	animation-delay: 0.5s;
}
.updown span:nth-child(12),
.updown-mv span:nth-child(12) {
	animation-delay: 0.55s;
}
.updown span:nth-child(13),
.updown-mv span:nth-child(13) {
	animation-delay: 0.6s;
}
.updown span:nth-child(14),
.updown-mv span:nth-child(14) {
	animation-delay: 0.65s;
}
.updown span:nth-child(15),
.updown-mv span:nth-child(15) {
	animation-delay: 0.7s;
}
.updown span:nth-child(16),
.updown-mv span:nth-child(16) {
	animation-delay: 0.75s;
}

.updown-mv span{

	/* animation: blinking 1s ease-in-out infinite alternate; */
	/* transition: opacity 0.8s cubic-bezier(0.26, 0.06, 0, 1),transform 1.2s cubic-bezier(0.36, 0.14, 0, 1);
	transform: rotate(0deg) translate(0, 0%); */
	transform: translateY(110%);
	animation: blinking 3.8s both cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite,
				.8s updown-anim cubic-bezier(.9,0,.1,1) forwards;
	/* animation-name: blinking-wh;
	animation-duration: 3.8s;
	animation-fill-mode: both;
	animation-timing-function: cubic-bezier(0.455, 0.03, 0.515, 0.955);
	animation-iteration-count: infinite; */
}
@keyframes blinking {
	/* 0% {opacity: 0;}
	100% {opacity: 1;} */
	0% {
        color: #333
    }

    12.5% {
        color: #3972B7;
    }

    25% {
        color: #333
    }

    100% {
        color: #333
    }
}

body.scrolled .updown-mv {
	transition: 3s;
}
body.scrolled .updown-mv span {
	transition: 3s;
    animation: blinking_2 3.8s both cubic-bezier(0.455, 0.03, 0.515, 0.955) infinite,
				.8s updown-anim cubic-bezier(.9,0,.1,1) forwards;
}
@keyframes blinking_2 {
	/* 0% {opacity: 0;}
	100% {opacity: 1;} */
	0% {
        color: #3972B7
    }

    12.5% {
        color: #274F7E;
    }

    25% {
        color: #3972B7
    }

    100% {
        color: #3972B7
    }
}
/* -----------------------------------------------------------
    side-nav
-------------------------------------------------------------- */
.contents-left {
	width: 880px;
	float: left;
    padding: 0 0;
}

.contents-right {
	margin: -160px 0 0;
	width: 250px;
	float: right;
}

.contents-right #side-scroll {
	margin: 160px 0 100px;
    position: fixed;
    width: 250px;
    top: 55px;
}

.contents-right #side-scroll .company-logo{
	margin: 0 0 30px;
	font: bold 1.6rem / 1 var(--font-en);
	/* letter-spacing: .1em; */
	/* color: var(--red); */
	color: var(--main-color);
	display: none;
}

.contents-right .ttl-s {
	background-size: 100% auto;
	padding: 15px 25px 20px;
    margin: 0 0 5px;
}

.contents-right .ttl-s span {
    font-size: 2rem;
}

/* .contents-right .side-nav {
} */

.contents-right .side-nav li {
	background: #F1F1F1;
	background: var(--pastelblue);
    position: relative;
}
.contents-right .side-nav li::after{
    position: absolute;
    content: "\f061";
    font-size: 1.4rem;
    font-family: "Font Awesome 6 Free";
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--main-color);
    z-index: 1;
    transition: .5s;
}
.contents-right .side-nav li:hover::after{
    right: 5px;
    transition: .5s;
}

.contents-right .side-nav li p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.5;
	position: relative;
	transition: 0.5s;
	font-weight: bold;
}
.contents-right .side-nav li p::after {
	/*
	background: #7C7C84;
	*/
	content: "";
	bottom: 0;
	display: block;
	margin: auto;
	position: absolute;
	right: -10px;
	top: -5px;
	transition: 0.5s;
	width: 30px;
	height: 8px;
	background: url("../img/arrow-icon.png") no-repeat left top / contain;
	z-index: 1;
}
.contents-right .side-nav li p:hover::after {
	right: -20px;
}

.contents-right .side-nav li p span {
	color: #333;
	font: 600 1.2rem / 1 'Poppins', sans-serif;
}

.contents-right .side-nav li p span.side-c-txt {
	color: var(--red);
	font: 500 1.2rem / 1 'Poppins', sans-serif;
}

.contents-right .side-nav li a {
	display: block;
}

/* .contents-right .side-nav li a:hover {
} */


@media screen and (max-width: 768px){
	.contents-left {
		width: 100%;
        padding: 0 0 0;
        float: none;
	}

	.contents-right {
		margin: 0;
		width: 100%;
		float: none;
        /* display: none; */
	}

	.contents-right #side-scroll {
		margin: 50px 0 0;
		position: unset;
		width: 100%;
		padding: 0 0px 20px;
	}

	.contents-right #side-scroll img{
		width: 280px;
		display: block;
		margin: 0 auto;
	}

	.content-right .ttl-s {
		padding: 15px 0;
	}

	.contents-right .ttl-s span {
		font-size: 1.8rem;
	}

	.contents-right .side-nav li p {
		font-size: 1.6rem;
        line-height: 1;
	}

	.contents-right .side-nav li p span {
		font-size: 1.0rem;
	}

	.contents-right .side-nav li a {
		background: url(../img/side-arrow.png) no-repeat right 10px center;
	}

	.contents-right .side-nav li a:hover {
		background: url(../img/side-arrow.png) no-repeat right 10px center;
	}

}


/* 動画背景共通 */
.low-mv{
	width: 100%;
	height: 100vh;
	overflow: hidden;
	position: absolute;
	opacity: .9;
	z-index: -1;
}
.low-mv video{
	position: fixed;
    top: 0;
    right: 0;
    left: auto;
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
	z-index: -1;
	opacity: .5;
	margin: 0 0 0 auto;
}
.low-mv.no-opa video{
	opacity: 1;
}


@media screen and (max-width: 768px){
	
	.low-mv video{
	}
	
}

.youtube-box{
    margin: 60px 0 0;
    text-align: center;
}
.youtube-box iframe{
    width: 100%;
    height: 650px;
}
/* イロトリドリプロジェクトページ 品部追加 */
 /* .sport-name {
    line-height: 1.3;
 } */
 @media screen and (max-width: 768px){
    .player-area .detail-box.player05 {
        border-radius: 10px;
        padding: 104px 20px 20px;
        margin: 0 0 40px;
    }
    .player-area .detail-box.player10 {
        border-radius: 10px;
        padding: 59px 20px 20px;
        margin: 0 0 40px;
    }
    .player-area .detail-box .detail-height {
    line-height: 1.6;
    }
}