@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/





.grecaptcha-badge { 
	visibility: hidden; 
}



.tel-span {
  font-size: 1.3rem;
}


.p-articleFoot {
  display: none;
}



.p-mainVisual__textLayer {
	justify-content: end!important;
}

.p-mainVisual__textLayer h2 {
  margin-bottom: 1rem!important;
 font-size: clamp(1.8rem, 6vw, 5rem)!important;
}

.p-mainVisual__textLayer p {
	  font-size: clamp(1rem, 2vw, 2rem)!important;
}


.p-mainVisual__textLayer p,
.p-mainVisual__textLayer h2 {
	text-shadow: 1px 1px 10px rgb(0 0 0 / 60%);
}

.p-mainVisual__textLayer .mv-text-yellow {
  color: #F5D63D!important;
}


.p-mainVisual__textLayer span{
  font-size: clamp(2.5rem, 9vw, 8rem)
}



.p-mainVisual__textLayer .mv-text-bule {
 color: #4BE2F2!important;
}






/*-----------------------------------------------
 * サイドバーがあるページのmargin
 */

.-sidebar-on .l-content {
  margin-top: 2rem!important;
	margin-bottom: 6rem!important;
}

/*
 * 
 -----------------------------------------------*/







.u-obf-cover {
  object-position: top;
}

.c-pageTitle {
 text-align: center;
}

.c-gnav>.menu-item>a:after {
 bottom: 30px;
}


.l-content {
  margin: 0 auto!important;
}



/*--------------------------------
 * メインビジュアルの文字


.p-mainVisual__slideTitle {
    writing-mode: vertical-lr;
}
	
.p-mainVisual__slideText {
	margin-top: 0!important;
	margin-left: 10px;
}


.p-mainVisual__textLayer {
  justify-content: end!important;
}

 
  -----------------------------*/




.p-mainVisual__slideTitle {
    position: absolute;
    top: 20%;
    text-align: left;
    line-height: 2!important;
}




/*--------------------------------
 * ナビゲーションの背景画像
  -----------------------------*/

.p-spMenu__inner::before {
    background-color: #fff;
	opacity: .9;
    background-position: center top;
	background-size: cover;
}

.p-spMenu__inner a {
	  color: #000;
}

.c-iconBtn {
  color: #000;
}

/*
.c-iconBtn {
  color: var(--color_main)!important;
}
*/


/*--------------------------------
 
  -----------------------------*/








/*--------------------------------
 * TOPページ
  -----------------------------*/



.top-news-fullwide .p-postList__body {
	  display: flex;
	  align-items: baseline;
}


.top-news-fullwide .p-postList__body span {
	  display: none!important;
}
/*--------------------------------
 * 
  -----------------------------*/





/*-------------------------------------------------
 *  TOPの最新の投稿リスト
 */

.top-news-fullwide .p-postList.-type-simple {
  border-top: none!important;}

.top-news-fullwide .-type-simple .p-postList__link {
  border-bottom: none!important;
}

.top-news-fullwide .p-postList__item {
	 margin-left: auto;
	width: 100%!important;
}


.top-news-fullwide .p-postList__body {
	justify-content: end;
    margin-right: 40px;
}


/*
 * 
  -------------------------------------------------*/






/*--------------------------------
 * 固定ページの見出し
  -----------------------------*/

.c-pageTitle__inner {
  display: none;
}

.l-mainContent__inner>.post_content {
  margin: 0!important;
}



.blue-span {
  color:var(--color_main);
}




.greeting-rich-column .img-column figure img {
  width: 100%;
}




.shisetsu-rich-column img {
	  width: 100%;
}




/*
 * 縦文字のフルワイド
 ---------------------------------------------------------------*/ 


.left-tate-fullwide .left-tate-rich-column .width100-img img{
   width: 100%!important;
   object-fit: cover;
   height: 400px;
}


.left-tate-fullwide .swell-block-columns__inner {
  justify-content: space-between;
}


.tate-h-jp {
  writing-mode: vertical-lr;
  margin-left: auto!important;
  color: #0F7BA6!important;
  padding: 0!important;
  background: none!important;
  line-height: 1.2!important;
}

.left-tate-fullwide .tate-h-jp,
.right-tate-fullwide .tate-h-jp {
  margin: 0 auto;
}


.activity-fullwide .text-group {
  margin-left: auto;
}

.tate-h-jp:before {
   display: none!important;
}
.tate-h-eng {
  color: #F5D63D!important;
  font-size: 3rem!important;
}
.story-rich-column .text-group {
   width: 80%;
}








/*----------------------------------------------
 *  ZOOM画像
 */

.hover-zoom-img {
  overflow: hidden;
}

.hover-zoom-img img {
   transition: 1s al;
}


.hover-zoom-img img:hover {
  transform: scale(1.2,1.2);
  transition: 1s all;
}

/*
 * ----------------------------------------------*/











/*----------------------------------
 * スライダー
 * -------------------------------*/


.d-demo__list--left {
animation :infinity-scroll-left 95s infinite linear 0.5s both;
	padding: 0!important;
}


