@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 !important;
}

/* ----font---- */
.en_ft {
	font-family: "Abril Fatface", serif;
	font-weight: 400;
	font-style: normal;
}

/* ----改行・整形---- */
.br_pc {
	display: block;
}
.br_sp {
	display: none;
}

/* ----見出し---- */
.h2_top {
	font-family: "Abril Fatface", serif;
	font-size: clamp(2.2rem, 1rem + 2vw, 2.6rem) !important;
	letter-spacing: 1.2rem;
	position: relative;
	font-weight: normal !important;
	line-height: 1 !important;
	margin-bottom: 50px !important;
}
.h2_top::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 3px;
	bottom: 40px;
	background: #fff;
}
.h2_top::after {
	content: "";
	position: absolute;
	width: calc(100% - 60px);
	height: 3px;
	left: 0;
	right: 0;
	margin: 0 auto;
	bottom: 40px;
	background: #949494;
}
.h2_top .s_ttl {
	font-family: "Noto Sans JP", sans-serif;
	display: block;
    font-size: clamp(1rem, 0.4rem + 1vw, 1.2rem);
	font-weight: 600;
    letter-spacing: 0.6rem;
	margin-top: 40px;
}
.h2_top.bk::before {
	background: #000;
}
.h2_ttl {
	font-family: "Abril Fatface", serif;
	font-size: 1.2rem !important;
    letter-spacing: 0.05rem;
    font-weight: normal !important;
    line-height: 1 !important;
}
.h2_ttl .s_ttl {
	font-family: "Noto Sans JP", sans-serif;
    font-size: 2rem;
    font-weight: bold;
    letter-spacing: 1rem;
    margin-top: 20px;
    display: block;
    text-indent: 1rem;
}

/* ----ボタン---- */
.cmn_btn {
	font-family: "Abril Fatface", serif;
    min-width: 240px;
	margin: 0 auto;
}
.cmn_btn a {
	background: rgba(255, 255, 255, .3);
	min-width: 240px;
    box-shadow: none;
	background: none;
    border: 1px solid #333;
    padding: 12px 25px;
    position: relative;
    transition: .3s;
    color: #333 !important;
    font-size: 1.1rem !important;
	letter-spacing: 0.2rem;
	font-weight: normal;
    text-align: left;
}
.cmn_btn.wh a {
    border: 1px solid #fff;
    color: #fff !important;
}
.cmn_btn a::after {
	content: "";
	width: 40px;
	height: 1px;
	background: #333;
	right: -20px;
	top: 0;
	bottom: 0;
	margin: auto 0;
}
.cmn_btn.wh a::after {
	background: #fff;
}
.cmn_btn a:hover {
	background: rgba(31, 58, 81, .1);
	transition: .2s;
}
.cmn_btn.wh a:hover {
	background: rgba(255, 255, 255, .2);
}

/* ----ヘッダー---- */
.l-header {
	position: absolute;
	background: rgba(51, 51, 51, .5);
}
.l-header .l-container {
	max-width: 100%;
	padding-right: 0;
}
.l-fixHeader {
    background: rgba(51, 51, 51, 0.7);
}
.l-fixHeader .l-container {
	max-width: 100%;
	padding-right: 0;
}
.-series .l-header__logo {
	min-width: 56px;
	margin-right: 1vw;
	padding: 10px 0;
}
.-series .c-headLogo {
	margin-right: 0;
}
.c-gnav>.menu-item.n_dis {
	display: none;	
}
.c-gnav>.menu-item>a{
	padding: 0 1vw;
	transition: .2s;
}
.c-gnav>.menu-item>a .ttl {
	font-weight: 500;
	font-style: normal;
	font-size: clamp(0.8rem, 0.35rem + 0.75vw, 0.95rem);
	order: 2;
}
.c-gnav>.menu-item.insta>a .ttl {
    font-size: 1.8rem;
}
.c-gnav li.contact a {
	background: var(--color_main) url(../../uploads/2025/05/icon_mail.svg) no-repeat left 45px center / 24px 24px !important;
    color: #fff;
	font-weight: normal;
    padding: 15px 50px 15px 85px;
    margin-left: 15px;
	transition: .2s;
}
.c-gnav li.contact a::after {
	background: none !important;
}
.c-gnav li.contact a:hover{
	opacity: .8;
}
.l-fixHeader__logo {
	padding: 10px 0;
}
.l-fixHeader .c-gnav {
	margin-top: 0;
	height: 100%;
}

