@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
*/

/*全体設定*/
html {
	letter-spacing: .07em;
}

/*角丸*/
.border-radius {
	border-radius:10px;
}

.border-radius-img img {
	border-radius:15px;
}

/*space-between設定*/
.space-between {
	display: flex;
    flex-direction: column;
    justify-content: space-between;
	gap:20px;
}

/*ボタンの文字色変更*/
.btn-text-maincolor a {
	color:var(--color_main) !important;
}

.btn-text-color01 a {
	color:var(--color_deep01) !important;
}

.btn-text-color01 a:hover {
	color:#fff !important;
	background: var(--color_deep01) !important;
	border: 1px solid var(--color_deep01) !important;
}

.is-style-btn_normal a {
	box-shadow: none;
	border: 1px solid var(--the-btn-bg);
	transition: .3s ease;
}

.is-style-btn_normal a:hover {
	box-shadow: none;
	opacity:1;
}

.is-style-btn_normal a:hover {
    color: var(--the-btn-bg);
	background: #fff;
	border: 1px solid var(--the-btn-bg);
}

.swell-block-button a .__icon {
	position: relative;
	transition: .4s ease;
}

.swell-block-button a .__icon.-right {
	left: -2px;
}

.swell-block-button a:hover .__icon.-right {
	left: 2px;
}

/*sp版のみ折り返し設定*/
@media not all and (min-width: 600px) {
	.sp-reverse>.swell-block-columns__inner {
		flex-direction:column-reverse;
	}
}

/*位置を上にずらす（はみ出るフルワイド）*/
.position-top .swell-block-fullWide__SVG {
	z-index:0;
}
.position-top>.swell-block-fullWide__inner>.wp-block-group {
	position:relative;
	bottom:150px;
}

/*ふわっと表示させるアニメーション*/
.fade-in-up,
.fade-in-left,
.fade-in-right,
.fade-in-only {
  opacity: 0;
  transition: opacity 1.5s ease, transform 1s ease;
}
/* 下から */
.fade-in-up {
  transform: translateY(40px);
}
.fade-in-up.show {
  opacity: 1;
  transform: translateY(0);
}
/* 左から */
.fade-in-left {
  transform: translateX(-40px);
}
.fade-in-left.show {
  opacity: 1;
  transform: translateX(0);
}
/* 右から */
.fade-in-right {
  transform: translateX(40px);
}
.fade-in-right.show {
  opacity: 1;
  transform: translateX(0);
}
/* フェードインのみ（移動なし） */
.fade-in-only {
  opacity: 0;
}
.fade-in-only.show {
  opacity: 1;
}

/*大きくなりながら表示するアニメーション*/
.zoom-up {
  transform: scale(0.8);
  opacity: 0;
  transition: transform .5s ease, opacity .5s ease;
}

.zoom-up.show {
  transform: scale(1);
  opacity: 1;
}

/*ヘッダー*/
.-body-solid .l-fixHeader {
    box-shadow: none;
}

.w-header__inner {
	display: flex;
    flex-direction: row;
	align-items: center;
    gap: 15px;
}

.c-gnav>.menu-item>a .ttl {
	font-size: 14px;
	font-weight: bold;
	transition:.5s ease;
}

@media (min-width: 960px) {
    .c-smallNavTitle {
        display: flex;
        justify-content: left;
        color: var(--color_main);
		font-size: 10px;
        font-weight: bold;
    }
}

.c-gnav > li:hover > a {
	background: transparent;
	opacity: 0.8;
}

.c-gnav > li:hover > a, .c-gnav > .-current > a {
	background: inherit;
	color: var(--color_main);
}

/*SNSリンク*/
.c-iconList__icon:before {
	transition: color .3s ease;
}

.c-iconList__icon.icon-facebook:hover:before {
    color: #1877f2;
}

.c-iconList__icon.icon-instagram:hover:before {
    color: #c32aa3;
}

