@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;600&family=Poppins:wght@400;600&display=swap');
@import url("default.css");

* {-webkit-text-size-adjust:100%;}
a:link {text-decoration:none; color:#111111;}
a:visited{text-decoration:none; color:#111111;}
a:hover{text-decoration:none; color:#111111;}
a:active{text-decoration:none; color:#111111;}

.grecaptcha-badge { opacity: 0; pointer-events: none; }
.full-width { margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }
.allWrapper { overflow: hidden; }
.container-fluid { max-width: 1160px; padding-left: 20px; padding-right: 20px; }
.container-fluid .container-fluid { padding-left: 0; padding-right: 0; }

body { min-width: 1100px; font-size: 15px; line-height: 1.8; color: #111111; background-color: #fff; font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif; font-weight: 400; font-family: 'Noto Sans JP', sans-serif; letter-spacing: .1em; }
header { position: fixed; left: 0; width: 100%; top: 0; z-index: 999; border-bottom: 1px solid rgba(255,255,255,.5); transition: .3s; }
header.active { background: #24221e; }
header .wrap { display: flex; justify-content: space-between; max-width: 1160px; padding-left: 20px; padding-right: 20px; margin-left: auto; margin-right: auto; align-items: center; height: 80px; }
header .gnav ul { display: flex; justify-content: space-between; }
header .gnav ul li { margin-left: 25px; }
header .gnav ul a { color: #fff; font-weight: bold; letter-spacing: .1em; }
header .menu-trg-area { position: fixed; top: 10px; right: 15px; margin: auto; display: none; width: 40px; height: 40px; background: #000; cursor: pointer; border-radius: 5px; }
header .menu-trigger,
header .menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box;}
header .menu-trigger { position: absolute; top: 13px; width: 17px; height: 13px; z-index: 2; left: 0; right: 0; margin: auto;}
header .menu-trigger span { position: absolute; left: 0; width: 100%; height: 1px; background-color: #fff;}
header .menu-trigger span:nth-of-type(1) { top: 0;}
header .menu-trigger span:nth-of-type(2) { top: 6px;}
header .menu-trigger span:nth-of-type(3) { bottom: 0;}
header .menu-trigger.active span:nth-of-type(1) { -webkit-transform: translateY(20px) rotate(-45deg); transform: translateY(20px) rotate(-45deg); top: -14px;}
header .menu-trigger.active span:nth-of-type(2) { left: 50%; opacity: 0; -webkit-animation: active-menu-bar02 .8s forwards; animation: active-menu-bar02 .8s forwards;}
header .menu-trigger.active span:nth-of-type(3) { -webkit-transform: translateY(-20px) rotate(45deg); transform: translateY(-20px) rotate(45deg); bottom: -14px;}
footer { position: relative; padding: 30px 0; }
footer .wrap { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }
footer .navs { display: flex; flex-wrap: wrap; }
footer .navs li { margin-left: 20px; font-weight: bold; letter-spacing: .1em; }
footer .navs li a:hover { text-decoration: underline; }

.en { font-family: 'Poppins', sans-serif; font-weight: 600; }
.sec-title .en { font-size: 72px; letter-spacing: .04em; color: #9bc254; line-height: 1; }
.sec-title .jp { letter-spacing: .12em; margin-top: 10px; }
.jp-title { font-size: 35px; letter-spacing: .15em; font-weight: bold; margin-bottom: 20px; }
.link-button { width: 225px; height: 65px; max-width: 100%; background: #fff; position: relative; display: flex; align-items: center; justify-content: center; color: #9bc254!important; border: solid 2px #9bc254;}
.link-s-button { height: 48px; max-width: 100%; position: relative; display: flex; align-items: center; justify-content: center; color: #fff!important; border: solid 1px #fff; border-radius: 5px;}
.link-button:before { content: ""; position: absolute; right: 17px; width: 30px; height: 18px; background-image: url(../images/arrow.svg); background-size: cover; }
.cnt-bt { margin:0 auto; }
.bg-dark { background: #24221e!important; color: #fff; }
.fv { position: relative; }
.fv .fv-slider { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.fv .fv-slider *,
.fv .fv-slider .child { width: 100%; height: 100%; }
.fv .musk { position: absolute; left: 0; top: 0; width: 100%; height: 100%; opacity: .5; }
.fv .title { position: absolute; bottom: 10%; width: 80%; left: 0; right: 0; margin: auto; display: block; }
.vision { padding: 85px 0 100px; position: relative; }
.vision .min-title { color: #9bc254; font-size: 25px; letter-spacing: .04em; }
.vision .container-fluid { position: relative; z-index: 1; }
.vision .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.news { background: #f0f4f7; padding: 100px 0 70px; position: relative; }
.news .container-fluid { position: relative; z-index: 1; }
.news .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.news-list li { border-bottom: 1px solid rgba(180,180,180,.5); padding: 20px 0; }
.news-list li:first-child { padding-top: 0; }
.news-list li:last-child { border-bottom: none; }
.news-list li a { display: block; }
.news-list li .head { display: flex; align-items: center; margin-bottom: 5px; }
.news-list li .time { font-size: 14px; letter-spacing: .14em; color: #b4b4b4; font-family: 'Poppins', sans-serif; margin-right: 10px; font-weight: 600; }
.news-list li .cat { background: #fff; font-weight: 400; font-family: 'Poppins', sans-serif; padding: 6px 14px 5px; line-height: 1; border-radius: 100px; }
.news-list li .title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.news .multiple-items { margin-left: -22px; margin-right: -22px; }
.news .multiple-items .child { padding: 22px; }
.news .multiple-items { position: relative; }
.news .multiple-items .slick-prev { position: absolute; right: 90px; left: auto; top: -30px; width: 35px; height: 35px; background-image: url(../images/slick_bk_arrow_left.svg); background-position: center; background-repeat: no-repeat; }
.news .multiple-items .slick-prev:before { display: none; }
.news .multiple-items .slick-next { position: absolute; right: 22px; left: auto; top: -30px; width: 35px; height: 35px; background-image: url(../images/slick_bk_arrow_right.svg); background-position: center; background-repeat: no-repeat; }
.news .multiple-items .slick-next:before { display: none; }
.bg-dark .news-list li .title { color: #fff; }
.project { position: relative; background: #24221e; padding: 85px 0; color: #fff; }
.project .container-fluid { position: relative; z-index: 1; }
.project .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.project .multiple-items { margin-left: -22px; margin-right: -22px; }
.project .multiple-items .child { padding: 22px; }
.project .multiple-items { position: relative; }
.project .multiple-items .slick-prev { position: absolute; right: 90px; left: auto; top: -30px; width: 35px; height: 35px; background-image: url(../images/slick_arrow_left.svg); background-position: center; background-repeat: no-repeat; }
.project .multiple-items .slick-prev:before { display: none; }
.project .multiple-items .slick-next { position: absolute; right: 22px; left: auto; top: -30px; width: 35px; height: 35px; background-image: url(../images/slick_arrow_right.svg); background-position: center; background-repeat: no-repeat; }
.project .multiple-items .slick-next:before { display: none; }
.project-block { color: #fff!important; }
.project-block .photo { padding-top: 70%; margin-bottom: 10px; }
.project-block .time { font-size: 14px; font-weight: 400; color: #b4b4b4; margin-bottom: 5px; }
.project-block .title { color:#1c1c1c; font-weight: bold; font-size: 18px; letter-spacing: .08em; line-height: 1.5; margin-bottom: 10px; overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; }
.project-block .detail { letter-spacing: .05em; color: #b4b4b4; overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-height: 1.6; }
.torikumi { background: #1c1c1c; padding: 100px 0; color: #b4b4b4; position: relative;}
.torikumi .container-fluid { position: relative; z-index: 1; }
.torikumi .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.torikumi .title { color: #9bc254; font-size: 26px; font-weight: bold; letter-spacing: .09em; line-height: 1.4; margin-bottom: 5px; }
.torikumi-title { color: #ffffff; }
.torikumi-list li:after { content: ""; background-image: url(../images/arrow_bottom.svg); width: 20px; height: 33px; background-position: center; background-repeat: no-repeat; display: block; margin: 24px 0 24px 90px; }
.torikumi-list li:last-child:after { display: none; }
.torikumi-list li p { font-size: 18px; letter-spacing: .09em; line-height: 1.5; }
.oen-title {    background: #FFF;
    padding: 10px;
    margin-bottom: 20px;
    display: inline-block;
    color: #000;}
.oen{ padding: 85px 0 40px; position: relative; }
.shien-block { border: 1px solid #b4b4b4; padding: 20px 10px; }
.shien-block .icon { padding: 10px; display: flex; align-items: center; justify-content: center; margin-bottom: 15px; }
.shien-block .title { text-align: center; line-height: 1.2; letter-spacing: .05em; }
.shien-block p { text-align: center; line-height: 1.6; letter-spacing: .02em; }
.schedule { position: relative; padding: 100px 0 85px; }
.schedule .container-fluid { position: relative; z-index: 1; }
.schedule .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.schedule-table table { width: 100%; letter-spacing: .08em; background: #fff;}
.schedule-table table th { border-bottom: 1px solid #b4b4b4; border-right: 1px solid #fff; background: #f0f4f7; text-align: left; padding: 25px 25px; font-weight: bold; }
.schedule-table table td { border-bottom: 1px solid #b4b4b4; padding: 25px 0 25px 70px; font-size: 17px; letter-spacing: .03em; }
.schedule-table table tbody tr:last-child th,
.schedule-table table tbody tr:last-child td { border: none; }
.faq { position: relative; background: #f0f4f7; padding: 70px 0 100px; }
.faq .container-fluid { position: relative; z-index: 1; }
.faq .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.qa-area li { margin-bottom: 20px; }
.qa-area .question-bar { background: #fff; cursor: pointer; }
.qa-area .question-bar .wrapper { display: flex; padding: 20px 30px; align-items: center; justify-content: space-between; }
.qa-area .question-bar .wrapper .wrap { display: flex; align-items: center; width: 80%;}
.qa-area .question-bar .q-img { width: 40px; font-size: 25px; line-height: 1.4; letter-spacing: .08em; font-weight: bold; color: #9bc254; }
.qa-area .question-bar .p1 { width:calc(100% - 40px); font-size: 18px; letter-spacing: .08em; font-weight: bold; }
.qa-area .question-bar .wrapper .box { width: 20%; display: flex; align-items: center; justify-content: flex-end; }
.qa-area .question-bar .wrapper .box .cat-btn { width: 111px; border: 1px solid #E1E1E1; padding: 2px 0; text-align: center;}
.qa-area .question-bar .wrapper .box .cross { background-image:url(../images/arrow.svg); width: 30px; height: 30px; background-position: center; background-repeat: no-repeat; transform: rotate(90deg); }
.qa-area .question-bar.open .wrapper .box .cross { transform: rotate(-90deg); }
.qa-area .question-bar.open .wrapper .box .cross::before { height: 0;}
.qa-area .answer { padding: 20px 30px; display: none; background: #fff; border-top: 1px solid #b4b4b4; }
.qa-area .answer.read-category { border-radius: 0;}
.qa-area .answer .block { display: flex; justify-content: center;}
.qa-area .answer .block .a-img { width: 40px; font-size: 25px; line-height: 1.4; letter-spacing: .08em; font-weight: bold; color: #b4b4b4; }
.qa-area .answer .block p { width: calc(100% - 40px); font-size: 15px; line-height: 1.53; letter-spacing: .08em; }
.contact { position:relative; background: #24221e; color: #fff; padding: 80px 0; }
.contact .container-fluid { position: relative; z-index: 1; }
.contact .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.contact .wrap { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; }
.contact .contents  { display: flex; align-items: center; flex-wrap: wrap; }
.contact .contents .tel .for { padding-bottom: 15px; font-weight: 800; color: #fff; font-size: 25px; line-height: 1.5;}
.contact .tel { margin-right: 20px; }
.contact .tel .num { font-size: 25px; letter-spacing: .06em; line-height: 1; }
.contact .tel .num span { font-size: 25px; }
.contact .tel p { color: #b4b4b4; }
.contact .buttons a { display: flex; background: #fff; height: 65px; align-items: center; justify-content: center; padding: 10px 40px; font-weight: bold; letter-spacing: .08em; }
.contact .buttons a img { margin-right: 10px; }
main > article { padding: 200px 0 100px; }
.form-title { display: flex; flex-wrap: wrap; align-items: center; margin-bottom: 40px; }
.form-title .main { font-size: 35px; letter-spacing: .15em; font-weight: bold; letter-spacing: .15em; }
.form-title p { color: #b4b4b4; letter-spacing: .09em; font-size: 18px; margin-left: 20px; }
.cf7_wrapper input[type="text"],
.cf7_wrapper input[type="email"] { width: 100%; background: #454340; border: none; height: 50px; padding: 10px; color: #fff; }
.cf7_wrapper textarea { width: 100%; background: #454340; border: none; padding: 10px; color: #fff; height: 270px; }
.cf7_wrapper dl { margin-bottom: 35px; }
.cf7_wrapper dl dt { font-size: 20px; letter-spacing: .15em; margin-bottom: 10px; }
.cf7_wrapper .submits { margin-top: 60px; text-align: center; }
.cf7_wrapper .submits .submit-parent { position: relative; width: 225px; height: 65px; display: inline-block; }
.cf7_wrapper .submits .submit-parent:before { content: ""; position: absolute; right: 16px; width: 32px; height: 35px; background-image: url(../images/arrow_black.svg); display: block; top: 0; bottom: 0; margin: auto 0; z-index: 1; background-position: center; background-repeat: no-repeat; pointer-events: none; }
.cf7_wrapper .submits .submit-parent input { position: absolute; left: 0; top: 0; width: 100%; height: 100%; border-radius: 0; border: none; cursor: pointer; letter-spacing: .2em; text-indent: .2em; }
.cf7_wrapper .submits .submit-parent input:hover { border: 2px solid #9bc254; }
.post-header { border-bottom: 1px solid rgba(255,255,255,.25); margin-bottom: 40px; padding-bottom: 20px; }
.post-header .date { font-size: 14px; color: #b4b4b4; margin-bottom: 10px; letter-spacing: .14em; }
.post-header .title { font-weight: bold; font-size: 27px; }
.post-contents .wp-post a { color: #fff; }

@media (max-width: 767px) {
	body { min-width: 375px; font-size: 14px; }
	header .wrap { height: 60px; }
	header .logo img { height: 35px; }
	header .gnav { position: fixed; left: 0; top: 60px; width: 100%; background: rgba(36,34,30,.98); height: calc(100% - 60px); transition: .3s; visibility: hidden; opacity: 0; }
	header .gnav.active { opacity: 1; visibility: visible; }
	header .gnav ul { display: block; padding: 30px; }
	header .gnav ul li { margin-left: 0; }
	header .gnav ul li a { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid rgba(255,255,255,.25); position: relative; padding: 15px 10px; }
	header .gnav ul li a:after { content: ""; width: 32px; height: 30px; background-image: url(../images/slick_arrow_right.svg); display: block; background-repeat: no-repeat; background-position: center; }
	header .menu-trg-area { display: block; }
	header.dark { background: #24221e; }
	footer .logo img { height: 35px; }
	footer .wrap { display: block; }
	footer .navs { display: none; }
	.sec-title .en { font-size: 36px; }
	.jp-title { font-size: 18px; line-height: 1.5em;}
	.link-button { margin-left: auto; margin-right: auto; width: 80%; height: 55px; }
	.fv .title { top: 0; bottom: 0; margin: auto; width: 90%; }
	.vision { padding: 50px 0 50px; }
	.vision .min-title { font-size: 18px; }
	.vision_img { overflow: auto; }
	.vision_img img { width: 800px; max-width: none; }
	.news { padding: 50px 0 50px; }
	.news-list li { padding: 15px 0; }
	.project { padding: 50px 0; }
	.project .multiple-items .child { padding: 0 10px; }
	.project .multiple-items .slick-next { top: 0; bottom: 0; margin: auto 0; z-index: 1; }
	.project .multiple-items .slick-prev { top: 0; bottom: 0; right: auto; margin: auto 0; z-index: 1; left: 22px; }
	.torikumi { padding: 50px 0; }
	.torikumi .title { font-size: 17px; }
	.torikumi-list li p { font-size: 14px; }
	.torikumi-list li:after { width: 15px; height: 24px; background-size: cover; margin: 15px 0 15px 20%; }
	.shien-block .icon img { height: 100px; }
	.schedule { position: relative; padding: 50px 0 35px; }
	.schedule .jp-title { letter-spacing: .04em; }
	.schedule-table table,
	.schedule-table table tbody,
	.schedule-table table tr,
	.schedule-table table th,
	.schedule-table table td { display: block; }
	.schedule-table table { border-top: 1px solid #b4b4b4; }
	.schedule-table table th { padding: 15px; }
	.schedule-table table td { padding: 15px 15px 30px; font-size: 13px; }
	.schedule-table table tbody tr:last-child th { border-bottom: 1px solid #b4b4b4; }
	.faq { padding: 50px 0 40px; position: relative;}
	.qa-area .question-bar .p1 { font-size: 14px; }
	.qa-area .question-bar .wrapper { padding: 15px; }
	.qa-area .question-bar .wrapper .wrap { width: calc(100% - 30px); padding-right: 5px; }
	.qa-area .question-bar .wrapper .box { width: 30px; }
	.qa-area .answer { padding: 15px; }
	.qa-area .answer .block p { font-size: 14px; }
	.contact { padding: 50px 0; }
	.contact .contents { display: block; }
	.contact .contents .tel .for { font-size: 22px; }
	.contact .tel .num { font-size: 22px; }
	.contact .tel .num span { font-size: 24px; }
	.contact .buttons { margin-top: 20px; }
	.contact .buttons a { height: 50px; }
	.contact .buttons a img { height: 17px; }
	main > article { padding: 100px 0 60px; }
	.form-title { display: block; margin-bottom: 30px; }
	.form-title .main { font-size: 18px; margin-bottom: 15px; }
	.form-title p { margin-left: 0; font-size: 12px; }
	.cf7_wrapper dl { margin-bottom: 20px; }
	.cf7_wrapper dl dt { font-size: 15px; margin-bottom: 7px; }
	.cf7_wrapper input[type="text"],
	.cf7_wrapper input[type="email"] { height: 40px; }
	.cf7_wrapper textarea { height: 150px; }
	.cf7_wrapper .submits { margin-top: 30px; }
	.cf7_wrapper .submits .submit-parent { height: 50px; }
	.post-header .title { font-size: 24px; }
	.pj-grids { grid-template-columns: 1fr !important; }
	.pj-grids.tworow { grid-template-columns: 1fr !important; gap: 0px;}
	.pj-box { height: auto !important; }
	/* スマホの時、偶数の場合.pj-logo-box { grid-template-columns: 1fr 1fr !important; padding-bottom:20px; } */
	.pj-logo-box {padding: 20px!important; gap: 30px !important;}
	.pj-logo-box img {
        width: calc( (100% - 30px) / 2 );
        max-width: none; /* スマホで2列表示させるためにmax-widthをリセット */
    }
	.project-single { padding-top: 100px !important;}
	.project-single h3{ padding: 50px 0 30px !important; }
	.news .multiple-items .slick-prev { top: -38px; width: 30px; height: 30px; right: 80px;}
	.news .multiple-items .slick-next { top: -38px; width: 30px; height: 30px; right: 34px;}
	.top-pj {padding: 10px !important;}
}
.top-pj { padding: 40px; margin: 50px auto; max-width:800px; background: #fff; }
/* PCの時、偶数の場合.pj-logo-box { justify-items: center; align-items: center; display: grid; grid-template-columns: 1fr 1fr; gap:30px; } */
.pj-logo-box {
    display: flex; /* Flexboxを有効化 */
    flex-wrap: wrap; /* アイテムの折り返しを許可 */
    justify-content: center; /* ★この設定で、折り返した行も含め全体を中央揃えに★ */
    gap: 60px; /* アイテム間の余白 */
    align-items: center; /* 垂直方向の中央揃え (元々のGrid設定から継承) */
}
.pj-logo-box img {
    /* HTMLでwidthを指定していますが、ここではFlexboxとして機能させるために */
    /* 最大幅を設定し、必要に応じてheightをautoにすることで縦横比を維持します。 */
    /* また、画像が大きくなりすぎないように調整します。 */
    max-width: 220px; /* 画像の最大幅を適当に設定（任意で調整） */
    height: auto;
}
.pj-logo.rs img {
height: 150px;
object-fit: contain;
}
.pj-logo.rs img {
	max-width: 100%;
}
.pj-hed header { background: #24221e; }
.project-single { padding: 150px 0 100px; text-align:center; position: relative;}
.project-single .container-fluid { position: relative; z-index: 1; }
.project-single .particles { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
.project-single h3{font-size: 1.6em; font-weight:600; text-decoration: underline; padding: 100px 0 50px; }
.pj-grids { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 40px; }
.pj-grids.tworow { grid-template-columns: 1fr 1fr;}
.pj-grids.onerow { grid-template-columns: 1fr;}
.pj-grids h4 {padding:15px; color:#fff; font-size: 1.3em; font-weight: 500;}
.pj-grid p { font-weight: 500; font-size: 1.2em; padding: 15px 0;}
.pj-grid.dx h4 { background: #50989a;}
.pj-grid.dx p { color: #50989a;}
.pj-grid.dx .pj-box { border: solid 2px #50989a;}
.pj-grids.tworow .pj-grid.dx h4 { background: #326ea4;}
.pj-grids.tworow .pj-grid.dx p { color: #326ea4;}
.pj-grids.tworow .pj-grid.dx .pj-box { border: solid 2px #326ea4;}
.pj-grids.onerow .pj-grid.dx h4 { background: #326ea4;}
.pj-grids.onerow .pj-grid.dx p { color: #326ea4;}
.pj-grids.onerow .pj-grid.dx .pj-box { border: solid 2px #326ea4;}
.pj-grid.new h4 { background: #ca743d;}
.pj-grid.new p { color: #ca743d;}
.pj-grid.new .pj-box { border: solid 2px #ca743d;}
.pj-grids.tworow .pj-grid.new h4 { background:#509a71;}
.pj-grids.tworow .pj-grid.new p { color: #509a71;}
.pj-grids.tworow .pj-grid.new .pj-box { border: solid 2px #509a71;}
.pj-grids.onerow .pj-grid.new h4 { background:#509a71;}
.pj-grids.onerow .pj-grid.new p { color: #509a71;}
.pj-grids.onerow .pj-grid.new .pj-box { border: solid 2px #509a71;}
.pj-grid.qol h4 { background: #588d55;}
.pj-grid.qol p { color: #588d55;}
.pj-grid.qol .pj-box { border: solid 2px #588d55;}
.pj-box { background: #fff; margin-bottom:30px; padding: 20px; height: 370px;}
.pj-logo {padding: 8px 0 20px;}
.pj-cname { font-weight: bold; padding-bottom:10px;}
.pj-txt { font-size: 14px; text-align: left;}
.page-id-40, .page-id-12 {background: #24221e; padding:0; }

@media screen and (max-width:599px) {
	.pc {
display:none;}
}
@media screen and (min-width:600px) {
	.sp {
display:none;}
}
