p
{
	margin: 0 0 1.5em;
}
ul
{
	padding-left: 1.5em;
	margin-top: 0;
}

html {
    font-size: 62.5%;
}

img
{
	max-width: 100%;
	vertical-align: top;
	pointer-events:none;
}
body
{
	background-color: #ebf7f6;
	color: var(--color-primary);
	font-family: -apple-system,Segoe UI,Helvetica Neue,Hiragino Kaku Gothic ProN,"メイリオ",meiryo,sans-serif;
	/* font-family: source-han-sans-japanese, "YuGothic","Yu Gothic","Hiragino Kaku Gothic ProN","Hiragino Sans","Meiryo",sans-serif; */
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.8;
	overflow-x: hidden;
	font-feature-settings: "palt";
	letter-spacing: 0.06em;
	background-image: url("../images/common/bg.webp");
	background-position: left top;
	background-repeat: repeat;
	background-size: 250px;
}

h1, h2, h3, h4
{
	color: var(--color-heading);
	/*font-family: "新ゴ B", -apple-system, Segoe UI, Helvetica Neue, Hiragino Kaku Gothic ProN, "メイリオ", meiryo, sans-serif;*/
	font-family: "M PLUS 1", sans-serif;
}

/* ===============================
 Header
=============================== */
body > header {
    background-color: rgb(255,255,255,.93);
    display: flex;
	width: 100%;
	height: 65px;
	justify-content: space-between;
    align-items: center;
	padding: 0;
	position: fixed;
    top: 0;
    left: auto;
    z-index: 1;
}
body > header > div:first-of-type {
	padding: 0 0 0 10px;
	width: 65%;
}
body > header > div:last-of-type {
	width: 35%;
}
.header-logo-wrap
{
    width: 100%;
    margin: 0;
    padding: 0;
	max-width: 450px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.header-logo
{
    margin: 0;
    padding: 0;
	line-height: 1;
	width: 35%;
}
.header-logo a
{
    display: block;
}
.header-logo img
{
    width: 100%;
    margin: 0;
    padding: 0;
	object-fit: cover;
}
.header-catch
{
    margin: 0;
    line-height: 1;
	width: 60%;
}
.header-catch img
{
    vertical-align: baseline;
}

@media screen and (min-width: 768px) {
	body > header {
		height: 95px;
		padding: 10px 15px;
		margin: 0;
		position: static;
	}
	body > header > div:first-of-type {
		padding: 0;
		width: 400px;
		max-width: 35%;
	}
	body > header > div:last-of-type {
		width: 50%;
	}

	.header-logo
	{
		width: 148px;
	}
	.header-catch
	{
		width: calc(100% - 148px - 20px);
		display: block;
	}
	.header-catch img
	{
		width: 100%;
		margin: 0;
		padding: 0;
		object-fit: cover;
	}
}


/* ===============================
  Global Navigation
=============================== */
.gnav-wrap
{
	margin-bottom: 15px;
}
.gnav {
	font-size: 1.5rem;
    list-style: none;
    display: flex;
	justify-content: flex-end;
	align-items: center;
    margin: 0;
    padding: 0;
}
.gnav li {
    padding: 1px 10px;
    border-left: 1px solid #ccc;
}
.gnav .gnav-sns {
    border-left: none;
    padding: 0 10px 0 0;
}
.gnav .gnav-sns img {
    height: 1em;
    width: auto;
}
.gnav a {
	color: #222;
	display: block;
	line-height: 1;
}
.gnav-form {
    display: flex;
    justify-content: flex-end;
}

.gnav-form .btn
{
	width: 225px;
    border: none;
    font-family: inherit;
    font-size: 1.4rem;
    cursor: pointer;
    display: inline-block;
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 1px;
	line-height: 1;
    font-weight: 700;
    outline: none;
    position: relative;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    background-color: #3ec4b7;
    color: #fff;
    padding: 1.2rem 20px 1.2rem 60px;
    border-radius: 8px;
}
.gnav-form .btn:after {
    content: '';
    position: absolute;
    z-index: -1;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}
.gnav-form .btn-write:before {
	border-right: 2px solid rgba(255,255,255,0.7);
    font-family: 'icomoon';
    font-size: 1.6rem;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    -webkit-font-smoothing: antialiased;
    content: "\f040";
	position: absolute;
    height: 100%;
    left: 0;
    top: 0;
    line-height: 2.4;
    width: 45px;
	text-align: center;
}
.gnav-form .btn-write:hover {
    background-color: #56B7B0;
}


.gnav-form-search .search-form {
    width: 300px;
    margin: 0 30px 0 0;
}
.gnav-form-search .search-form-text
{
	font-size: 1.4rem;
	padding: 1.2rem;
	outline: none;
}
.search-form-btn
{
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
}


/* ===============================
  Global Navigation for SP
=============================== */
.gnav-sp-header-hamburger
{
	width: 100%;
	padding-bottom: 1em;
}
.gnav-sp-hamburger-menu
{
    font-size: 3.2vw;
    position: absolute;
    bottom: 0;
}

.gnav-sp-header-button {
	position: relative;
	z-index: 2;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	color: #222;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	width: 55px;
	height: 43px;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	background-color: transparent;
	border: 0;
	padding: 10px;
	cursor: pointer;
	margin: 0 0 0 auto;
}

.gnav-sp-header-button span {
	display: block;
	width: 100%;
	height: 2px;
	background-color: black;
	margin: 0 0 7px;
	-webkit-transition: 500ms ease-in-out;
	transition: 500ms ease-in-out;
}

.gnav-sp-header-button.is-open span {
	margin: 0;
}

.gnav-sp-header-button.is-open span:nth-child(1) {
	-webkit-transform: translateY(1px) rotate(45deg);
	transform: translateY(1px) rotate(45deg);
}
.gnav-sp-header-button.is-open span:nth-child(2) {
	-webkit-transform: translateY(-1px) rotate(-45deg);
	transform: translateY(-1px) rotate(-45deg);
}

.gnav-sp {
    border-top: 1px solid #ccc;
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 1);
	padding: 0 0 20px;
	display: block;
	z-index: 1;
	-webkit-transform: translateX(100%);
	transform: translateX(100%);
	-webkit-transition: transform 500ms ease-in-out;
	transition: transform 500ms ease-in-out;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	margin-left: 0;
}
.gnav-sp.is-show {
	-webkit-transform: translateX(0);
	transform: translateX(0);
}