.c-iconList__icon.icon-youtube:hover:before {
    color: #FF0000;
}

.c-iconList__item .hov-flash:hover {
    -webkit-animation: none;
    animation: none;
}

/*sp版メニュー*/
.p-spMenu__body {
    width: 90%;
    height: 90%;
    padding: 40px;
	margin: 0 auto;
	background: var(--color_bg);
    border-radius: 10px;
	display: flex;
    flex-direction: column;
    justify-content: center;
	overflow-y: hidden;
}

.c-widget__title.-spmenu {
	display:none;
}

.c-spnav a {
	border-bottom:none;
}

.c-listMenu a {
	display: flex;
    flex-direction: column;
	font-size:16px;
	font-weight:bold;
	padding-left: 0;
}

.p-spMenu .c-listMenu a:hover {
    padding-left: 0;
    padding-right: 0;
}

.c-listMenu a:before {
	display:none;
}

.c-spnav .desc {
    margin-left: 0;
}

.c-smallNavTitle {
	color: var(--color_main);
    opacity: .8;
}

/*メインビジュアル*/
.p-mainVisual__inner {
    border-radius: 10px;
}

.p-mainVisual.-margin-on {
    padding: 0 20px;
}
@media (min-width: 600px) {
    .p-mainVisual.-margin-on {
        padding: 0 40px;
        max-width: 1280px;
        margin: 0 auto;
    }
}

.p-mainVisual__video {
	border-radius: 20px;
}

.p-mainVisual__slideTitle {
	font-size: 28px;
	font-weight: bold;
	text-shadow: 0px 0px 5px rgba(0, 0, 0, .8);
	padding-top: 200px;
}
@media (min-width: 600px) {
    .p-mainVisual__slideTitle {
        font-size: 40px;
		padding-top: 0;
    }
}

/*トップページ*/
/*CONCEPT*/
@media not all and (min-width: 960px) {
	.concept .swell-block-column:nth-of-type(2) {
		height: 480px;
	}
}
@media not all and (min-width: 600px) {
	.concept .swell-block-column:nth-of-type(2) {
		height: 440px;
	}
}

.concept .swell-block-column figure {
	width: 350px;
	position: absolute;
}
@media not all and (min-width: 600px) {
	.concept .swell-block-column figure {
		width: 250px;
	}
}

.concept .swell-block-column figure:nth-of-type(1) {
    transform: rotate(-10deg);
    bottom: 400px;
}
@media not all and (min-width: 960px) {
	.concept .swell-block-column figure:nth-of-type(1) {
		bottom: 300px;
	}
}

.concept .swell-block-column figure:nth-of-type(2) {
	transform: rotate(5deg);
    bottom: 200px;
    right:20px;
}
@media not all and (min-width: 960px) {
	.concept .swell-block-column figure:nth-of-type(2) {
		bottom: 150px;
	}
}

.concept .swell-block-column figure:nth-of-type(3) {
    transform: rotate(-10deg);
    bottom: 0;
	right: 15%;
}
@media not all and (min-width: 960px) {
	.concept .swell-block-column figure:nth-of-type(3) {
		right:auto;
	}
}

/*スライドショー*/
.slides>.swell-block-columns__inner{
	animation: slide 60s linear infinite;
	width:2800px;
}

@media (max-width: 600px) {
	.slides>.swell-block-columns__inner{
		width:1600px;
	}
}

@media (min-width: 2000px) {
	.slides>.swell-block-columns__inner{
		width:5000px;
	}
}

.slides img {
	width:320px;
	height:320px;
	object-fit:cover;
	border-radius:15px;
}

@media (max-width: 600px) {
	.slides img {
		width:190px;
		height:190px;
	}
}

@media (min-width: 2000px) {
	.slides img {
		width:560px;
		height:560px;
	}
}

@keyframes slide {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(-30%);
    }
}

@keyframes slide-rev {
    0% {
        transform: translateX(-30%);
    }

    100% {
        transform: translateX(0%);
    }
}

