/*
Theme Name: SIK_エスアイケイ_ver_01_2025
Theme URL:
Author:
Author URI:
Description: SIK_エスアイケイ_のテンプレートver01
Version: 9999
Tags:
License:
License URI:
*/
/* ==========================================================================
   Foundation
   ========================================================================== */
/* Reset
   ----------------------------------------------------------------- */
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav.gnav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:400;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav.gnav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}
figure{margin-bottom:0;}
/* Base
   ----------------------------------------------------------------- */
.serif{
	font-family:"Noto Serif JP", serif;
	font-weight: 500;
  font-style: normal;
}
body{
	font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
	color:#333;
	margin:0 auto;
	letter-spacing: 1px;
	font-feature-settings: "palt";
}
a{
	text-decoration:none;
	color:#481900;
}
a:hover{opacity:0.8;}
img{
	vertical-align:top;
	max-width:100%;
	height:auto;
}

figcaption{
	text-align:center;
	font-size:clamp(13px, 1.5vw, 16px);
	line-height:1.5em;
	margin:5px 0;
}
ol{list-style:none}

/* ==========================================================================
   共通
========================================================================== */
html{
	font-size:clamp(13px, 2vw, 16px);
	scroll-padding-top: 50px;/*追従headerの高さ指定*/
}
main{/*overflow:hidden;*/}

/*文字寄せ*/
.txt-right{text-align:right;}
.txt-center{text-align:center;}
/*一文字空白*/
.indent{text-indent: 1em;}
/*URL改行防止*/
main p{word-break: break-all;}

/*共通ボタン*/
.btn{text-align:left;}
.btn a{
	font-size:clamp(11px, 1.5vw, 16px);
	box-sizing:border-box;
	line-height:40px;
	text-align:center;
	min-width:200px;
	display:inline-block;
	margin:0 auto 1rem;
	padding:0 1rem;
	border:solid 2px #481900;
	background-color:#fff;
	color:#481900;
	font-weight:bold;
	border-radius:22px;
	box-shadow:5px 5px 0 #FFEDE5;
}
.btn a:hover{color:#fff;background:#E57200;border:solid 2px #E57200;opacity:1;}


/*共通テーブル*/
table.tbl100{width: 100%;}
.tbl01 td,
.tbl01 th{
	padding: 1.5rem ;
	line-height: 1.5rem;
	font-size:clamp(13px, 1.5vw, 16px);
	border-bottom:solid 1px #ccc;
}
.tbl01{
	margin-bottom: 2rem;
	box-sizing: border-box;
}
.tbl01 th{
	border-bottom:solid 1px #481900;
	vertical-align: top;
	text-align: left;
}
@media screen and (max-width: 768px){
.scroll{
	overflow: auto;
	white-space: nowrap;
	margin-bottom: 1em;
}
.scroll table{
	width: 100%;
	margin-bottom: 0.5em;
}
}
@media screen and (max-width: 480px){
.tbl01 td,
.tbl01 th{padding: 1rem .5rem;}
}
/*線なしのミニテーブル*/
.tbl-min{
	margin-bottom: 2rem;
	box-sizing: border-box;
}
.tbl-min td,
.tbl-min th{
	padding: 0.5rem 1rem;
	line-height: 1.75rem;
	font-size:clamp(13px, 1.5vw, 16px);
}
.tbl-min th{
	vertical-align: top;
	text-align: left;
}

/*mapレスポンシブ*/
.gmap {
height: 0;
overflow: hidden;
padding-bottom: 56.25%;
position: relative;
}
.gmap iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}

/*動画レスポンシブ*/
.yt_movie {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.yt_movie iframe {
  width: 100%;
  height: 100%;
}

/*tel スマホサイズのみクリック可*/
@media (min-width: 769px) {
a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}
}

.sec{padding:6rem 2rem;}
@media screen and (max-width: 768px){.sec{padding:3rem 2rem;}}
@media screen and (max-width: 480px){.sec{padding:2rem 1rem;}}
.inner{ 
	max-width:1280px;
	margin:0 auto;
	box-sizing:border-box;
}
.inner1080{
	max-width:1080px;
	margin:0 auto;
	box-sizing:border-box;
}
.inner800{
	max-width:800px;
	margin:0 auto;
	box-sizing:border-box;
}
@media screen and (max-width: 1580px){
	.inner{ /*max-width:1080px;*/}
}

/*見出し*/

/*共通の見出しサイズ*/
h1,
h2,
h3,
h4,
h5,
p{line-height:1.75em;}

h1:not(.not){font-size:clamp(24px, 3.5vw, 34px);}
h2:not(.not){font-size:clamp(24px, 3vw, 34px);}
h3:not(.not){font-size:clamp(20px, 2.5vw, 28px);}
h4:not(.not){font-size:clamp(18px, 2vw, 24px);}
h5:not(.not){font-size:clamp(15px, 1.75vw, 18px);}
h6:not(.not){font-size:clamp(13px, 1.5vw, 16px);}
p,a{font-size:clamp(13px, 1.25vw, 16px);}

h1:not(.not) span,
h2:not(.not) span, 
h3:not(.not) span,
h4:not(.not) span,
h5:not(.not) span,
h6:not(.not) span{display:inline-block;}
p span{display:inline-block;}

