@charset "UTF-8";
/* CSS Document */

/*
	00 Fonts
	01 Layout
	02 Trigger
*/

/*
00 Fonts
========================================================================== */
/* latin */
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/oswald/v24/TK3_WkUHHAIjg75cFRf3bXL8LICs18NvsUZiYySUhiCXAA.woff) format('woff');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: local('Open Sans Regular'), local('OpenSans-Regular'), url(https://fonts.gstatic.com/s/opensans/v17/mem8YaGs126MiZpBA-UFVZ0bf8pkAg.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: local('Open Sans SemiBold'), local('OpenSans-SemiBold'), url(https://fonts.gstatic.com/s/opensans/v17/mem5YaGs126MiZpBA-UNirkOUuhpKKSTjw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
	font-family: 'Yu Gothic';
	src: local('Yu Gothic Medium');
	font-weight: 100;
}
@font-face {
	font-family: 'Yu Gothic';
	src: local('Yu Gothic Medium');
	font-weight: 200;
}
@font-face {
	font-family: 'Yu Gothic';
	src: local('Yu Gothic Medium');
	font-weight: 300;
}
@font-face {
	font-family: 'Yu Gothic';
	src: local('Yu Gothic Medium');
	font-weight: 400;
}
@font-face {
	font-family: 'Yu Gothic';
	src: local('Yu Gothic Bold');
	font-weight: 600;
}

/*
01 Layout
========================================================================== */

/* color ======

base = rgba(75,75,75,1)
blue = rgba(25,120,210,1)
thick blue = rgba(240,245,248,1)
orange = rgba(235,80,0,1)
yellow = rgba(245,225,0,1)
thick yellow = rgba(240,240,225,1)
red = rgba(145,15,35,1)

*/


* {
	color: rgba(75,75,75,1);
  font-family: 'Open Sans', 'Yu Gothic', 'YuGothic', '游ゴシック', '游ゴシック体', sans-serif;
	font-weight: 600;
	font-style: normal;
	box-sizing: border-box;
	text-decoration: none;
}
.emFont { font-family: 'Oswald', sans-serif; }

html { height: 100%; }
body {
	height: 100%;
	font-size: 13px;
	margin: 0;
	padding: 0;
	transition-property: opacity;
	transition-duration: .2s;
	transition-timing-function: ease;
}

h1,h2,h3,h4,div,dl,dt,dd,ul,li,img,a,p,span,iframe,small,strong,figure,address,select,input,button,textarea,i,b,hr,sub,em {
	margin:0;
	padding:0;
	color:inherit;
	font-family: inherit;
	font-size: inherit;
	font-style:inherit;
	font-weight: inherit;
	list-style:none;
	text-align: justify;
	outline:none;
	background: none;
	border: none;
}
select {
	cursor: pointer;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}
select::-ms-expand { display: none; }
input {}
button { cursor: pointer; }
p { line-height: 2; }
mark {}
picture { display: block; }
br { line-height: 1; }
sub { bottom: initial; }
img { display: block; width: 100%; }

hr {}

::placeholder { color: rgba(44,57,89,1); }
:-ms-input-placeholder { color: rgba(44,57,89,1); }
::-ms-input-placeholder { color: rgba(44,57,89,1); }

.verWid { display: block !important; }
.verMid { display: none !important; }
.verNar { display: none !important; }

.verStandard { background-color: rgba(25,120,210,1); }
.verLight { background-color: rgba(41,147,193,1); }
.verFlesh { background-color: rgba(43,91,188,1); }

/* General ===================== */
.frame {
	width: 100%;
	max-width: 1600px;
	margin: auto;
	position: relative;
}

/* --- bgShape --- */
.bgShape {
  position: absolute;
  z-index: -1;
  overflow: hidden;
}

/* --- Anchor --- */
.anchor {
	position: absolute;
	top: 0;
	left: 0;
}

/* --- Title --- */
.ttlBasic {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: rgba(25,120,210,1);
  position: relative;
}
.ttlBasic i { font-size: 45px; }
.ttlBasic b { margin: 25px 0 0 0; font-size: 15px; }
.ttlBasic hr {
  width: 160px;
  height: 125px;
  background-image: url(/images/common/arrow-icon.svg);
  background-size: cover;
  background-position: center;
  position: absolute;
  bottom: 5px;
  left: calc(50% + 35px);
  z-index: -1;
}