.gnav-sp-profile {
    height: 60px;
    padding: 0 15px;
}
.gnav-sp-profile ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    height: 100%;
    align-items: center;
}
.gnav-sp-profile a
{
	color: #222;
	padding: 5px;
	text-decoration: underline;
}
.gnav-sp-navi {
    border-top: 1px solid #81d8d0;
}
.gnav-sp-group,
.gnav-sp-banner-group
{
    list-style: none;
    padding: 0;
	margin: 0;
}
.gnav-sp-group .gnav-sp-group .gnav-sp-group a {
    padding-left: 2em;
}
.gnav-sp-banner-group
{
	margin: 20px 15px 30px;
}
.gnav-sp-banner-group li
{
	margin-bottom: 10px;
}
.gnav-sp-group-warap > a:first-of-type
{
    background-color: #81d8d0;
    color: #fff;
    cursor: none;
    display: block;
	font-size: .9em;
	font-weight: 700;
    pointer-events: none;
    padding: 8px 15px;
    width: 100%;
	line-height: 1;
}
.gnav-sp-item a
{
    display: block;
    color: #222;
    line-height: 1;
    padding: 15px 15px;
    border-bottom: 1px solid #81d8d0;
}
.gnav-sp-item a span
{
	font-size: .7em;
}

.gnav-sp-sns-title {
    color: #555;
	font-size: 1.4rem;
	line-height: 1;
    text-align: center;
}
.gnav-sp-sns-group {
    padding: 0;
    list-style: none;
    display: flex;
    justify-content: center;
}
.gnav-sp-sns-item {
    padding: 0 7px;
}

.gnav-sp-copy
{
	text-align: center;
	font-size: 1.2rem;
	margin-top: 25px;
}
.gnav-sp-copy a
{
	color: #222;
}





/* ------------------------------
　　共通
------------------------------ */
main
{
	padding-top: 65px;
}
.base-container
{
    padding: 0 15px 30px;
	max-width: 1160px;
}
.narrow-container
{
	max-width: 1050px;
	position: relative;
	height: 100%;
}
.wide-container
{
    padding: 0 15px 50px;
	max-width: 100%;
	position: relative;
}


.topicpath-wrap
{
	height: auto;
	margin: 15px 0;	
	display: none;
}
.topicpath
{
	padding: 0;
	overflow: inherit;
	font-size: 1.3rem;
}
.topicpath a:link, .topicpath a:visited {
    color: var(--color-link);
}

.main-column
{
	margin-bottom: 50px;
}


.pagetitle-category {
    font-size: 2.1rem;
}

@media screen and (min-width: 768px) {
	main
	{
		padding-top: 0;
	}
	.base-container
	{
		padding: 0 15px 50px;
	}
	.main-column {
		-ms-flex: 1 1 830px;
		flex: 1 1 830px;
		max-width: 830px;
		padding-right: 30px;
	}
	.sub-column {
		width: 300px;
	}
	
	.topicpath-wrap
	{
		display: block;
	}
	.main-column
	{
		margin-bottom: 0px;
	}


	.pagetitle-category {
		font-size: 2.8rem;
	}
}



/* ------------------------------
　　ページタイトル
------------------------------ */
.pagetitle-tag::before
{
	content: "#";
}