/*共通の見出し装飾と余白*/
.bold{font-weight: 700;}
h1:not(.not){margin-bottom:2rem;}
h2:not(.not){margin-bottom:1.5rem;}
h3:not(.not){margin-bottom:1.5rem;font-weight: 700;}
h4:not(.not){margin-bottom:1.5rem;}
h5:not(.not){margin-bottom:1.5rem;}
p:not(.not){margin-bottom:1.5rem;}


/*下に斜め線が入る見出し*/
h2.ubtit span{
	position:relative;
	z-index:1;
	display:inline-block;
	background-image:url(img/border01.png);
	background-repeat:repeat-x;
	background-position:bottom left;
	padding-bottom: 1rem;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 2px;
	font-size:clamp(20px, 2.5vw, 28px);
}
/*下に短い線が入る見出し(中央寄せ）*/
h2.ub-center{
	position:relative;
	z-index:1;
	text-align:center;
	margin-bottom:2rem;
	background-image:url(img/h2_bg01.svg);
	background-repeat:no-repeat;
	background-position:bottom center;
	padding: 0 0 1rem;
	font-size:clamp(18px, 2.5vw, 21px);
	letter-spacing: 2px;
}
h2.ub-center span{
	display:block;
	color:#ddd;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	font-size:clamp(28px, 4vw, 42px);
	margin-bottom:1rem;
}

/*下に短い線が入る見出し（左寄せ）*/
h2.ub-left{
	position:relative;
	z-index:1;
	margin-bottom:2rem;
	background-image:url(img/h2_bg01.svg);
	background-repeat:no-repeat;
	background-position:bottom left;
	padding: 0 0 1rem;
	font-size:clamp(18px, 2.5vw, 21px);
	letter-spacing: 2px;
}
h2.ub-left span{
	display:block;
	color:#ddd;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	font-size:clamp(28px, 4vw, 42px);
	margin-bottom:1rem;
}

/*左に線が入るラベル風見出し*/
h2.label{
	background-color:#fff;
	background-image:url(img/border02.png);
	background-repeat:repeat-y;
	background-position:top left 8px;
	box-shadow:0 3px 6px rgba(0,0,0,0.16);
	position:relative;
	z-index:1;
	padding:.5rem .5rem .5rem 2rem;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 2px;
	margin-bottom:2rem;
}
h2.label span{
	display:inline-block;
	font-size:clamp(15px, 1.75vw, 18px);
	font-weight: 500;
	line-height: 1.25rem;
}
/*小さい見出し*/
h3.min{font-weight:bold;font-size:clamp(13px, 2vw, 16px);line-height: 1.25rem;}
h3.min span{font-weight:bold;display:inline-block;}