/* ShowMore */
.showmore {}
.showmore a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 825px;
  height: 60px;
  margin: auto;
  border-radius: 5px;
  color: rgba(255,255,255,1);
  background-color: rgba(25,120,210,1);
  position: relative;
}
.showmore a:before {
  content: '';
  width: 20px;
  height: 20px;
  background-image: url(/images/common/arrow-circle.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translate(0,-50%);
}
.showmore a img {
  width: 32px;
  height: 32px;
  margin: 0 20px 0 0;
}
.showmore a em { font-size: 15px; }

.price {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1;
}
.price > * { position: relative; }
.price i {
  top: -1px;
}
.price b {
  display: inline-flex;
  padding: 0 0 0 3px;
  font-size: 30px;
  letter-spacing: -.02rem;
  top: -3px;
}
.price b:before {
  content: '¥';
  padding: 3px 2px 0 0;
  font-size: 28px;
}
.price sub {
  font-size: 12px;
}

/* nav ===================== */
/* standard */
nav h1 { width: 110px; }
nav > * {
	display: flex;
  justify-content: center;
  align-items: center;
}
nav .gloval { flex-direction: column; }
nav .gloval li { font-size: 14px; letter-spacing: -.02rem; }
nav .gloval > li + li { margin: 20px 0 0 0; }
nav .sns { margin: 40px 0 0 0; }
nav .sns > li + li { margin: 0 0 0 10px; }
nav .sns li img { width: 23px; height: 23px; }

/* overlay */
.blockOverlay {
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,.97);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1001;
	visibility: hidden;
	opacity: 0;
	transition: visibility .3s ease .3s, opacity .3s ease;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
}
.blockOverlay:before {
  content: '';
  width: 100%;
  height: 100%;
  background-image: url(/images/common/arrow-icon.svg);
  background-position: right 12.5% bottom;
  background-repeat: no-repeat;
  background-size: auto 90%;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: .7;
}
.blockOverlay .frame {
	display: flex;
  flex-direction: row-reverse;
 	justify-content: center;
	align-items: center;
  height: 100%;
  padding: 0 0 25px 0;
}
[data-nav-active='1'] .overlayNav {
	visibility: visible;
	opacity: 1;
	transition-delay: 0s
}
.overlayNav .frame > * {
	display: flex;
  flex-direction: column;
	justify-content: center;
	align-items: center;
}
.overlayNav ul li > * { white-space: nowrap; }
.overlayNav h2 {}
.overlayNav h2 > * {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.overlayNav h2 img { width: 110px; }
.overlayNav h2 i {
  margin: 5px 0 0 0;
  font-size: 17px;
  color: rgba(137,28,36,1);
}
.overlayNav nav {
  width: 560px;
  margin: 0 165px 0 0;
}
.overlayNav nav > * {}
.overlayNav nav ul {}
.overlayNav .gloval {
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  margin: 0 0 20px 0;
}
.overlayNav .gloval li {
  width: 100%;
  font-size: 13px;
  letter-spacing: 0;
  border-top: 1px solid rgba(220,215,200,1);
  position: relative;
}
.overlayNav .gloval > li + li { margin: 0; }
.overlayNav .gloval li:before {
  content: '';
  width: 17px;
  height: 17px;
  background-image: url(/images/common/arrow-circle-blk.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0,-50%);
  transition: .4s ease;
  pointer-events: none;
}
.overlayNav .gloval li:hover:before { right: 0; }
.overlayNav .gloval li a {
  display: block;
  padding: 19px 3px;
}
.overlayNav .info { width: 100%; }
.overlayNav .info .entry { margin: 0 auto 35px auto; }
.overlayNav .info .entry > * {
  width: 100%;
  padding: 9px 0 9px 10px;
}
.overlayNav .info ul {
  width: 100%;
  justify-content: space-between;
}
.overlayNav .info ul > li + li {}
.overlayNav .info ul li i {
   width: 35px;
   height: 35px;
}
.overlayNav .sub {
  justify-content: flex-start;
  width: 100%;
  margin: 33px 0 0 0;
  padding: 33px 0 0;
  border-top: 1px solid rgba(220,215,200,1);
  position: relative;
}
.overlayNav .sub li { font-size: 12px; }
.overlayNav .sub > li + li { margin: 0 0 0 25px; }
.overlayNav .sub li:not(:last-child) > a {
  padding: 0 0 0 12px;
  position: relative;
}
.overlayNav .sub li:not(:last-child) a:before {
  content: '';
  width: 6px;
  height: 6px;
  background-color: rgba(75,75,75,1);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0,-40%);
}
.overlayNav .sub li:last-child {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  position: absolute;
  bottom: -5px;
  right: 0;
}
.overlayNav .sub li:last-child a {
  width: 30px;
  height: 30px;
}
.overlayNav .sub li:last-child > a + a { margin: 0 0 0 7px; }

