@charset "utf-8";
/* webfonts */
@font-face {
font-family: 'Butler Light';
font-style: normal;
font-weight: normal;
src: local('Butler Light'), 
url('../webfonts/Butler_Light.woff') format('woff'),
url('../webfonts/Butler_Light.eot'),
url('../webfonts/Butler_Light.eot?#iefix') format('embedded-opentype'),
url('../webfonts/Butler_Light.ttf')  format('truetype');
font-display:swap;
}
@font-face{
	font-family:'F+UD TsukuMin R';
	src:local('TsukuMin-R'),
	url('../fonts/F+UD-TsukuMin-R.eot'),
	url('../fonts/F+UD-TsukuMin-R.eot?#iefix') format('embedded-opentype'),
	url('../fonts/F+UD-TsukuMin-R.woff') format('woff'),
	url('../fonts/F+UD-TsukuMin-R.ttf')  format('truetype');
	font-display:swap;
}				
/* base */
body {
	font-family: YakuHanJP,'Noto Sans Japanese', sans-serif;
	font-size:1.4rem;
	line-height:1.6;
	color:#111;
	-webkit-text-size-adjust:100%;
	letter-spacing:0.1em;
}
a img {
	border-style: none;
}
a:link {
	color: #287B44;
	text-decoration: underline;
}
a:visited {
	color: #287B44;
}
a:hover {
	text-decoration: none;
}
.clear  {
	clear: both;
	visibility: hidden;
	height: 0px;
}

::selection {
    background: #287B44;
    color: #fff;
}

/*Firefox*/
::-moz-selection {
    background: #287B44;
    color: #fff;
}


/*-------------------------------------------------
	padding margin font-size
-------------------------------------------------*/

.p-0{padding: 0px !important;}
.p-5{padding: 5px !important;}
.p-10{padding: 10px !important;}
.p-15{padding: 15px !important;}
.p-20{padding: 20px !important;}
.p-25{padding: 25px !important;}
.p-30{padding: 30px !important;}
.p-35{padding: 35px !important;}
.p-40{padding: 40px !important;}
.p-45{padding: 45px !important;}
.p-50{padding: 50px !important;}

.pt-0 {padding-top: 0 !important;}
.pt-5 {padding-top: 5px !important;}
.pt-10 {padding-top: 10px !important;}
.pt-15 {padding-top: 15px !important;}
.pt-20 {padding-top: 20px !important;}
.pt-25 {padding-top: 25px !important;}
.pt-30 {padding-top: 30px !important;}
.pt-35 {padding-top: 35px !important;}
.pt-40 {padding-top: 40px !important;}
.pt-45 {padding-top: 45px !important;}
.pt-50 {padding-top: 50px !important;}

.pr-0 {padding-right: 0 !important;}
.pr-5 {padding-right: 5px !important;}
.pr-10 {padding-right: 10px !important;}
.pr-15 {padding-right: 15px !important;}
.pr-20 {padding-right: 20px !important;}
.pr-25 {padding-right: 25px !important;}
.pr-30 {padding-right: 30px !important;}
.pr-35 {padding-right: 35px !important;}
.pr-40 {padding-right: 40px !important;}
.pr-45 {padding-right: 45px !important;}
.pr-50 {padding-right: 50px !important;}

.pb-0 {padding-bottom: 0 !important;}
.pb-5 {padding-bottom: 5px !important;}
.pb-10 {padding-bottom: 10px !important;}
.pb-15 {padding-bottom: 15px !important;}
.pb-20 {padding-bottom: 20px !important;}
.pb-25 {padding-bottom: 25px !important;}
.pb-30 {padding-bottom: 30px !important;}
.pb-35 {padding-bottom: 35px !important;}
.pb-40 {padding-bottom: 40px !important;}
.pb-45 {padding-bottom: 45px !important;}
.pb-50 {padding-bottom: 50px !important;}