/*下線ありの見出し*/
h4.ub{
	background-image: repeating-linear-gradient(90deg, #8D3D1A, #8D3D1A 5px, transparent 5px, transparent 10px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 1px;
}

/*固定ページ共通*/
.page-top{
	margin-bottom:0;
	position:relative;
	height:320px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding:1rem;
	box-sizing:border-box;
	background:#481900;
}
.page-top .page-tit{
	color:#fff;
	font-size:clamp(20px, 2.75vw, 34px);
	position: relative;
	z-index: 9;
	    width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	box-sizing:border-box;
	text-shadow: 0 0 3px rgba(12 0 0 / 50%);
	line-height: 1.5em;
}
.page-top .page-tit span{
font-size:clamp(15px, 1.75vw, 18px);
}

.page-top .pagetop-img:before{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:50%;
	height:100%;
	background-image: linear-gradient(90deg, #481900, #481900 85%, transparent 100%);
	z-index:5;
}
.page-top .pagetop-img img{
		position: absolute;
	top: 0;
	right: 0;
	width: 60%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
@media screen and (max-width: 980px){
.page-top .page-tit{padding-top:2rem;}
}
@media screen and (max-width: 480px){
.page-top{height:230px;}
}

/*共通リスト*/

/*ドットが歪んだ丸のリスト*/
ul.list01{
	margin-left: 0.5rem;
	margin-bottom:2rem;
}
ul.list01 > li{
	font-size:clamp(13px, 2vw, 16px);
	line-height: 2em;
	padding:.5rem .5rem .5rem 26px;
	position:relative;
	margin-bottom:.5rem;
}
ul.list01 > li:before{
	content: "";
	position:absolute;
	left:4px;
	top:calc(1em + 4px);
	width:10px;
	height:10px;
	background:#197BCD;
	display: block;
	border-radius:5px;
}

/*ドットが歪んだ丸のリストmini*/
ul.list01-min{
	margin-left: 0.5rem;
}
ul.list01-min > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 1.5em;
	padding:0 0 0 26px;
	position:relative;
	margin-bottom:1rem;
}
ul.list01-min > li:before{
	content: "";
	position:absolute;
	left:4px;
	top:calc(1em / 2);
	width:10px;
	height:10px;
	background:#197BCD;
	display: block;
	border-radius:5px;
}

/*inlist*/
ul.list01 > li ul{margin-left:1rem;}

/*ドットがシンプルなリスト*/
ul.list02{
	margin-left: 0.5rem;
	margin-bottom:2rem;
}
ul.list02 > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
ul.list02 > li:before{
	content: "";
	position:absolute;
	left:7px;
	top:15px;
	width:4px;
	height:4px;
	background:#5A391D;
	display: block;
	border-radius:10px;
}
ul.list02 > li ul{margin-left:1rem;}
/*ドットがシンプルなリストmin*/
ul.list02-min{
	margin-bottom:0;
}
ul.list02-min > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 1.75rem;
	margin: 0 0;
	padding:0 0 0 1rem;
	position:relative;
}
ul.list02-min > li:before{
	content: "";
	position:absolute;
	left:0;
	top:calc((1.75rem - 2px) / 2);
	width:4px;
	height:4px;
	background:#5A391D;
	display: block;
	border-radius:10px;
}
ul.list02-min > li ul{margin-left:1rem;}



/*inlineリスト*/
ul.list-inline > li{
	display:inline-block;
	margin-right:1rem;
	font-size:clamp(14px, 2vw, 16px);
	margin-bottom:1rem;
	line-height:1.5rem;
}

/*手前に■付きinlineリスト*/
ul.list-inline-sq > li{
	display:inline-block;
	margin-right:1rem;
	font-size:clamp(14px, 2vw, 16px);
	margin-bottom:1rem;
	line-height:1.5rem;
}
ul.list-inline-sq > li:before{
	content:"\0025a0";
	margin-right:5px;
}


/*チェックリスト*/
ul.list-check{
	margin-left: 0.5rem;
	margin-bottom:2rem;
}
ul.list-check > li{
	font-size:clamp(15px, 2vw, 18px);
	line-height: 2em;
	padding:0 0 0 26px;
	position:relative;
	margin-bottom:.5rem;
}
ul.list-check > li:before{
	content: "";
	position:absolute;
	left:4px;
	top:calc(.5em + 4px);
	width:10px;
	height:10px;
	background:rgb(255,255,255);
	display: block;
	border:solid 1px #333;
}


ol.list-num01 {
	margin-left: 0.5rem;
	margin-bottom:2rem;
	counter-reset: listnum;
}
ol.list-num01 > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
ol.list-num01 > li:before{
	position: absolute;
	left: 0px;
	counter-increment: listnum;
	content: counter(listnum) ".";
	width: 23px;
	text-align: right;
}

/*（）付き数字リスト*/

ol.in-list-num {
	margin-left: 0.5rem;
	margin-bottom:2rem;
	counter-reset: listnum;
}
ol.in-list-num > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
ol.in-list-num > li:before{
	position: absolute;
	left: 0px;
	counter-increment: listnum;
	content: "(" counter(listnum) ")";
	width: 23px;
	text-align: right;
}

/*共通2カラム*/
.col2 .item{margin-bottom:2rem;}
@media screen and (min-width: 769px){
.col2{display:flex;flex-wrap:wrap;}
.col2 .item{width:calc((100% - 4rem) / 2);}
.col2 .item:nth-child(2n-1){margin-right:4rem;}
}
@media screen and (min-width: 769px) and (max-width: 1380px){
.col2 .item{width:calc((100% - 50px) / 2);}
.col2 .item:nth-child(2n-1){margin-right:50px;}
}

/* ==========================================================================
   Layout
========================================================================== */


/* Header と side
----------------------------------------------------------------- */
header{
	width:100%;
	box-sizing:border-box;
	position:relative;
	z-index:10;
	background:#fff;
}
.h-top{
	background:#481900;
	padding:5px 1.5rem;
}
.h-top h2{
	color:#fff;
	font-weight:bold;
	letter-spacing: 1px;
	font-size:clamp(10px, 1.25vw, 14px);
}
.header-in{
	background:#fff;
	margin:0 auto;
	display:flex;
	flex-wrap:wrap;
	justify-content: center;
	align-items:center;
	box-sizing: border-box;
	height:90px;
	position: relative;
}
.h-logo{
	width: 200px;
	height: 150px;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	top:0;
	z-index: 2;
	left: 1rem;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
	padding:1rem 2rem;
	box-sizing:border-box;
}
.toiawase-btn {
	width: 240px;
	height: 100%;
}
.toiawase-btn a{
	background:#E57200;
	color:#fff;
	display:block;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	font-weight: bold;
}
@media screen and (max-width: 980px){
.header-in{height:0;}
.toiawase-btn{position:absolute;right:70px; top:0;}
}
/*追従*/
header.m_fixed{
	width:100%;
	box-sizing: border-box;
	position:fixed;
	z-index:999;
	left:0;
	top:0;
	height:70px;
	background:#fff;
}
header.m_fixed .header-in,
header.m_fixed .globalMenuSp-in{height:70px; box-shadow: 0 0 1px #ccc;}


header.m_fixed .h-logo{
	width:150px;
	height:100px;
}


header.m_fixed .toiawase-btn{height:70px;}

@media screen and (max-width: 980px){
header.m_fixed .header-in,
header.m_fixed .globalMenuSp-in{height:unset;        box-shadow: none;}
}

@media screen and (max-width: 480px){
	header.m_fixed{height:50px;}
	header.m_fixed .h-logo{width:100px;height:70px;}
	header.m_fixed .toiawase-btn{height:50px;}
}
/*tab sp ナビ*/
.globalMenuSp-in::-webkit-scrollbar{width: 8px;}
.globalMenuSp-in::-webkit-scrollbar-track{background-color: #ddd;}
.globalMenuSp-in::-webkit-scrollbar-thumb{background-color: #F2AC7F;}




/*ナビデザイン共通*/

.h_nav > li > a{
	text-align: center;
	display:flex;
	flex-direction: column;
	justify-content: center;
	padding:10px 2rem;
	position:relative;
	line-height:1.25rem;
	letter-spacing:0;
	font-weight:bold;
	font-size:clamp(12px, 1.25vw, 16px);
	box-sizing:border-box;
	height: 100%;
}
.h_nav > li > a span{
	font-size:clamp(10px, 1vw, 12px);
	font-weight:bold;
}
.h_nav > li > a:hover{
	opacity:1;
	background:#481900;
	color:#fff;
}






@media screen and (min-width: 981px){
	.navToggle{display:none;}
	.globalMenuSp{flex:1;}
	.globalMenuSp-in{
		display:flex;
		flex-wrap:wrap;
		justify-content: center;
		height: 90px;
	}
	
	.h_nav {
		display:flex;
		flex-wrap:wrap;
		margin-left:200px;
	}

}

@media screen and (min-width: 981px) and (max-width: 1200px){
.h_nav > li > a{padding:10px 1rem;}

}


@media screen and (max-width: 1200px){
.toiawase-btn{width:180px;height:90px;}
.h-logo{width: 150px;height: 100px; padding:1rem 2rem;}
}
@media screen and (max-width: 980px){
	.toiawase-btn{width:180px;height:70px;}
}

@media screen and (max-width: 480px){
.toiawase-btn{width:120px;height:50px; right:50px;}
.h-logo{width: 100px;height: 70px;padding: 1rem 1.5rem;}

}


@media screen and (max-width: 980px){

nav.globalMenuSp {
	position: fixed;
	height: 100%;
	z-index: 999;
	top: 0;
	right: 0;
	background:#f8f8f8;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 240px;
	margin:0;
	padding-bottom:45px;
	border-left:solid 1px #ddd;
	box-sizing:border-box;
}
.globalMenuSp-in{
	position:absolute;
	height: calc(100vh - 1rem);
	padding:70px 0 0 ;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
	width:100%;
	box-sizing:border-box;
	display: flex;
	flex-direction: column;
}
/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
	transform: translateX(0%);
	display:block;
	top:0px;
}
.navToggle {
	display: block;
	position: absolute;
	right: 0px;
	top: 0px;
	width: 70px;
	height: 70px;
	cursor: pointer;
	z-index: 999999;
	text-align: center;
	background:#481900;
}




.navToggle span {
	display: block;
	position: absolute;    /* .navToggleに対して */
	width: 40px;
	height:4px;
	background:#fff;
	border-radius:2px;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
	left: 15px;
}
.navToggle span:nth-child(1) {top: 18px;}
.navToggle span:nth-child(2) {top: 46px; }
.navToggle span:nth-child(3) {top: 32px;}
.navToggle span:nth-child(4) {
	/*top:30px;
	color:#F96C93;
	font-size:12px;
	font-weight:bold;
	background:none;*/
	display:none;
}
.navToggle.active{position:fixed; }
/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
	top: 30px;
	left: 15px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
	top: 30px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
}
.navToggle.active span:nth-child(3),
.navToggle.active span:nth-child(4){display:none;}

/*ハンバーガー内のナビ*/
.h_nav{margin-bottom:2rem;}
.h_nav .js-megaMenu{margin-top:1rem;}
.p-megaMenu__navigation h3{/*display:none;*/}


.col-wrap .child_nav{margin-bottom:1rem;}
.h_nav > li button{
	padding: 5px 1rem;
	background:#45C1AC;
	color:#fff;
	margin-bottom:5px;
	pointer-events: none;
	display: block;
	width: 100%;
	box-sizing: border-box;
	text-align: left;
}
.h_nav > li button > a{color:#fff;}

.h_nav > li > a{
	    display: block;
    line-height: 1.5em;
    font-size: clamp(13px, 1.125vw, 16px);
    position: relative;
    display: block;
    font-size: 1rem;
		    position: relative;
    padding-left: 26px;
		padding:1rem 0;
}
.h_nav > li > a:before{
	content: "";
    position: absolute;
    left: 0;
    top: calc(1rem - 2px);
    bottom: 0;
    width: 16px;
    height: 16px;
    background-image: url(img/arrow.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: center;
    display: block;
}
.child_nav > li > a:hover{
	opacity: 1;
    color: #FF4E4E;
}
}

@media screen and (max-width: 480px){
	.navToggle{width:50px;height:50px;}
	.navToggle span{width: 30px;left:10px;}
	.navToggle span:nth-child(1){top: 14px;}
	.navToggle span:nth-child(2) {top: 34px;}
	.navToggle span:nth-child(3) {top: 24px;}
	.navToggle.active span:nth-child(1){top: 24px;left:10px;}
	.navToggle.active span:nth-child(2), .navToggle.active span:nth-child(3){top:24px;}
}


/*----ハンバーガー end----*/







/* footer
---------------------------------------------------------------- */

.totop{
	position: fixed;
	z-index: 9;
	right: 0;
	bottom: 0;
}
.totop a{
	display: block;
	background: #e57200;
	width: 45px;
	height: 45px;
	position: relative;
}

.totop a:before{
	content: " ";
	position: absolute;
	left: calc(50% - 7px);
	top: calc(50% - 5px);
	width: 14px;
	height: 10px;
	clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	background: #fff;
}


footer{
	border-top:solid 1px #481900;
	padding:4rem 2rem;
}
footer .f_inner{
	max-width:1280px;
	margin:0 auto;

}

@media screen and (min-width: 769px){
footer .f_inner{display:flex;flex-wrap:wrap;}
footer .f_inner .item01,
footer .f_inner .item02{width:calc((100% - 2rem) / 2);}
footer .f_inner .item01{margin-right:2rem;}
}


footer .f_inner .item01 h2{
	font-size:clamp(11px, 1.125vw, 14px);
	margin-bottom:.5rem;
}
footer .f_inner .item01 h2 span{display:inline-block;}
footer .f_inner .item01 .f-logo{
	margin-bottom:.5rem;
}
footer .f_inner .item01 p{
	margin-bottom:0;
	font-size:clamp(11px, 1.125vw, 14px);
}
footer .f_inner .item01 .btn{margin-top:1rem;}
footer .f_inner .item02{
	display:flex;
	flex-wrap:wrap;
}
footer .f_inner .item02 .inbox{
	width:calc((100% - 2rem) / 2);
}
footer .f_inner .item02 .inbox:nth-child(1){margin-right:2rem;}
footer .f_inner .item02 h2{
	font-size:clamp(13px, 1.25vw, 16px);
}
.f-nav li{
	padding-left:2rem;
	margin-bottom:1.5rem;
	position:relative;
}
.f-nav li:before{
	content:"";
	width:1.5rem;
	height:1px;
	border-bottom:solid 1px #E57200;
	position:absolute;
	left:0;
	top:.5rem;

}

.f-nav li a{
	display:block;
	font-size:clamp(10px, 1.25vw, 14px);
}
.f-nav li a span{
	font-size:clamp(9px, 1.125vw, 13px);
	display:block;
	margin-top:5px;
}
@media screen and (max-width: 768px){

footer .f_inner .item01{margin-bottom:2rem;}
}

.address{
	background:#481900;
	padding:1rem;
	color:#fff;
	text-align:center;
	font-size:clamp(11px, 1vw, 14px);
}

/*pagenavi*/
.pagenavi{
	color: #fff;
	margin: 20px auto 20px;
	line-height:2em;
	text-align:center;
	clear: both;
	margin-bottom:2em;
}
.pagenavi a{
	text-decoration:none;
	color: #fff;
	background: #e57200;
}
.pagenavi a:hover{background:#481900;}
.pagenavi a.page-numbers, .pagenavi .current{
	line-height: 33px;
	display: inline-block;
	padding: 0 12px;
	text-decoration: none;
	font-size: 16px;
	border-radius:30px;
}
.pagenavi .current{
	color: #fff;
	background: #481900;
	font-weight: bold;
}
.pagenavi .prev.page-numbers,
.pagenavi .next.page-numbers{
	background:none;
	color:#1f1f1f;
}
@media screen and (max-width: 480px){
	.pagenavi a.page-numbers, .pagenavi .current{
		font-size:12px;
		padding:0 9px;
		line-height:24px;
	}
}

/*記事内*/
#single{overflow: hidden;}

@media screen and (max-width: 768px){
	#single{margin-top:6rem;}
}
#single .entry_content .tit-wrap .date{
	text-align:right;
}
#single .entry_content .tit-wrap h1:not(.not){
	font-size: clamp(24px, 3.5vw, 40px);
	margin-bottom: 2rem;
	font-weight: bold;
	color:#481900;
	background-image: url(img/border01.png);
	background-repeat: repeat-x;
	background-position: bottom left;
	padding-bottom: 1rem;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 2px;
}

#single .entry_content .tit-wrap .cat-name-wrap{
	margin-bottom:1rem;
}
#single .entry_content .tit-wrap .cat-name-wrap .cat-name a{
	text-decoration:none;
	color:#481900;
	display:inline-block;
	margin-right:1rem;
	font-size:clamp(14px, 2vw, 16px);
	font-weight:bold;
}

#single .entry_content .cont-wrap{
	max-width:900px;
	margin:0 auto;
}
#single .entry_content .cont-wrap1200{
	max-width:1200px;
	margin:0 auto;
}