/* ----コンテンツヘッダー---- */
.l-topTitleArea {
    height: 38vh;
    color: #fff !important;
	position: relative;
}
.l-topTitleArea div.l-topTitleArea__body {
    text-shadow: unset;
    color: #fff;
	padding: 0;
}
.c-pageTitle,
.c-postTitle__ttl {
	display: flex;
	flex-direction: column;
	font-style: normal;
    font-weight: 500;
	margin-top: 70px;
    font-size: 1.2rem !important;
    letter-spacing: 0.7rem;
}
.c-pageTitle__subTitle {
	font-family: "Abril Fatface", serif;
	font-style: normal;
	visibility: visible;
    display: block;
    font-size: 2.4rem;
    letter-spacing: 1.5rem;
    opacity: 1;
    position: relative;
    margin: 0;
    order: -1;
    margin-bottom: 25px;
}

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

/* ----コンテンツ---- */
.swell-block-fullWide + .swell-block-fullWide {
	margin-top: 0;
}
.swell-block-fullWide__inner {
	padding: 0;
}
.swell-block-columns__inner {
	justify-content: space-between;
}

/* ----概要---- */
.outlineBox {
	max-width: 800px;
	margin: 0 auto;
}
.outlineBox {
	justify-content: space-between;
}
.outlineBox .swell-block-dl__dt{
	width: 160px;
	background: #fff;
	padding: 10px 15px;
    color: var(--color_main);
    display: flex;
    align-items: stretch;
	margin-bottom: 5px;
}
.outlineBox .swell-block-dl__dt:after{
    display: none;
}
.outlineBox .swell-block-dl__dd{
	width: calc(100% - 160px - 5px);
	background: #fff;
	padding: 10px 15px;
	margin-bottom: 5px;
}

/* ----フッター---- */
.fix_Btn {
	position: fixed;
    right: 30px;
    bottom: 160px;
	transition: .2s;
}
.fix_insta {
	position: fixed;
    right: 30px;
    bottom: 90px;
    transition: .2s;
}
.c-fixBtn {
	width: 40px;
	height: 40px;
}
.bn_snsArea {
	padding-bottom: 5em !important;
	margin-bottom: 0 !important;
}
.f-bn .swell-block-columns__inner {
	justify-content: space-between;
}
.f-bn .swell-block-column {
	width: calc(100% / 2 - 5px);
}
.f-bn .wp-block-cover {
	min-height: auto;
	padding: 2em 6em 2em;
}
.f-bn a .wp-block-cover__background {
	opacity: .2 !important;
	transition: .4s;
}
.f-bn a:hover .wp-block-cover__background {
	opacity: 0 !important;
	transition: .4s;
}
.f-bn a h2 {
	max-width: 320px;
    font-size: 2.2rem !important;
    letter-spacing: 0.9rem;
    text-indent: 0.9rem;
    margin-bottom: 100px !important;
}
.f-bn a .cmn_btn {
    min-width: 240px;
	margin: 0 auto;
}
.f-bn a .cmn_btn .swell-block-button__link {
	min-width: 240px;
	background: rgba(255, 255, 255, .4);
    box-shadow: none;
    padding: 8px 30px;
    position: relative;
    transition: .3s;
    font-size: 1.1rem !important;
    letter-spacing: 0.6rem;
	border: 1px solid #333;
}
.f-bn a .cmn_btn .swell-block-button__link::after {
	position: absolute;
	content: "";
	width: 40px;
	height: 1px;
	background: #333;
	right: -20px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	transition: .4s;
}
.f-bn a:hover .cmn_btn .swell-block-button__link {
	background: rgba(255, 255, 255, 1);
	transition: .4s;
}
.f-bn a:hover .cmn_btn .swell-block-button__link::after {
	right: -28px;
	transition: .4s;
}
.f-bn.service .wp-block-cover {
	padding: 4em 6em 4em;
}
.f-bn.service a .wp-block-cover__background {
	opacity: .9 !important;
}
.f-bn.service a:hover .wp-block-cover__background {
	opacity: 0 !important;
}
.f-bn.service a h2 {
	width: auto;
    font-size: 0.7rem !important;
	font-weight: normal !important;
    letter-spacing: 0.2rem;
    text-indent: 0;
}
.f-bn.service a h2 .s_ttl {
	font-family: "Noto Sans JP", sans-serif;
    font-size: 1.2rem;
    letter-spacing: 0.6rem;
    display: block;
	margin-top: 10px;
}
.f-bn.service a .cmn_btn .swell-block-button__link {
    border: 1px solid #fff;
    color: #fff !important;
	background: rgba(255, 255, 255, .2);
}
.f-bn.service a:hover .cmn_btn .swell-block-button__link {
	background: rgba(255, 255, 255, 0);
}
.f-bn.service a .cmn_btn .swell-block-button__link::after {
	background: #fff;
}
.f-bn.con {
	margin-top: 10px !important;
}

