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


/* ----全体font---- */
body {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
}
.post_content h2,
.post_content h3 {
	margin: 0;
}
.dis_none {
	display: none;
}
/* ----font---- */
.en_ft {
	font-family: "Cormorant Garamond", serif;
	font-optical-sizing: auto;
	font-weight: 100;
	font-style: normal;
}
.min_ft {
	font-family: "Zen Old Mincho", serif;
	font-weight: 400;
	font-style: normal;
}
/* ----改行・整形---- */
.br_pc {
	display: block;
}
.br_sp {
	display: none;
}

/* ----見出し---- */
.h2_ttl {
	font-family: "Zen Old Mincho", serif;
    margin: 0 auto 2.2em !important;
	display: block;
	text-align: left;
	font-size: 1.6rem !important;
}
.h2_ttl .s_ttl {
	font-family: "Cormorant Garamond", serif;
    position: relative;
    font-size: 1.3rem !important;
    font-weight: 500;
    display: block;	
    margin-top: 5px;
}

/* h2_tate_ttl */
.h2_tate_ttl {
    font-family: "Zen Old Mincho", serif;
    font-weight: 400 !important;
    font-style: normal;
    writing-mode: vertical-rl;
    position: absolute !important;
    font-size: clamp(2rem, 1.4rem + 1vw, 2.2rem) !important;
    letter-spacing: 0.6rem;
    height: max-content;
}
.h2_tate_ttl::before {
    content: "";
    position: absolute;
    background: url(../../uploads/2025/04/cap_line.svg) no-repeat center / 100%;
    width: 95px;
    height: 95px;
    right: -40px;
    top: -50px;
}
.h2_tate_ttl::after {
    content: "";
    position: absolute;
    background: url(../../uploads/2025/04/cap_line.svg) no-repeat center / 100%;
    width: 95px;
    height: 95px;
    left: -40px;
    bottom: -50px;
    transform: rotate(180deg);
}

/* ----ボタン---- */
.cmn_btn {
    min-width: 320px;
	margin: 0 auto;
}
.cmn_btn a {
	min-width: 320px;
    box-shadow: none;
	background: none;
    border: 1px solid var(--color_main);
    padding: 12px 25px;
    position: relative;
    transition: .3s;
    color: var(--color_main) !important;
    font-size: 0.9rem !important;
	font-weight: normal;
    text-align: left;
}
.cmn_btn.wh a {
    border: 1px solid #ccc;
    color: #fff !important;
}
.cmn_btn a::after {
	display: none;
}
.cmn_btn a:hover {
	background: rgba(31, 58, 81, .1);
	transition: .2s;
}
.cmn_btn.wh a:hover {
	background: rgba(255, 255, 255, .2);
}
.cmn_btn a svg {
	margin: 0 0 0 auto;
}

/* ----ヘッダー---- */
.l-header {
	position: absolute;
	background: none;
}
.l-header .l-container {
	max-width: 100%;
}
.l-fixHeader .l-container {
	max-width: 100%;
}
.-series .l-header__logo {
	min-width: 56px;
	margin: 30px 1vw 0 0;
	padding: 0;
}
.-series .c-headLogo {
	margin-right: 0;
}
.c-gnav {
    margin-top: 30px;
	height: 70px;
}
.c-gnav>.menu-item>a{
	padding: 0 1vw;
	transition: .2s;
	display: flex;
	flex-direction: column;
	color: #fff;
	height: auto;
}
.c-gnav>.menu-item>a:hover{
	opacity: .7;
}
.c-gnav>.menu-item>a::after {
	background: none;
}
.c-gnav>.menu-item>a .ttl {
	font-family: "Zen Old Mincho", serif;
	font-weight: 300;
	font-style: normal;
	font-size: clamp(0.8rem, 0.35rem + 0.75vw, 0.95rem);
	order: 2;
}
.c-gnav>.menu-item>a .c-smallNavTitle {
	font-family: "Cormorant Garamond", serif;
    font-optical-sizing: auto;
    font-weight: 100;
    font-style: normal;
    font-size: 1.1rem;
    letter-spacing: 0.2rem;
	margin-bottom: 10px;
	opacity: 1;
}
.c-gnav li.contact a {
	background: var(--color_main) url(../../uploads/2025/04/icon_mail.svg) no-repeat left 15px center / 17px 14px !important;
    color: #fff;
	font-weight: normal;
    padding: 15px 20px 15px 45px;
    margin-left: 15px;
	transition: .2s;
}
.c-gnav li.contact a::after {
	background: none !important;
}
.c-gnav li.contact a:hover{
	background: #5C6670 url(../../uploads/2025/04/icon_mail.svg) no-repeat left 15px center / 17px 14px !important;
	opacity: 1;
}
.c-gnav li.contact a .c-smallNavTitle {
	display: none;
}
.c-gnav .sub-menu {
	background: rgba(255, 255, 255, .8);
	border: 1px solid var(--color_main);
	width: 16em;
}
.c-gnav .sub-menu a {
	color: var(--color_main);
	transition: .3s;
	border-bottom: 1px solid var(--color_main);
	font-size: clamp(0.8rem, 0.35rem + 0.75vw, 0.95rem);
}
.c-gnav .sub-menu a:before,
.c-listMenu a:before {
	top: 55%;
}
.c-gnav .sub-menu a:last-child {
	border-bottom: none;
}
.c-gnav .sub-menu a:hover {
	background: var(--color_main);
	color: #fff;
	transition: .2s;
}
.l-fixHeader__logo {
	padding: 10px 0;
}
.l-fixHeader .c-gnav {
	margin-top: 0;
	height: 100%;
}
.l-fixHeader .c-gnav>.menu-item>a{	
	color: #fff;
	height: 100%;
    padding-bottom: 5px;
}
.l-fixHeader .c-gnav>.menu-item>a .c-smallNavTitle {
    font-size: 1rem;
}
.l-fixHeader .c-gnav li.contact {	
    display: flex;
    align-items: center;
}
.l-fixHeader .c-gnav li.contact a {
	background: #fff url(../../uploads/2025/04/icon_mail_b.svg) no-repeat left 15px center / 17px 14px !important;
	color: var(--color_main);
    height: auto;
    padding: 15px 20px 15px 45px;
}
.l-fixHeader .c-gnav li.contact a:hover {
	background: #F3F2EF url(../../uploads/2025/04/icon_mail_b.svg) no-repeat left 15px center / 17px 14px !important;
}