#single .entry_content h1:not(.not){
	font-size:clamp(24px, 3.5vw, 40px);
	margin-bottom:2rem;
	font-weight:bold;
}
#single .entry_content h2:not(.not){
	border-bottom:solid 1px #ccc;
	font-size:clamp(22px, 3.25vw, 30px);
	margin-bottom:2rem;
	font-weight:bold;
	border:none;
	padding:0;
}
#single .entry_content h2:not(.not):before{
	content: "";
	background: none;
}
#single .entry_content h3:not(.not){
	font-size:clamp(20px, 3vw, 28px);
	margin-bottom:2rem;
	font-weight:bold;
}
#single .entry_content h4:not(.not){
	font-size:clamp(16px, 2.75vw, 22px);
	margin-bottom:2rem;
	font-weight:bold;
}
#single .entry_content h5:not(.not){
	font-size:clamp(13px, 2.5vw, 18px);
	margin-bottom:2rem;
	font-weight:bold;
}
#single .entry_content h6:not(.not){
	font-size:clamp(14px, 2.25vw, 18px);
	margin-bottom:2rem;
	font-weight:bold;
}
#single .entry_content p:not(.not){
	font-size:clamp(13px, 1.75vw, 16px);
	margin-bottom:2rem;
}
#single .entry_content b,
#single .entry_content strong{
	font-weight:bold;
}
#single .entry_content a{text-decoration:underline;}
#single .entry_content img{
	display:inline-block;
	margin-bottom:5px;
}
#single .entry_content p.date{margin-bottom:0;color:#999;}
#single .entry_content ul:not(.list01){
	margin-left: 0.5rem;
	margin-bottom:2rem;
}
#single .entry_content ul:not(.list01) > li{
	font-size:clamp(13px, 1.75vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
#single .entry_content ul:not(.list01) > li:before{
	content: "";
	position:absolute;
	left:7px;
	top:15px;
	width:4px;
	height:4px;
	background:#5A391D;
	display: block;
	border-radius:10px;
}
#single .entry_content ul > li ul(.list01){margin-left:1rem;}
#single .entry_content ol:not(.list-num01) {
	margin-left: 0.5rem;
	margin-bottom:2rem;
	counter-reset: listnum;
}
#single .entry_content ol:not(.list-num01) > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
#single .entry_content ol:not(.list-num01) > li:before{
	position: absolute;
	left: 0px;
	counter-increment: listnum;
	content: counter(listnum) ".";
	width: 23px;
	text-align: right;
}
#single .to-cat{padding:1rem 0;}
#single .to-cat ul{
	display: flex;
	flex-wrap:wrap;
	justify-content: flex-end;
}
#single .to-cat ul li a{
	display:inline-block;
	color:#fe8f93;
	border:solid 1px #fe8f93;
	padding:8px 12px;
	margin-left:8px;
	border-radius:5px;
	font-size:;
}
#single .to-cat ul li a:before{
	content:"\00bb";
	margin-right:4px;
}
#single .to-cat ul li a:hover{
	background:#fe8f93;
	color:#fff;
}

