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

/* ========== サイト共通部分 ========== */
body {
	font-family: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif !important;
	letter-spacing: 0.04em;
}

body a {
	text-decoration: none;
}

:root{
  --color-or:#E89B3C;
  --color-gr:#6B7F4C;
  --color-text:#4A3428;
  --color-capture:#4B5563;
  --color-bg:#F5EFE7;
	
  --font-en: "Albert Sans", sans-serif;
}

#content, .l-content, .swell-block-fullWide__inner {
	padding: 0 !important;
	margin-bottom: 0;
}

#breadcrumb {
	display: none;
}

.c-pageTitle {
	display: none;
}

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

.l-article {
	max-width: none;
}

/* セクション上下の余白 */
.swell-block-fullWide.sec-padding {
	padding: 100px 0 !important;
}

@media(max-width: 640px) {
	.swell-block-fullWide.sec-padding {
	    padding: 56px 0 !important;
    }
}

/* セクション内のコンテンツ幅 */
.content {
	width: 1160px;
	margin: 0 auto;
}

@media(max-width: 1200px) {
	.content {
	    width: 89.333vw;
    }
}

/* セクションリード文の左右余白 */
.sec-read {
	width: 89.333vw;
}

/*@media(max-width: 640px) {
	.sec-read {
		margin: 0 auto 32px !important;
	}
}*/

.br-sp {
    display: none;
}

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

/* リキャプチャ */
.grecaptcha-badge {
	z-index: 1
}

/* トップボタン */
@media (min-width: 960px) {
    .p-fixBtnWrap {
        bottom: 5.5em;
		right: 1em;
		
    }
}

@media not all and (min-width: 960px) {
    .p-fixBtnWrap {
        bottom: 84px;
    }
}

/* -------- ヘッダー -------- */
header {
	height: 80px;
}

.-body-solid .l-fixHeader {
    box-shadow: none;
}

.l-header__inner {
	width: 1200px;
	height: 80px;
	margin: 0 auto;
	padding: 0;
}

.c-gnav a::after {
    display: none !important;
}

.l-header__inner .menu-item span, #fix_header .l-fixHeader__gnav li span {
	font-size: 0.9375rem !important;
	font-weight: 500;
	transition: all .2s;
}

.l-header__inner .menu-item:hover span, #fix_header .l-fixHeader__gnav li:hover span {
	color: var(--color-or);
}

.wp-block-buttons {
	margin-bottom: 0 !important;
}

@media(max-width: 1260px) {
	.l-header__inner {
	    width: 89.333vw;
    }
}

@media(max-width: 960px) {
	header, .l-header__inner  {
	    height: 64px;
    }
	
	.p-spMenu__inner {
		padding-top: 64px;
	}
	
	.-right .p-spMenu__closeBtn {
        right: 5.333vw;
		top: 10px;
    }
	
	.p-spMenu__nav {
        margin-top: 0;
    }
	
	.c-widget__title {
		display: none;
	}
	
	.c-listMenu a {
        padding: .5em 1em .5em 1.2em;
		border-bottom: none;
	}
	
	.c-listMenu a:hover {
		padding-left: 1.5em;
	}
	
	.c-listMenu a:hover {
        background-color: #FFF;
		color: var(--color-or);
   }
	
	.c-gnav .sub-menu a:before, .c-listMenu a:before {
        content: "";
		background-image: url(/wp-content/uploads/2026/02/arrow02.png);
		width: 5px;
		height: 6px;
    }
	
	.p-spMenu__bottom {
		margin-top: 12px;
	}
	
	.p-spMenu .cta-buttons {
		margin-bottom: 16px;
	}
	
	.p-spMenu .cta-btn {
		justify-content: center;
	}
	
	.p-spMenu .cta-btn--orange {
        color: var(--color-or);
    }
	
	.p-spMenu .cta-btn--green {
        color: var(--color-gr);
    }
	
	.p-spMenu__bottom .cta-btn, .nav-btn {
        width: 320px;
	}
	
	.nav-btn {
		color: #FFF !important;
		justify-content: center;
    }
	
	.nav-btn:hover {
		color: var(--color-or) !important;
    }
}

/* -------- 【ここまで】ヘッダー -------- */

/* -------- テキスト関連 -------- */
h2, h3, h4 {
	margin: 0 !important;
}

/* h2・h3のデザインをもとに戻す */
.usually-title {
	padding: 0 !important;
	background: transparent !important;
}

