@import url('https://fonts.googleapis.com/css2?family=Google+Sans+Flex:opsz,wght@6..144,600&display=swap');

.google-sans-flex-600 {
	font-family: "Google Sans Flex", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	font-variation-settings:
		"slnt" 0,
		"wdth" 100,
		"GRAD" 0,
		"ROND" 0;
}

/* 全体 */
*{
	letter-spacing:0.1em;
}
body {
	font-family: "Google Sans Flex", "Noto Sans JP", sans-serif;
}
@media (max-width: 640px) {
	html {
		font-size: 16px;
	}
}

/* ヘッダー */
.c-site-branding__title a{
	position: relative;
	top:-4px;
}
@media screen and (min-width: 1024px) and (max-width: 1210px) {
	.p-global-nav .c-navbar__item > a {
		font-size: 16px;
		padding-left: 12px;
		padding-right: 12px;
	}
}
.sm-nav-menu-item-highlight{
	background-color:#3e3a39!important;
	transition: all .5s ease;
}
.sm-nav-menu-item-highlight:hover{
	background-color:#b28247!important;
}

/* フッター */
#menu-fnav-footer{
	width:100%;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: auto;
	gap: 8px;
	padding:0;
	margin:0;
}
.c-copyright{
	text-align: center;
}
@media (min-width: 40em){
	#menu-fnav-footer {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
}
@media (min-width: 64em){
	#menu-fnav-footer {
		grid-template-columns: repeat(5, 1fr);
	}
}
#menu-fnav-footer .menu-item {
	margin:0;
	padding:0;
}
#menu-fnav-footer .menu-item a{
	display: block;
	text-align: center;
	padding:10px;
	border: 1px solid #cecece;
	border-radius: 6px;
	margin:0;
	text-decoration:none;
}
.l-footer-widget-area .c-row .c-row__col:last-child{
	--_item-width: 100%;
}
.c-footer-issouichimoku p{
	margin-top: 8px!important;
}

/* ドロワーメニュー */
.c-drawer .c-drawer__menu .menu-item{
	font-size: 1.25rem;
	text-align: center;
}
.c-drawer__menu .sm-nav-menu-item-highlight{
	border-radius: 40px;
}
.c-drawer__menu .sm-nav-menu-item-highlight:hover{
	background-color:#3e3a39!important;
}

/* コンテンツ幅調整 */
.l-contents__main{
	flex-basis: auto;
}

/* サイドバー幅調整 */
[data-has-sidebar=true] .l-contents__sidebar{
	flex-basis: 280px;
}
.l-contents__inner .l-contents__sidebar .wp-block-heading{
    background-color: #f7f7f7;
    display: block;
    padding: 8px 16px;
}

/* ページヘッダー */
.c-page-header{
	background:#f7f7f7;
}
.c-page-header[data-has-image=true] {
	max-height: 200px;
}
@media (min-width: 40em){
	.c-page-header[data-has-image=true] {
		max-height: 280px;
	}
}
@media (min-width: 64em){
	.c-page-header[data-has-image=true] {
		max-height: 360px;
	}
}
.c-page-header[data-has-image=true] .c-page-header__bgimage{
	background-color: #000;	
}
.c-page-header__bgimage>img, .c-page-header__bgimage>picture>img{
	opacity:0.5;
}

/* パネル */
.smb-panels__item__action, .smb-panels__item__content {
    text-align: left;
}

/* テーブル */
.c-aa51-table table tr:not(:first-child) > th:first-child,
.c-aa51-table table tr:not(:first-child) > td:first-child {
	width: 25%;
}
@media (max-width: 640px) {
	.c-aa51-table table tr:not(:first-child) th,
	.c-aa51-table table tr:not(:first-child) td {
		font-size: 15px;
	}
	.c-aa51-table table tr:not(:first-child) > th:first-child,
	.c-aa51-table table tr:not(:first-child) > td:first-child {
		width: 38%;
	}
}