/*次の記事*/
#prevnext{padding-top:3rem;}
.navigation{
	display: flex;
	flex-wrap:wrap;
	justify-content: space-between;
}
.navigation .alignleft,
.navigation .alignright{
	width:50%;
	box-sizing:border-box;
	position:relative;
}
.navigation .alignleft{padding-right:1rem;}
.navigation .alignright{padding-left:1rem;text-align:right; /*border-left:solid 1px #ddd;*/}
.navigation .next,
.navigation .prev{
	position:absolute;
	z-index:1;
	top:0;
	background:#481900;
	padding:3px 6px;
	color:#fff;
	font-size:12px;
}
.navigation .next{right:0;}
.navigation .prev{left:0;}

.navigation .tit{margin-bottom:0;}
.navigation a{
	display:block;
	padding:2rem 0;
	font-weight:bold;
	position:relative;
}
.navigation .date{
	position:absolute;
	bottom:5px;
	font-size:12px;
	color:#666;
}
.navigation .alignleft .date{left:0;}
.navigation .alignright .date{right:0;}

/* ==========================================================================
   カテゴリー
========================================================================== */
.category-top{
	padding:8rem 2rem 0rem 2rem;
}
.category-tit{
	max-width:1200px;
	margin:0 auto;
	font-size:clamp(24px, 3.5vw, 36px);
	font-weight:bold;
}