.pagetitle-top,
.pagetitle-category,
.pagetitle-tag
{
	background: linear-gradient(transparent 60%, #ffcc33 60%);
    display: inline-block;
    margin: 15px 0 30px;
    line-height: 1.3;
    padding: 0 10px;
}
.pagetitle-top span {
    font-size: 0.5em;
    letter-spacing: 0.1px;
}
/* ------------------------------
　　エントリー
------------------------------ */

.btn-like,
.btn-clip
{
    display: inline-block;
	font-size: 1.4rem;
}
.like-on,
.like-off,
.clip-on,
.clip-off
{
    border-radius: 3px;
    display: flex;
    align-items: center;
	cursor: pointer;
    padding: 3px 5px;
    line-height: 1;
}
.like-on > div:last-of-type,
.like-off > div:last-of-type,
.clip-on > div:last-of-type,
.clip-off > div:last-of-type
{
	padding-left: 3px;
	font-size: .8em;
}
.like-on
{
    border: 1px solid #fa3ca2;
	background-color: #fa3ca2;
	color: #fff;
}
.like-off
{
    border: 1px solid #ccc;
	background-color: #fff;
	color: var(--color-black);
}
.like-off .fa-heart-o
{
	color: #fa3ca2;
}


.clip-on
{
    border: 1px solid #555;
	background-color: #555;
	color: #fff;
}
.clip-off
{
    border: 1px solid #ccc;
	background-color: #fff;
	color: var(--color-black);
}




#loginBg
{
	background-image: url("../images/bg_green.webp");
	background-repeat: repeat;
	background-position: left top;
	background-size: 270px;
}



.header-title a
{
	width: 100%;
	max-width: 400px;
    display: block;
    height: 50px;
}
.header-title a img
{
    width: 100%;
    height: 100%;
    object-fit: cover;
}




body > footer {
	background-color: var(--color-key01);
	color: #fff;
    padding: 20px 0;
}
.footer-copyright-text {
    text-align: center;
    font-size: 1.2rem;
    padding: 10px 0;
	margin: 0;
}
.footer-copyright-text a {
	color: #fff;
}


.fotter-contents
{
	margin-bottom: 20px;
}
.footer-nav
{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	font-size: 1.3rem;
	margin-bottom: 30px;
}
.footer-nav > div
{
	width: 48%;
}
.footer-nav h3
{
	margin: 0 0 5px;
	font-size: 1.4rem;
}
.fotter-nav-title {
    margin: 0 0 5px;
    font-size: 1.4rem;
	font-weight: 600;
}
.footer-nav > div:last-of-type
{
	padding-right: 0px;
}
.fnav-group
{
	padding-left: 1.2em;
}
.footer-nav a
{
	color: #fff;
}
.footer-nav a:hover,
.footer-nav a:active,
.footer-nav a:visited
{
	color: #fff;
}
.footer-logo
{
	width: 100%;
	text-align: center;
}
.footer-logo a
{
	display: block;
}
.footer-logo img
{
	width: 60%;
}

.gototop {
    position: fixed;
    bottom: 0;
    right: 0;
}
.gototop a {
    display: block;
    line-height: 50px;
    width: 50px;
    text-align: center;
    background-color: rgb(255,255,255, .85);
    color: var(--color-btn-primary);
}

@media screen and (min-width: 768px) {
	.fotter-contents
	{
		display: flex;
		margin-bottom: 20px;
	}
	.footer-nav
	{
		width: 85%;
		justify-content: flex-start;
		font-size: 1.4rem;
	}
	.footer-nav > div
	{
		padding-right: 25px;
		width: auto;
	}

	.footer-logo
	{
		width: 15%;
	}
	.footer-logo img
	{
		width: 100%;
	}
}


/* ------------------------------
　Widget
------------------------------ */
.side-widget
{
}
.side-banner {
	margin: 0;
}

.side-banner ul {
	padding: 0;
	list-style: none;
	margin: 0;
}
.side-banner li {
  margin: 0 0 15px;
}
.side-banner a {
  display: block;
}

._taxel_recommend_articles
{
	margin-bottom: 20px !important;
}

.bnr-calender-wrap
{
	display: flex;
	justify-content: space-between;
}
.bnr-event-calender,
.bnr-live-calender
{
	width: calc(50% - 1px);
}

@media screen and (min-width: 768px) {
	.side-widget
	{
		margin: 0 0 30px;
	}
	.side-widget:last-of-type
	{
		margin: 0;
	}
	._taxel_recommend_articles
	{
		margin-bottom: 30px !important;
	}
}




/* ------------------------------
　Ranking Widget
------------------------------ */
.side-widget.side-entry-list {
   	margin: 30px -15px;
}
.side-widget.side-entry-list h2 {
	border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    margin: 0;
    padding: 10px 15px;
	background-color: var(--color-key01);
    color: #fff;
	font-size: 1.8rem;
}
.side-ranking-monthry {
    margin: 0;
    padding: 15px 15px;
    background-color: #fff;
}
.side-entry-list ol,
.side-entry-list ul
{
	list-style: none;
	margin: 0;
	padding: 0;
} 
.side-entry-list li
{
	margin: 0 0 8px;
	padding: 0 0 8px;
	border-bottom: 1px solid #ddd;
}
.side-entry-list li:last-of-type
{
	margin: 0;
	padding: 0;
	border-bottom: none;
}
.side-entry-list li
{
	display: flex;
	justify-content: space-between;
	position: relative;
}
.side-entry-list li > div:first-of-type
{
	width: 100px;
	height: 100px;
}
.side-entry-list li > div:first-of-type a
{
	display: block;
}

.side-entry-list li > div:last-of-type
{
	width: calc(100% - 110px);
}
.side-entry-list li > div:last-of-type .icon,
.side-entry-list li > div:last-of-type time
{
	font-size: 1.2rem;
}
.side-ranking-no {
    border-radius: 50%;
    background-color: #F4F4F4;
    border: 1px solid #fff;
    font-size: 1.4rem;
	font-weight: 600;
	font-style: italic;
    position: absolute;
    top: -12px;
    left: -12px;
    line-height: 22px;
    width: 24px;
    height: 24px;
    text-align: center;
}
.side-ranking-no.no1 {
    background-color: gold;
}
.side-ranking-no.no2 {
    background-color: silver;
}
.side-ranking-no.no3 {
    background-color: sandybrown;
}
.side-entry-list-title,
.side-entry-list-title a
{
	color: #333;
    line-height: 1.4;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	margin-bottom: 3px;
    font-size: 1.6rem;
	font-weight: 600;
	font-family: "M PLUS 1", sans-serif;


}
.side-entry-list li a img
{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.side-entry-list-access-num
{
	margin: 0;
	line-height: 1;
	font-size: 1.2rem;
}
.side-entry-list-pr {
    margin: 0;
    color: #555;
    font-size: 1.2rem;
    text-align: right;
}

@media screen and (min-width: 768px) {
	.side-widget.side-ranking {
		margin: 0 0 30px 0;
	}
	.side-ranking li > div:first-of-type
	{
		width: 60px;
		height: 60px;
	}
	.side-ranking li > div:last-of-type
	{
		font-size: 1.3rem;
		line-height: 1.4;
		width: calc(100% - 70px);
	}
	.side-ranking-no {
		top: -8px;
		left: -8px;
		line-height: 16px;
		width: 19px;
		height: 19px;
		font-size: 1.3rem;
	}
	.side-entry-list-title,
	.side-entry-list-title a
	{
		font-size: 1.3rem;
	}
}


.ranking-tab-wrap {
	background: #fff;
	box-shadow: 0 0 5px rgba(0,0,0,.1);
	display: flex;
	flex-wrap: wrap;
	overflow: hidden;
	padding: 0 0 20px;
}
.side-ranking-summary
{
	counter-reset: listnum;
	list-style: none;
}
.side-ranking-summary .side-ranking-no::before{
	counter-increment: listnum;
	content: counter(listnum);
}

.side-ranking-summary li:nth-of-type(1) .side-ranking-no
{
    background-color: gold;
}
.side-ranking-summary li:nth-of-type(2) .side-ranking-no
{
    background-color: silver;
}
.side-ranking-summary li:nth-of-type(3) .side-ranking-no
{
    background-color: sandybrown;
}

.ranking-tab-label {
	color: #808080;
	cursor: pointer;
	flex: 1;
	font-weight: bold;
	order: -1;
	padding: 10px 5px;
	position: relative;
	text-align: center;
	transition: cubic-bezier(0.4, 0, 0.2, 1) .2s;
	user-select: none;
	white-space: nowrap;
	-webkit-tap-highlight-color: transparent;
	width: 33.33333%;
	font-size: 16px;
    border-bottom: 1px solid #ddd;
}

.ranking-tab-label:hover {
	background: rgba(0, 191, 255,.1);
}

.ranking-tab-switch:checked + .ranking-tab-label {
	color: #00A9E2;
}

.ranking-tab-label::after {
	background: #00A9E2;
	bottom: 0;
	content: '';
	display: block;
	height: 3px;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transform: translateX(100%);
	transition: cubic-bezier(0.4, 0, 0.2, 1) .2s 80ms;
	width: 100%;
	z-index: 1;
}

.ranking-tab-switch:checked ~ .ranking-tab-label::after {
	transform: translateX(-100%);
}

.ranking-tab-switch:checked + .ranking-tab-label::after {
	opacity: 1;
	transform: translateX(0);
}

.ranking-tab-content {
	height:0;
	opacity:0;
	padding: 0 20px;
	pointer-events:none;
	transform: translateX(-30%);
	transition: transform .3s 80ms, opacity .3s 80ms;
	width: 100%;
}

.ranking-tab-switch:checked ~ .ranking-tab-content {
	transform: translateX(30%);
}

.ranking-tab-switch:checked + .ranking-tab-label + .ranking-tab-content {
	height: auto;
	opacity: 1;
	order: 1;
	pointer-events:auto;
	transform: translateX(0);
}

.ranking-tab-wrap::after {
	content: '';
	height: 20px;
	order: -1;
	width: 100%;
}

.ranking-tab-switch {
	display: none;
}

/* ------------------------------
　Tag Cloud Widget
------------------------------ */
.tag-cloud a {
    font-size: 13px;
    font-weight: 700;
    background-color: #dbdbdb;
    padding: 5px 10px;
    border-radius: 9999999px;
    line-height: 1;
    display: inline-block;
    color: #fff;
    margin-bottom: 7px;
}





/* ------------------------------
　Tag List Page
------------------------------ */
.tags-list
{
	display: flex;
    flex-wrap: wrap;
	list-style: none;
	font-size: 1.5rem;
	padding: 0;
}
.tags-list li
{
    width: 25%;
    padding: 0 1em 0 0;
}
.tags-list li a::before
{
    content: "#";
}



/* ------------------------------
　Area List Page
------------------------------ */
.area-list-group {
	list-style: none;
	padding: 0;
}
.area-list-group a {
    color: var(--color-primary);
	line-height: 2.2;
	border-bottom:dotted;
	border-color: cadetblue;
}
.area-list-group-item.level1 {
    font-size: 2rem;
	font-weight: 700;
}
.area-list-group-item.level2 {
    font-size: 1.8rem;
	font-weight: 700;
}
.area-list-group-item + ul {
    padding-left: 1em;
}
.area-list-group-item.level2 + ul {
    display: flex;
    flex-wrap: wrap;
}
.area-list-group-item.level2 + ul li {
    width: 33.333%;
}

@media screen and (min-width: 768px) {
	.area-list-group-item + ul {
		padding-left: 2em;
	}
	.area-list-group-item.level2 + ul li {
		width: 20%;
	}
}


/* ------------------------------
　Contact
------------------------------ */
/* Step
------------------------------ */
.form-step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0 25px 0;
  padding: 0;
  /* カウンターの設定 */
  counter-reset: mailStep;
}

.form-step-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 14px 0 10px;
  color: var(--color-gray100);
  font-weight: bold;
  list-style: none;
  font-size: 1.6rem;
}
@media print {
  .form-step-item {
    font-size: 1.6rem;
  }
}
.form-step-item::before {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  height: 30px;
  margin: 0 0 10px 0;
  color: var(--color-primary);
  line-height: 1.7;
  background: var(--color-gray10);
  border-radius: 50%;
  content: counter(mailStep);
  /* カウンターの設定 */
  counter-increment: mailStep;
}
.form-step-item.is-current::before {
  color: var(--color-white);
  background: var(--color-primary);
}
.form-step-item:not(:last-child) {
  margin: 0 20px 0 0;
}