.pl-0 {padding-left: 0 !important;}
.pl-5 {padding-left: 5px !important;}
.pl-10 {padding-left: 10px !important;}
.pl-15 {padding-left: 15px !important;}
.pl-20 {padding-left: 20px !important;}
.pl-25 {padding-left: 25px !important;}
.pl-30 {padding-left: 30px !important;}
.pl-35 {padding-left: 35px !important;}
.pl-40 {padding-left: 40px !important;}
.pl-45 {padding-left: 45px !important;}
.pl-50 {padding-left: 50px !important;}

.m-0{margin: 0px !important;}
.m-5{margin: 5px !important;}
.m-10{margin: 10px !important;}
.m-15{margin: 15px !important;}
.m-20{margin: 20px !important;}
.m-25{margin: 25px !important;}
.m-30{margin: 30px !important;}
.m-35{margin: 35px !important;}
.m-40{margin: 40px !important;}
.m-45{margin: 45px !important;}
.m-50{margin: 50px !important;}

.mt-0{margin-top: 0px !important;}
.mt-5{margin-top: 5px !important;}
.mt-10{margin-top: 10px !important;}
.mt-15{margin-top: 15px !important;}
.mt-20{margin-top: 20px !important;}
.mt-25{margin-top: 25px !important;}
.mt-30{margin-top: 30px !important;}
.mt-35{margin-top: 35px !important;}
.mt-40{margin-top: 40px !important;}
.mt-45{margin-top: 45px !important;}
.mt-50{margin-top: 50px !important;}

.mr-0{margin-right: 0px !important;}
.mr-5{margin-right: 5px !important;}
.mr-10{margin-right: 10px !important;}
.mr-15{margin-right: 15px !important;}
.mr-20{margin-right: 20px !important;}
.mr-25{margin-right: 25px !important;}
.mr-30{margin-right: 30px !important;}
.mr-35{margin-right: 35px !important;}
.mr-40{margin-right: 40px !important;}
.mr-45{margin-right: 45px !important;}
.mr-50{margin-right: 50px !important;}

.mb-0{margin-bottom: 0px !important;}
.mb-5{margin-bottom: 5px !important;}
.mb-10{margin-bottom: 10px !important;}
.mb-15{margin-bottom: 15px !important;}
.mb-20{margin-bottom: 20px !important;}
.mb-25{margin-bottom: 25px !important;}
.mb-30{margin-bottom: 30px !important;}
.mb-35{margin-bottom: 35px !important;}
.mb-40{margin-bottom: 40px !important;}
.mb-45{margin-bottom: 45px !important;}
.mb-50{margin-bottom: 50px !important;}

.ml-0{margin-left: 0px !important;}
.ml-5{margin-left: 5px !important;}
.ml-10{margin-left: 10px !important;}
.ml-15{margin-left: 15px !important;}
.ml-20{margin-left: 20px !important;}
.ml-25{margin-left: 25px !important;}
.ml-30{margin-left: 30px !important;}
.ml-35{margin-left: 35px !important;}
.ml-40{margin-left: 40px !important;}
.ml-45{margin-left: 45px !important;}
.ml-50{margin-left: 50px !important;}

.fs-1 {font-size:.1rem !important;}
.fs-2 {font-size:.2rem !important;}
.fs-3 {font-size:.3rem !important;}
.fs-4 {font-size:.4rem !important;}
.fs-5 {font-size:.5rem !important;}
.fs-6 {font-size:.6rem !important;}
.fs-7 {font-size:.7rem !important;}
.fs-8 {font-size:.8rem !important;}
.fs-9 {font-size:.9rem !important;}
.fs-10{font-size:1rem !important;}
.fs-11{font-size:1.1rem !important;}
.fs-12{font-size:1.2rem !important;}
.fs-13{font-size:1.3rem !important;}
.fs-14{font-size:1.4rem !important;}
.fs-15{font-size:1.5rem !important;}
.fs-16{font-size:1.6rem !important;}
.fs-17{font-size:1.7rem !important;}
.fs-18{font-size:1.8rem !important;}
.fs-19{font-size:1.9rem !important;}
.fs-20{font-size:2rem !important;}
.fs-21{font-size:2.1rem !important;}
.fs-22{font-size:2.2rem !important;}
.fs-23{font-size:2.3rem !important;}
.fs-24{font-size:2.4rem !important;}
.fs-25{font-size:2.5rem !important;}
.fs-26{font-size:2.6rem !important;}
.fs-27{font-size:2.7rem !important;}
.fs-28{font-size:2.8rem !important;}
.fs-29{font-size:2.9rem !important;}
.fs-30{font-size:3.0rem !important;}
.fs-31{font-size:3.1rem !important;}
.fs-32{font-size:3.2rem !important;}
.fs-33{font-size:3.3rem !important;}
.fs-34{font-size:3.4rem !important;}
.fs-35{font-size:3.5rem !important;}
.fs-36{font-size:3.6rem !important;}
.fs-37{font-size:3.7rem !important;}
.fs-38{font-size:3.8rem !important;}
.fs-39{font-size:3.9rem !important;}
.fs-40{font-size:4rem !important;}
.fs-41{font-size:4.1rem !important;}
.fs-42{font-size:4.2rem !important;}
.fs-43{font-size:4.3rem !important;}
.fs-44{font-size:4.4rem !important;}
.fs-45{font-size:4.5rem !important;}
.fs-46{font-size:4.6rem !important;}
.fs-47{font-size:4.7rem !important;}
.fs-48{font-size:4.8rem !important;}
.fs-49{font-size:4.9rem !important;}
.fs-50{font-size:5rem !important;}