.blog-list{
	margin-bottom:2rem;
}
.blog-list > li{
	border-bottom: solid 1px #555;
}
.blog-list > li a{
	display: flex;
    flex-wrap: wrap;
    padding: 1.5rem 0;
}
.blog-list > li a span{
	width: 7em;
}
.blog-list > li a h2{
	flex:1;
	line-height:1em;
}

/*パンくず*/
#breadcrumb{
	max-width: 1280px;
	margin: 0 auto 1rem;
	box-sizing:border-box;
	padding:8px;
	background:rgb(255,246,225);
	border-radius:4px;
}
#breadcrumb ul{display:flex;flex-wrap:wrap;}
#breadcrumb ul li{
	padding:0 .8rem 0 0;
	font-size:.8rem;
	line-height: 1rem;
}
#breadcrumb ul li a{font-size:.8rem;}
#breadcrumb ul li:not(:first-child):before{
	content:"\003e";
	display:inline-block;
	margin-right:5px;
}

@media screen and (max-width: 769px){
	#breadcrumb ul li{padding:0 0.2rem 0 0 ; font-size:0.7rem;}
	#breadcrumb ul li a{font-size:0.7rem;}
}

/* ==========================================================================
   main内共通
========================================================================== */

/*サービス内容*/
.service-list{
	display:flex;
	flex-wrap:wrap;
}
.service-list li{
	box-sizing:border-box;
	width:calc((100% - 50px) / 2);
	margin-bottom:50px;
	box-shadow:0 3px 6px rgba(0, 0, 0, 0.16);
	display:flex;
	flex-wrap:wrap;
	padding-left:2rem;
	background-color: #fff;
    background-image: url(img/border02.png);
    background-repeat: repeat-y;
    background-position: top left 8px;
}
.service-list li:nth-child(2n-1){margin-right:50px;}
.service-list li .item-txt{
	flex:1;
	display: flex;
	flex-direction: column;
	margin-right:1rem;
}
.service-list li .item-img{text-align:center;}
.service-list li .item-txt h3{
	font-weight:normal;
	margin-top:1rem;
	line-height:1.25em;
	font-size:clamp(18px, 2vw, 28px);
}
.service-list li .item-txt p{
	font-size:clamp(11px, 1.25vw, 16px);
}
.service-list li .item-txt .btn{
	margin-top:auto;
}
.service-list li .item-txt .btn a{	min-width:150px;}