@media screen and (min-width: 768px) {
  .form-step-item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 18px 0 14px;
    font-size: 2.2rem;
  }
  .form-step-item::before {
    width: 38px;
    height: 38px;
    margin: 0 10px 0 0;
    font-size: 2.4rem;
  }
  .form-step-item:not(:last-child) {
    margin: 0 30px 0 0;
  }
}
@media screen and (max-width: 767px) {
  .form-step {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
/* フォームレイアウト
------------------------------ */
.form-group-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none !important;
}
.form-group-list.is-confirm {
  padding: 0 10px;
}

.form-group-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  margin: 0;
  padding: 0;
}

.form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  margin: 0 0 30px 0;
  padding: 0;
}

.form-label {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  margin: 0 0 10px 0;
  font-weight: bold;
  text-align: left;
}

.form-control {
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  line-height: 1.7;
}

.form-button-group .button {
  margin: 0;
}

@media screen and (min-width: 768px) {
  .form-label {
    vertical-align: top;
  }
}
.form-button-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 30px 0 0 0;
}

@media screen and (min-width: 480px) {
  .form-button-group {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    margin: 40px 0 0 0;
  }

  .form-button:not(:last-child) {
    margin: 0 20px 0 0;
  }
}
@media screen and (max-width: 479px) {
  .form-button {
    width: 100%;
    margin: 0 0 15px 0;
  }
  .form-button .button {
    width: 100%;
  }

  .form-button-return {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
/* ラベル
------------------------------ */
.label-required {
  margin: 0 0 0 5px;
  padding: 2px 8px;
  color: #FFF;
  vertical-align: middle;
  background: var(--color-error);
  border-radius: 3px;
  font-size: 1.2rem;
}
@media print {
  .label-required {
    font-size: 1.2rem;
  }
}
.label-required:first-child {
  margin: 0 5px 0 0;
}

@media screen and (min-width: 768px) {
  .label-required {
    margin: 0 0 0 10px;
  }
  .label-required:first-child {
    margin: 0 10px 0 0;
  }
}
.label-optional {
  margin: 0 0 0 5px;
  padding: 2px 8px;
  color: var(--color-gray100);
  vertical-align: middle;
  background: var(--color-gray40);
  border-radius: 3px;
  font-size: 1.2rem;
}
@media print {
  .label-optional {
    font-size: 1.2rem;
  }
}
.label-optional:first-child {
  margin: 0 5px 0 0;
}

@media screen and (min-width: 768px) {
  .label-optional {
    margin: 0 0 0 10px;
  }
  .label-optional:first-child {
    margin: 0 10px 0 0;
  }
}
/* フォーム要素
------------------------------ */
.form-group select[required]:required {
  border: 1px solid var(--color-error);
}
.form-group select.focused:invalid {
  border: 1px solid var(--color-error);
}
.form-group select[required]:valid {
  border: 1px solid var(--color-gray40);
}
.form-group input[required]:required,
.form-group textarea[required]:required {
  background: var(--color-gray10);
}
.form-group input.focused:invalid, .form-group input.invalid,
.form-group textarea.focused:invalid,
.form-group textarea.invalid {
  background: var(--color-gray10);
  border-color: var(--color-error);
  -webkit-box-shadow: var(--box-shadow-error), 0 1px 1px rgba(0, 0, 0, 0.1) inset;
          box-shadow: var(--box-shadow-error), 0 1px 1px rgba(0, 0, 0, 0.1) inset;
}
.form-group input[required]:valid,
.form-group textarea[required]:valid {
  background: var(--color-gray10);
}
.form-group input[type=text],
.form-group input[type=password],
.form-group input[type=datetime],
.form-group input[type=datetime-local],
.form-group input[type=date],
.form-group input[type=month],
.form-group input[type=time],
.form-group input[type=week],
.form-group input[type=number],
.form-group input[type=email],
.form-group input[type=url],
.form-group input[type=search],
.form-group input[type=tel] {
  font-size: 1.6rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 11px 15px;
  line-height: 1.5;
  border-radius: 3px;
}
@media print {
  .form-group input[type=text],
.form-group input[type=password],
.form-group input[type=datetime],
.form-group input[type=datetime-local],
.form-group input[type=date],
.form-group input[type=month],
.form-group input[type=time],
.form-group input[type=week],
.form-group input[type=number],
.form-group input[type=email],
.form-group input[type=url],
.form-group input[type=search],
.form-group input[type=tel] {
    font-size: 1.6rem;
  }
}
.form-group textarea {
  font-size: 1.6rem;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 11px 15px;
  border-radius: 3px;
}
@media print {
  .form-group textarea {
    font-size: 16px;
  }
}
.form-group select {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  min-height: 48px;
  padding: 9px 44px 9px 15px;
  vertical-align: top;
  background-color: var(--color-gray10);
  font-size: 1.6rem;
  border-radius: 3px;
}
@media print {
  .form-group select {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 768px) {
  .form-group input[type=text],
.form-group input[type=password],
.form-group input[type=datetime],
.form-group input[type=datetime-local],
.form-group input[type=date],
.form-group input[type=month],
.form-group input[type=time],
.form-group input[type=week],
.form-group input[type=number],
.form-group input[type=email],
.form-group input[type=url],
.form-group input[type=search],
.form-group input[type=tel] {
    padding: 11px 15px;
  }
  .form-group textarea {
    padding: 11px 15px;
  }
}
.form-checkbox-only {
  display: block;
  margin: 0;
  padding: 16px 15px 12px;
  background: var(--color-gray20);
  border-radius: 3px;
}
.form-checkbox-only:hover {
  background: var(--color-gray30);
}

.form-checkbox-only-label {
  vertical-align: middle;
}
.form-checkbox-only-label a:link,
.form-checkbox-only-label a:hover,
.form-checkbox-only-label a:visited,
.form-checkbox-only-label a:active,
.form-checkbox-only-label a:focus {
  text-decoration: none;
  border-bottom: 1px dashed;
}

/* 検索フォーム
------------------------------ */
.form-search .form-search-action {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
}
.form-search .form-search-action .button {
	margin-left: -1px;
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
	font-size: 2rem;
	width: 80px;
	background: var(--color-key01);
}
.form-search input.form-search-input {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
	height: 48px;
	padding: 10px;
	background: var(--color-gray10);
	border: 3px solid var(--color-key01);
	border-radius: 4px;
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	-webkit-transition: background-color 0.25s ease;
	transition: background-color 0.25s ease;
	-webkit-appearance: none;
	font-size: 1.6rem;
	width: calc(100% - 80px);
	outline: none;
}
@media print {
	.form-search input.form-search-input {
		font-size: 1.6rem;
	}
}
.form-search input.form-search-input:hover {
  background: var(--color-white);
  border-color: var(--color-gray50);
}
.form-search input.form-search-input:focus {
  background: var(--color-white);
  border-color: #137AF3;
  outline: none;
  -webkit-box-shadow: 0 0 0 2px rgba(19, 122, 243, 0.4), 0 1px 1px rgba(0, 0, 0, 0.1) inset;
          box-shadow: 0 0 0 2px rgba(19, 122, 243, 0.4), 0 1px 1px rgba(0, 0, 0, 0.1) inset;
}
.form-search .form-search-side-button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	white-space: nowrap;
	width: 80px;
}
.form-search .form-search-button {
  padding: 12px 15px;
}
@media screen and (min-width: 768px) {
  .form-search input.form-search-input {
    height: 60px;
    padding: 15px 20px;
    font-size: 2.2rem;
  }
  .form-search .form-search-button {
    width: 100px;
  }
	.form-search .form-search-action .button {
		font-size: 2.8rem;
	}
}

/* ヘルパーテキスト
------------------------------ */
.form-helper-text {
  margin: 10px 0;
  font-size: 1.4rem;
  color: var(--color-gray90);
}
@media print {
  .form-helper-text {
    font-size: 1.4rem;
  }
}

/* バリデーター
------------------------------ */
.form-group .valid-mark {
  display: none;
}
.form-group .valid-mark.valid {
  display: inline;
  float: right;
  color: #5cb85c;
}
.form-group .invalid {
  border-color: var(--color-error);
}

.form-error-text {
  margin: 10px 0;
  color: var(--color-error);
  font-size: 1.4rem;
}
@media print {
  .form-error-text {
    font-size: 1.4rem;
  }
}
.form-helper-text + .validator-result-0 .form-error-text {
  margin-top: 0;
}

.transaction-notice-, .v-result-, .v-result-1, .validator-result-, .validator-result-1 {
  display: none;
}

/* メッセージ
------------------------------ */
.form-message {
  margin: 0 0 40px 0;
}

.form-message-back {
  text-align: center;
}

@media screen and (min-width: 768px) {
  .form-message {
    margin: 0 0 60px 0;
  }
}

/* ------------------------------
　　ボタン
------------------------------ */
.button {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 10px 20px;
  color: var(--color-white);
  font-weight: bold;
  text-align: center;
  background: var(--color-primary);
  border: 0;
  border-radius: 4px;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
  font-size: 1.8rem;
	width: 100%;
}
@media print {
  .button {
    font-size: 1.8rem;
  }
}
.button:hover, .button:visited, .button:active, .button:focus {
  color: var(--color-white);
  text-decoration: none;
}
.button:hover {
  background: var(--color-primary-hover);
}
.button.is-lg {
  display: inline-block;
  margin: 0 auto;
  padding: 15px 20px;
}
.button.is-block {
  width: 100%;
}
.button.is-xl {
  width: 280px;
  max-width: 100%;
}
.button.is-width-lg {
  width: 280px;
  max-width: 100%;
}
.button.is-shadow {
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
}
.button.is-shadow-light {
  -webkit-box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3);
          box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3);
}
.button.is-inverse {
  color: var(--color-gray100);
  background: var(--color-white);
}
.button.is-inverse:hover {
  background: var(--color-gray10);
}
.button.is-bordered {
  color: var(--color-gray100);
  background: transparent;
  border: 1px solid var(--color-gray40);
}
.button.is-bordered:hover {
  background: var(--color-gray20);
}
.button.is-rounded {
  border-radius: 10em;
}
@media screen and (min-width: 768px) {
	.button
	{
		width: auto;
	}
  .button.is-xl {
    min-width: 340px;
    padding: 15px;
    font-size: 2.4rem;
  }
}