.usually-title::before, .usually-title::after {
	border-bottom: none !important;
	border-top: none !important;
}

/* セクションタイトル */
.sec-titles {
	margin-bottom: 56px;
}

.sec-titles.right {
	text-align: right;
}

.sec-title__en {
	font-family: var(--font-en);
	position: relative;
	padding-left: 15px;
	margin-bottom: 10px;
	display: inline-block;
}

.sec-title__en::before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	top: 50%;
	transform: translatey(-50%);
	left: 0;
	background-color: var(--color-or);
}

.sec-title {
	font-size: 3rem !important;
}

@media(max-width: 600px) {
	.sec-title {
	    font-size: clamp(32px, 8.533vw, 48px) !important;
    }
	
	.sec-title__en {
		font-size: 15px !important;
    }
}

@media(max-width: 480px) {
	.sec-titles {
	    margin-bottom: 40px;
    }
}

/* セクションタイトル中央揃え */
#safe .sec-titles, #price .sec-titles, #story .sec-titles, #faq .sec-titles, #experience .sec-titles {
	text-align: center;
}

/* セクション締めの文章 */
.closing-lead {
  text-align: center;
}

.closing-lead__sub {
	font-size: 1.375rem;
    font-weight: 700;
    margin-bottom: 8px;
}

.closing-lead__main {
  font-size: 2rem;
  font-weight: 700;
}

.ttl-green {
  border-bottom: 5px dotted var(--color-gr);
}

.ttl-orange {
  border-bottom: 5px dotted var(--color-or);
}

@media(max-width: 960px) {
    .closing-lead__sub {
	    font-size: 1.25rem;
        margin-bottom: 8px;
    }

    .closing-lead__main {
      font-size: 1.75rem;
    }
}

@media(max-width: 600px) {
    .closing-lead__sub {
	    font-size: clamp(18px, 4.8vw, 20px);
        margin-bottom: 8px;
    }

    .closing-lead__main {
      font-size: clamp(24px, 6.4vw, 28px);
    }
}
/* -------- 【ここまで】テキスト関連 -------- */

/* ------ CTA ------ */
#cta .content {
	width: 89.333vw;
	margin: 0 auto;
	border-radius: 36px 36px 0 0;
	padding: 80px 0;
}

#cta h2 {
	margin-bottom: 24px !important;
}

#cta .lead {
	font-size: 1.25rem;
	margin-bottom: 40px;
}

#cta .inner {
	width: 680px;
	margin: 0 auto;
}

#cta .p-blogParts {
	margin-bottom: 8px;
}

#cta .cta-buttons {
	flex-direction: row;
	justify-content: center;
	margin-bottom: 0;
}

#cta .cta-buttons a {
	height: 68px;
}

#cta .cta-btn__text {
	font-size: 1.125rem;
}

#cta .cta-btn--orange:hover, #cta .cta-btn--green:hover{
	border: solid 1px #FFF;
}

@media(max-width: 960px) {
	#cta .content {
	    padding: 80px 32px;
	}

    #cta .inner {
	    width: 420px;
    }

    #cta .cta-buttons {
	    flex-direction: column;
    }

    #cta .cta-buttons a {
	    width: 100%;
		justify-content: center;
    }
}

@media(max-width: 640px) {
	#cta .content {
	   padding: 56px 16px;
   }
	
	#cta h2 {
		font-size: 2rem !important;  
	    margin-bottom: 24px !important;
    }

    #cta .lead {
	    font-size: 1rem;
	    margin-bottom: 32px;
    }
	
	#cta .inner {
	    width: 100%;
    }
	
	#cta .cta-buttons a {
		padding: 20px 32px; 
    }
}
/* ------ 【ここまで】CTA ------ */

/* -------- フッター -------- */
#footer {
	background-color: var(--color-bg);
}

#footer .l-footer__widgetArea {
	padding-top: 0;
	width: 89.333vw;
	margin: 0 auto;
	background-color: #FFF;
	border-radius: 0 0 36px 36px;
}

#footer .w-footer__box {
	padding: 64px 0 32px;
}

#footer .wrapper {
	max-width: 1160px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

#footer .left a {
	display: inline-block;
	width: 180px;
	margin-bottom: 20px;
}

#footer .left p {
	font-size: 0.9375rem;
	font-weight: 400;
}