@media screen and (max-width: 1180px){
.service-list li{width:calc((100% - 20px) / 2);margin-bottom:20px;}
.service-list li:nth-child(2n-1){margin-right:20px;}
}
@media screen and (min-width: 769px){
	.service-list li .item-img{
	width:45%;
	max-width:250px;
}
}
@media screen and (min-width: 481px) and (max-width: 768px){
	.service-list li{flex-direction: column-reverse;}
	.service-list li.kimono{width:100%; margin-right:0;}
}
@media screen and (max-width: 480px){
	.service-list li{width:100%;}
	.service-list li:nth-child(2n-1){margin-right:0;}
	.service-list li .item-img{
	width:45%;
	max-width:250px;
}
.service-list li .item-txt .btn a{min-width:120px;line-height:30px;}
}

/*f_contact*/
#f_contact{background:#FEF7F3;}
#f_contact .btn{text-align:center;}


/*ちいさめのContact*/
.min-contact{
	background: #FEF7F3;
	padding: 4rem 2rem;
}
.min-contact .btn{text-align:center;}
/* ==========================================================================
   section別
========================================================================== */

/*スライダー*/
#index-topimg{
}
.swiper-slide{
	display:flex!important;
	flex-wrap:wrap;
}

@media screen and (min-width: 981px){
	.swiper-slide .txt{
	width:40%;
	padding: 6rem 2rem 1rem;
	min-width:400px;
	margin-left:auto;
}
.swiper-slide .slide-media{
	flex:1;
	max-width:1000px;
}
.swiper-slide .slide-media img{
	object-fit:cover;
	height:100%;
	width:auto;
}
}

@media screen and (min-width: 1281px) and (max-width: 1380px){
	.swiper-slide .slide-media img{height:500px;}
}

@media screen and (min-width: 1381px){
.swiper-slide .txt{padding: 6rem 2rem 1rem 6rem;}
}

@media screen and (max-width: 980px){
	#index-topimg{margin-top:70px;}
	.swiper-slide{
		flex-direction:column-reverse;
	}
	.swiper-slide .txt{
		padding:0 2rem;
		position:relative;
		top:-2rem;
	}
	.swiper-slide .slide-media{padding-left:4rem;}
}
@media screen and (max-width: 480px){
	#index-topimg{margin-top:50px;}
}

.swiper-slide .txt p{
	font-size:clamp(16px, 2vw, 24px);
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: 2px;
}
.namelabel{
	position:relative;
	z-index:2;
	margin-bottom: 1rem;
}
.namelabel .in-label{
	display:inline-block;
	padding:1rem 3rem 1rem 1rem;
	border:solid 1px #E57200;
	background:#fff;
	position:relative;
	z-index:3;
	font-size:clamp(13px, 1.25vw, 16px);
}
.namelabel:before{
	content:"";
	display:block;
	width:100%;
	height:1px;
	background:#481900;
	position:absolute;
	top:50%;
	right: -3rem;
	z-index:1;
}
.namelabel .in-label:before{
	content:"";
	display:block;
	width:8px;
	height:8px;
	background:#481900;
	border-radius:4px;
	position: absolute;
	right: 30px;
	top: calc(50% - 4px);
	z-index: 5;
}
.namelabel .in-label:after{
	content:"";
	display:block;
	width:30px;
	height:1px;
	background:#481900;
	position:absolute;
	top:50%;
    right: 0;
	z-index:1;
}
.namelabel .in-label span{
	font-size:clamp(11px, 1vw, 14px);
	display:block;
	margin-bottom:.5rem;
}

@media screen and (max-width: 980px){
	.namelabel:before{right:-1rem;}
}
@media screen and (max-width: 480px){
	h2.ubtit span,.swiper-slide .txt p{letter-spacing:0;}
}

/*index-catch*/
#index-catch .item .cont h3{
	font-size:clamp(16px, 2vw, 24px);
	margin-bottom:2rem;
}
#index-catch .before,
#index-catch .after{
	display:flex;
	flex-wrap:wrap;
	align-items: flex-start;
	margin-bottom: 2rem;
}
#index-catch .before h4,
#index-catch .after h4{
	font-size:clamp(13px, 1.25vw, 16px);
	width:120px;
	margin-right:2rem;
	margin-top:1rem;
	text-align: center;
	padding: 0.5rem 1rem;
	box-sizing: border-box;
	font-weight:bold;
	border:solid 1px;
	position:relative;
	
}
#index-catch .before h4 span,
#index-catch .after h4 span{font-weight:bold;}

#index-catch .before h4{border-color:#707070;}
#index-catch .after h4{border-color:#E57200;}

#index-catch .before h4:before,
#index-catch .after h4:before{
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	background: #481900;
	border-radius: 4px;
	position: absolute;
	right: 10px;
	top: calc(50% - 4px);
	z-index: 5;
}
#index-catch .before h4:after,
#index-catch .after h4:after{
	content: "";
	display: block;
	width: 50px;
	height: 1px;
	background: #481900;
	position: absolute;
	top: 50%;
	right: -40px;
	z-index: 1;
}

#index-catch .before img,
#index-catch .after img{flex:1;}