.c-widget+.c-widget {
	margin: 0 auto;
}
.w-beforeFooter{
	margin: 0 auto;
}
.w-footer {
	margin: 0 auto;
    padding: 0;
    width: 100%;
}
.l-footer {
    margin-top: 10px;
}
.l-footer__widgetArea {
	padding: 0;
}
.w-footer__box {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}
.w-footer__box .swell-block-fullWide {
	padding-bottom: 11em !important;
}
.w-footer__box .swell-block-columns__inner {
	max-width: 85vw;
	margin: 0 auto;
	justify-content: flex-start;
}
.f_logo {
	margin-bottom: 30px !important;
}
.f_add {
	margin-right: 1vw !important;
}
.f_add p {
	font-size: clamp(0.9rem, 0.6rem + 0.5vw, 1rem);
}
.footer_in {
	border-top: 1px solid var(--color_main);
	padding-top: 60px;
}
.footer_in .swell-block-columns__inner {
	justify-content: space-between;	
}
.w-footer__box .brand_list {
    margin-bottom: 60px;
}
.w-footer__box .brand_list .swell-block-column{
	width: auto;
}
.w-footer__box .wp-block-list{
    list-style: none;
	justify-content: flex-start;
}
.w-footer__box .sns_list {
    --the-gap: .5em 0.2em !important;
	margin-bottom: 10px;
}
.w-footer__box .sns_list li a .swl-inline-icon {
	transition: .2s;	
}
.w-footer__box .sns_list li a:hover .swl-inline-icon {
	opacity: .8;
	transition: .2s;
}
.footer-list {
    list-style: none;
    justify-content: center;
	padding-left: 0 !important;
	gap: 1.8vw !important;
}
.footer-list li {
    font-size: clamp(0.8rem, 0.5rem + 0.5vw, 0.9rem);
	font-weight: 500;
	line-height: 1;
	margin: 0;
}
.footer-list li a{
	transition: .2s;
}
.footer-list li a:hover {
    opacity: .7;
	transition: .2s;
}
.footer-list .s_list li {
	padding-left: 0.4em;
}
.footer-list .s_list li::marker {
    content: "-";
}
.l-footer__foot {
	padding: 0;
}
.l-footer .copyright {
	font-family: "Abril Fatface", serif;
	font-size: 0.8rem;
	font-weight: normal;
	padding: 0 30px 30px;
	letter-spacing: 0.05rem;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: 0px;
}


/*---------------------------------------------pc_small---*/
@media screen and (max-width: 1279px) {	
.swell-block-fullWide__inner {
	width: 90vw;
    margin: 0 auto;
}
.l-topTitleArea__body {
	padding: 0 4vw !important;
}
.f-bn .swell-block-fullWide__inner {
	width: 100%;
}
.f-bn .wp-block-cover {
	padding: 2em 3em 2em;
}
.w-footer__box .swell-block-columns__inner {
	max-width: 90vw;
}
.f_link {
	--clmn-w--pc: 65% !important;
}
}