/* pc / sp */

@media screen and (min-width: 768px) {

.pc-hidden{
	display:none;
}

}

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

.sp-hidden{
	display:none;
}

}

/* basic layout */
header {
width: 100%;
height: 75px;
position: relative;
background-color: rgba(255,255,255,0.9);
position: fixed;
left: 0;
top:0;
z-index: 100;
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
/*border-bottom: solid 1px #eee;*/
}
.header_logo {
width: 220px;
height: auto;
}
.header_logo img {
width: 100%;
}
.gNavi {
font-size: 1.4rem;
line-height: 100%;
display: flex;
list-style: none;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 500;
margin-right: 25px;
}
.gNavi li a {
color: #111;
letter-spacing: 0.1rem;
text-decoration: none;
white-space: nowrap;
margin-left: 28px;
margin-right: 28px;
}
.gNavi li a:hover {
color: #287B44;
}
.contact a {
text-decoration: none;
}
.cBg {
background-color: #287B44;
width: 130px;
padding: 27px 0px 26px 0px;
}
.menuContact {
text-decoration: none;
color: #fff;
font-family: 'Noto Sans JP', sans-serif;
font-size: 1.4rem;
font-weight: 500;
text-align: center;
}
.cBg:hover {
background-color: #111;
}
.gNaviBox {
display: flex;
justify-content: flex-start;
align-items: center;
}
.header_inner {
max-width: 1260px;
width: 100%;
height: 75px;
margin: 0 auto;
display: flex;
justify-content: space-between;
align-items: center;
}
.titleBg {
background-image: url("../common/img/titleBg.png");
height: 220px;
background-repeat: no-repeat;
background-position: center top;
background-size: cover;
}
.titleBg_inner {
max-width: 1260px;
margin: 0 auto;
position: relative;
}
.titleBox {
position: absolute;
text-align: center;
top: 120px;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}
.titleBox h2 {
font-size: 3.2rem;
font-family:  'Fjalla One', sans-serif;
font-weight: normal;
color: #fff;
letter-spacing: 0.15em;
line-height: 100%;
margin-bottom: 5px;
}
.titleBox .subTitle {
font-size: 1.2rem;
color: #fff;
letter-spacing: 0.3em;
}
.pankuzu {
max-width: 980px;
margin: 0 auto;
padding-top: 15px;
display: flex;
}
.pHome,
.p01{
margin-right: 10px;
}
.pHome a {
font-family: 'Fjalla One', sans-serif;
text-decoration: none;
font-size: 1.2rem;
color: #111;
letter-spacing: 0.1em;
}
.pHome a:hover {
color: #287B44;
text-decoration: underline;
}
.p02 {
font-size: 1.1rem;
padding-top: 2px;
padding-right: 10px;
}
.p02 a {
text-decoration: none;
color: #111;
}
.p02 a:hover {
text-decoration: underline;
color:#287B44 ;
}
.wrapper {
max-width: 1260px;
margin: 0 auto;
}
main {
max-width: 980px;
width: 100%;
margin: 30px auto 70px;
padding-bottom: 30px;
}
footer {
width: 100%;
/*height: 470px;*/
background-color: #287B44;
}
.contactBox {
width: 100%;
/*height: 270px;*/
padding:73px 0 61px;
background-color: #F9F8F4;
border-top: solid 1px #ddd;
border-bottom: solid 1px #ddd;
}
.contactBox_inner {
max-width: 980px;
width: 100%;
margin: 0 auto;
}
.footTxt01 {
font-size: 1.5rem;
text-align: center;
line-height: 200%;
margin-bottom: 30px;
}
.footTel {
font-family: 'Butler Light';
font-weight: normal;
font-size: 3.0rem;
letter-spacing: 0.1em;
color: #267944;
line-height: 100%;
margin-bottom: 5px;
}
.footTxt02 {
font-size: 1.2rem;
}
.contactBtn {
width: 260px; 
height: auto;
}
.contactBtn a {
text-decoration: none;
}
.btnBox{
position: relative;
max-width: 260px;
width: 100%;
height: 50px;
line-height: 100%;
display: flex;
background: #287B44;
font-size: 1.5rem;
padding-top: 20px;
text-align: left;
}
.cBtn{
width: 100%;
height: 100%;
color: #fff;
z-index: 10;
text-align: center;
font-family: 'Fjalla One', sans-serif;
font-size: 1.3rem;
}
.cBtn:before{
content: "";
position: absolute;
top: 0;
bottom: 0;
width: 0;
display: block;
background: #000;
z-index: -1;
transition: .2s;
}
.cBtn::after{
content: "";
display: block;
position: absolute;
top: calc(50% - 5px);
right: 20px;
width: 8px;
height: 8px;
border: 2px solid;
border-color: transparent transparent #FFF #FFF;
transform: rotate(-135deg);
transition: .3s;
}
.cBtn:hover{
color: #fff;
}
.cBtn:hover:before{
width: 100%;
}
.cBtn:hover::after{
right: 10px;
}