[data-training-active='1'] .overlayNavTraining {
  visibility: visible;
  opacity: 1;
  transition-delay: 0s
}
.sliderTraining {
  height: 100%;
  position: relative;
}
.sliderTraining > .slick-list {
  width: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%,-50%,0)!important;
}
.sliderTraining > .slick-arrow {
  border-bottom: 2px solid rgba(75,75,75,1);
  border-left: 2px solid rgba(75,75,75,1);
  width: 25px;
  height: 25px;
  font-size: 0;
  position: absolute;
  top: 50%;
  transition: opacity .3s ease;
  z-index: 2;
}
.sliderTraining > .slick-prev {
  left: 95px;
  transform: translate3d(0,-50%,0) rotate(45deg)!important;
}
.sliderTraining > .slick-next {
  right: 95px;
  transform: translate3d(0,-50%,0) rotate(-135deg)!important;
}
.sliderTraining > .slick-arrow.slick-disabled {
  opacity: 0;
}
.trainingText > * {
  display: flex;
  flex-direction: column;
  width: 45%;
  margin: auto;
}
.trainingText h3 {
  margin: 0 0 20px 0;
  font-size: 15px;
}
.trainingText h3 b { margin: 0 0 0 5px; }
.trainingText h4 {
  font-size: 18px;
  padding: 0 0 30px 0;
}
.trainingText dl {
  display: flex;
  flex-direction: column;
  padding: 0 0 30px 0;
}
.trainingText dl dt {
  padding: 0 0 12px 15px;
  position: relative;
}
.trainingText dl dt:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 4px 0 4px;
  border-color: rgba(75,75,75,1) transparent transparent transparent;
  position: absolute;
  top: 4px;
  left: 2px;
}
.trainingText dl dd {}
.trainingText dl dd > * {
  padding: 2px 15px;
  font-size: 12px;
  background-color: rgba(75,75,75,1);
  color: rgba(255,255,255,1);
  border-radius: 3px;
}

[data-calendar-active='1'] .overlayCalender {
	visibility: visible;
	opacity: 1;
	transition-delay: 0s
}
.overlayCalender {

}
.overlayCalender .frame {
  flex-direction: column;
}
.overlayCalender h2 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.overlayCalender h2 > * { position: relative; }
.overlayCalender h2 i {
  display: flex;
  font-size: 28px;
}
.overlayCalender h2 i > span + span:before { content: '.'; }
.overlayCalender h2 b {
  margin: 15px 0 0;
  font-size: 16px;
}
.overlayCalender ul {
  width: 650px;
  margin: 50px auto 40px;
}
.overlayCalender ul li {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 25px 0;
  font-size: 12px;
  border-bottom: 1px solid rgba(75,75,75,1);
}
.overlayCalender ul li:first-child { border-top: 1px solid rgba(75,75,75,1); }
.overlayCalender ul li * { position: relative; }
.overlayCalender ul li > * + * {
  margin: 0 0 0 22px;
  padding: 0 0 0 22px;
}
.overlayCalender ul li > * + *:before {
  content: '';
  width: 1px;
  height: 15px;
  background-color: rgba(75,75,75,1);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0,-50%);
}
.overlayCalender ul li time { font-size: 14px; }
.overlayCalender ul li time > i + i:before { content: '〜 '; }
.overlayCalender ul li time b { margin: 0 0 0 5px; }
.overlayCalender ul li a {
  padding: 0 0 0 20px;
  letter-spacing: -.03rem;
  white-space: nowrap;
}
.overlayCalender ul li a:before {
  content: '';
  width: 15px;
  height: 18px;
  background-image: url(/images/common/mappin.svg);
  background-size: cover;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0,-50%);
}

