@charset "UTF-8";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, address, em, img, small, strong, var, dl, dt, dd, ol, ul, li,  form, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, figure, figcaption, footer, header,  nav, section, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	border-style: none;
}
html {
scroll-behavior: smooth;
letter-spacing: 1px;
font-size: 18px;
line-height: 1.8em;
margin: auto;
font-feature-settings: "palt" 1;/*--字詰め(プロポーショナルメトリクス)--*/
}
body {
font-family: "ヒラギノ丸ゴ Pro","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
width: 904px;
margin: auto;
color: #333;
display: block;
}

h1 {}

h2 {
height: 25px;
}

h3 {
margin: 20px auto 15px 0;
padding: 5px 0px 5px 10px;
color: #fff;
font-weight: 900;
font-size: 20px;
border-left: solid 10px rgba(0, 0, 0, 0.50);
}

h4 {
margin: 10px 0;
padding: 5px auto 5px 0;
border-bottom: solid 2px #bde2ff;
font-weight: 900;
}

h5{
margin: 10px 0;
}
h5::before {
content: "●";
color: #999;
}

p {}

a {
color: #333;
text-decoration: underline;
transition: 0.2s;
}
a:visited {
color: #333;
}
a:hover {
font-size: 1em;
opacity: 0.5;
}
/*--aタグの下線無し--*/.no_deco{
text-decoration: none;
}

.font-l {
font-size: 1.2em;
font-weight: 900;
}
.font-ll {
font-size: 2em;
font-weight: 900;
}
.font-s {
font-size: 0.8em;
}
.font-ss {
font-size: 0.5em;
}
.center {
text-align: center;
margin: auto;
}

/*--テーマカラー--*/.b_tmc , .t_tmc {
background: #add23f;
}

/*------------基本設定ここまで------------*/

.title {
margin-right: calc(50% - 50vw);
margin-left: calc(50% - 50vw);
max-width: none;
width: 100vw;
height: 50px;
display: flex;
justify-content: center;
align-items: center;
}
.title img {
height: 22px;
margin-top: 10px;
}
.title .header_tel {
color: #fff;
padding: 0 10px;
}
.title .header_tel span {
vertical-align: top;
}


/*----------------------!要見直し!--------------------*/
.visiual {
    margin-right: calc(50% - 50vw);
margin-left: calc(50% - 50vw);
max-width: none;
width: 100vw;
height: 500px;
overflow: hidden;
position: relative;
align-items: center;
}
@media screen and (max-width: 767px){
.visiual {
   height: 250px;
}}
.v01, .v02, .v03{
   position: absolute;
   top:0;
   left:0;
   width: 100%;
   height: 100%;
   background-size: cover;
   background-repeat: no-repeat;
}
.v01 {
   background-image: url('../img/top_main1.jpg');
   animation: slide-animation-01 20s infinite;
}
.v02 {
   background-image: url('../img/top_main2.jpg');
   animation: slide-animation-02 20s infinite;
}
.v03 {
   background-image: url('../img/top_main3.jpg');
   animation: slide-animation-03 20s infinite;
}
@keyframes slide-animation-01 {
    0% {opacity: 1; transform: scale(1.0);}
  30% {opacity: 1;}
  40% {opacity: 0; transform: scale(1.15);}
  90% {opacity: 0}
100% {opacity: 1; transform: scale(1.0);}
}
@keyframes slide-animation-02 {
    0% {opacity: 0;}
  30% {opacity: 0; transform: scale(1.1);}
  40% {opacity: 1;}
  60% {opacity: 1;}
  70% {opacity: 0; transform: scale(1.0);}
100% {opacity: 0;}
}
@keyframes slide-animation-03 {
    0% {opacity: 0;}
  60% {opacity: 0;  transform: scale(1.0);}
  70% {opacity: 1;}
  90% {opacity: 1;}
100% {opacity: 0; transform: scale(1.1);}
}
/*----------------------!要見直し!--------------------*/


.navi {
display: flex;
margin: 20px auto;
}
.nav_c {
padding: 10px;
margin: 0 1px;
width: 200px;
color: #fff;
}
.nav_c h2 {
line-height: 25px;
height: 60px;
}
.nav_c .font-l {
font-size: 25px;
}
.nav_c .font-s {
font-size: 16px;
}
.nav_c p {
font-size: 14px;
line-height: 20px;
}
.ansinkan {
background-color: #add23f;
border-radius: 5px;
}
.sasae {
background-color: #ffa04d;
border-radius: 5px;
}
.yuusibata {
background-color: #87cfe6;
border-radius: 5px;
}
.akane {
background-color: #ff8787;
border-radius: 5px;
}
.akane p {
letter-spacing: 0;
}

.tel {
margin-bottom: 10px;
}
.tel,a {
color: #6a8d40;
}
.tel,a:visited {
color: #6a8d40;
}
.recruit {
padding: 5px 0;
border-top: solid 2px #6a8d40;
border-bottom: solid 2px #6a8d40;
}


.link {
display: flex;
justify-content: center;
margin-bottom: 10px;
}
.link img {
width: 300px;
margin: 0 10px;
}


.greeting {
background: #f1f7eb;
padding: 30px 50px;
margin: 30px 0;
}
.greeting_title {
margin-bottom: 20px;
}
.greeting_flex {
display: flex;
}
.greeting_flex .left img {
object-fit: cover;
height: 100%;
max-width: 300px;
}
.greeting_flex .right {
margin-left: 20px;
}
.greeting_flex .right .font-l,.greeting_flex .right .font-s {
color: #4b672a;
}



.yoko {
display: flex;
justify-content: space-evenly;
}
.yoko .left {
line-height: 30px;
}

footer {
margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    max-width: none;
    width: 100vw;
}
.footer_menu {
font-size: 12px;
}
footer .font-ss {
padding: 15px 0 20px 0;
}
footer a {
white-space: nowrap;
}


/*--タブレット--*/
@media screen and (max-width: 903px){
html {
letter-spacing: 0.5px;
}
body {
width: 600px;
}

.navi {
flex-wrap: wrap;
justify-content: center;
}
.navi a {
margin: 0 5px 10px 5px;
}
.link img {
width: 250px;
}
.greeting_flex {
flex-direction: column;
align-items: center;
}
.greeting_flex .right {
margin-left: 0px;
}
.greeting_flex .right .font-l{
display: block;
margin-top: 20px;
}

.yoko {
flex-direction: column;
align-items: center;
}
}

/*--スマホ--*/
@media screen and (max-width: 599px) {
html {
font-size: 16px;
line-height: 1.5em;
}
body {
width: 90%;
}
.font-l {
font-size: 1em;
}
.title {
height: 125px;
flex-direction: column;
align-items: center;
}
.title .header_tel {
    color: #fff;
    padding: 0px;
}
.navi {
flex-direction: column;
align-items: center;
}
.navi a {
margin: 10px 0;
}
.link {
flex-direction: column;
}
.greeting {
padding: 30px 10px;
}
}