.pager
{
	margin-bottom: 0;
}


.btn-wrap
{
	text-align: center;
}
.btn
{
	display: inline-block;
	width: 100%;
	line-height: 1;
	padding: 15px 15px;
	font-size: 1.6rem;
	text-align: center;
	border-radius: 5px;
	font-weight: 600;
	-webkit-transition: all 0.3s;
	position: relative;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}
.btn-default
{
	background-color: #3ec4b7;
	color: #fff !important;
}
.btn-default:visited,
.btn-default:active
{
	background-color: #3ec4b7;
	color: #fff;
}
.btn-default {
  border-bottom: 5px solid #2E998E;
  position: relative;
  padding: 1.5rem 3rem 1.5rem 2rem;
  border-radius: 100vh;
}

.btn-default:hover {
	color: #fff;
	background-color: #3ec4b7;
	margin-top: 3px;
	border-bottom: 2px solid #2E998E;
}

.btn-default:before {
  font-family: 'icomoon';
  font-size: 1.6rem;
  line-height: 1;
  position: absolute;
  top: calc(50% - .8rem);
  right: 2rem;
  margin: 0;
  padding: 0;
  content: '\f054';
}
@media screen and (min-width: 768px) {
	.btn
	{
		width: 80%;
		max-width: 400px;
	}

}