/* セクションタイトル */
.c-aa51-section .smb-section__header .smb-section__subtitle{
	font-size: 3.2rem;
	line-height:1;
}
.c-aa51-section .smb-section__header .smb-section__title{
	font-size: 1.2rem;
	margin-top:16px;
}
@media (max-width: 640px) {
	.c-aa51-section .smb-section__header .smb-section__subtitle{
		font-size: 2.4rem;
	}
	.c-aa51-section .smb-section__header .smb-section__title{
		font-size: 1rem;
		margin-top:8px;
	}
}

/* セクションタイトル（背景色） */
.c-aa51-section.u-aa51-section-title .smb-section__header{
	background-color: var(--wp--preset--color--sm-accent);
	padding: 40px 0;
}
.c-aa51-section.u-aa51-section-title .smb-section__header .smb-section__subtitle{
	color: #FFF;
}
.c-aa51-section.u-aa51-section-title .smb-section__header .smb-section__title{
	color: #FFF;
}

/* 特長リスト */
.c-aa51-list-benefit{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: auto;
	gap: 16px 4%;
	padding: 0;
	list-style: none;
}
.c-aa51-list-benefit li{
	font-size: 1.2rem;
	line-height:1.4;
	font-weight: 800;
	border-bottom: #231815 2px solid;
	padding: 0 0 8px;
	margin:0;
}
@media (max-width: 640px) {
	.c-aa51-list-benefit{
		grid-template-columns: repeat(1, 1fr);
	}
	.c-aa51-list-benefit li{
		font-size: 1rem;
	}
}
.c-aa51-list-benefit li:last-child {
	border-bottom: 0 none;
}

/* 画像リンク */
.c-aa51-image-link a{
	display: block;
	transition: .3s ease;
}
.c-aa51-image-link a:hover{
	transform: translateY(-4px);
	box-shadow: 0px 4px 16px 0px rgba(0, 0, 0, 0.2);
}

/* お問い合わせ */
.c-aa51-contact .smf-item__label{
	color: #FFF;
}

/* Snow Monkey Forms */
.smf-form--letter .smf-text-control__control,
.smf-form .smf-textarea-control__control{
	border: none;
}
.snow-monkey-form[data-screen="confirm"] .agreement-text, .snow-monkey-form[data-screen="confirm"] .smf-item__description{display:none;}
.snow-monkey-form[data-screen="confirm"] .smf-placeholder{
    padding: 8px;
    background-color: #f5f5f5;
}
.smb-form__control::placeholder {
	color: #999999;
}
.smf-text-control__control::placeholder,
.smf-textarea-control__control::placeholder {
	color: #999999;
}
.smf-progress-tracker__item__number {
	padding-top: 4px;
	height: 40px;
	width: 40px;
	color: #b28247;
	background-color: #FFF;
}
.smf-progress-tracker__item--input{
	color: #FFF;
}
.c-aa51-section .smf-progress-tracker__item:after,
.c-aa51-section .smf-progress-tracker__item:before {
	background-color: #FFF;
	height: 1px;
	top:20px;
}
.smf-progress-tracker__item__text {
    color: #FFF;
}
.smf-error-messages{
	font-size: 0.8rem;
	background-color: #FFEBEB;
	padding: 8px 8px 2px;
	border-radius: 7px;
}
.smf-form [data-invalid="1"] {
    background-color:#FFEBEB;
}
.snow-monkey-form--button-has-accent-color .smf-button-control__control{
	font-size: 1.25rem;
	font-weight: bold;
	border-radius: 8px;
	padding: 16px 48px;
	background: #3e3a39;
}

/* その他 */
@media (max-width: 640px) {
	.u-sp-align_left{
		text-align:left!important;	
	}
}
@media (max-width: 640px) {
	.u-aa51-text-sp_left{
		text-align:left;
	}
}