@charset "UTF-8";
/*==========================================
変数 inc.scss
===========================================*/
.format-area .format-txt {
  line-height: 2; }
  .format-area .format-txt a {
    color: #000;
    text-decoration: underline !important; }
    .format-area .format-txt a img {
      transition: .3s; }
    .format-area .format-txt a:hover {
      text-decoration: none !important; }
      .format-area .format-txt a:hover img {
        opacity: 0.7; }
  .format-area .format-txt p:not(:last-child) {
    margin-bottom: 1em; }
  .format-area .format-txt strong {
    font-weight: bold; }
  .format-area .format-txt em {
    font-style: italic; }
  .format-area .format-txt img {
    height: auto; }
  .format-area .format-txt ul {
    margin: 1em 0; }
    .format-area .format-txt ul li {
      position: relative;
      padding: 0 0 0 1em; }
      .format-area .format-txt ul li:not(:last-child) {
        margin-bottom: 0.7em; }
      .format-area .format-txt ul li::before {
        top: 0.6em;
        left: 0;
        content: "";
        display: block;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: #000;
        position: absolute; }
  .format-area .format-txt ol {
    list-style-type: decimal;
    margin: 1em 0 1em 1em; }
    .format-area .format-txt ol li {
      padding: 0; }
      .format-area .format-txt ol li:not(:last-child) {
        margin-bottom: 0.7em; }
.format-area .format-img {
  font-size: 0;
  text-align: center; }
.format-area .img-caption {
  font-size: 1.6rem;
  margin-top: 10px;
  text-align: left; }
.format-area .format-row {
  display: flex;
  justify-content: space-between; }
.format-area .format01 {
  margin: 60px auto; }
.format-area .format02 {
  margin: 60px auto; }
.format-area .format03 {
  margin: 60px auto; }
.format-area .format04 {
  margin: 60px auto; }
.format-area .format05 {
  margin: 60px auto; }
.format-area .format06 {
  margin: 60px auto; }
.format-area .format07 {
  margin: 60px auto; }
.format-area .format08 {
  margin: 60px auto; }
.format-area .format09 {
  margin: 60px auto; }