.d-demo__list--right{
animation :infinity-scroll-right 95s infinite linear 0.5s both;
	padding: 0!important;
}

.d-demo__wrap {
  display: flex;
  overflow: hidden;
}

.d-demo__list {
  display: flex;
  list-style: none;
}



.d-demo .d-demo__wrap .d-demo__list li  {
  width: calc(100vw / 2);
}
.d-demo__item > img{
   width: 100%;
}


.d-demo__item::marker {
	  display: none!important;
}







/*------------------------
 * 　固定ページの見出し
 * -------------------------*/


.first-fullwide h2 {
  text-shadow: 1px 1px 0px rgb(0 0 0 / 20%);
  color: #fff!important;
  background: none!important;
  border-radius: none!important;
}

.first-fullwide h2::before {
  display: none!important;
}


.first-fullwide h2::after {
  content: '';
  width: 80px;
 height: 1px;
 background: #fff;
 position: absolute;
 top: 50%;
 margin-left: 10px;
}

/*------------------------
 * 　
 * -------------------------*/



.l-footer__foot {
  padding-top: 2rem!important;
}













input[type="text"],
input[type="password"],
input[type="datetime"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="week"],
input[type="number"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="tel"],
input[type="color"],
select,
textarea,
.place,
.field {
  display: block;
  width: 100%;
  height: 45px;
  margin-bottom: 0;
  padding: 0 12px;
  border: 0;
  border-radius: 3px;
  background-color: #eff1f5;
  box-shadow: none;
  color: #5c6b80;
  font-size: 1em;
  vertical-align: middle;
  line-height: 45px;
  transition: background-color 0.24s ease-in-out;
}
textarea {
  max-width: 100%;
  min-height: 120px;
  line-height: 1.5em;
  padding: 0.5em;
  overflow: auto;
}

@media(max-width:500px) {
    .inquiry td,
    .inquiry th {
        display: block !important;
        width: 100% !important;
        border-top: none !important;
        -webkit-box-sizing: border-box !important;
        -moz-box-sizing: border-box !important;
        box-sizing: border-box !important
    }
    .inquiry tr:first-child th {
        border-top: 1px solid #d7d7d7 !important
    }
    .inquiry .any,
    .inquiry .haveto {
        font-size: 10px
    }
}
.inquiry th {
    text-align: left;
    font-size: 14px;
    color: #444;
    padding-right: 5px;
    width: 30%;
    background: #f7f7f7;
    border: solid 1px #d7d7d7
}
.inquiry td {
    font-size: 13px;
    border: solid 1px #d7d7d7
}
.entry-content .inquiry tr,
.entry-content table {
    border: solid 1px #d7d7d7
}
.haveto {
    font-size: 7px;
    padding: 5px;
    background: #ff9393;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px
}
.any {
    font-size: 7px;
    padding: 5px;
    background: #93c9ff;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px
}
.verticallist .wpcf7-list-item {
    display: block
}
#formbtn {
    display: block;
    padding: 15px;
    width: 350px;
    background: var(--color_main);
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    border-radius: 2px;
    margin: 25px auto 0
}
#formbtn:hover {
    background: #fff;
    color: var(--color_main);
    border: 2px solid var(--color_main);
}
th {
    font-weight: 700;
    text-transform: uppercase;
    padding: 13px
}
td {
    border-top: 1px solid #ededed;
    padding: 12px
}
input,
select,
textarea {
    border: 1px solid #dfdfdf;
    letter-spacing: 1px;
    margin: 0;
    max-width: 100%;
    resize: none
}
}



@media(min-width: 1300px) {
  .left-tate-fullwide .swell-block-columns__inner img {
     height: 500px;
}
}


@media(max-width: 959px) {
	.sp-br {
		display: block;
	}
}


@media (min-width: 960px){
	.sp-br {
  display: none;
	}

	.p-mainVisual__textLayer.p-blogParts.sp-py-20 {
		margin-bottom: 25vw!important;
	}
}


@media (min-width: 600px){
.l-topTitleArea {
 min-height: 350px!important;
}
.l-content {
  padding-top: 0!important;
}
	
	
.p-mainVisual__slideTitle {
    font-size: 2.8rem!important;
}
	
.p-mainVisual__slideText {
    font-size: 2.8rem!important;
}
}


@media(max-width: 600px) {
	.p-mainVisual__slideTitle {
    font-size: 7vw!important;
}
	
	
	.right-fullwide .swell-block-columns__inner {
		flex-direction: column-reverse;
	}
	
	
.p-mainVisual__slideText {
    font-size: 7vw!important;
}
	
.top-news-fullwide .p-postList__body {
    margin-right: 10px;
	} 
	
	
/*---	
	.activity-fullwide .text-group {
		margin-left: 10px!important;
	}
	*/
	
	
	
	.sp-yoko-h {
      writing-mode: inherit!important;
      text-align: center!important;
}
	
	.text-group {
      width: 90%;
	  margin: 0 auto;
	}
	
}



/*
右から左へ
----------------------------*/
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}


/*
左から右へ
----------------------------*/
@keyframes infinity-scroll-right {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(0%);
  }
}
