@charset "UTF-8";

/*テンプレートcssファイルの読み込み
---------------------------------------------------------------------------*/
@import url("aos.css");
@import url("drawer.css");
@import url("../webfonts/css/all.css");


/*全体の設定
---------------------------------------------------------------------------*/
html {
-moz-text-size-adjust:none;
-webkit-text-size-adjust:100%;
overflow-x: hidden;
overflow-y:scroll;
}
body {font-size:1em;
font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";;font-style:normal;
line-height: 1.9;color: #fff;-webkit-text-size-adjust: 100%;text-align: center;-webkit-font-smoothing: antialiased;background: #5e4032}
* {
margin: 0;
padding: 0;
}
*, *:before, *:after { box-sizing: border-box;}
*:focus {  outline: none;}

/*リセット*/
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, menu, nav, section, summary,
time, mark, audio, video {
margin:0;
padding:0;
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
}
dd {margin: 0;}
nav,ul,li,ol {margin: 0;padding: 0;}
ul {list-style: none;}
input {font-size: 1rem;}

.clearfix:after {
content: "."; 
display: block;
clear: both;
height: 0;
visibility: hidden;
}
.clearfix {
min-height: 1px;
overflow:hidden;
}


/*container（サイト全般を囲むブロック）
---------------------------------------------------------------------------*/
.container{
padding: 0 6%;
box-sizing:border-box;
width:100%;
}
#main {
display: grid;
grid-template-rows: auto 1fr auto;
grid-template-columns: 100%;
min-height: 100vh;
}
@media screen and (min-width: 768px) {
.container {
margin: 0 auto;
}
a[href^="tel:"] {
pointer-events: none;
}
}
@media screen and (min-width: 1024px) {
.container{
width:1000px;
padding: 0;
}}

/*img*/
img{vertical-align:middle;border-style:none;border:0;-webkit-backface-visibility: hidden; backface-visibility: hidden;}
a {-webkit-tap-highlight-color:rgba(0,0,0,0); cursor:pointer;}
a:hover img{opacity:0.8;filter:alpha(opacity=80);-ms-filter:"alpha( opacity=80 )";}
/*img Chromeのみ*/
@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
img {image-rendering: -webkit-optimize-contrast;}
}

a img,
ol li img,
li img,
ul li img {/*上揃え*/
vertical-align: top;
text-align:center;
border-style:none;
}
img {
vertical-align: middle;
border: none;
max-width: 100%;
height: auto;
}

/*フロート設定*/
.tex img.centered,.tex img.aligncenter {
display:block;
margin-left:auto;
margin-right:auto;
clear:none;
}
.tex img.alignright,
.tex .alignright img{
margin-left:20px;
margin-right:0;
margin-bottom:20px;
display:inline;
clear:none;
}
.tex img.alignleft,
.tex .alignleft img {
margin-left:0;
margin-right:20px;
margin-bottom:20px;
display:inline;
clear:none;
}
.tex img.alignnone,
.tex .alignnone img {
margin-left:0;
margin-right:0;
margin-bottom:10px;
clear:none;
display:block;
}
.tex .alignright,.right {
float:right;
}
.tex .alignleft {
float:left;
}
@media only screen and (max-width:60em) {
.tex img.alignright,.tex img.alignleft,.tex img.alignnone,.tex img.aligncenter {clear:both;display:block;margin-left:auto;margin-right:auto;}
.tex .alignright {float:none;}
.tex .alignleft {float:none;}
.tex .aligncenter {clear:both;display:block;margin-left:auto;margin-right:auto;}
}


/*	header
/* ------------------------------------- */
.logo{
margin: 0;
text-align: left;
position: absolute;
left: 30px;
top: 30px;
z-index:99999
}
h1 a {
	background: url(../img/logo.svg) no-repeat;
	background-size: 115px 80px;
  display: block;
  width: 115px;
  height: 80px;
}
h1 a span {
display: none;
}
.drawer-hamburger .drawer-hamburger-icon {
  margin: 30px 30px 0 0;
}

@media screen and (min-width: 768px) {
h1 a {
	background-size: 187px 130px;
  display: block;
  width: 187px;
  height: 130px;
}
}


/*	NEWS
/* ------------------------------------- */
.news_list {
  margin: 0 auto;
	width: 100%;
	text-align: left;
	padding-bottom: 5%
}
ul.news_list {
  list-style: none;
}
.news_list_item {
  padding: 25px 0;
  border-bottom: 1px solid #f4e9db;
}
.news_list_item a {
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
 color: #fff;
text-decoration: none;
}
.news_list_item a:hover{
opacity: 0.5;
}
.news_list_item .date {
  font-size: .8em; 
  margin-right: 20px;
  align-items: top;
}
.news_list_item .category{
  margin-right: 20px;
  min-width: 90px;
	height: 25px;
  background: #d08d04;
  color: #FFF;
  text-align: center;
  font-size: 12px;
  line-height: 25px;
	border-radius: 100vh;
	align-items: center;
}
.news_list_item .title{
  margin: 0;
  width: 100%;
}
@media screen and (max-width: 767px){
.news_list_item a{
  flex-wrap: wrap;
}
.news_list_item .title{
  margin-top: 10px;
}
}