/*追従バナー*/
.pop-up-banner {
	width: 220px;
    position: fixed;
    z-index: 9999;
    bottom: 0em;
	left:auto;
    right: 2.5em;
}

.pop-up-banner .wp-block-group__inner-container {
	width: 220px;
}

@media not all and (min-width: 960px) {
	.pop-up-banner {
		width: 100%;
		right: 0;
	}
}

.pop-up-banner>.c-bannerLink {
	border-radius: 10px;
    border: 3px solid #fff;
}

.pop-up-banner .c-bannerLink__description {
	margin-top:0;
}

.pop-up-banner strong {
	text-shadow: 0px 0px 5px #00000011;
}


.close-btn {
	position: absolute;
	top: -15px;
	right: -15px;
	background-color: #fff;
	border-radius:50%;
	border:1px solid #00000011;
	font-size: 16px;
	color: #888;
	display:flex;
	align-items:center;
	justify-content:center;
	line-height:1.1;
	width:30px;
	height:30px;
	padding:0;
	box-shadow:0 2px 8px rgba(0,0,0,.1);
	z-index:2;
}

.l-fixHeader .pop-up-banner {
	display: none;
}

/*タブレットとPCのみで表示（SPで非表示）*/
@media not all and (min-width:600px) {
	.tab-pc-only {
		display:none;
	}
}

/*SPのみで表示（タブレットとPCで非表示）*/
@media (min-width:600px) {
	.sp-only-not-tab-pc {
		display:none;
	}
}

/*固定ページ*/
/*通常のタイトルを非表示*/
.page-template-default .c-pageTitle {
	display:none;
}

.page-template-default .l-content {
	padding-top: 0;
}

@media (min-width: 600px) {
    .page-template-default .l-content {
        padding-top: 0;
    }
}

.page-template-default .l-mainContent__inner>.post_content {
	margin-top: 0;
}

/*パンくずリスト*/
.p-breadcrumb {
    top: 0;
	z-index: 2;
}
@media (min-width: 960px) {
    .p-breadcrumb {
		top: 60px;
	}
}

.p-breadcrumb__list {
	display: flex;
    justify-content: right;
	font-weight: bold;
}
@media (min-width: 600px) {
    .p-breadcrumb__list {
        font-size: 14px;
    }
}

.archive .p-breadcrumb {
    top: 20px;
}
@media (min-width: 600px) {
    .archive .p-breadcrumb {
		top: 70px;
	}
}

.post-template-default .p-breadcrumb {
    top: 10px;
}
@media (min-width: 600px) {
    .post-template-default .p-breadcrumb {
		top: 40px;
	}
}

/*アーカイブページ*/
.archive .pop-up-banner {
	display:none;
}

.c-pageTitle__subTitle {
	display:none;
}

.archive .c-pageTitle {
        font-size: 2em;
}

.p-termNavigation.c-categoryList {
	display:none;
}

@media (min-width: 960px) {
	#sidebar {
		margin-top: 140px;
	}
}

#sidebar .wp-block-heading {
	font-size: 20px;
	color: var(--color_main);
}

.wp-block-archives-list>li>a, .wp-block-categories-list>li>a {
	padding-left: 1.75em;
	border-bottom: none;
	transition: .3s ease;
}

.wp-block-archives-list>li>a:before, .wp-block-categories-list>li>a:before {
	color: var(--color_deep01);
	content: "\e93b";
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: inline-block;
    font-family: icomoon !important;
    left: .4em;
    line-height: 1;
    opacity: .85;
    position: absolute;
    top: 50%;
    -webkit-transform: scale(.8) translateX(1px) translateY(-50%);
    transform: scale(.8) translateX(1px) translateY(-50%);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
}

.wp-block-archives-list>li>a:hover, .wp-block-categories-list>li>a:hover {
	color: var(--color_deep01);
    background-color: inherit;
}