/* ----コンテンツヘッダー---- */
.l-topTitleArea {
    height: 34vh;
    color: #fff !important;
	position: relative;
    font-size: 1.2rem !important;
	text-align: center;
}
.l-topTitleArea div.l-topTitleArea__body {
    text-shadow: unset;
    color: #fff;
}
.c-pageTitle,
.c-postTitle__ttl {
	font-family: "Zen Old Mincho", serif;
	font-weight: 400;
	font-style: normal;
	margin-top: 40px;
	letter-spacing: 0.3rem;
    font-weight: 500;
}
.c-pageTitle__subTitle {
	font-family: "Cormorant Garamond", serif;
	font-optical-sizing: auto;
	font-weight: 100;
	font-style: normal;
	visibility: visible;
    display: block;
    font-size: 1.1rem;
    letter-spacing: 0.1rem;
    opacity: 1;
    margin: 5px auto 0;
}
.p-articleMetas {
	justify-content: center;
}

/* ----パンくずー---- */
.p-breadcrumb__text .__home:before {
	display: none;
}

/* ----コンテンツ---- */
.swell-block-fullWide__inner {
	padding: 0;
}
/* ----概要---- */
.outlineBox > .swell-block-dl__dt{
    padding: 20px 15px;
    color: var(--color_main);
	border-top: 1px solid var(--color_main);
    display: flex;
    align-items: stretch;
	font-weight: normal;
}
.outlineBox > .swell-block-dl__dt:last-of-type{
	border-bottom: 1px solid var(--color_main);
}
.outlineBox > .swell-block-dl__dt:after{
    display: none;
}
.outlineBox > .swell-block-dl__dd{
    border-top: 1px solid #D9D9D9;
	padding: 20px 14px;
    line-height: 1.8;
}
.outlineBox > .swell-block-dl__dd:last-of-type{
    border-bottom: 1px solid #D9D9D9;
}
.outlineBox .s_detail .swell-block-dl__dt:after {
	background: none;
    content: "…";
    color: var(--color_main);
    top: 0.3em;
    width: 1em;
    font-size: 1em;	
}
.outlineBox > .swell-block-dl__dd .s_ttl {
	font-size: 1.1rem;
}

/* ----投稿---- */
.p-postList__title {
	font-weight: normal !important;
}
.p-postList__times {
	font-size: 0.8rem;
}
.p-postList__meta :before {
	display: none;
}
/* post_query */
.post_queryBox ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
	padding: 0;
	width: 90vw;
	margin: 0 auto;
}
.post_queryBox ul::after{
	content: "";
	display: block;
	width: calc(100% / 3 - 1.8vw);
}
.post_queryBox ul li.wp-block-post {
	width: calc(100% / 3 - 1.8vw) !important;
    padding: 0;
	list-style: none;
	margin-bottom: 40px;
	position: relative;
    display: flex;
    flex-direction: column;
}
.post_queryBox ul li.wp-block-post figure {
    aspect-ratio: 3 / 2;
	overflow: hidden;
	margin-bottom: 20px;
}
.post_queryBox ul li.wp-block-post figure img {
    object-fit: cover;
    object-position: center;
    height: -webkit-fill-available;
	transition: .2s;
}
.post_queryBox ul li.wp-block-post figure:hover img {
	transform: scale(1.05);
	transition: .2s;
	opacity: .8;
}
.post_queryBox ul li.wp-block-post:hover .wp-block-post-date,
.post_queryBox ul li.wp-block-post:hover h2.wp-block-post-title{
	opacity: 1 !important;
}
.post_queryBox ul li.wp-block-post .wp-block-post-date {
	font-size: 0.8rem;
	color: #474B53;
    order: 2;
}
.post_queryBox ul li.wp-block-post h2.wp-block-post-title {
	font-size: 1rem !important;
	font-weight: 400;
	transition: .2s;
    margin: 0 0 8px;
}
.post_queryBox .wp-block-query-pagination {
	justify-content: center;
	margin-top: 2em;
}
.post_queryBox .wp-block-query-pagination-numbers {
	display: flex;
    align-items: center;	
}
.post_queryBox .wp-block-query-pagination-numbers .page-numbers {
	margin: 0 6px 0 0;
}