.format-area .format01 .ttl-lrg {
  font-size: 3.4rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  padding: 15px 0 15px 15px;
  border-left: 12px solid #2b3531;
  color: #2b3531; }
.format-area .format02 .ttl-mid {
  color: #cacf2e;
  font-size: 2.2rem;
  font-weight: bold;
  padding: 0 0 20px;
  border-bottom: 1px solid #cacf2e; }
.format-area .format07 .format-img {
  width: 48%; }
  .format-area .format07 .format-img-wrap {
    position: relative;
    overflow: hidden;
    padding-top: 60.78%; }
    .format-area .format07 .format-img-wrap img {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      height: 100%;
      width: auto;
      max-width: inherit; }
.format-area .format08 .format-img {
  width: 32%; }
  .format-area .format08 .format-img-wrap {
    position: relative;
    overflow: hidden;
    padding-top: 60.78%; }
    .format-area .format08 .format-img-wrap img {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      height: 100%;
      width: auto;
      max-width: inherit; }

@media screen and (min-width: 768px) {
  .format-area .format-rowPC {
    display: flex;
    justify-content: space-between; }
    .format-area .format-rowPC .head, .format-area .format-rowPC .body {
      width: 48%; }
  .format-area .format05 .format-rowPC {
    flex-direction: row-reverse; } }
@media screen and (max-width: 767px) {
  .format-area .format-rowPC .head {
    margin-bottom: 25px; }
  .format-area .format01 .ttl-lrg {
    font-size: 2.6rem; }
  .format-area .format02 .ttl-mid {
    font-size: 2.2rem; }
  .format-area .format08 .format-row {
    flex-wrap: wrap; }
  .format-area .format08 .format-img {
    width: 48%; }
  .format-area .format08 .format-img:last-child {
    width: 100%;
    margin-top: 25px; } }
@media screen and (max-width: 576px) {
  .format-area .format01 {
    margin: 40px auto; }
  .format-area .format02 {
    margin: 40px auto; }
  .format-area .format03 {
    margin: 40px auto; }
  .format-area .format04 {
    margin: 40px auto; }
  .format-area .format05 {
    margin: 40px auto; }
  .format-area .format06 {
    margin: 40px auto; }
  .format-area .format07 {
    margin: 40px auto; }
  .format-area .format08 {
    margin: 40px auto; }
  .format-area .format09 {
    margin: 40px auto; }
  .format-area .format01 .ttl-lrg {
    font-size: 2.2rem;
    border-width: 8px;
    padding: 7px 0 7px 15px; }
  .format-area .format02 .ttl-mid {
    font-size: 1.8rem;
    padding: 0 0 15px; }
    .format-area .format02 .ttl-mid::before {
      width: 60%; }
  .format-area .format09 iframe {
    height: 320px; } }
/*==========================================
 　共通
===========================================*/
.event-archive .sec-ttl, .event-single .sec-ttl {
  margin: 0 auto 150px; }

@media screen and (min-width: 768px) {
  .event-archive .sec-ttl-ja, .event-single .sec-ttl-ja {
    right: calc(50% - 13em); } }
@media screen and (max-width: 767px) {
  .event-archive .sec-ttl, .event-single .sec-ttl {
    margin: 0 auto 100px; } }
/*==========================================
 　一覧
===========================================*/
.event-item a {
  display: block; }
  .event-item a:hover .item-img img {
    transform: scale(1.1, 1.1); }
.event-item .item-img {
  font-size: 0;
  overflow: hidden;
  margin: 0 auto 20px; }
  .event-item .item-img img {
    transition: all 0.8s ease; }
.event-item .item-date {
  display: inline-block;
  margin: 0 45px 0 0; }
.event-item .item-cat {
  display: inline-block;
  border: 1px solid #787878;
  color: #787878;
  padding: 2px 25px;
  margin: 0 .5% .5vw 0; }
.event-item .new-area {
  display: inline-block;
  margin: 0 .5% .5vw 0; }
  .event-item .new-area span {
    display: none; }
  .event-item .new-area .new {
    display: inline-block;
    background: #e70012;
    border: 1px solid #e70012;
    color: #fff;
    padding: 2px 25px; }
.event-item .item-ttl {
  display: block;
  font-weight: bold;
  margin: 20px auto 0; }

.event-pickup .event-item {
  max-width: 720px;
  width: 100%;
  margin: 0 auto 130px; }
  .event-pickup .event-item .item-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    font-family: 'object-fit: cover;'; }
  .event-pickup .event-item .item-ttl {
    font-size: 2rem; }

.event-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .event-list .event-item {
    max-width: 485px;
    width: 48%; }
    .event-list .event-item:nth-of-type(n+3) {
      margin-top: 100px; }
    .event-list .event-item .item-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      font-family: 'object-fit: cover;'; }

@media screen and (max-width: 1140px) {
  .event-list .event-item {
    max-width: none; }
    .event-list .event-item .item-date {
      margin: 0 25px 0 0; }
    .event-list .event-item .item-cat {
      font-size: 1.4rem;
      padding: 2px 15px; }
    .event-list .event-item .new-area .new {
      font-size: 1.4rem;
      padding: 2px 15px; }
    .event-list .event-item .item-img img {
      height: 100%; } }
@media screen and (max-width: 767px) {
  .event-pickup .event-item .item-img img {
    height: 100%; }
  .event-pickup .event-item .item-date {
    display: block;
    margin: 0 auto 10px; } }
@media screen and (max-width: 576px) {
  .event-pickup .event-item {
    margin: 0 auto 100px; }
    .event-pickup .event-item .item-ttl {
      font-size: 1.8rem; }

  .event-list .event-item:nth-of-type(n+3) {
    margin-top: 80px; } }
/*==========================================
 　詳細
===========================================*/
.event-article-mainimg {
  font-size: 0;
  margin: 0 auto 100px; }
  .event-article-mainimg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    font-family: 'object-fit: cover;'; }

@media screen and (max-width: 1140px) {
  .event-article-mainimg img {
    height: 100%; } }
@media screen and (max-width: 576px) {
  .event-article-mainimg {
    margin: 0 auto 40px; } }