.overlayCalender .listCalender .lane {
	display: flex;
	align-items: center;
	padding: 1.75em 7.5em;
	border-top: 1px solid rgba(25,120,210,1);
}
.overlayCalender .listCalender .lane:last-child { border-bottom: 1px solid rgba(25,120,210,1); }
.overlayCalender .listCalender .lane > * { padding: 0 2em; color: rgba(25,120,210,1); line-height: 1; position: relative; }
.overlayCalender .listCalender .lane > *:not(:first-child):before {
	content: '';
	width: 1px;
	height: 15px;
	background-color: rgba(25,120,210,1);
	position: absolute;
	top: 50%;
	left: 0;
	transform: translate(0,-50%);
}
.overlayCalender .listCalender .lane h3 { font-size: 15px; }
.overlayCalender .listCalender .lane h3 i { line-height: 1; }
.overlayCalender .listCalender .lane h4 { font-size: 15px; }
.overlayCalender .listCalender .lane h4 time {}
.overlayCalender .listCalender .lane h4 > time + time:before {
	content: '〜';
	font-weight: 600;
	padding: 0 .35em 0 .15em;
	position: relative;
}
.overlayCalender .listCalender .lane h4 small { font-size: 12px; position: relative; top: -1px; }
.overlayCalender .listCalender .lane p {
	font-size: 12px;
	font-weight: 600;
}
.overlayCalender .listCalender .lane time { color: inherit; line-height: inherit; }
.overlayCalender .linkForm {
	margin: 5.5em 0 0 0;
}
.overlayCalender .linkForm > * {
	padding: 1.25em 10em;
	font-weight: 600;
	letter-spacing: .02rem;
	line-height: 1;
	border-radius: 7px;
	background-color: rgba(245,225,0,1);
	position: relative;
}
.overlayCalender .linkForm > *:before,
.overlayCalender .linkForm > *:after {
	content: '';
	height: 1px;
	background-color: rgba(75,75,75,1);
	position: absolute;
	top: 50%;
	right: 2.5em;
	transition: .3s ease;
}
.overlayCalender .linkForm > *:before { width: 20px; transform: translate(0,2px); }
.overlayCalender .linkForm > *:after { width: 8px; transform: translate(0,0) rotate(30deg); }
.overlayCalender .linkForm > *:hover:before,
.overlayCalender .linkForm > *:hover:after { right: 2em; }

.btnHumb {
	width: 75px;
	height: 90px;
	background-color: rgba(25,120,210,.98);
  filter: drop-shadow(3px 3px 4px rgba(0,0,0,.2));
	position: fixed;
	top: 0;
	left: 55px;
	transition: .4s ease;
	cursor: pointer;
	z-index: 1000;
}
.btnHumb button {
	width: 32px;
	height: 35px;
	position: absolute;
	top: 18px;
	left: 50%;
	transform: translate(-50%,0);
	transform-origin: left top;
	transition: .4s ease;
}
.btnHumb button hr {
	width: 100%;
	height: 3px;
	background-color: rgba(255,255,255,1);
  position: relative;
  left: 50%;
  transition: .3s ease;
}
.btnHumb button hr:nth-child(1) { transform: translate(-50%,-4px); }
.btnHumb button hr:nth-child(2) { transform: translate(-50%,0); }
.btnHumb button hr:nth-child(3) { transform: translate(-50%,4px); }
.btnHumb:hover button hr { width: 75%; }
.btnHumb:hover button hr:nth-child(1) { transform: translate(-50%,2px) rotate(90deg); }
.btnHumb:hover button hr:nth-child(2) { transform: translate(-50%,0) rotate(0deg); }
.btnHumb:hover button hr:nth-child(3) { opacity: 0; }
.btnHumb p {
	font-size: 12px;
	letter-spacing: .05rem;
	color: rgba(255,255,255,1);
	position: absolute;
	bottom: 18px;
	left: 50%;
	transform: translate(-50%,-7.5%) scaleY(.85);
}
.btnHumb.verOpen {
  opacity: 0;
  visibility: hidden;
  transition: visibility .3s ease .3s, opacity .3s ease;
}
[data-show-open-button='1'] .btnHumb.verOpen {
  opacity: 1;
  visibility: visible;
  transition-delay: 0s;
}
.btnClose {
	width: 55px;
	height: 55px;
	position: absolute;
	top: 30px;
	left: 65px;
	z-index: 1;
}
.btnClose button { width: 100%; height: 100%; position: relative; }
.btnClose button hr {
	width: 50px;
	height: 2px;
	background-color: rgba(75,75,75,1);
	position: absolute;
	top: 50%;
	left: 50%;
	transform-origin: center;
	transition: .4s ease;
}
.btnClose button:hover { background-color: rgba(75,75,75,1); }
.btnClose button:hover hr { width: 35px; background-color: rgba(255,255,255,1); }
.btnClose button hr:nth-child(1) { transform: translate(-50%,-50%) rotate(-45deg); }
.btnClose button hr:nth-child(2) { transform: translate(-50%,-50%) rotate(45deg); }