.phoneBox {
margin-right: 30px;
}
.cBox {
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap;
}
.linkBanner {
width: 100%;
background-color: #fff;
padding: 35px 0;
}
.linkBanner_inner {
max-width: 1080px;
width: 100%;
margin: 0 auto;
}
.siteLink {
display: flex;
justify-content: flex-start;
align-items: center;
/*height: 60px;*/
/*padding: 65px 0;*/
}
.siteLink li {
margin-right: 10px;
}
.siteLink a:hover {
opacity: 0.8;
}
.copyright {
font-size: 1.0rem;
display: block;
color: #fff;
font-family: brandon-grotesque, sans-serif;
font-weight: 400;
font-style: normal;
text-align: center;
margin-top: 29px;
padding-bottom: 25px;
}


/*　page top 　*/

.page_top {
width: 55px;
height: 55px;
position: fixed;
right: 20px;
bottom: 80px;
background: #000;
opacity: 0.9;
border-radius: 50%;
z-index: 999;
}
.page_top a{
position: relative;
display: block;
width: 55px;
height: 55px;
text-decoration: none;
}
.page_top a::before{
font-family: 'Font Awesome 5 Free';
font-weight: 700;
content: '\f106';
font-size: 17px;
color: #fff;
position: absolute;
width: 30px;
height: 30px;
top: 0px;
bottom: 0;
right: 0;
left: 0;
margin: auto;
text-align: center;
}

/*　for iPad 横　*/
@media screen and (min-width:980px) and ( max-width:1024px) {
.header_logo {
margin-left: 10px;
}
.gNavi {
font-size: 1.3rem;
}
.gNavi li a {
margin-left: 15px;
margin-right: 15px;
}
.menuContact {
font-size: 1.3rem;
}
.header_inner {
max-width: 1024px;
}
.linkBanner_inner {
width: 98%;
margin: 0 auto;
}
.siteLink li {
width: calc(20% - 5px);
}

}