/*---------------------------------------------------tb---*/
@media screen and (max-width: 959px) {
.br_pc {
	display: none;
}
.br_sp {
	display: block;
}
.-series .l-header__logo {
	margin: 0 0 0 5vw;
}
.-img .c-headLogo__link {
	padding: 6px 0;
}
.l-header {
	background: rgba(51, 51, 51, .5);
}
.l-header__inner {
	justify-content: space-between;
	height: 50px;
}
.p-spMenu__inner::before {
	background: rgba(93, 27, 54, .9);
}
.p-spMenu__inner .icon-close-thin:before {
	color: #fff;
}
.c-widget__title.-spmenu {
	color: #fff;
	font-family: "Abril Fatface", serif;
	font-size: 2.5rem;
	line-height: 1;
	margin: 30px 0 40px;
	padding: 0 .35em;
	background: none;
	letter-spacing: 0.6rem;
}
.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.insta{
	display: none;
}
.c-spnav a {
	color: #fff;
	border-bottom: none;
	font-size: 1.4rem;
	padding: 0.5em 1em 0.5em 1.5em;
	line-height: 1.8;
	border-bottom: 1px dashed rgba(255, 255, 255, 0.2);
}
.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-header__customBtn {
	margin: 0 -6px 0 auto;
}
.l-topTitleArea {
	min-height: 180px;
    height: 30vh;
	margin-top: -50px;
}
.c-pageTitle,
.c-postTitle__ttl {
	font-size: 0.9rem !important;
	margin-top: 40px;
	letter-spacing: 0.3rem;
}
.c-pageTitle__subTitle {
	font-size: 2rem;
	letter-spacing: 1rem;
	margin-bottom: 5px;
}
.fix_Btn {
	right: 15px;
    bottom: 115px;
    width: 80px;
}
.fix_insta {
	right: 15px;
    bottom: 66px;
    width: 75px;
}
.f-bn .swell-block-column {
	width: 100%;
}
.f-bn a .wp-block-cover__background {
    background-color: #fff !important;
	opacity: .4 !important;
}
.f-bn.service a .wp-block-cover__background {
	opacity: 0 !important;
}
.f-bn.service .wp-block-cover {
	padding: 3em 4em 4em;
}
.w-footer__box .swell-block-columns__inner {
	flex-direction: column;
}
.f_add {
	font-size: 0.9rem;
	margin-bottom: 20px !important;
}
.f_link {
	display: none;
}
.l-footer .copyright {
	padding: 0 4vw 30px;		
}
}
	
	
/*---------------------------------------------------sp---*/
@media screen and (max-width: 599px) {
.h2_top {
	font-size: 2rem !important;
}
.h2_top::before{
	height: 2px;
    bottom: 30px;
}
.h2_top::after {
	height: 2px;
	bottom: 30px;
}
.h2_top .s_ttl {
	margin-top: 30px;
}
.h2_ttl .s_ttl {
	font-size: 1.6rem;
    letter-spacing: 0.7rem;
    margin-top: 10px;
    text-indent: 0.7rem;
}
.c-pageTitle__subTitle {
	letter-spacing: 0.4rem;
}
.outlineBox .swell-block-dl {
	flex-direction: column;
}
.outlineBox .swell-block-dl__dt,
.outlineBox .swell-block-dl__dd {
	width: 100%;
}
.outlineBox .swell-block-dl__dt {
	margin-bottom: 0;
	padding: 8px 15px 0;
}
.outlineBox .swell-block-dl__dd {	
	padding: 5px 15px 10px;
}
.fix_Btn {
	right: 14px;
    bottom: 89px;
    width: 55px;
}
.fix_insta {
	right: 15px;
    bottom: 61px;
    width: 50px;
}
.p-fixBtnWrap {
	right: 15px;
	bottom: 15px;
}
.f-bn .wp-block-cover {
	padding: 3em;
}
.f-bn a h2 {
	margin-bottom: 80px !important;
}
.f-bn a .cmn_btn {
	text-align: center;
}
}