/* ----事業---- */
.serviceArea .swell-block-fullWide__inner {
    padding: 0;
    max-width: 90vw;
    margin: 0 auto;
}
.serviceArea .wp-block-media-text__media {
    height: 540px;
    overflow: hidden;
}
.serviceArea .wp-block-media-text__media img {
    height: 100%;
    object-fit: cover;
}
.serviceArea .wp-block-media-text {
    margin-bottom: 100px;
    display: flex;
}
.serviceArea .wp-block-media-text__content {
    background: rgba(243, 242, 239, .9);
    padding: 70px 30px 70px 230px;
    margin-top: 110px;
    align-self: auto;
    max-width: 920px;
    position: absolute;
    right: 0;
    width: 90vw;
    min-height: 460px;
    display: flex;
    align-items: center;
}
.serviceArea .wp-block-media-text__content .h2_tate_ttl {
    left: 70px;
    bottom: 8vw;
}
.serviceArea .wp-block-media-text__content p {
    line-height: 2.3;
    font-size: clamp(0.9rem, 0.6rem + 0.5vw, 1rem);
}
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__media {
    margin: 0 0 0 auto;
}
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content {
    padding: 70px 230px 70px 80px;
    right: auto;
    left: 0;
    margin-top: 110px !important;
    min-height: 530px;
}
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content .h2_tate_ttl {
    left: auto;
    right: 80px;
    bottom: 6vw;
}
.serviceArea.ls {
    padding-bottom: 8em !important;
}
.serviceArea.ls .wp-block-media-text {
    display: flex;
    align-items: center;
}
.serviceArea.ls .wp-block-media-text__content {
    flex-direction: column;
    align-items: normal;
    padding: 70px 90px;
    margin-top: 0;
    min-height: auto;
}
.serviceArea.ls h2 {
    font-family: "Zen Old Mincho", serif;
    font-weight: 400 !important;
    font-style: normal;
    font-size: 2.5rem;
    letter-spacing: 0.2rem;
    margin-bottom: 20px;
}
.serviceArea.ls .cmn_btn {
    margin: 0 auto 0 0;
}
.serviceArea.ls .bg_ttl {
    position: absolute;
    right: 4vw;
    bottom: -90px;
    font-family: "Cormorant Garamond", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-size: clamp(4rem, 1rem + 5vw, 5rem);
    letter-spacing: 0.3rem;
}

/* ----その他事業---- */
.otherArea {
    padding-bottom: 8em !important;
}
.otherArea figure {
    margin-bottom: 60px; 
}
.otherArea h2 {
    margin-bottom: 15px;
}
.otherArea h2 span {
    position: absolute;
    z-index: -1;
    font-family: "Cormorant Garamond", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-size: clamp(3rem, 0.3rem + 4.5vw, 3.9rem);
    letter-spacing: 0.2rem;
    left: 0;
    bottom: -10px;
}