#footer .right {
	display: flex;
	gap: 56px;
}

#footer .outer {
	display: flex;
	gap: 56px;
}

#footer .right .heading {
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: 12px;
}

#footer .right ul {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

#footer .right li a {
	font-size: 0.9375rem;
	font-weight: 500;
	padding-left: 10px;
	position: relative;
	transition: all .2s;
}

#footer .right li a:hover {
	color: var(--color-or);
}

#footer .right li a::before {
	content: "";
	position: absolute;
	background-image: url(/wp-content/uploads/2026/02/arrow02.png);
	width: 5px;
	height: 6px;
	top: 50%;
	transform: translatey(-50%);
	left: 0;
}

#footer .right .footer-btn, .nav-btn {
	font-size: 1rem;
	font-weight: 700;
	color: #FFF;
	background: var(--color-or);
	border-radius: 100px;
	border: solid 1px var(--color-or);
	transition: all .2s;
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 16px 40px;
}

#footer .right .footer-btn:hover, .nav-btn:hover {
	color: var(--color-or);
	background: #FFF;
}

#footer .right .footer-btn .icon-mail, .nav-btn .icon-mail {
	width: 18px;
	height: 14px;
}

#footer .l-footer__foot {
	padding: 40px 0 24px;
}

@media(max-width: 1260px) {
	#footer .l-container {
		padding: 0 32px;
	}
	
	#footer .wrapper {
		flex-direction: column;
		gap: 56px;
	}
	
	#footer .right {
        justify-content: space-evenly;
    }
}

@media(max-width: 960px) {
	#footer .wrapper {
		gap: 24px;
	}
	
    #footer .left a {
	    width: 160px;
	    margin-bottom: 16px;
    }
	
	#footer .right {
        flex-direction: column-reverse;
		gap: 40px;
    } 
	
	#footer .footer-btn {
		width: 320px;
		justify-content: center;
	}
}

@media(max-width: 640px) {
	#footer .l-footer__widgetArea {
		padding-bottom :0;
	}
	
	#footer .l-container {
		padding: 0 24px;
	}
	
	#footer .w-footer__box {
        padding: 40px 0 32px;
    }
	
	#footer .outer {
		flex-direction: column;
		gap: 32px;
	}
	
	#footer .footer-btn {
		width: 100%;
	}
	
	#footer .l-footer__foot {
        padding: 24px 0 16px;
    }
}
/* -------- 【ここまで】フッター -------- */
/* ========== 【ここまで】サイト共通部分 ========== */

/* -------- 下層ページ FV -------- */
#lower-fv {
	background: linear-gradient(-35deg, #F5EFE7, #FFFFFF, #FBF8F3);
	padding: 0 !important;
	position: relative;
}

#lower-fv::before, #lower-fv::after {
	content: "";
	position: absolute;
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 0;
}

#lower-fv::before {
	background-image: url(/wp-content/uploads/2026/02/shape02.png);
	width: 320px;
	height: 300px;
	top: 0;
	left: 40px;
}

#lower-fv::after {
	background-image: url(/wp-content/uploads/2026/02/shape01.png);
	width: 384px;
	height: 288px;
    bottom: 0;
	right: 40px;
}

#lower-fv .sec-titles {
	width: 1160px;
	margin: 0 auto;
	padding: 132px 0 64px;
	position: relative;
	z-index: 1;
}

#lower-fv .sec-titles .sec-title {
	margin-bottom: 20px !important;
}

@media(max-width: 1200px) {
	#lower-fv .sec-titles {
	    width: 89.333vw;
	    padding: 132px 0 64px;
    }
}

@media(max-width: 480px) {
	#lower-fv .sec-titles {
	    padding: 120px 0 56px;
    }
}
/* -------- 【ここまで】下層ページ FV -------- */

/* -------- プライバシーポリシー・利用規約 共通部分 -------- */
#privacy-policy .content, #service .content {
	width: 896px;
	margin: 0 auto;
}

#privacy-policy .update, #service .update {
	padding: 24px;
	border-radius: 16px;
	margin-bottom: 48px;
}

#privacy-policy .outer .swell-block-columns__inner, #service .outer .swell-block-columns__inner {
	gap: 48px;
}

#privacy-policy .inner, #service .inner {
	padding: 32px;
	border-radius: 16px;
	border: solid 1px #F3F4F6;
}

#privacy-policy .inner.contact, #service .inner.contact  {
	background-color: #F5EFE7;
	border: none;
}