/*	footer
/* ------------------------------------- */
#footer{
	width: 100%;
	margin: 0;
	padding: 50px 0;
	background: #f4e9db;
	color: #5e4032
}
.footer_box {
	padding: 30px 0 30px 0;
	text-align:center;
}
#footer p {
	font-style: normal;
	font-size: 80%;
line-height:1.6em;
  margin: 10px 0;
}
#footer p span{
color: #5f61b1;
}
#copy {
font-family:Verdana, “Droid Sans”;
font-size: 80%;
width:100%;
text-align: center
}
.f_logo img{
width: 230px;
height: auto;
margin-bottom: 30px
}
.f_tel img{
width: 200px;
height: auto;
}


/*	footer menu
/* ------------------------------------- */
.md_box {
margin:0 0 40px 0;
padding: 0;
}
.md-flex li a {
color: #5e4032;
font-size: 1em;
text-decoration:none;
}
@media screen and (min-width: 768px) {
.md-flex {
margin: 0 auto;
text-align: center;
}
.md-flex li {
display: inline;
padding: 0 5px;
line-height: 1
}

.md-flex li:last-child {
border:0;
}
.md-flex li a:hover {
opacity: 0.5;
transition: 0.5s;
text-decoration:none;
}
}
@media only screen and (max-width: 767px) {
.f_logo img{
width: 200px;
}
.md-flex li {
padding: .5em;
font-size: 90%;
border-bottom: #e8d1b4 1px solid;
text-align:left
}
.md-flex li a {
display: block;
}
}

/*	pagetop
/* ------------------------------------- */
.pagetop {
    display: none;
    position: fixed;
    bottom: 20px;
    left: 20px;
}
.pagetop a {
    display: block;
    background-color: #38261e;
    text-align: center;
    color: #FFF;
    font-size: 12px;
    text-decoration: none;
    padding: 2px 10px 5px 10px;
    filter:alpha(opacity=60);
    -moz-opacity: 0.6;
    opacity: 0.6;
}
.pagetop a:hover {
    display: block;
    text-align: center;
    color: #fff;
    text-decoration: none;
}


/*	header .tel
/* ------------------------------------- */
.header_tel {
position: absolute;
top:30px;
right:70px;
text-align: left;
font-size: 120%;
font-weight: normal;
line-height: 1.2;
margin: 0;
color: #fff;
white-space: nowrap;
padding: 0
}
.header_tel span{
font-size: .5em;
display: block;
letter-spacing:.05em;
color: #f9be00;
}
.header_tel a{
color: #fff;
text-decoration: none;
}
@media screen and (min-width: 1024px) {
.header_tel{
font-size: 140%;
right:170px
}
}

/*	google-maps youtube
/* ------------------------------------- */
.google-maps {
position: relative;
padding-bottom: 75%;
height: 0;
overflow: hidden;
}
.google-maps iframe {
position: absolute;
top: 0;
left: 0;
width: 100% !important;
height: 100% !important;
}
.youtube {
 position: relative;
 padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
 height: 0;
 overflow: hidden;
}
 
.youtube iframe {
 position: absolute;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
}

/*badge Contact
---------------------------------------------------------------------------*/
.badge a{
width: 110px;
height: 110px;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
border-radius: 50%;
background-color: #ec6c00;
color: #ffffff;
text-align: center;
display: inline-flex;
position: fixed;
bottom: 10px;
right: 10px;
z-index: 100;
 flex-flow: column wrap; 
vertical-align: middle;
justify-content: center;
align-items: center;
text-decoration:none
}
.badge a:hover {
opacity: 0.8;
transition: 0.8s;
color: #fff;
background-color: #ec6c00;
}
.badge_text {
font-size: 1em;
line-height:1.3em;
font-weight: bold;
}
.badge_text_small {
font-size: 0.5em;
line-height: 1.4em;
text-align: center;
margin-top: 5px
}
@media screen and (min-width: 1024px) {
.badge a{
width: 160px;
height: 160px;
bottom: 30px;
right: 30px;
}
.badge_text {
font-size: 1.3em;
line-height:1.4em;
}
.badge_text_small {
font-size: 0.7em;
line-height: 1.6em;
text-align: center;
margin-top: 10px
}
}