@charset "UTF-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css2?family=Ms+Madi&display=swap');
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@2.0.0/dist/css/yakuhanjp.min.css");
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.2/css/all.min.css');


/* 
 format
-------------------------------------------------------------------*/
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
dl,
dd,
dt,
figure,
div {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

header,
footer,
article,
section,
nav,
aside,
details,
figcaption,
figure,
menu {
  display: block;
  box-sizing: border-box;
}

li,
a {
	box-sizing: border-box;
}

img {
	max-width: 100%;
}


html {
  font-size: 62.5%; }

body {
	font-family: "Noto Sans Japanese";
}
.Container {
	position: relative;
	margin: auto;
	background: #FFF;
	text-align: left;
	font-family: "YakuHanJP", Meiryo, sans-serif;
	color: #333;
	fontz-size: 10px;
	font-size: 1.0rem;
	line-height: 170%;
}

li {
  list-style-type: none;
}

img {
  border: none;
  vertical-align: top;
}

address,
em,
th {
  font-style: normal;
  font-weight: normal;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.clear {
  clear: both;
}

.cf:after {
  content: "";
  display: block;
  clear: both;
}

.sp {
  display: block !important;
}

br.sp {
	display: inline-block!important;
}

.pc {
  display: none !important;
}

.Container a:link {
  text-decoration: none;
  color: #333;
}

.Container a:visited {
  text-decoration: none;
  color: #333;
}

.Container a:active {
  text-decoration: none;
  color: #333;
}

.Container a:hover {
  text-decoration: underline;
  color: #333;
	opacity: .6;
	text-decoration: none;
}

small {
  font-size: 12px;
}

small .lg {
  font-size: larger;
}

.notes small {
  display: block;
  padding-left: 1em;
  text-indent: -1em;
}

.notes small:first-letter {
  font-family: sans-serif;
}

.caution {
  display: block;
  padding-left: 1em;
  text-indent: -1em;
  color: #F00;
}

.br:before {
  content: "¥A";
  white-space: pre;
}

.contents {
  width: 1200px;
  margin: auto;
  padding: 0 10px;
}

/*
footer {
  padding: 16px 10px;
}

footer .notes {
  display: block;
}
*/


/* 
 basic
-------------------------------------------------------------------*/
.containerInner {
	
}
.titlePage {
	
}

.titlePage__name {
	text-align: center;
	padding-top: 40px;
	padding-bottom: 40px;
}

.titlePage__nameItem {
	width: 65%;
	margin-left: auto;
	margin-right: auto;
}

.Contents {
	background: url("../images/bg-001.png") repeat-y center top;
	background-size: 100% auto;
	padding-left: 20px;
	padding-right: 20px;
	padding-bottom: 60px;
	border-bottom: 1px dotted #000;
}

.blockTopBanner {
	padding-top: 20px;
	padding-left: 25px;
	padding-right: 25px;
	padding-bottom: 1px;
	background: rgba(0, 0, 0, .05);
}

.blockTopBanner__slider .slick-slide a {
	position: relative;
	display: block;
}

.blockTopBanner__slider .slick-slide .slideBnrTitle {
	position: absolute;
    top: calc(50% - 20px);
    /*left: 25%;*/
	left: 24%;
    font-size: 2.8vw;
	font-weight: bold;
	line-height: 130%;
}

.blockTopBanner__slider .slick-slide .slideBnrCaption {
	position: absolute;
    top: calc(50% - 10px);
    right: 9%;
    font-size: 2.0vw;
    font-weight: bold;
    color: #fff;
}

.blockTopBanner__slider .slick-slide .slideBnrCaption::after {
	font-family: "Font Awesome 5 Free";
	content: "\f054";
	font-weight: 900;
	font-size: 2.0vw;
	position: absolute;
	right: -14px;
	top: 1px;
	margin: auto;
}


/* 
 button
-------------------------------------------------------------------*/
.Container a.button001,
.Container a.button002,
.Container a.button003 {
	display: inline-block;
	font-weight: bold;
	color: #fff;
	border-radius: 1000px;
	text-align: center;
	padding-top:1em;
	padding-bottom: 1em;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1em;
	padding-right: 2em;
	min-width: 260px;
	position: relative;
}

.Container a.button001 {
	font-size: 1.2rem;
	background: #6ab4a5;
}

.Container a.button002 {
	background: #a18f77;
}

.Container a.button003 {
	color: #6ab4a5;
	font-size: 1.2rem;
	border: 3px solid #6ab4a5;
	background: #fff;
	padding-top: .5em;
	padding-bottom: .5em;
}

.Container a.button001::after,
.Container a.button002::after {
	content: "";
	background: url("../images/icon-right-002.png") left center no-repeat;
	background-size: auto 14px;
	width: 14px;
	height: calc(100% - 7px);
	position: absolute;
	right: .5em;
	top: 4px;
}

.Container a.button003::after {
	content: "";
	background: url("../images/icon-right-003.png") left center no-repeat;
	background-size: auto 14px;
	width: 14px;
	height: calc(100% - 7px);
	position: absolute;
	right: .5em;
	top: 4px;
}

/* 
 Tab frame
-------------------------------------------------------------------*/
/* Tab button */
.blockTab {
	
}

.blockTabButton {
	margin-bottom: 30px;
	margin-top: 40px;
}

.blockTabButton ul {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
}

.blockTabButton li {
	width: 48%;
}

.blockTabButton a.buttonTab {
	background: #6ab4a5;
	color: #fff;
	width: 100%;
	text-align: center;
	display: inline-block;
	padding-top: 10px;
	padding-bottom: 10px;
	border-radius: 10px;
	font-size: 1.2rem;
}

.buttonTab__strong {
	font-size: 1.5rem;
	font-weight: bold;
	display: inline-block;
}

.blockTabButton a.buttonTab.isActive {
	background: #eceab7;
	color: #333;
	position: relative;
}

.blockTabButton a.buttonTab.isActive::after {
	content: "";
	background: #eceab7;
	height: calc(tan(60deg) * 16px / 2);
	width: 16px;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	position: absolute;
	bottom: -12px;
	left: calc(50% - 8px);
}

/* Tab frame */
.blockTabContents {
	
}

.blockTabContents__item {
	
}

/* 
 Plan description
-------------------------------------------------------------------*/
.blockPlanDescription {
	position: relative;
	margin-bottom: 60px;
}

.blockPlanDescription__image {
	width: 90%;
	padding-bottom: 30px;
}

.blockPlanDescription__image img {
	width: 100%;
	height: 200px;
	object-fit: contain;
	object-position: 0 0;
}

.blockPlanDescription__title {
	background: #eceab7;
	border-radius: 20px;
	padding: 15px;
	position: absolute;
	width: 60%;
	bottom: 0;
	right: 0;
}

.blockPlanDescription__titleItem001 {
	font-family: 'Ms Madi', cursive;
	color: #6ab4a5;
	font-size: 1.5rem;
	font-weight: bold;
}

.blockPlanDescription__titleItem002 {
	font-weight: bold;
	font-size: 1.5rem;
	margin-top: 5px;
}

.blockPlanDescription__titleItem003 {
	margin-top: 5px;
}

/* 
 Plan items
-------------------------------------------------------------------*/
/* titles */
.blockTitleTime {
	background: url("../images/title-time.png") left center no-repeat;
	background-size: auto 100%;
	font-size: 2.5rem;
	font-weight: bold;
	padding-left: .5em;
	width: 200px;
	height: 50px;
	line-height: 50px;
	margin-left: -22px;
	margin-bottom: 40px;
}

.blockActTitle {
	position: relative;
	color: #6ab4a5;
	border-bottom: 2px solid #b0e2d7;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 40px;
}

.blockActTitle::after {
	content: "";
	height: 20px;
	width: 120px;
	position: absolute;
	right: 0;
}

.blockActTitle.titleActivity::after {
	background: url("../images/title-act-activity.png") right bottom no-repeat;
	background-size: auto 20px;
	bottom: -5px;
}

.blockActTitle.titleAthletic::after {
	background: url("../images/title-act-athletic.png") right bottom no-repeat;
	background-size: auto 16px;
	position: absolute;
	bottom: -2px;
}

.blockActTitle.titleDrive::after {
	background: url("../images/title-act-drive.png") right bottom no-repeat;
	background-size: auto 16px;
	position: absolute;
	bottom: -2px;
}

.blockActTitle.titleWalking::after {
	background: url("../images/title-act-walking.png") right bottom no-repeat;
	background-size: auto 20px;
	position: absolute;
	bottom: -5px;
}

.blockTitlePhrase {
	text-align: center;
}

.titlePhrase {
	position: relative;
	display: inline-block;
	font-size: 1.5rem;
	font-weight: bold;
	margin-bottom: 40px;
	margin-top: 20px;
}

.titlePhrase:before,
.titlePhrase:after { 
  content:'';
  width: 10px;
  height: 20px;
  position: absolute;
  display: inline-block;
}

.titlePhrase:before {
  border-left: solid 2px #333;
  border-top: solid 2px #333;
  top: -20px;
  left: -20px;
}

.titlePhrase:after {
  border-right: solid 2px #333;
  border-bottom: solid 2px #333;
  bottom: -20px;
  right: -20px;
}

.titlePhrase__strong {
	border-bottom: double 4px #333;
}

/* item */
.blockPlaceItem {
	margin-bottom: 60px;
}

.blockPlaceItem.type001.itemRocco {
	margin-top: 30px;
}

.blockPlaceItem.type002 {
	position: relative;
	background: #fff;
	border: 2px solid #eceab7;
	padding: 20px;
}

.blockPlaceItem.type003 {
	background: url("../images/bg-002-bottom-sp.png"), url("../images/bg-002-top-sp.png");
	background-repeat: no-repeat;
    background-position: center bottom, center top;
    background-size: 100%;
    background-color: rgba(255,255,255,0.7);
    position: relative;
	padding-bottom: 20px;
}

.blockPlaceItem.type003 .blockPlaceItem__inner {
	background: url("../images/bg-002-middle-sp.png") repeat-y center top;
    background-size: 100%;
    padding-top: 50px;
	padding-left: 20px;
	padding-right: 20px;
	margin-top: 40px;
}

.blockPlaceItem__phrase {
	color: #a18f77;
	text-align: center;
	font-weight: bold;
	margin-bottom: 20px;
	font-size: 1.2rem;
}

.blockPlaceItem__caption {
	position: absolute;
	right: -10px;
	top: -30px;
	width: 80px;
	height: auto;
}

.blockPlaceItem__image {
	position: relative;
	padding-left: 10px;
	padding-right: 10px;
}

.blockPlaceItem__image img {
	
}

.blockPlaceItem__imageCaption {
	position: absolute;
	right: -10px;
	top: -30px;
	width: 80px;
	height: auto;
}

.blockPlaceItem__label {
	position: absolute;
	top: -15px;
	color: #9d9706;
	background: #eceab7;
	font-weight: bold;
	font-size: 1.2rem;
	text-align: center;
	padding-left: 2em;
	padding-right: 2em;
	padding-top: 5px;
	padding-bottom: 5px;
	display: inline-block;
	clip-path: polygon(7% 0%, 100% 0, 92% 100%, 0% 100%);
}

.blockPlaceItem__label span {
	font-size: .9rem;
}

.blockPlaceItem__notes {
	text-align: center;
	margin-top: 10px;
	margin-bottom: 30px;
}

.blockPlaceItem__notes .caption {
	font-size: 1.0rem;
}

.blockPlaceItem__link {
	text-align: center;
}

.blockStepupItem {
	margin-bottom: 60px;
	margin-left: auto;
	margin-right: auto;
}

.blockAttractionLinks {
	margin-top: -40px;
	margin-bottom: 60px;
}

.blockAttractionLinks li {
	text-align: center;
}

.blockAttractionLinks li + li {
	margin-top: 15px;
}

.blockSubLink {
	margin-top: -40px;
	margin-bottom: 60px;
}

.blockSubLink__caption {
	text-align: center;
	margin-bottom: 10px;
}

.blockSubLink__item {
	text-align: center;
}


/* 
 Page Links
-------------------------------------------------------------------*/
.blockPageLinks {
	
}

.blockPageLinks__title {
	text-align: center;
	margin-bottom: 30px;
}

.blockPageLinks__titleItem {
	display: inline-block;
	font-weight: bold;
	font-size: 2.0rem;
	padding-left: 1em;
	padding-right: 1em;
	background: linear-gradient(transparent 70%, #b7dfdc 70%);
}

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

.blockPageLinksItems a {
	display: block;
	width: 48%;
	margin-bottom: 20px;
}

.blockPageLinksItems dt {
	font-weight: bold;
	margin-top: 5px;
}

/* 
 Page Bottom Banner
-------------------------------------------------------------------*/
.blockBannerFoot {
	text-align: center;
	margin-top: 60px;
	margin-bottom: 60px;
}

.blockBannerFoot__phrase {
	font-weight: bold;
	margin-bottom: 20px;
}

.blockBannerFoot__item {
	width: 85%;
	margin-left: auto;
	margin-right: auto;
}

.blockBannerFoot__item a {
	display: block;
	position: relative;
}

.blockBannerFoot__item a + a {
	margin-top: 20px;
}

.blockBannerFoot__item a .footBnrTitle {
	position: absolute;
    top: calc(50% - 20px);
    left: 25%;
    font-size: 2.8vw;
	font-weight: bold;
	text-align: left;
}

.blockBannerFoot__item a .footBnrCaption {
	position: absolute;
    top: calc(50% - 10px);
    right: 9%;
    font-size: 2.0vw;
    font-weight: bold;
    color: #fff;
}

.blockBannerFoot__item a .footBnrCaption::after {
	font-family: "Font Awesome 5 Free";
	content: "\f054";
	font-weight: 900;
	font-size: 1.6vw;
	position: absolute;
	right: -11px;
	top: 0;
	margin: auto;
}

.blockBannerFoot__copy {
	margin-top: -40px;
	margin-bottom: 100px;
	text-align: center;
	font-weight: bold;
}

.blockBannerFoot__copy .price001 {
	font-size: 2.0rem;
}

.blockBannerFoot__copy .price002 {
	font-size: 2.8rem;
	margin-top: 20px;
	display: block;
}

.blockToTop {
	width: 50px;
    height: 50px;
    position: fixed;
    right: 30px;
    bottom: 50px;
    z-index: 200;
	opacity: .8;
}

/* page path */
.pagePath {
	width: auto;
    margin: 50px 5% 5%;
    font-size: 12px;
    line-height: 1.8;
}

.pagePath a {
	color: #12290f;
    text-decoration: none;
}

/* 表示アニメーション */
.isSlidein {
    opacity: 0;
    
    transform: translate(0,30px);
}
.isSlidein.isShow {
    opacity: 1.0;
	transition: .8s;
    transform: translate(0,0);
}

/* slick.js */

.blockTopBanner__slider button{
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.blockTopBanner__slider .slide-arrow{
  position: absolute;
  top: 50%;
  margin-top: -10px;
}

.blockTopBanner__slider .prev-arrow{
	background: url("../images/icon-left-001.png") center center no-repeat;
	background-size: 20px auto;
  left: -18px;
  width: 18px;
  height: 20px;
}
.blockTopBanner__slider .next-arrow{
	background: url("../images/icon-right-001.png") center center no-repeat;
	background-size: 20px auto;
  right: -18px;
  width: 18px;
  height: 20px;
}

.slick-dots {
	bottom: -15px;
}

.slick-dots li {
	height: 2px;
	width: 25px;
	background: #ccc;
}

.slick-dots li.slick-active {
	background: #a18f77;
}

.slick-dots li button {
	width: 100%;
	padding: 0;
}
.slick-dots li button:before {
	content: none;
}

/* footer */

.footer { margin: 0 auto 20px; }