/* List */


/* Header ===================== */
header {}

/* Nav --- */
header section nav {}
.verGeneral { padding: 25px 65px; }
.verGeneral nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.verGeneral nav .gloval {
  flex-direction: row;
  padding: 15px 0 0 0;
}
.verGeneral nav .gloval li {
  font-size: 13px;
  letter-spacing: .03rem;
  position: relative;
  transition: .4s ease;
}
.verGeneral nav .gloval li:before,
.verGeneral nav .gloval li.current:before,
.verGeneral nav .gloval li.current:after {
  content: '';
  position: absolute;
  left: 50%;
  transform: translate(-50%,0);
  transition: .4s ease;
}
.verGeneral nav .gloval li:before { width: 0; }
.verGeneral nav .gloval li:hover:before,
.verGeneral nav .gloval li.current:before {
  width: calc(100% - 2px);
  height: 2px;
  background-color: rgba(245,225,0,.9);
  bottom: -12px;
}
.verGeneral nav .gloval li.current:after {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 5px 0 5px;
  border-color: rgba(245,225,0,.9) transparent transparent transparent;
  bottom: -20px;
}
.verGeneral nav .gloval > li + li { margin: 0; }
.verGeneral nav .gloval a {
  display: block;
  padding: 3px 20px;
  margin: 0 2px;
  white-space: nowrap;
}
.verGeneral nav .gloval > li + li a:before {
  content: '';
  width: 1px;
  height: 15px;
  background-color: rgba(180,175,170,1);
  position: absolute;
  top: 50%;
  left: -3px;
  transform: translate(0,-50%);
}
.verGeneral nav .gloval li > * { position: relative; }

.toEntry {
  width: 165px;
  height: 155px;
  position: absolute;
  top: 0;
  right: 0;
}
.toEntry:before {
  content: '';
  width: 37px;
  height: 8px;
  background-image: url(/images/common/arrow-blk.svg);
  background-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  top: 105px;
  left: 50%;
  transform: translate(0,0);
  z-index: 2;
  transition: .3s ease;
}
.toEntry:hover:before { transform: translate(10px,0); }
.toEntry > * {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  height: 100%;
  padding: 0 0 0 25px;
  color: rgba(75,75,75,1);
  position: relative;
  overflow: hidden;
}
.toEntry hr {
  width: 275px;
  height: 275px;
  background-color: rgba(245,225,0,1);
  border-radius: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
}
.toEntry i,
.toEntry b { text-align: center; position: relative; z-index: 1; }
.toEntry i { font-size: 12px; font-weight: 600; text-align: left; line-height: 1.4; padding: 22px 0 0 32px; }
.toEntry b { font-size: 21px; margin: 10px 0 0 0; }
.toEntry img {
  width: 28px;
  position: absolute;
  top: 25px;
  left: -3px;
}


/* Main ===================== */
main {}
main section { position: relative; }