#privacy-policy .inner .wp-block-group, #service .inner .wp-block-group {
	margin-bottom: 24px;
	gap: 16px;
}

#privacy-policy .inner .wp-block-group .num, #service .inner .wp-block-group .num {
	width: 48px;
	height: 48px;
	border-radius: 12px;
	padding: 4px;
	display: flex;
	justify-content: center;
	align-items: center;
}

#privacy-policy .inner.contact .text, #service .inner.contact .text {
	margin-bottom: 12px;
}

#privacy-policy .inner.contact .btn, #service .inner.contact .btn{
	padding: 16px 40px;
	color: var(--color-gr);
	font-size: 16px;
	font-weight: 700;
	background-color: #FFF;
	border-radius: 100px;
	border: solid 1px #6B7F4C;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 275px;
	transition: all .2s;
}

#privacy-policy .inner.contact .btn:hover, #service .inner.contact .btn:hover {
	color: #FFF;
	background-color: var(--color-gr);
	
}

#privacy-policy .inner.contact .btn svg, #service .inner.contact .btn svg {
	width: 18px;
    height: 14px;
}

@media(max-width: 960px) {
	#privacy-policy .content, #service .content {
	    width: 89.333vw;
    }
}

@media(max-width: 640px) {
	#privacy-policy .update, #service .update {
	    margin-bottom: 32px;
    }
	
	#privacy-policy .outer .swell-block-columns__inner, #service .outer .swell-block-columns__inner {
	    gap: 32px;
    }
}
/* -------- 【ここまで】プライバシーポリシー・利用規約 共通部分 -------- */

/* -------- お問い合わせ -------- */
#contact .content {
	width: 940px;
	margin: 0 auto;
}

#contact .wp-block-columns {
	gap: 48px !important;
}

#contact .wp-block-columns .left .wp-block-group {
	position: sticky;
    top: 80px;
	padding: 24px;
	border-radius: 16px;
	border: solid 1px #F5EFE7;
	background: linear-gradient(-35deg, #FFF, #FBF8F3);
}

#contact .wp-block-columns .left h3 {
	margin-bottom: 12px !important;
}

#contact .wp-block-columns .left .text01 {
	margin-bottom: 16px !important;
}

#contact .wp-block-columns .left .text02 {
	display: inline-block;
	position: relative;
	padding-right: 20px;
}

#contact .wp-block-columns .left .text02::after {
	content: "";
	position: absolute;
	background-image: url(/wp-content/uploads/2026/02/arrow03.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 10px;
	height: 9px;
	top: 51%;
	right: 0;
	transform: translatey(-50%);
}

.wpcf7 {
	padding: 32px;
	border-radius: 16px;
	border: solid 1px #F3F4F6;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

.wpcf7 label {
	font-weight: 500;
}

.wpcf7 .required {
	color: #EF4444;
	font-weight: 500;
	margin-left: 3px;
}

.wpcf7 .wpcf7-form-control {
	margin-top: 8px !important;
	margin-bottom: 24px;
	padding: 12px 16px;
	border-radius: 12px;
	border: solid 1px #E5E7EB;
	background-color: #FFF;
	width: 100% !important;
}

.wpcf7 .wpcf7-select {
	background-color: #EFEFEF;
	border: solid 1px #E5E7EB;
}

.wpcf7 .text {
	margin: 24px 0;
	padding: 16px;
	border-radius: 12px;
	background-color: #faf7f3;
	font-size: 13px;
	font-weight: 400;
	color: #4B5563;
}

.wpcf7 .contact_btn {
	width: 100%;
	border-radius: 100px;
	padding: 16px 24px;
	background-color: var(--color-or);
	color: #FFF;
	border: solid 1px var(--color-or);
	font-size: 16px;
	font-weight: 500;
	transition: all .2s;
}

.wpcf7 .contact_btn:hover {
	color: var(--color-or);
	background-color: #FFF;
}

@media(max-width: 1100px) {
	#contact .content {
	    width: 89.333vw;
    }

    #contact .wp-block-columns {
		flex-direction: column;
	    gap: 40px !important;
    }
	
	#contact .wp-block-columns .left .wp-block-group {
	    position: static;
    }
}

@media(max-width: 640px) {
    .wpcf7 {
	    padding: 24px;
    }
}
/* -------- 【ここまで】お問い合わせ -------- */