.select2-dropdown {
    z-index: 9999999 !important;
}

._taxel_recommend_container[gmo_css='gmo_rw_36376'] h2 {
    background-color: var(--color-key01) !important;
}



.side-instagram_gallery h2
{
    font-weight: 700;
    font-size: 2.1rem;
    text-align: center;
    letter-spacing: 0;
    background: rgb(76,100,211);
    background: linear-gradient(90deg, rgba(76,100,211,1) 0%, rgba(207,46,146,1) 33%, rgba(242,105,57,1) 67%, rgba(255,221,131,1) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 10px;
}
.instagram-gallery {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
	list-style: none;
    margin: 0 -15px;
	padding: 0;
}
.instagram-gallery a {
	display: block;
}
.instagram-gallery img {
	aspect-ratio: 1/1;
	transition-duration: .3s;
}
.instagram-gallery a:hover img {
	filter: contrast(130%);
}
@media screen and (min-width: 768px) {
	.instagram-gallery {
		grid-template-columns: repeat(6, 1fr);
		margin: 0;
	}

	.side-instagram_gallery .instagram-gallery {
		grid-template-columns: repeat(3, 1fr);
	}

}


/* Amazon リンクカード ジェネレーター
------------------------------ */
.amazon-card {
	max-width: 600px;
	margin: 1.5rem 0;
	border: 1px solid #ddd;
	border-radius: 8px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 2px 4px rgba(0,0,0,0.08);
	transition: box-shadow 0.2s ease;
  }
  .amazon-card:hover {
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  }
  .amazon-card-link {
    display: flex;
    text-decoration: none !important;
    color: inherit !important;
    border: none !important;
	padding: 0 !important;
  }
  .amazon-card-image {
	flex-shrink: 0;
	width: 150px;
	padding: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #f8f8f8;
  }
  .amazon-card-image img {
	max-width: 100%;
	max-height: 180px;
	object-fit: contain;
  }
  .amazon-card-content {
	flex: 1;
	padding: 15px;
	display: flex;
	flex-direction: column;
	justify-content: center;
  }
  .amazon-card-title {
    margin: 0 0 8px !important;
    font-size: 1.5rem !important;
    font-weight: 600;
    line-height: 1.4;
    color: #111 !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
  }
  .amazon-card-author {
	margin: 0 0 5px;
	font-size: 0.875rem;
	color: #555;
  }
  .amazon-card-price {
    margin: 0 0 10px !important;
    font-size: 1.5rem;
    font-weight: bold;
    color: #B12704;
    line-height: inherit !important;
  }
  .amazon-card-button {
	display: inline-block;
	padding: 8px 16px;
	background: #FFD814;
	border-radius: 20px;
	font-size: 1.4rem;
	font-weight: 500;
	color: #111;
	text-align: center;
	margin-top: auto;
	width: fit-content;
  }
  .amazon-card-link:hover .amazon-card-button {
	background: #F7CA00;
  }
  @media (max-width: 480px) {
	.amazon-card-link {
	  flex-direction: column;
	}
	.amazon-card-image {
	  width: 100%;
	  padding: 20px;
	}
	.amazon-card-image img {
	  max-height: 200px;
	}
  }


/* ------------------------------
　　Various
------------------------------ */
.header-message
{
	padding-top: 65px;
	margin-bottom: -60px;
}
.header-message a
{
	display: block;
}
.header-message img
{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.gmap {
  width: 100%;
  position: relative;
  padding-top: 56.25%;
}

.gmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}



.bg-white-op80
{
	background-color: rgba(255, 255, 255, .8);
	display: inline-block;
	width: 100%;
    height: 100%;
}

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

.fadeUpTrigger{
    opacity: 0;
}


.icon-calender {
    background-color: rgba(238,232,170,1.00);
    border-radius: 5px;
    font-size: 1.2rem;
    line-height: 1;
	letter-spacing: 0.01em;
	margin-right: 2px;
    padding: 2px 4px;
}

.color-royalblue
{
	color: royalblue;
}
.color-forestgreen
{
	color: forestgreen;
}
.color-lightcoral
{
	color: lightcoral;
}


.m-0
{
	margin: 0px;
}

.mt-0
{
	margin-top: 0px;
}
.mt-1
{
	margin-top: 10px;
}
.mt-2
{
	margin-top: 20px;
}
.mt-3
{
	margin-top: 30px;
}
.mt-4
{
	margin-top: 40px;
}
.mt-5
{
	margin-top: 50px;
}

.mb-0
{
	margin-bottom: 0 !important;
}
.mb-1
{
	margin-bottom: 10px !important;
}
.mb-2
{
	margin-bottom: 20px !important;
}
.mb-3
{
	margin-bottom: 30px !important;
}
.mb-4
{
	margin-bottom: 40px!important;
}
.mb-5
{
	margin-bottom: 50px !important;
}

.pb-0
{
	padding-bottom: 0;
}

.text-center
{
	text-align: center;
}
.text-right
{
	text-align: right !important;
}

.text-deco
{
	text-decoration: underline;
}

.pc-br
{
	display: none;
}
.sp-br
{
	display: block;
}
.disp-sp
{
}
.disp-pc
{
	display: none;
}
.space-pc
{
	display: none;
}

.text-sm-center
{
	text-align: center;
}

.fs-mini {
    font-size: .8em;
}
.pc-space
{
	display: none;
}

.video-responsive-1_1 video
{
	width: 100%;
	aspect-ratio: 1/1;
}

#adminBox, .acms-admin-box {
    margin-bottom: 0 !important;
}

@media screen and (min-width: 768px) {
	/* Layout */
	.columns
	{
		display: flex;
		justify-content: space-between;
		padding: 0 15px;
		margin: 0 -15px;
	}
	.column
	{
		width: 50%;
		padding: 0 15px;
	}
	.header-message
	{
		display: none;
	}

	.pc-br
	{
		display: block;
	}
	.sp-br
	{
		display: none;
	}
	.disp-sp
	{
		display: none;
	}
	.disp-pc
	{
		display: block;
	}
	.space-pc
	{
		display: inline-block;
	}
	.text-sm-center
	{
		text-align: left;
	}

	.text-md-center
	{
		text-align: center;
	}
	.acms-grid
	{
		margin-right: -15px;
		margin-left: -15px;
	}
	.pc-space
	{
		display: inline-block;
	}
}