/* Footer ===================== */
footer {
	padding: 50px 0 0 0;
	position: relative;
}
.info {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.info h2 { margin: 0 0 40px 0; }
.info h2 > * {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 105px;
}
.info h2 i {
  margin: 7px 0 0 0;
  font-size: 16px;
  color: rgba(137,28,36,1);
  white-space: nowrap;
}
.info .entry {
  width: 100%;
  margin: 0 auto 40px auto;
}
.info .entry > * {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 650px;
  margin: auto;
  padding: 12px 0 12px 10px;
  background-color: rgba(245,225,0,1);
  border-radius: 5px;
}
.info .entry img {
  width: 32px;
  height: 32px;
  margin: 0 15px 0 0;
}
.info .entry i {}
.info .entry em { font-size: 15px; }
.info ul {
  display: flex;
  width: 650px;
}
.info ul li {
  width: 50%;
  position: relative;
}
.info ul li:before,
.info ul li:last-child:after {
  content: '';
  width: 1px;
  height: 30px;
  background-color: rgba(180,175,170,1);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0,-50%);
}
.info ul li:last-child:after { left: initial; right: 0; }
.info ul li > * {
  display: flex;
  justify-content: center;
  align-items: center;
}
.info ul li i {
  width: 42px;
  height: 42px;
  margin: 0 10px 0 0;
}
.info ul li b {
  font-size: 12px;
  line-height: 1.5;
}
.info ul li b small { font-size: 11px; }
.info .copy {
  margin: 50px 0 0 0;
  letter-spacing: .02rem;
}
.info .copy em { margin: 0 2px 0 0; }

footer .sponsor {
  width: 100%;
  margin: 70px 0 0 0;
}
footer .sponsor ul {
  padding: 35px 0;
  background-color: rgba(230,239,244,.75);
}
footer .sponsor ul li {
	display: flex;
	justify-content: center;
	align-items: center;
}
footer .sponsor ul li img { width: 150px; }


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

nav h1 { width: 92px; min-width: 90px; }
nav .gloval li { font-size: 13px; letter-spacing: 0; }

.ttlBasic i { font-size: 42px; }
.ttlBasic b { font-size: 14px; }
.ttlBasic hr {
  width: 140px;
  height: 105px;
}

.verGeneral { padding: 15px 40px; }
.verGeneral nav .gloval { position: relative; right: -20px; }
.verGeneral nav .gloval li { font-size: 12px; }
.verGeneral nav .gloval a { padding: 3px 15px; letter-spacing: -.02rem; }
.toEntry { width: 125px; height: 140px; }
.toEntry:before {
  width: 30px;
  height: 7px;
  top: 90px;
  left: 52.5%;
}
.toEntry img {
  width: 25px;
  top: 17px;
  left: 0;
}
.toEntry i {
  padding: 15px 0 0 30px;
  font-size: 11px;
  line-height: 1.3;
}
.toEntry b { font-size: 18px; margin: 8px 0 0 0; }

.showmore a { width: calc(100% - 150px); }
.btnHumb { left: 35px; }

.trainingText > * { width: 55%; }

.blockOverlay .frame { padding: 35px 0; }
.overlayNav h2 img { width: 95px; }
.overlayNav nav {
  width: 440px;
  margin: 0 80px;
}
.overlayNav .gloval { margin: 0 0 15px 0; }
.overlayNav .gloval li { font-size: 12px; }
.overlayNav .gloval li a { padding: 17px 3px; }
.overlayNav .info .entry { margin: 0 auto 30px auto; }
.overlayNav .info .entry > * { font-size: 12px; }
.overlayNav .sub {
  flex-wrap: wrap;
}
.overlayNav .sub li:last-child {
  justify-content: flex-start;
  width: 100%;
  margin: 30px 0 0 0;
  position: relative;
  bottom: initial;
  right: initial;
}


}


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

.verWid { display: none !important; }
.verMid { display: block !important; }
.verNar { display: none !important; }

nav h1 {
  width: 115px;
  margin: auto;
}

.verGeneral nav .gloval,
.verGeneral nav .sns { display: none; }

.blockOverlay .frame { flex-direction: column; }
.overlayNav nav { width: calc(100% - 200px); }
.btnHumb {
  filter: drop-shadow(1px 1px 2px rgba(0,0,0,.2));
  left: 0;
}
.btnHumb.verOpen:not(.verIndex) {
  opacity: 1;
  visibility: visible;
}
[data-fv-finished="1"] .btnHumb.verOpen.verIndex {
  opacity: 1;
  visibility: visible;
  transition: opacity .3s ease 1s, visibility .3s ease 1s;
}
.btnClose { top: 20px; left: 20px; }
.showmore a {
  width: calc(100% - 225px);
  height: 55px;
}