/*index-news*/
#index-news .btn{text-align:center;}
.news-list{margin-bottom:2rem;}
.news-list li{
	padding:1rem 0;
	background-image: repeating-linear-gradient(90deg, #8D3D1A,#8D3D1A 5px, transparent 5px, transparent 10px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 100% 1px;
}
.news-list li span.date{margin-right: 2rem;}


/*サービス関連のページ*/

.tbl-service tr{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}
.tbl-service th{
	border: solid 1px #707070;
	width: 5em;
}
.tbl-service td{
	flex:1;
}

.flow .inner{
	max-width:1000px;
	box-sizing:border-box;
	padding:4rem 2rem;
	box-shadow:0 0 6px rgba(0,0,0,0.16);
}


.flow-list{
	counter-reset: listnum;
	max-width: 800px;
	margin: 0 auto;
}
.flow-list li{
	position:relative;
	margin-bottom: 3rem;
    padding: 0 0 0 5rem;
}
.flow-list li:before{
	position: absolute;
	left: 0px;
	top: -8px;
	counter-increment: listnum;
	content: counter(listnum);
	width: 4rem;
	height: 4rem;
	text-align: center;
	background: #E57200;
	line-height: 4rem;
	font-weight: bold;
	color: #fff;
	text-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
	font-size: 2rem;
	font-family: "Noto Serif JP", serif;
    font-weight: 500;
    font-style: normal;

}
.flow-list li:not(:last-child):after{
	content:"";
	position: absolute;
	bottom: -3rem;
	left: 2rem;
	width: 4px;
	height: 100%;
	border-left: solid 1px #E57200;
	background-image: repeating-linear-gradient(180deg, #E57200, #E57200 5px, transparent 5px, transparent 10px);
  background-position: right top;
  background-repeat: repeat-y;
  background-size: 1px 100%;
}

/*パールトーン加工*/
#pearltone .cont{
	background-image:url(img/pt_bg.jpg);
	background-position:right bottom;
	background-size:auto 100%;
	background-repeat: no-repeat;
}
#pearltone .cont h3{
	font-size:clamp(24px, 3.5vw, 34px);
	margin-bottom:2rem;
}

#pearltone .cont .pt-box{
	display:flex;
	flex-wrap:wrap;
	max-width:920px;
	margin-bottom:1rem;
}
#pearltone .cont .pt-box h4{
	width:4.5em;
	padding:2rem;
	font-size:clamp(20px, 2.5vw, 28px);
	text-align:center;
	background:#FEF7F3;
	display: flex;
	justify-content: center;
	align-items: center;
}
#pearltone .cont .pt-box p{
	flex: 1;
	padding: 2rem;
	margin-bottom: 0;
}
@media screen and (max-width: 768px){
	#pearltone .cont{
		    background-size: 200px auto;
	}
}
@media screen and (max-width: 480px){
	#pearltone .cont .pt-box{display:block;}
	#pearltone .cont .pt-box h4{
		position: relative;
    margin-bottom: -2em;
    z-index: -1;
    justify-content: unset;
		}
}

/*お問い合わせフォーム*/

#contact .cont{
	margin-bottom:4rem;
}

#contact .required{
	color:red;
}

.form__inner{max-width:800px; margin:0 auto;}

.field{
	display: flex;
	gap: 5px 10px;
	margin-bottom:5px;
}
.field .field-head{
	display: flex;
	align-items: center;
	gap: 20px;
	min-width: 250px;
	padding: 10px;
	
}
.field .field-body{
	flex: 1;
	width: 100%;
	position: relative;
	padding: 0;
}
.field p{margin-bottom:0;}
.field input[type="text"],
.field input[type="tel"],
.field input[type="email"],
.field textarea{
	padding: 1rem;
	border: none;
	background-color: #F8F8F8;
	width: 100%;
	box-sizing:border-box;
}

.field input[type="checkbox"]{
	
}
.field .wpcf7-form-control-wrap{
	display: block;
}
.field .your-service .wpcf7-list-item{
	display: block;
	margin: 0;
}
.form-privacypolicy{
	max-width: 900px;
	margin: 0 auto;
}
.form-privacypolicy h3{
	font-size:clamp(15px, 1.75vw, 18px);
	margin-bottom: .5rem;
}
.form-privacypolicy__body{
	padding: 20px 10px;
    border: 1px solid #d8dce5;
    height: 200px;
    overflow-y: scroll;
    margin-bottom: 40px;
		box-sizing: border-box;
}
.form-privacypolicy__body .sec{padding:0 1rem;}
.form-submit {text-align:center;}
.form-submit input{
	padding: 10px 2em;
	margin-left: 15px;
	background-color: #E57200;
	border:none;
	border-radius:30px;
	font-size: clamp(15px, 1.75vw, 18px);
	color: #fff;
	margin-left: 72px;
}

@media screen and (max-width: 768px){
.field{display:block;}
.field .field-head .field-label{font-weight:bold;}
.field .field-body{margin-bottom:1rem;}
}

/*会社概要*/
@media screen and (max-width: 480px){
#outline .tbl01 tr{display: flex;flex-direction: column;}
#outline .tbl01 th{background:#f8f8f8;}
#outline .tbl01 td{border-bottom:none; margin-bottom:2rem;}

}

/*特商法*/
@media screen and (max-width: 480px){
#tokushoho .tbl01 tr{display: flex;flex-direction: column;}
#tokushoho .tbl01 th{background:#f8f8f8;}
#tokushoho .tbl01 td{border-bottom:none; margin-bottom:2rem;}

}
