@charset "utf-8";

/*//////////////////////////////////////////////////////////////
  Temp
//////////////////////////////////////////////////////////////*/

@keyframes fadein {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes bgfade {
	0% {
        opacity: 0;
    }
    6% {
        opacity: 1;
    }
    33% {
        opacity: 1;
    }
    41% {
        opacity: 0;
    }
    100% {
		opacity: 0;
	}
}

/*//////////////////////////////////////////////////////////////
  Html Reset
//////////////////////////////////////////////////////////////*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	vertical-align:baseline;
	background:transparent;
}
html {
	font-size: 10px;
}
body {
	line-height:1;
	-webkit-text-size-adjust : 100%;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
	display:block;
}
ul,ol,li {
	list-style-type:none;
}
img {
	vertical-align:top;
}
blockquote, q {
	quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content:'';
	content:none;
}
a {
	margin:0;
	padding:0;
	vertical-align:baseline;
	background:transparent;
}
table {
	border-collapse: separate;
	border-spacing: 0px;
}

/*//////////////////////////////////////////////////////////////
  Base
//////////////////////////////////////////////////////////////*/

a[href^="tel:"] {
	cursor: default;
}

/* Clearfix ------------------------------------------------- */

.clear-fix:before,
.clear-fix:after {
  content: "";
  display: block;
  clear: both;
}

/* body ----------------------------------------------------- */

body {
	color: #000000;
    /* font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif; */
    font-family: "游明朝体", "Yu Mincho", YuMincho, 'Noto Serif JP', "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-size: 10px;
    font-weight: 500;
    text-align: center;
	width: 100%;
    -webkit-text-size-adjust: 100%;
}
h2,h3,h4,p,li,dt,dd,th,td {
	transform: rotate(0.01deg);
}
section {
	clear: both;
}
.smallonly {
	display: none;
}
@media screen and (max-width: 768px) {
	.smallonly {
		display: block;
	}
	.largeonly {
		display: none;
	}
	section {
		background-color: #ffffff;
		overflow: hidden !important;
	}
}


/* link ----------------------------------------------------- */

a:link,
a:visited {
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

/*//////////////////////////////////////////////////////////////
[Layout]
//////////////////////////////////////////////////////////////*/

body > div {
	height: 100vh;
	position: relative;
	width: 100%;
}
.bg {
	height: 100vh;
	z-index: 1;
}
.bg > div {
	height: 100%;
	width: 100%;
	position: relative;
	overflow: hidden;
}
.bg > div > div {
	height: 100%;
	width: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.cont {
	animation: fadein 1500ms;
	box-sizing: border-box;
	position: relative;
	z-index: 100;
}
@media screen and (min-width: 769px) {
	.bg {
		position: fixed;
		width: calc(100% - 640px);
	}
	.cont {
		background-color: #ffffff;
		left: calc(100% - 640px);
		width: 640px;
	}
}
@media screen and (max-width: 768px) {
	.bg {
		position: absolute;
		width: 100%;
	}
	.cont {
		width: 100%;
	}
}
.fadeImg {
	animation: bgfade 21s 0s infinite;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 0;
}
.hero-1 {
	background-image: url("../../jsa/img/bg_1.jpg");
}
.hero-2 {
	background-image: url("../../jsa/img/bg_2.jpg");
	animation-delay: 7s;
}
.hero-3 {
	background-image: url("../../jsa/img/bg_3.jpg");
	animation-delay: 14s;
}

/* Header --------------------------------------------------- */

header {
	position: relative;
	text-align: center;
}
@media screen and (min-width: 769px) {
	header {
		height: 100vh;
	}
	header h1 {
		background: url("../../jsa/img/ttl_large.png") no-repeat 0 0;
		height: 490px;
		font-size: 0;
		margin: 0 auto;
		left: 0;
		position: absolute;
		right: 0;
		top: 13.88%;
		width: 310px;
	}
	.badge {
		background: url("../../jsa/img/badge-202204_large.png") no-repeat 0 0;
		display: block;
		font-size: 0;
		height: 128px;
		position: absolute;
		right: 62px;
		top: 69%;
		width: 130px;
	}
	.scroll {
		background: url("../../jsa/img/scroll_large.png") no-repeat 0 0;
		display: block;
		font-size: 0;
		height: 32px;
		margin: 0 auto;
		left: 0;
		position: absolute;
		right: 0;
		bottom: 8%;
		width: 43px;
	}
	.scroll a {
		display: block;
		height: 100%;
		width: 100%;
	}
}
@media screen and (max-width: 768px) {
	header {
		background: rgba(0,0,0,0.5);
		min-height: 100vh;
		min-height: calc(var(--vh, 1vh) * 100);
	}
	header h1 {
		background: url("../../jsa/img/ttl_small.png") no-repeat 0 0;
		background-size: cover;
		height: 354.5px;
		font-size: 0;
		margin: 0 auto;
		left: 0;
		position: absolute;
		right: 0;
		top: 16.95%;
		width: 215px;
	}
	.badge {
		background: url("../../jsa/img/badge-202204_small.png") no-repeat 0 0;
		background-size: cover;
		display: block;
		font-size: 0;
		height: 89px;
		position: absolute;
		right: 7.2%;
		top: 80%;
		width: 90px;
	}
	.scroll {
		background: #ffffff url("../../jsa/img/scroll_small.png") no-repeat center center;
		background-size: 29.5px 22px;
		display: block;
		font-size: 0;
		height: 40px;
		margin: 0 auto;
		left: 0;
		position: absolute;
		right: 0;
		bottom: 0;
		width: 41px;
	}
	.scroll a {
		display: block;
		height: 100%;
		width: 100%;
	}
}

/* Footer --------------------------------------------------- */

footer {
	background-color: #9f9946;
	color: #ffffff;
	padding: 58px 0 0;
}
footer dt {
	font-size: 0px;
	margin: 0 auto 15px;
}
footer .logo-5relax {
	background: url("../../jsa/img/logo-5relax.svg") no-repeat 0 0;
	background-size: 169px 128px;
	height: 128px;
	width: 169px;
}
footer .logo-kitada {
	background: url("../../jsa/img/logo-kitada.svg") no-repeat 0 0;
	background-size: 169px 104px;
	height: 104px;
	width: 169px;
}
footer dd {
	border: 1px solid #ffffff;
	border-radius: 4px;
	display: inline-block;
	font-size: 1.7rem;
	font-weight: 500;
	margin: 0 auto 70px;
	position: relative;
}
footer dd a {
	display: block;
	box-sizing: border-box;
	padding: 12px 40px 12px 24px;
	position: relative;
}
footer dd a:after {
    border: 6px solid transparent;
    border-left: 9px solid #ffffff;
    content: "";
    right: 18px;
    position: absolute;
    top: calc(50% - 6.5px);
}
footer dd a:link,
footer dd a:visited,
footer dd a:hover {
	color: #ffffff;
}
footer .logo-jsa {
	background: url("../../jsa/img/logo-jsa.svg") no-repeat 0 0;
	background-size: 114px 147px;
	font-size: 0px;
	height: 147px;
	margin: 0 auto 15px;
	width: 114px;
}
footer p {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 2em;
}
@media screen and (max-width: 768px) {
	footer {
		padding: 40px 0 20px;
	}
	footer dt {
		margin: 0 auto 10px;
	}
	footer .logo-5relax {
		background-size: 99px 75px;
		height: 75px;
		width: 99px;
	}
	footer .logo-kitada {
		background-size: 99px 61px;
		height: 61px;
		width: 99px;
	}
	footer dd {
		font-size: 1.2rem;
		font-weight: 500;
		margin: 0 auto 40px;
	}
	footer dd a {
		padding: 9px 30px 9px 16px;
	}
	footer dd a:after {
		border: 4.5px solid transparent;
		border-left: 7px solid #ffffff;
		right: 12px;
		top: calc(50% - 5px);
	}
	footer .logo-jsa {
		background-size: 67px 86px;
		height: 86px;
		margin: 0 auto 10px;
		width: 67px;
	}
	footer p {
		font-size: 1.0rem;
		line-height: 2em;
	}
}

/* Lead Area ------------------------------------------------ */

.lead {
	padding: 30px 12.8% 40px;
}
.lead > h2 {
	color: #407899;
	display: inline-block;
	font-size: 2.5rem;
	line-height: 1.4em;
	margin: 0 auto;
	text-align: center;
}
.lead > h2:after {
	background-color: #407899;
	content: ' ';
	display: block;
	height: 1px;
	margin: 30px auto 34px;
	width: 31.25%;
}
.lead > h3 {
	background-color: #a39c46;
	box-sizing: border-box;
	color: #ffffff;
	font-size: 2.0rem;
	line-height: 1.5em;
	margin-bottom: 30px;
	padding: 1.5px 10px 0;
}
.lead p,
.lead li,
.lead dd,
.lead th,
.lead td {
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.6em;
	text-align: left;
}
.lead p {
	margin-bottom: 24px;
}
.lead i {
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 1.55rem;
	font-style: normal;
    font-weight: bold;
	vertical-align: top;
	padding: 0 1.5px;
}
.lead aside {
	background-color: #dfe8ef;
	border-radius: 6px;
	box-sizing: border-box;
	margin: 34px 0 94px;
	padding: 24px 0;
}
.lead aside h3 {
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0 auto 15px;
}
.lead aside p {
	font-size: 1.4rem;
	margin: 0 34px;
}
.lead ul {
	padding-bottom: 40px;
}
.lead li {
	padding: 0 0 5px 1.3em;
}
.lead li:before {
	color: #a39c46;
	content: '●';
	margin: 0 0.3em 0 -1.3em;
}
.lead dl {
	padding-bottom: 10px;
}
.lead dt {
	border-left: solid 2px #a39d46;
	color: #a39c46;
	font-size: 2.0rem;
	line-height: 1.2em;
	margin: 0 0 10px 5px;
	padding: 0 0 0 8px;
	text-align: left;
}
.lead dd {
	padding: 0 5px 30px;
}
.lead dd ul {
	padding-bottom: 0px;
}
.lead dd li {
	padding: 0 0 5px 15px;
}
.lead dd li:before {
	background-color: #000000;
	content: ' ';
	height: 1px;
	display: inline-block;
	width: 5px;
	vertical-align: middle;
	margin: -3px 10px 0 -15px;
}
.lead dd table {
	width: 100%;
}
.lead dd th {
	width: 40px;
	white-space: nowrap;
}
.lead dd td {
	width: calc(100% - 40px);
}
@media screen and (max-width: 768px) {
	.lead {
		padding: 45px 25px 40px;
	}
	.lead h2 {
		font-size: 1.8rem;
	}
	.lead > h2:after {
		margin: 25px auto 28px;
	}
	.lead > h3 {
		font-size: 1.4rem;
		margin-bottom: 20px;
	}
	.lead p,
	.lead li,
	.lead dd,
	.lead th,
	.lead td {
		font-size: 1.2rem;
	}
	.lead i {
		font-size: 1.4rem;
		padding: 0 1.5px;
	}
	.lead aside {
		margin: 30px 0 50px;
		padding: 20px 0 18px;
	}
	.lead aside h3 {
		font-size: 1.3rem;
		margin: 0 auto 10px;
	}
	.lead aside p {
		font-size: 1.1rem;
		margin: 0 24px;
	}
	.lead ul {
		padding-bottom: 30px;
	}
	.lead li {
		padding: 0 0 2.5px 1.3em;
	}
	.lead dt {
		font-size: 1.4rem;
		margin: 0 0 10px 2.5px;
		padding: 0 0 0 5px;
	}
	.lead dd {
		padding: 0 2.5px 20px;
	}
	.lead dd li {
		padding: 0 0 2.5px 10px;
	}
	.lead dd li:before {
		width: 4px;
		margin: -3px 6px 0 -10px;
	}
	.lead dd th {
		width: 30px;
	}
	.lead dd td {
		width: calc(100% - 30px);
	}
}

/* Outline -------------------------------------------------- */

.outline {
	background-color: #417293;
	color: #ffffff;
	padding: 58px 12.8% 0px;
}
.outline > h2 {
	display: inline-block;
	font-size: 2.5rem;
	letter-spacing: 0.06em;
	line-height: 1.4em;
	margin: 0 auto 38px;
	text-align: center;
}
.outline > h2 span {
	background-color: #ffffff;
	color: #417293;
	display: table;
	font-size: 1.65rem;
	font-weight: bold;
	letter-spacing: 0;
	line-height: 1em;
	margin: 0 auto 16px;
	padding: 4px 3px 0;
}
.outline > div {
	border-top: 1px solid #ffffff;
	padding: 32px 0;
}
.outline h3 {
	font-size: 2.0rem;
	line-height: 1.5em;
	margin-bottom: 28px;
}
.outline p,
.outline li,
.outline dd,
.outline th,
.outline td {
	font-size: 1.5rem;
	font-weight: 400;
	line-height: 1.6em;
	text-align: left;
}
.outline p.notes {
	font-size: 1.25rem;
	margin-top: 8px;
}
.outline p.kitada {
	background: url("../../jsa/img/pic-kitada.jpg") no-repeat 0 0;
	background-size: 140px 140px;
	box-sizing: border-box;
	min-height: 140px;
	padding-left: 155px;
	width: 100%;
}
.outline p.kitada strong {
	font-size: 1.8rem;
	font-weight: 400;
	display: block;
	margin-bottom: 8px;
}
.outline p.kitada span {
	background-color: #ffffff;
	border-radius: 3px;
	color: #1068b8;
	display: inline-block;
    font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
	font-size: 1.4rem;
	font-weight: 800;
	margin-left: 10px;
	position: relative;
}
.outline p.kitada span a {
	display: block;
	box-sizing: border-box;
	padding: 0 6px 0 16px;
	position: relative;
}
.outline p.kitada span a:before {
    border: 5px solid transparent;
    border-left: 7px solid #1068b8;
    content: "";
    left: 6px;
    position: absolute;
    top: calc(50% - 5px);
}
.outline a:link,
.outline a:visited,
.outline a:hover {
	color: #ffffff;
}
.outline p.kitada span a:link,
.outline p.kitada span a:visited,
.outline p.kitada span a:hover {
	color: #1068b8;
}
.outline dl {
	padding: 10px 0;
}
.outline dt {
	border-left: solid 2px #ffffff;
	color: #ffffff;
	font-size: 2.0rem;
	line-height: 1.2em;
	margin: 0 0 10px;
	padding: 0 0 0 10px;
	text-align: left;
}
.outline dd {
	padding: 0 0 30px;
}
.outline dd li {
	padding-left: 13px;
}
.outline dd li:before {
	background-color: #ffffff;
	content: ' ';
	height: 1px;
	display: inline-block;
	width: 5px;
	vertical-align: middle;
	margin: -3px 8px 0 -13px;
}
@media screen and (max-width: 768px) {
	.outline {
		padding: 40px 25px 0px;
	}
	.outline > h2 {
		font-size: 1.8rem;
		margin: 0 auto 30px;
	}
	.outline > h2 span {
		font-size: 1.15rem;
		margin: 0 auto 10px;
		padding: 2px;
	}
	.outline > div {
		padding: 26px 0;
	}
	.outline h3 {
		font-size: 1.4rem;
		margin-bottom: 20px;
	}
	.outline p,
	.outline li,
	.outline dd,
	.outline th,
	.outline td {
		font-size: 1.2rem;
	}
	.outline p.notes {
		font-size: 1.0rem;
		margin-top: 5px;
	}
	.outline p.kitada {
		background-size: 95px 95px;
		min-height: 95px;
		padding-left: 105px;
	}
	.outline p.kitada strong {
		font-size: 1.3rem;
		margin-bottom: 5px;
	}
	.outline p.kitada span {
		font-size: 1.0rem;
		margin-left: 8px;
	}
	.outline p.kitada span a {
		padding: 0 5px 0 12px;
	}
	.outline p.kitada span a:before {
		border: 4px solid transparent;
		border-left: 5px solid #1068b8;
		left: 5px;
		top: calc(50% - 5px);
	}
	.outline dl {
		padding: 0;
	}
	.outline dt {
		font-size: 1.4rem;
		margin: 0 0 10px;
		padding: 0 0 0 5px;
	}
	.outline dd {
		padding: 0 0 20px;
	}
	.outline dd li {
		padding-left: 10px;
	}
	.outline dd li:before {
		width: 4px;
		margin: -3px 6px 0 -10px;
	}
}

/* Profile -------------------------------------------------- */

.profile {
	background-color: #efeee0;
	border-radius: 6px;
	margin: 78px 12.8%;
	padding: 28px;
}
.profile dl {
	text-align: left;
}
.profile dt {
	align-items: center;
	background:  url("../../jsa/img/ic-person_pm.png") no-repeat 0 0;
	background-size: 112px 112px;
	box-sizing: border-box;
	display: flex;
	justify-content: flex-start;
	min-height: 112px;
	margin-bottom: 20px;
	padding-left: 132px;
}
.profile dt div {
	font-size: 2.3rem;
	font-weight: 600;
	line-height: 1.5em;
}
.profile dt span {
	background-color: #9f9946;
	color: #ffffff;
	display: table;
	font-size: 1.65rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1em;
	margin-bottom: 8px;
	padding: 4px 3px 0;
}
.profile dd {
	font-size: 1.3rem;
	font-weight: 600;
	line-height: 1.6em;
}
.profile dd + dd {
	margin-top: 35px;
}
@media screen and (max-width: 768px) {
	.profile {
		margin: 32px 25px;
		padding: 20px 19px;
	}
	.profile dt {
		background-size: 78px 78px;
		min-height: 78px;
		margin-bottom: 15px;
		padding-left: 90px;
	}
	.profile dt div {
		font-size: 1.6rem;
	}
	.profile dt span {
		font-size: 1.2rem;
		margin-bottom: 8px;
		padding: 2px;
	}
	.profile dd {
		font-size: 1.1rem;
	}
	.profile dd + dd {
		margin-top: 18px;
	}
}