.info ul li i {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
}

/* trigger transitionend */
header.dirRoot nav .gloval,
header.dirRoot nav .sns,
header.dirRoot .scrollDown,
header.dirRoot .toEntry {
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    visibility: hidden !important;
    opacity: 1;
}

}


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

body { font-size: 12px; }
p { line-height: 1.9; }

.verWid { display: none !important; }
.verMid { display: block !important; }
.verNar { display: block !important; }

nav h1 {
  width: 100px;
  min-width: initial;
}

.ttlBasic i {
  font-size: 35px;
  letter-spacing: -.1rem;
}
.ttlBasic b {
  margin: 23px 0 0 0;
  font-size: 12px;
}
.ttlBasic hr {
  width: 115px;
  height: 85px;
}

.showmore a {
  width: calc(100% - 50px);
  height: 48px;
  border-radius: 3px;
}
.showmore a:before {
  width: 15px;
  height: 15px;
  right: 18px;
}
.showmore a img {
  width: 22px;
  height: 22px;
  margin: 0 10px 0 0;
}
.showmore i { font-size: 11px; }
.showmore i em { font-size: 13px; }

.toEntry { display: none; }

.blockOverlay:before {
  background-position: center bottom;
  background-size: auto 40%;
  position: fixed;
}
.overlayNav h2 img { width: 72px; }
.overlayNav h2 i {
  font-size: 13px;
  letter-spacing: -.04rem;
}
.overlayNav nav {
  width: calc(100% - 50px);
  margin: 32px auto;
}
.blockOverlay .frame {
  height: auto;
  min-height: 100%;
}
.overlayNav .gloval li a { padding: 15px 3px; }
.overlayNav .info .entry > * { padding: 13px 0 13px 10px; }
.overlayNav .info ul li i {
  width: 27px;
  height: 27px;
}
.overlayNav .gloval li:before {
  width: 14px;
  height: 14px;
}
.overlayNav .sub {
  flex-direction: column;
  align-items: flex-start;
}
.overlayNav .sub li { font-size: 11px; }
.overlayNav .sub > li + li { margin: 9px 0 0 0; }
.overlayNav .sub li:last-child {
  display: flex;
  justify-content: center;
  align-items: center;
  width: auto;
  margin: 0;
  position: absolute;
  bottom: 0;
  right: 0;
}
.overlayNav .sub li:last-child a {
  width: 27px;
  height: 27px;
}
.verGeneral { padding: 30px 40px 0; }
.verGeneral nav h1 { width: 92px; }

.overlayCalender h2 i {
  font-size: 19px;
  letter-spacing: -.05rem;
}
.overlayCalender h2 b { font-size: 14px; }
.overlayCalender ul {
  width: calc(100% - 50px);
  margin: 30px auto 40px;
}
.overlayCalender ul li {
  flex-direction: column;
}
.overlayCalender ul li > * + * {
  margin: 10px 0 0 0;
  padding: 0;
}
.overlayCalender ul li > * + *:before { display: none; }
.overlayCalender ul li time { letter-spacing: -.05rem; }
.overlayCalender .info .entry > * {
  width: 100% !important;
  padding: 13px 20px 13px 20px;
}

.btnHumb {
  width: 62px;
  height: 77px;
}
.btnHumb button { top: 15px; }
.btnHumb button hr { height: 2px; }
.btnHumb p {
  font-size: 11px;
  letter-spacing: .03rem;
  bottom: 15px;
}
.btnClose { width: 45px; height: 45px; }
.btnClose button hr { width: 38px; }

.info h2 { margin: 0 0 30px 0; }
.info h2 > * { width: 90px; }
.info h2 i {
  margin: 5px 0 0 0;
  font-size: 14px;
  letter-spacing: -.04rem;
}
.info ul li i {
  width: 27px;
  height: 27px;
  min-width: 27px;
  min-height: 27px;
}
.info ul li b {
  font-size: 10px;
  line-height: 1.4;
}
.info ul li b small { font-size: 10px; }
.info .entry { margin: 0 auto 30px auto; }
.info .copy {
  margin: 35px 0 0 0;
  letter-spacing: -.04rem;
}

.price b {
  font-size: 27px;
  letter-spacing: -.08rem;
}
.price b:before { font-size: 25px; }


}