/* 参加ボタン  ==================================*/
.event-article-status {
  padding: 20px 0; }
  .event-article-status.sticky {
    position: sticky;
    top: 77px;
    background: rgba(255, 255, 255, 0.9); }
  .event-article-status-inner {
    display: flex;
    justify-content: space-between;
    align-items: center; }
  .event-article-status .status-left {
    width: 100%; }
  .event-article-status .status-right {
    min-width: 320px; }

.event-article-cat {
  display: inline-block;
  border: 1px solid #787878;
  color: #787878;
  padding: 2px 25px;
  margin: 0 .5% .5vw 0; }

.btn-evententry {
  display: block;
  background: #cacf2e;
  width: 100%;
  text-align: center;
  padding: 20px 0;
  position: relative; }
  .btn-evententry:hover {
    background: #2b3531;
    color: #fff; }
    .btn-evententry:hover .arw::before {
      border-color: #2b3531; }
  .btn-evententry .arw {
    position: absolute;
    right: 10px;
    top: calc(50% - 15px);
    display: block;
    vertical-align: middle;
    width: 30px;
    height: 30px;
    background: #fff;
    border-radius: 50%; }
    .btn-evententry .arw::before {
      transition: .3s;
      content: "";
      width: 5px;
      height: 5px;
      border-right: 2px solid #cacf2e;
      border-bottom: 2px solid #cacf2e;
      transform: rotate(-45deg);
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      margin: auto; }

.wide-cvs {
  margin: 100px auto; }
  .wide-cvs .btn-evententry {
    max-width: 500px;
    margin: 0 auto;
    font-size: 2rem; }

@media screen and (max-width: 576px) {
  .event-article-status {
    padding: 15px 0; }
    .event-article-status.sticky {
      top: 59px; }
    .event-article-status-inner {
      display: block; }
    .event-article-status .status-right {
      min-width: inherit;
      margin: 10px auto 0; }

  .event-article-cat {
    font-size: 1.4rem;
    padding: 2px 15px; } }
/* タイトル =============================== */
.event-article-ttl {
  text-align: center;
  font-size: 3.8rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  border-top: 1px solid #cacf2e;
  border-bottom: 1px solid #cacf2e;
  padding: 20px 0;
  margin: 20px auto 0; }

@media screen and (max-width: 1140px) {
  .event-article-ttl {
    font-size: 3rem; } }
@media screen and (max-width: 767px) {
  .event-article-ttl {
    font-size: 2.6rem; } }
@media screen and (max-width: 576px) {
  .event-article-ttl {
    font-size: 2.4rem; } }
/* 詳細 =============================== */
.event-article-detail {
  max-width: 780px;
  width: 100%;
  margin: 0 auto; }
  .event-article-detail .detail-box {
    display: flex;
    justify-content: space-between;
    padding: 40px 0;
    border-bottom: 1px solid #cacf2e; }
    .event-article-detail .detail-box dt {
      padding: 0.3em 0 0;
      font-size: 2.2rem;
      letter-spacing: 0.1em;
      font-weight: bold;
      color: #cacf2e;
      min-width: 150px;
      text-align: center; }
    .event-article-detail .detail-box dd {
      width: 100%;
      font-size: 3rem;
      text-align: center; }
  .event-article-detail .detail-note {
    margin: 40px auto 0; }
  .event-article-detail .detail-map {
    margin: 80px auto 0; }

@media screen and (max-width: 1140px) {
  .event-article-detail .detail-box dt {
    font-size: 2rem; }
  .event-article-detail .detail-box dd {
    font-size: 2.6rem; } }
@media screen and (max-width: 767px) {
  .event-article-detail .detail-box dt {
    font-size: 1.8rem;
    min-width: 120px;
    text-align: left; }
  .event-article-detail .detail-box dd {
    font-size: 2.4rem;
    text-align: left; } }
@media screen and (max-width: 576px) {
  .event-article-detail .detail-box {
    padding: 25px 0; }
    .event-article-detail .detail-box dt {
      font-size: 1.6rem;
      min-width: 80px; }
    .event-article-detail .detail-box dd {
      font-size: 1.8rem; }
  .event-article-detail .detail-map {
    margin: 60px auto 0; } }
/*==========================================
 その他の記事
===========================================*/
.other-block {
  margin: 120px auto 0;
  padding: 80px 0 150px; }

/* タイトル */
@media screen and (min-width: 1141px) {
  .other-block-ttl .ttl-ja {
    right: calc(50% - 23em); } }
@media screen and (max-width: 767px) {
  .other-block {
    margin: 80px auto 0;
    padding: 80px 0 100px; } }
/* リスト */
.other-event-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

/*.other-event-item{
	max-width: 480px;
	width: 48%;
	a{
		display: block;
		&:hover{
			.item-img img{
				transform: $imgTFM;
			}
		}
	}
	.item-img{
		font-size: 0;
		overflow: hidden;
		margin: 0 auto 20px;
		img{
			@include of($of_height:33vw);
			transition: $imgTST;
		}
	}
	
	.item-ttl{
		font-weight: bold;
		letter-spacing: 0.05em;
		margin: 10px 0 20px;
	}
	.item-cat{
		.tag{
			display: inline-block;
			border: 1px solid #787878;
			color: #787878;
			padding: 2px 25px;
		}
	}
	.item-more{
		font-weight: 500;
		text-align: right;
		margin: 15px 0 0;
		.arw{
			display: inline-block;
			vertical-align: middle; 
			width: 30px;
			height: 30px;
			position: relative;
			background: $accent_color;
			border-radius: 50%;
			margin: 0 0 0 0.4em;
			&::before{
				content: "";
				width: 5px;
				height: 5px;
				border-right: 2px solid #fff;
				border-bottom: 2px solid #fff;
				transform: rotate(-45deg);
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				right: 0;
				margin: auto;
			}
		}
	}
}*/
.other-event-item {
  /*ログイン時テスト08/25*/
  max-width: 480px;
  width: 48%; }
  .other-event-item a {
    display: block; }
    .other-event-item a:hover .item-img img {
      transform: scale(1.1, 1.1); }
  .other-event-item .item-img {
    font-size: 0;
    overflow: hidden;
    margin: 0 auto 20px; }
    .other-event-item .item-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      font-family: 'object-fit: cover;';
      transition: all 0.8s ease; }
  .other-event-item .item-ttl {
    font-weight: bold;
    letter-spacing: 0.05em;
    margin: 10px 0 20px; }
  .other-event-item .item-cat .tag {
    display: inline-block;
    border: 1px solid #787878;
    color: #787878;
    padding: 2px 25px; }
  .other-event-item .item-more {
    font-weight: 500;
    text-align: right;
    margin: 15px 0 0; }
    .other-event-item .item-more .arw {
      display: inline-block;
      vertical-align: middle;
      width: 30px;
      height: 30px;
      position: relative;
      background: #cacf2e;
      border-radius: 50%;
      margin: 0 0 0 0.4em; }
      .other-event-item .item-more .arw::before {
        content: "";
        width: 5px;
        height: 5px;
        border-right: 2px solid #fff;
        border-bottom: 2px solid #fff;
        transform: rotate(-45deg);
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        margin: auto; }

/*//ログイン時テスト08/25*/
@media screen and (min-width: 1141px) {
  .other-event-list::before, .other-event-list::after {
    content: "";
    display: block;
    width: 23%; }
  .other-event-list::before {
    order: 1; }

  /*	.other-event-item{
  		width: 23%;
  		max-width: 240px;
  		.item-img img{
  			height: 170px;
  		}
  	}*/
  .other-event-item {
    width: 23%;
    max-width: 240px; }
    .other-event-item .item-img img {
      height: 100%;
      /*ログイン時テスト08/25*/
      /*//ログイン時テスト08/25*/ } }
@media screen and (max-width: 1140px) {
  .other-event-list .other-event-item:nth-of-type(n+3) {
    margin-top: 80px; }

  .other-event-item .item-more {
    font-size: 1.4rem; } }
@media screen and (max-width: 576px) {
  .other-event-list .other-event-item:nth-of-type(n+3) {
    margin-top: 60px; }

  .other-event-item .item-cat .tag {
    font-size: 1.4rem;
    padding: 2px 15px; }
  .other-event-item .item-more {
    font-size: 1rem; }
    .other-event-item .item-more .arw {
      width: 20px;
      height: 20px;
      margin: 0 0 0 0.3em; }
      .other-event-item .item-more .arw::before {
        width: 3px;
        height: 3px; } }

/*# sourceMappingURL=event.css.map */