/*投稿一覧リスト*/
.p-postList__link {
	box-shadow: 3px 3px 3px #ffece0;
}


.-type-thumb .p-postList__body {
	background: #ffffff;
	color: var(--color_text);
	padding: .5em .75em;
}

.-type-thumb .p-postList__title {
	height:36px;
	font-size:14px;
	line-height: 1.3;
}

@media (min-width: 600px) {
    .-type-thumb .p-postList__title {
		height:42px;
		font-size:16px;
	}
}

.p-postList__link:hover .c-postThumb__img {
    -webkit-transform: scale(1);
    transform: scale(1);
}

/*投稿ページ*/
.post-template-default .pop-up-banner {
	display:none;
}

.p-articleFoot {
	display: none;
}

@media (min-width: 600px) {
    .l-content {
        padding-top: 0;
    }
}

/*採用情報*/
.recruit-tab.is-style-default>.c-tabList {
	gap: 10px;
}

@media (min-width: 600px) {
	.recruit-tab.is-style-default>.c-tabList {
		gap: 20px;
	}
}

.recruit-tab.is-style-default>.c-tabList .c-tabList__button {
	padding: 1.5em 0;
	border-radius: 5px 5px 0 0;
	background: var(--color_bg);
	opacity:1;
}
.recruit-tab.is-style-default>.c-tabList .c-tabList__button:hover, .recruit-tab.is-style-default>.c-tabList .c-tabList__button[aria-selected=true] {
	background-color: var(--color_main);
}

.recruit-tab.is-style-default .c-tabBody {
	border:none;
	border-top: 2px solid var(--color_main);
	border-radius: 0 0 5px 5px;
	padding: 1em 0.5em;
}

@media (min-width: 600px) {
    .recruit-tab.is-style-default .c-tabBody {
        padding: 1em 0;
    }
}

@media (min-width: 960px) {
	.wp-block-table.recruit-table th {
		width: 250px !important;
	}
}

.wp-block-table.recruit-table td, .wp-block-table.recruit-table th {
	padding: 1.25em 1em;
	border: 1px solid #FFECE0;
}

/*FAQ*/
.custom-faq.is-style-faq-stripe .faq_q {
	background: #fff;
	border-radius: 5px;
}

/*FLOW*/
.swell-block-step__item:before {
	border-left: 1px solid var(--color_main);
	height: 50%;
    left: 23px;
	top: 41%;
}

@media not all and (min-width: 600px) {
	.swell-block-step__item:before {
		display:block !important;
	}

    .swell-block-step:not(.is-style-big):not(.is-style-small)>.swell-block-step__item>.swell-block-step__body {
        margin-left: 0;
    }
}

/*お問い合わせフォーム*/
.wpcf7-form {
	display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.wpcf7-form p {
	width:100%;
	min-width: 100%;
	margin-bottom: 30px;
    border-radius: 10px;
}

.wpcf7-form p label {
	display:flex;
	flex-direction:column;
	gap:10px;
}

.wpcf7-form input, .wpcf7-form select, .wpcf7-form textarea {
	background-color:#ffffff;
	border-radius: 5px;
	width: 100%;
}

.wpcf7-form textarea {
	height:250px;
}

.wpcf7-form span {
    display: inline-block;
    min-width: 200px;
	color:var(--color_main);
	font-weight:bold;
}

.wpcf7-form p:last-of-type {
	padding:0;
	background:transparent;
	display:flex;
	justify-content:center;
}

.wpcf7-form .wpcf7-submit {
	width:300px;
	color:#fff;
	font-weight:bold;
	background: var(--color_main);
	border-radius:80px;
	border: 1px solid var(--color_main);
	padding:.75em 4.5em;
	line-height: 1.5;
	transition:.3s ease;
}

.wpcf7-form .wpcf7-submit:hover {
	color: var(--color_main);
	background: #fff;
}

.wpcf7-spinner {
	display:none !important;
}