/* ----採用---- */
.recruitArea .swell-block-fullWide__inner {
    padding: 0 2vw;
}
.recruitArea .wp-block-media-text {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.recruitArea .wp-block-media-text__media {
    position: absolute;
    width: 620px;
    z-index: 20;
}
.recruitArea .wp-block-media-text__content {
    border: 1px solid var(--color_main);
    padding: 40px 60px 70px 140px;
    width: 56%;
    margin: 0 0 0 auto !important;
}
.recruitArea .wp-block-media-text__content h2 {
    font-weight: 500;
    font-size: 4.4rem;
    letter-spacing: 0.2rem;
    margin-bottom: 40px;
}
.recruitArea .wp-block-media-text__content h2 span {
    font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.2rem;
    letter-spacing: 0.1rem;
    margin-left: 20px;
}
.recruitArea .wp-block-media-text__content p {
    line-height: 2.4;
}
.recruitArea .wp-block-media-text__content .cmn_btn {
    min-width: 260px;
}
.recruitArea .wp-block-media-text__content .cmn_btn a {
    min-width: 260px;
}

/* ----事業内容---- */
.l-conceptArea {
	min-height: 700px;
    display: flex;
    align-items: center;
}
.l-conceptArea .swell-block-fullWide__inner {
    width: 100%;
    max-width: 1180px;
	display: flex;
    align-items: center;
	justify-content: space-between;
}
.l-conceptArea .main_ttl {
    writing-mode: vertical-rl;
    font-size: clamp(2rem, 0.8rem + 2vw, 2.4rem);
    font-weight: normal;
    letter-spacing: 1rem;
    text-align: right;
	line-height: 1.6;
}
.l-conceptArea .wp-block-group {
    padding: 6em 0;
	text-align: right;
}
.l-conceptArea .wp-block-group .h3_jp {
    font-size: clamp(1.7rem, 1.1rem + 1vw, 1.9rem);
    font-weight: bold;
    letter-spacing: 0.5rem;
    line-height: 1.7;
    margin-bottom: 35px;
}
.l-conceptArea .wp-block-group .txt_jp {
    line-height: 2.6;
    letter-spacing: 0.1rem;
    font-size: clamp(1rem, 0.25rem + 1.25vw, 1.25rem);
}
.pointArea {
	padding-bottom: 6em !important;
}
.pointArea .swell-block-fullWide__inner {
    width: 90vw;
    margin: 0 auto;
}
.pointArea .swell-block-columns__inner {
    justify-content: space-between;
}
.pointArea .txt_in {
	width: 38vw;
    min-height: 460px;
    background: rgba(243, 242, 239, .9);
    position: relative;
    padding: 3vw 4vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 0 0 0 3vw;
}
.pointArea .txt_in::before {    
    content: "";
    position: absolute;
    background: url(../../uploads/2025/04/cap_line.svg) no-repeat center / 100%;
    width: 95px;
    height: 95px;
    right: -40px;
    top: -40px;
}
.pointArea .txt_in::after {    
    content: "";
    position: absolute;
    background: url(../../uploads/2025/04/cap_line.svg) no-repeat center / 100%;
    width: 95px;
    height: 95px;
    left: -40px;
    bottom: -40px;
    transform: rotate(180deg);
}
.pointArea .txt_in .point_num {
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.1rem;
    margin-bottom: 20px;
}
.pointArea .txt_in .point_ttl {
    font-size: clamp(1.7rem, 0.9rem + 1.3333vw, 2.5rem);
    font-weight: normal;
    margin-bottom: 30px;
}
.pointArea .txt_in p {
    line-height: 2.3;
    font-size: clamp(0.9rem, 0.6rem + 0.5vw, 1rem);
}
.pointArea .img_in {
    width: 44vw;
}
.pointArea .img_in figure img {
    width: auto;
    object-fit: cover;
}
.pointArea .swell-block-columns:nth-child(2n) .txt_in {
    margin: 0 3vw 0 0;
}
.exampleArea {
    padding-bottom: 5em !important;
}
.exampleArea .swell-block-column {
    margin-bottom: 15px;
}
.exampleArea .swell-block-column figure {
    margin-bottom: 15px;
}
.achieveArea .p-postList {
    justify-content: space-between;
}
.achieveArea .p-postList .p-postList__item {
    width: calc(100% / 3 - 1.2vw) !important;
}
.achieveArea .p-postList .p-postList__thumb {
    box-shadow: none;
}
.achieveArea .p-postList .p-postList__item figure {
    aspect-ratio: 3 / 2.1;
}
.achieveArea .cmn_btn a {
    min-width: 260px;
}
.flowArea dl {
    border-bottom: 1px solid var(--color_main);
    margin: 0;
    padding: 50px 40px;
    align-items: center;
}
.flowArea dl:first-of-type {
    border-top: 1px solid var(--color_main);
}
.flowArea dl dt {
    width: 330px !important;
    display: flex;
    align-items: center;
    font-size: 1.6rem;
    padding: 0 !important;
}
.flowArea dl dt::after {
    display: none !important;
}
.flowArea dl dt .flow_num {
    font-size: 3.2rem;
    font-weight: normal;
    margin-right: 40px;
}
.flowArea dl dd {
    width: calc(100% - 330px) !important;
    line-height: 2.2;
}
.faqArea {
    padding-top: 3em !important;
}
.faqArea .swell-block-accordion__item {
    margin-bottom: 30px;
}
.faqArea .swell-block-accordion__title {
    padding: 20px 35px;
    font-size: 1.1rem;
}
.faqArea .swell-block-accordion__title::before {
    content: "Q";
	  font-family: "Cormorant Garamond", serif;
    font-size: 2.4rem;
    line-height: 1;
    margin-right: 30px;
}
.faqArea .swell-block-accordion__body {
    padding: 25px 35px 35px;
    line-height: 2.4;
}
.faqArea .swell-block-accordion__body p {
    display: flex;
}
.faqArea .swell-block-accordion__body p::before {
    content: "A";
	font-family: "Cormorant Garamond", serif;
    font-size: 2.4rem;
    line-height: 1;
    margin-right: 30px;
}

/* ----施工事例---- */
.cateArea {
    padding-bottom: 0em !important;
}
.cateArea .swell-block-fullWide__inner {
    width: 90vw;
}
.cate_btn.focus a {
    background: rgba(159, 173, 189, .4);
}
.cate_btn a {
    font-family: "Zen Old Mincho", serif;
    background: rgba(217, 217, 217, .3);
    border: 1px solid var(--color_main);
    padding: 15px 0;
    box-shadow: none;
    font-size: clamp(0.92rem, 0.08rem + 1.4vw, 1.2rem);
}
.cate_btn a:after {
    display: none;
}
.cate_btn a:hover {
    background: rgba(159, 173, 189, .4);
}

/* ----フッター---- */
.c-widget+.c-widget {
	margin: 0 auto;
}
.w-beforeFooter{
	margin: 0 auto;
}
.f-about .capL {
    width: 540px;
}
.f-about .capL h2 {
    font-weight: normal;
    font-size: 4.4rem;
    letter-spacing: 0.3rem;
    line-height: 1;
}
.f-about .txtR {
    width: calc(100% - 540px);
    padding-right: 50px;
}
.f-about .txtR p {
    font-size: 1.2rem;
    line-height: 2.4;
    letter-spacing: 0.1rem;
}
.f-about .txtR .cmn_btn {
    min-width: 260px;
}
.f-about .txtR .cmn_btn a {
    min-width: 260px;
}
.f-bn .wp-block-cover {
	min-height: auto;
	padding: 2em 2em 4em;
}
.f-bn .estimate .wp-block-cover__background,
.f-bn .contact .wp-block-cover__background {
	transition: .4s;
}
.f-bn .estimate:hover .wp-block-cover__background, 
.f-bn .contact:hover .wp-block-cover__background {
	opacity: 0;
	transition: .4s;
}
.f-bn .estimate h2, 
.f-bn .contact h2 {
	font-weight: 500;
    font-size: clamp(3.6rem, 1.2rem + 4vw, 4.4rem);
    letter-spacing: 0.2rem;
    margin-bottom: 10px;
}
.f-bn .estimate h2 span, 
.f-bn .contact h2 span {
	font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    font-style: normal;
    font-size: clamp(1rem, 0.4rem + 1vw, 1.2rem);
    letter-spacing: 0.1rem;
    margin-left: 20px;
}
.f-bn .estimate p, 
.f-bn .contact p {
	font-family: "Zen Old Mincho", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 0.9rem;
}
.f-bn .estimate .cmn_btn,
.f-bn .contact .cmn_btn {	
    min-width: 260px;
	margin: 0 auto;
}
.f-bn .estimate .cmn_btn .swell-block-button__link,
.f-bn .contact .cmn_btn .swell-block-button__link {	
	min-width: 260px;
    box-shadow: none;
	background: none;
    border: 1px solid #fff;
    padding: 12px 25px;
    position: relative;
    transition: .3s;
    color: #fff !important;
    font-size: 0.9rem !important;
	font-weight: normal;
    text-align: left;
}
.f-bn .estimate .cmn_btn .swell-block-button__link .__icon,
.f-bn .contact .cmn_btn .swell-block-button__link .__icon {
	margin: 0 0 0 auto;
}
.f-bn .estimate:hover .cmn_btn .swell-block-button__link,
.f-bn .contact:hover .cmn_btn .swell-block-button__link{
	background: rgba(255, 255, 255, .2);
	transition: .4s;
}
.w-footer__box {
	width: 100%;
	margin: 0 auto;
}
.footer_in .swell-block-columns__inner {
	justify-content: space-between;	
}
.w-footer__box .wp-block-list{
    list-style: none;	
}
.w-footer__box .post_content li {
	line-height: 3;
	margin: 0;
}
.w-footer__box .swell-block-fullWide__inner {
	padding-left: 80px;
}
.w-footer__box .sns_list {
    --the-gap: .5em 0.2em !important;
}
.w-footer__box .sns_list li a .swl-inline-icon {
	transition: .2s;	
}
.w-footer__box .sns_list li a:hover .swl-inline-icon {
	color: #9FADBD !important;
	transition: .2s;
}
.footer-list {
    list-style: none;
    justify-content: center;
	padding-left: 0 !important;
}
.footer-list li {
    font-size: clamp(0.75rem, 0.3rem + 0.75vw, 0.9rem);
}
.footer-list li a{
	transition: .2s;
}
.footer-list li a:hover {
    opacity: .7;
	transition: .2s;
}
.footer-list .s_list li {
	padding-left: 0.8em;
}
.footer-list .s_list li::before {
	position: absolute;
	left: 0;
    content: "-";
}
.l-footer .copyright {
	font-family: "Cormorant Garamond", serif;
	font-optical-sizing: auto;
	font-weight: 100;
	font-style: normal;
	font-size: 0.85rem;
    text-align: left;
    letter-spacing: 0.15rem;
	padding: 0 30px 50px;
}


@media screen and (max-width: 1279px) {	
.swell-block-fullWide__inner {
	width: 90vw;
    margin: 0 auto;
}

.serviceArea .wp-block-media-text__media {
    width: 100%;
    aspect-ratio: 3 / 1.8;
}
.serviceArea .wp-block-media-text__content {
    left: 0;
    margin: 30vw auto 0 !important;
}
.serviceArea .wp-block-media-text {
    margin-bottom: 30vw;
	height: 65vw;
}
.serviceArea .wp-block-media-text.kojin {
	height: 70vw !important;
}
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content {
    right: 0;
    margin: 30vw auto 0 !important;
}
	
.recruitArea .wp-block-media-text {
    flex-direction: column;
}
.recruitArea .wp-block-media-text__content {
    width: 80vw;
    margin: 0 auto !important;
    padding: 150px 12vw 70px;
    margin-top: 250px !important;
}
.recruitArea .wp-block-media-text__content .br_pc {
    display: none;
}
.recruitArea .wp-block-media-text__content h2 {
    margin-bottom: 10px;
}
.recruitArea .wp-block-media-text__content .cmn_btn {
    text-align: center;
}

.l-conceptArea .swell-block-fullWide__inner {
    width: 90vw;
}
.pointArea .swell-block-fullWide__inner {
    width: 95vw;
}
.pointArea .txt_in {
    width: 48vw;
    margin: 0 0 0 1.5vw;
}
.pointArea .swell-block-columns:nth-child(2n) .txt_in {
    margin: 0 1.5vw 0 0;
}
	
.w-beforeFooter .swell-block-fullWide__inner {
	width: 100%;
}
.w-footer__box .swell-block-fullWide__inner {
	padding-left: 2vw;
}
}


/*---------------------------------------------------tb---*/
@media screen and (max-width: 959px) {
.h2_ttl {
	margin: 0 auto 1.6em !important;
}
.h2_tate_ttl {
    writing-mode: lr;
    position: relative !important;
    letter-spacing: 0.4rem;
}
.h2_tate_ttl::before {
    left: -60px;
    top: -40px;
    transform: rotateY(180deg);
    right: auto;
}
.h2_tate_ttl::after {
    right: -60px;
    bottom: -40px;
    transform: rotateX(-180deg);
    left: auto;
}
.-series .l-header__logo {
	margin: 0 0 0 5vw;
}
.-img .c-headLogo__link {
	padding: 6px 0;
}
.l-header {
	background: rgba(31, 58, 81, .9);
}
.l-header__inner {
	justify-content: space-between;
}
.p-spMenu__inner::before {
	background: rgba(31, 58, 81, .9);
}
.p-spMenu__inner .icon-close-thin:before {
	color: #fff;
}
.c-widget__title.-spmenu {
	color: #fff;
	font-family: "Cormorant Garamond", serif;
	font-optical-sizing: auto;
	font-weight: 100;
	font-style: normal;
	font-size: 2.5rem;
	line-height: 1;
	margin-bottom: 20px;
	padding: 0 .45em;
	background: none;
	letter-spacing: 0.3rem;
}
.c-spnav>.menu-item>a {
	font-size: clamp(1rem, 0.8569rem + 0.5725vw, 1.2rem);
}
.c-spnav>.menu-item>a .br_pc{
	display: none;
}
.c-spnav>.menu-item.tel{
	display: none;
}
.c-spnav a {
	color: #fff;
	border-bottom: none;
	font-size: 1.4rem;
	padding: 0.5em 1em .5em 1.5em;
	line-height: 1.8;
}
.c-spnav a .c-smallNavTitle {
	font-family: "Cormorant Garamond", serif;
	font-optical-sizing: auto;
	font-weight: 100;
	font-style: normal;	
	font-size: 0.8rem;
}
.c-gnav li.contact a .c-smallNavTitle {
	display: block;
}
	
.l-topTitleArea {
	min-height: 180px;
    height: 30vh;
	font-size: clamp(1rem, 0.6657rem + 0.8914vw, 1.2rem) !important;
	margin-top: -65px;
}
.c-pageTitle {
	margin-top: 60px;
}	
.c-pageTitle__subTitle {
	font-size: clamp(1rem, 0.8329rem + 0.4457vw, 1.1rem);
}

/* ----概要---- */
.outlineBox .s_detail {
	flex-direction: columm;
}
.outlineBox .s_detail .swell-block-dl__dt:after {
	display: none;
}
.outlineBox .s_detail .swell-block-dl__dd {
	width: 100%;
}
/* post_query */
.post_queryBox ul {
	max-width: 700px;
}
.post_queryBox ul li.wp-block-post {
    width: calc(100% / 2 - 1.5vw) !important;
}	
	
.serviceArea .wp-block-media-text {
    flex-direction: column;
}
.serviceArea .wp-block-media-text:first-child {
	height: auto;
    min-height: 90vh !important;
    margin-bottom: 20vw !important;
}	
.serviceArea .wp-block-media-text.kojin {
	min-height: auto !important;
}
.serviceArea .wp-block-media-text__media {
    height: auto;
}
.serviceArea .wp-block-media-text__content,
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content {
    margin: 45vw auto 0 !important;
    width: 85vw;
    min-height: auto;
    padding: 10vw 6vw 8vw;
}
.serviceArea .wp-block-media-text__content p .br_pc {
    display: none;
}
.serviceArea .wp-block-media-text__content .wp-block-group {
    width: 100%;
}
.serviceArea .wp-block-media-text__content .wp-block-group__inner-container {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.serviceArea .wp-block-media-text__content .h2_tate_ttl,
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content .h2_tate_ttl {
    left: auto;
    right: auto;
    bottom: auto;
	margin-bottom: 60px;
}
.serviceArea .wp-block-media-text__content p {
    line-height: 2;
}
.serviceArea .wp-block-media-text__content .cmn_btn {
    text-align: center;
    margin: 0 auto;
}
.serviceArea.ls .wp-block-media-text {
	min-height: 60vh !important;
	margin-bottom: 25vw !important;
}
.serviceArea.ls .wp-block-media-text__content {
    padding: 8vw 6vw;
}
.serviceArea.ls .bg_ttl {
    font-size: clamp(3.4rem, 2.3972rem + 2.6741vw, 4rem);
    bottom: -7vw;
}
.serviceArea.ls .wp-block-media-text__content .cmn_btn {
    text-align: center;
    margin: 0 auto;
}
	
.otherArea {
    padding-bottom: 4em !important;
}
.otherArea figure {
    margin-bottom: 50px;
}
.otherArea h2 span {
    font-size: clamp(3.4rem, 3.0657rem + 0.8914vw, 3.6rem);
}
	
.recruitArea .swell-block-fullWide__inner {
    max-width: 600px;
}
.recruitArea .wp-block-media-text__media {
    width: auto;
}
.recruitArea .wp-block-media-text__content {
    width: auto;
    padding: 140px 6vw 50px;
    margin-top: 250px !important;
}
.recruitArea .wp-block-media-text__content p {
    font-size: 0.9rem;
}
.recruitArea .wp-block-media-text__content h2 {
    font-size: clamp(3.6rem, 2.263rem + 3.5655vw, 4.4rem);
}
.recruitArea .wp-block-media-text__content h2 span {
    font-size: clamp(1rem, 0.6657rem + 0.8914vw, 1.2rem);
}
	
.l-conceptArea .main_ttl {
    font-size: clamp(1.6rem, 0.9315rem + 1.7827vw, 2rem);
}
.l-conceptArea .wp-block-group {
    padding: 4em 0;
}
.l-conceptArea .wp-block-group .br_sp {
	display: block;
}
.l-conceptArea .wp-block-group .h3_jp {
    letter-spacing: 0.3rem;
    font-size: clamp(1.25rem, 0.4979rem + 2.0056vw, 1.7rem);
}
.l-conceptArea .wp-block-group .txt_jp {
    font-size: clamp(0.9rem, 0.7329rem + 0.4457vw, 1rem);
}
.pointArea .swell-block-fullWide__inner {
	width: 90vw;
}
.pointArea .txt_in {
    width: 90vw;
    max-width: 510px;
    min-height: auto;
    order: 2;
    margin: 0 auto;
    padding: 40px 30px;
}
.pointArea .swell-block-columns:nth-child(2n) .txt_in {
    margin: 0 auto;
}
.pointArea .txt_in .point_num {
    font-size: 1.4rem;
}
.pointArea .txt_in .point_ttl {
    font-size: clamp(1.5rem, 1.1657rem + 0.8914vw, 1.7rem);
}
.pointArea .txt_in p {
    line-height: 2;
}
.pointArea .img_in {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}
.exampleArea .swell-block-column figure {
    margin-bottom: 8px;
}
.exampleArea .swell-block-column p {
    font-size: clamp(0.8rem, 0.4657rem + 0.8914vw, 1rem);
}
.achieveArea .p-postList .p-postList__item {
    width: calc(100% / 2 - 0.5vw) !important;
}
.flowArea dl {
    flex-direction: column;
    padding: 20px 3vw 40px;
}
.flowArea dl dt {
    width: 100% !important;
    justify-content: center;
}
.flowArea dl dt .flow_num {
    margin-right: 20px;
}
.flowArea dl dd {
    width: 100% !important;
    line-height: 2;
}
.faqArea {
    padding-top: 1em !important;
}
.faqArea .swell-block-accordion__title {
    font-size: 1rem;
}
.faqArea .swell-block-accordion__body {
    line-height: 2;
    font-size: 0.9rem;
}
	
.cateArea .swell-block-fullWide__inner {
    max-width: 700px;
}
	
.f-about .swell-block-columns__inner {
    width: 85vw;
}
.f-about .capL {
    width: 100%;
    text-align: right;
}
.f-about .capL h2 {
    font-size: clamp(3.6rem, 2.263rem + 3.5655vw, 4.4rem);
}
.f-about .txtR {
    width: 100%;
    padding-right: 0;
}
.f_add {
	font-size: 0.9rem;
}
.f_link {
	display: none;
}
.l-footer .copyright {
	padding: 0 4vw 30px;		
}
}


/*---------------------------------------------------sp---*/
@media screen and (max-width: 599px) {
.br_pc {
	display: none;
}
.br_sp {
	display: block;
}	
.h2_tate_ttl {
    font-size: 1.7rem !important;
    letter-spacing: 0.3rem;
}
.h2_tate_ttl::before,
.h2_tate_ttl::after {
    background-size: 50%;
}
.h2_tate_ttl::before {
    top: -50px;
    left: -55px;
}
.h2_tate_ttl::after {
    bottom: -50px;
    right: -55px;
}
.cmn_btn {
    min-width: 260px;
}
.cmn_btn a{
	min-width: 260px;
	padding: 12px 15px;
}
.l-header {
	background: var(--color_main);
}
.l-topTitleArea {
	min-height: 4em;
    height: 20vh;
	font-size: 1rem !important;
	margin-top: 0;
}
.c-pageTitle {
    margin-top: 5px;
}
.c-pageTitle__subTitle {
	font-size: 1rem;
	margin: 2px auto 0;
}
.c-postTitle__ttl {
	margin-top: 0;
    font-size: 1.2rem !important;
}
	
/* ----概要---- */
.outlineBox {
    flex-direction: column;
    margin: 0 auto 2em !important;
}
.outlineBox > .swell-block-dl__dt{
    width: 100%;
    padding: 8px 8px 2px;
    border-top: 1px solid #D9D9D9;
	font-weight: bold;
}
.outlineBox > .swell-block-dl__dt:last-of-type{
    border-bottom: 0;
}
.outlineBox > .swell-block-dl__dd{
    border: 0;
    width: 100%;
    padding: 2px 8px 8px;
    line-height: 1.6;
}
.outlineBox .s_detail {
	margin-bottom: 1em !important;
}
.outlineBox .s_detail .swell-block-dl__dt {
	padding-bottom: 0;
}
.outlineBox .s_detail .swell-block-dl__dd {
	margin-bottom: 5px;
}

/* post_query */
.post_queryBox ul li.wp-block-post {
	margin-bottom: 30px;
}
.post_queryBox ul li.wp-block-post figure {
	margin-bottom: 10px;
}
.post_queryBox ul li.wp-block-post h2.wp-block-post-title {
	margin: 0 0 5px;
}
.post_queryBox .wp-block-query-pagination-numbers {
	flex-wrap: wrap;
}
.post_queryBox .wp-block-query-pagination-numbers .page-numbers {
	margin: 0 6px 6px 0;
}
.post_queryBox .wp-block-query-pagination-numbers .page-numbers:last-child {
	margin-bottom: 6px !important;
}
.post_queryBox .wp-block-query-pagination-prev,
.post_queryBox .wp-block-query-pagination-next {
	margin-bottom: 6px;
}
	
.serviceArea .wp-block-media-text:first-child {
	min-height: 80vh;
    margin-bottom: 138vw;
}
.serviceArea .is-style-broken.is-stacked-on-mobile .wp-block-media-text__content {
    margin: 45vw auto 0 !important;
    padding: 10vw 5vw !important;
}
.serviceArea .wp-block-media-text__content .h2_tate_ttl,
.serviceArea .wp-block-media-text.kojin .wp-block-media-text__content .h2_tate_ttl {
    margin-bottom: 35px;
}
.serviceArea .wp-block-media-text.kojin {
	min-height: 60vh !important;
}
.serviceArea.ls .wp-block-media-text {        
    min-height: auto !important;
    margin-bottom: 55vw !important;
}
.serviceArea.ls h2 {
    font-size: 1.7rem;
    margin: 0 auto 20px;
}
.serviceArea.ls .bg_ttl {
    bottom: -12vw;
	letter-spacing: 0.2rem;
}

.otherArea figure {
    margin-bottom: 35px;
}
.otherArea h2 span {
    letter-spacing: 0.2rem;
}
.otherArea .swell-block-column p {
    font-size: 0.9rem;
}

.recruitArea {
    padding-bottom: 2em !important;
}
.recruitArea .wp-block-media-text__media {
    position: relative;
}
.recruitArea .is-style-broken.is-stacked-on-mobile .wp-block-media-text__content {
    margin: 0 auto !important;
    padding: 3vw 6vw 10vw !important;
}
.recruitArea .wp-block-media-text__content h2 {
    font-size: 3.4rem;
}
.recruitArea .wp-block-media-text__content p {
    line-height: 2;
}

.l-conceptArea {
	min-height: auto;
}
.l-conceptArea .swell-block-fullWide__inner {
    width: 93vw;
}
.l-conceptArea .main_ttl {
    font-size: 1.5rem;
	left: 0;
	letter-spacing: 0.5rem;
}
.l-conceptArea .main_ttl br {
    display: none;
}
.l-conceptArea .wp-block-group {
	padding: 2em 0;
}
.l-conceptArea .wp-block-group .h3_jp {
    line-height: 1.8;
	letter-spacing: 0.2rem;
	font-size: 1.1rem;
}
.l-conceptArea .wp-block-group .txt_jp {
    line-height: 2.2;
	font-size: 0.8rem;
}
.pointArea {
    padding-bottom: 3em !important;
}
.pointArea .swell-block-columns {
    --swl-clmn-mrgn--y: 1rem !important;
    margin-bottom: 4em !important;
}
.pointArea .txt_in {
    max-width: 90vw;
	padding: 30px 5vw;
}
.pointArea .txt_in::before,
.pointArea .txt_in::after {
    background-size: 50%;
}
.pointArea .txt_in .point_num {
    margin-bottom: 15px;
}
.pointArea .txt_in .point_ttl {
    margin-bottom: 20px;
}
.achieveArea .p-postList .p-postList__item {
    margin-bottom: 30px;
}
.achieveArea .p-postList .p-postList__item .p-postList__body {
    padding-top: 10px;
}
.flowArea dl {
    padding: 15px 3vw 30px;
}
.flowArea dl dt {
    margin-bottom: 5px;
}
.flowArea dl dt .flow_num {
    font-size: 2.6rem;
}
.faqArea .swell-block-accordion__item {
    margin-bottom: 15px;
}
.faqArea .swell-block-accordion__title {
    padding: 15px 15px 15px 20px;
    line-height: 1.6;
}
.faqArea .swell-block-accordion__title::before {
    font-size: 2rem;
    margin-right: 16px;
}
.faqArea .swell-block-accordion__label {
    padding: 0;
}
.faqArea .swell-block-accordion__body {
    padding: 15px 20px 25px;
}
.faqArea .swell-block-accordion__body p::before {
    font-size: 2rem;
    margin-right: 20px;
}
	
.cateArea .swell-block-columns {
    --swl-clmn-mrgn--x: 2vw !important;
}
.cate_btn a {
    letter-spacing: 0;
    padding: 10px 0;
    font-size: 0.85rem;
}
	
.f-about .swell-block-columns__inner {
    margin: 0 auto;
}
.f-about .swell-block-columns {
    --swl-clmn-mrgn--y: 1.5rem !important;
}
.f-about .txtR p {
    font-size: 1rem;
    margin-bottom: 30px !important;
}
.f-about .txtR .cmn_btn {
    text-align: center;
}
.f-bn .estimate .wp-block-cover__background,
.f-bn .contact .wp-block-cover__background {
	display: none;
}
.f-bn .estimate h2, .f-bn .contact h2 {
    font-size: 3.4rem;
}
.l-footer .copyright {
	padding: 0 4vw 20px;
}
	
}