/*　for iPad 縦　*/
@media screen and (min-width:768px) and ( max-width:979px) {
.header_logo {
width: 180px;
margin-left: 20px;
height: auto;
}
.gNavi {
font-size: 1.2rem;
font-weight: 400;
}
.gNavi li a {
white-space: nowrap;
margin-left: 20px;
margin-right: 20px;
}
.header_inner {
max-width: 979px;
}
.cBg {
background-color: #287B44;
width: 120px;
padding: 27px 0px 26px 0px;
}
.menuContact {
font-size: 1.2rem;
}
.titleBg {
height: 200px;
}
.titleBox {
position: absolute;
text-align: center;
top: 120px;
}
.titleBox h2 {
font-size: 2.2rem;
line-height: 100%;
margin-bottom: 8px;
}
.titleBox .subTitle {
font-size: 1.0rem;
letter-spacing: 0.15em;
}
.pankuzu {
padding-left: 15px;
}
main {
padding: 0 15px 30px;
}
footer {
width: 100%;
}
.contactBox {
width: 100%;
padding:35px 0 30px;
}
.footTxt01 {
font-size: 1.3rem;
line-height: 180%;
margin-bottom: 20px;
}
.footTel {
font-size: 2.6rem;
line-height: 100%;
margin-bottom: 5px;
}
.footTxt02 {
font-size: 1.1rem;
}
.linkBanner {
width: 100%;
background-color: #fff;
padding: 20px 0;
}
.linkBanner_inner {
width: 98%;
margin: 0 auto;
}
.siteLink li {
width: calc(20% - 5px);
}
.copyright {
margin-top: 20px;
padding-bottom: 20px;
}
}

/* IE11にのみ適用したいスタイルシート */
@media screen and (-ms-high-contrast: none) {

}
/*スマートフォン*/

@media all and (max-width : 767px ){
header {
height: 48px;
}
.header_inner {
height: 48px;
padding-left: 0px;
position: relative;
}
.header_logo {
width: 150px;
height: auto;
position: absolute;
left: 50%;
transform: translateX(-50%);
-webkit-transform: translateX(-50%);
-ms-transform: translateX(-50%);
}
.gNavi {
display: none;
}
.cBg {
display: none;
}
.titleBg {
background-image: url("../common/img/titleBg.png");
height: 130px;
}
.titleBox {
position: absolute;
top: 70px;
}
.titleBox h2 {
font-size: 1.4rem;
letter-spacing: 0.2em;
margin-bottom: 4px;
white-space: nowrap;
}
.titleBox .subTitle {
font-size: 0.7rem;
}
.pankuzu {
display: none;
}
main {
margin-bottom: 30px;
}
footer {
width: 100%;
}
.contactBox {
padding:35px 0 30px;
}
.footTxt01 {
font-size: 1.1rem;
padding: 0 20px;
line-height: 200%;
margin-bottom: 20px;
}
.footTel {
font-size: 2.2rem;
margin-bottom: 5px;
text-align: center;
}
.footTxt02 {
font-size: 1.0rem;
text-align: center;
}
.btnBox {
position: relative;
max-width: 240px;
width: 100%;
height: 40px;
line-height: 100%;
display: flex;
background: #287B44;
font-size: 1.2rem;
padding-top: 15px;
}
.contactBtn a {
text-decoration: none;
}
.cBtn{
font-size: 1.2rem;
}
.phoneBox {
margin-right: 0px;
margin-bottom: 15px;
}
.linkBanner {
width: 100%;
height: auto;
padding: 10px 0 5px;
}
.linkBanner_inner {
width: 95%;
margin: 0 auto;
}
.siteLink {
display: flex;
justify-content: flex-start;
align-items: center;
flex-wrap: wrap;
}
.siteLink li {
width: calc(33% - 5px);
margin-bottom: 6px;
margin-right: 6px;
}
.copyright {
font-size: 0.7rem;
text-align: center;
line-height: 130%;
display: block;
margin-top: 12px;
padding-bottom: 15px;
}
.page_top {
width: 40px;
height: 40px;
position: fixed;
right: 10px;
bottom: 60px;
}
.page_top a{
width: 40px;
height: 40px;
}
.page_top a::before{
top: 1px;
}
}