:root {
  --main-logo-color: #005e00;
  --bg--transparent-color:rgba(255,255,255,.7);
  --bg--info-contents:#f0f0f0;
  --bg--bnr-contents:#dce3dd;
  --main-footer-color:#304a30;
}

body {
    /*font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1;
    padding: 0;
    margin: 0px;
    /*background-color: #e7f2f5;*/
    -ms-user-select: none;
    -webkit-text-size-adjust: 100%;
    position: relative;
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.sanyu {
    font-family: 'Noto Serif JP', serif; 
}

html,
body {
    height: 100%;
}

.forSP {
    display: none;
}

.forPC {
    display: block;
}

.alternative {
    display:none;
}

.subTitle {
    font-size:20px;
    font-weight:400;
    margin:20px 0 30px 0;
    padding-left:20px;
    border-left:5px solid #005e00;
}

.subSection {
    font-size:18px;
    font-weight:400;
    margin:20px 10px;
    padding-bottom:5px;
    border-bottom:1px dotted #005e00;
}

.full div {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 100vh;
  margin: 0;
}
.full div.main01 {
  background-image: url(../images/slide-1.jpg);
}
.full div.main02 {
  background-image: url(../images/slide-2.jpg);
}
.full div.main03 {
  background-image: url(../images/slide-3.jpg);
}
.full .slick-dots {
    bottom: 4%;
    z-index: +1;
}

/**/
.full .slick-slide div div {
  transform-origin: center top;
  transform: scale(1);
  transition: 5s ease-out;
}
.full .slick-slide.slick-active div div {
  transform: scale(1.05);
}

.slick-dotted.slick-slider {
    margin-bottom: 0px;
}

/**/
.js-fade {
    opacity: 0;
    visibility: hidden;
    transform: translateY(50px);
    transition: opacity 1s,visibility 1s, transform 1s;
}

.inview {
    opacity: 1;
    visibility: visible;
    transform: translateY(0px);
}

/**/
.navbar {
    background-color:var(--bg--transparent-color);
}

.navbar-menu {
    font-size:14px;
}

a.navbar-item,a.navbar-link {
    transition: all .5s ease;
    border-right:dotted 1px #999;
}

a.navbar-item.logo {
    padding-right:40px!important;
    padding-left:40px!important;
    /*border-right:none;*/
}

.navbar-item, .navbar-link {
    color: #000;
}

.navbar-item img {
    max-height: 41px;
}

.navbar-item, .navbar-link {
    padding: 1em;
}

.navbar-link:not(.is-arrowless)::after {
    border-color:var(--main-logo-color);
    margin-top: -0.375em;
    right: 1.125em;
}

a:hover.navbar-link:not(.is-arrowless)::after {
    border-color:#fff;
}

a:hover.navbar-item,a:hover.navbar-link {
    color:#fff!important;
    background-color:var(--main-logo-color)!important;
}

a:hover.navbar-item.logo {
    color:#fff;
    background-color:#fff!important;;
}

.navbar-end {
    background-color:var(--main-logo-color);
}
.navbar-end a {
    color:#fff!important;
}

.navbar-end a:hover {
    color:var(--main-logo-color)!important;
    background-color:#fff!important;
}

.navbar-burger {
    color: var(--main-logo-color);
    height: 5rem;
    width: 5rem;
}

/**/
.catchCopy {
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    margin:auto;
    width:100%;
    height:100vh;
    display:flex;
    justify-content: center;
    flex-direction:column;
    align-items: center;
    background-image:url(../images/img-sliding.png) , url(../images/img-anzen.png);
    background-size:100px 100px , 50vw auto;
    background-position:right bottom , center bottom;
    background-repeat:no-repeat,no-repeat;
}

.copyArea {
    position:relative;
    margin:auto;
    max-width:75vw;
}

.copyBox {
    margin-top:36px;
    padding:20px;
    background-color: var(--bg--transparent-color);
}

.mainCopy {
    line-height:1.75;
    font-size: calc(2vw + .5rem);
    color:#000;
    margin-bottom:.5em;
    text-shadow: 1px 1px 10px rgba(255,255,255,1);
}

.readCopy {
    line-height:1.75;
    font-size: calc(1vw + .5rem);
    color:#000;
    margin-bottom:.5em;
    text-shadow: 1px 1px 10px rgba(255,255,255,1);
    padding-left:20px;
    border-left:5px solid #005e00;
}

.slideCopyArea {
    padding-bottom:10px;
    color:#fff;
    font-size:10px;
    letter-spacing: .2px;
}

.full .slick-dots li button:before {
    color:#fff;
}

.full .slick-dots li.slick-active button:before {
    color:#fff;
}

/**/
.full .slick-dotted.slick-slider {
    margin-bottom: 0;
}
.topicsArea {
    background-color:var(--bg--info-contents);
}
.contentsCage {
    width:100%;
    max-width:980px;
    margin:0 auto;
    padding:30px 10px 30px 10px;
}
.bnrArea {
    background-color: var(--bg--bnr-contents);
}
.bnrContents {
    display: flex;
    justify-content: space-between;
}
.bnrItem {
    display:block;
    width:31%;
    background-color:#fff;
    box-shadow:2px 2px 10px rgba(0,0,0,0.3);
    padding:10px;
    transition: all .5s ease;
    /*transform:scale(1);*/
    opacity:1;
}

a:hover.bnrItem {
    transition: all .5s ease;
    /*transform:scale(0.98);*/
    box-shadow:2px 2px 0px rgba(0,0,0,0);
    opacity:0.9;
}


.bnrPhoto {
    position:relative;
}
.bnrTitle {
    position:absolute;
    left:20px;
    bottom:20px;
    color:#fff;
    font-weight: 400;
}

/**/
.indexSubContents {
    margin-bottom:0px;
    padding:10px;
}

.indexBusinessInfo img,.businessInfo img {
    height:290px;
    margin:20px 10px 20px 10px;
}

.indexBusinessInfo .slick-prev:before,.indexBusinessInfo .slick-next:before,
.businessInfo .slick-prev:before,.businessInfo .slick-next:before {
    color:#aaa;
}
.indexBusinessInfo .slick-prev:before,.businessInfo .slick-prev:before {
    margin-left:-19px;
}
.indexBusinessInfo .slick-next:before,.businessInfo .slick-next:before {
    margin-left:14px;
}

.slick-prev, .slick-next {
    width:40px;
    height:40px;
}

.slick-prev:before, .slick-next:before {
    font-size:40px;
}

.slick-prev:before {
    content: '<';
}

.slick-next:before {
    content: '>';
}

.indexBusinessInfo a,.businessInfo a {
    display:block;
}

.biText {
    text-align:center;
    font-size:14px;
    margin:10px;
    color:#000;
}
/**/
.infoList {
    padding:10px;
    font-size:14px;
    line-height:1.75;
    display:flex;
    flex-wrap: wrap;
    justify-content:flex-start;
}
.infoList li {
    position:relative;
    display:block;
    padding:10px;
    border:solid 1px #ddd;
    width:32.75%;
    background-color:#fff;
    margin-bottom:5px;
    margin:.25%;
}

.infoList li.new::after {
    position:absolute;
    top:0;
    right:0;
    content:'新着';
    background-color:#900;
    color:#fff;
    display:inline-block;
    padding:1px 10px;
    font-size:12px;
    font-weight:300;
}

.infoList li.important::after {
    position:absolute;
    top:0;
    right:0;
    content:'注目';
    background-color:rgb(155, 83, 0);
    color:#fff;
    display:inline-block;
    padding:1px 10px;
    font-size:12px;
    font-weight:300;
}

.infoList a {
    display:block;
    color:#000;
}

.infoList a :hover{
    display:block;
    color:#005e00;
}

.infoList a .yymmdd {
    display:block;
    background-color:var(--main-logo-color);
    color:#fff;
    padding:2px 5px;
    margin-bottom:5px;

}

.infoList a .summary {
}

.pastList {
    font-size:14px;
    text-align:right;
    padding:0 20px 20px 0;
}

footer {
    clear:both;
    display:block;
    padding:30px 60px;
    text-align:center;
    background-color:var(--main-footer-color);
    color:#fff;
    font-size:10px;
    line-height:1.75;
}
/**/
.subPage {
    padding-top:0;
    /*78px;*/
}
.entryContents {
    margin-bottom:0px;
    padding:10px;
}
.mainText {
    line-height: 1.75;
    font-size:14px;
    margin:1em;
}
.imageRightArea {
    float:right;
    text-align:center;
    padding:0 0 20px 20px;
}
.imageLeftArea {
    float:left;
    text-align:center;
    padding:0 20px 20px 0;
}
.imageRightArea.profile {
    width:100%;
    max-width:240px;
    margin:auto;
}
.imageRightArea .photoCaption {
    font-size:14px;
    line-height:1.75;
}
.mainText.sign {
    text-align: right;
    margin-top:0;
    margin-bottom:5px;
    line-height:1;
}
.mainText .name {
    font-weight:700;
    font-size:16px;
}
.contentsArea.subImage {
    width:100%;
    height:200px;
    margin-top:78px;
}
.contentsArea.subImage.image01 {
    background-image:url(../images/image-01.jpg);
    background-size:cover;
    background-position:center;
}
.contentsArea.subImage.image02 {
    background-image:url(../images/image-02.jpg);
    background-size:cover;
    background-position:center;
}
.contentsArea.subImage.image03 {
    background-image:url(../images/image-04.jpg);
    background-size:cover;
    background-position:center;
}
/**/
.mainTextUL {
    font-size:14px;
    margin:20px 0 20px 40px;
    line-height:1.75;
    list-style-type:disc;
}
.mainTextUL .contactList {
    list-style: none;
}
.mainTextUL .contactList:first-child {
    font-weight:800;
    font-size:18px;
    color:var(--main-logo-color);
}
.current {
    font-weight:700!important;
    color:var(--main-logo-color);
}
.aboutTable {
    margin:20px 1em 30px 1em;
    width:100%;
    border-collapse: collapse;
    font-size:14px;
    line-height:1.75;
}
.aboutTable th {
    border: solid 1px #ddd;
    padding:10px;
    background-color:#f7f7f7;
}
.aboutTable td {
    border: solid 1px #ddd;
    padding:10px;
    background-color:#fff;
}
/**/
.pdfArea {
    width:100%;
    display:flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.pdfArea::after {
    content:"";
    display:block;
    width:30%;
}
.pdfArea a {
    display:block;
    width:30%;
    margin-bottom:20px;
    padding:10px;
    border:solid 10px #f8f8f8;
    box-shadow: 2px 2px 5px rgba(0,0,0,.25);
    transition: all .5s ease;
    opacity:1;
}
.pdfArea a:hover {
    border:solid 10px #f8f8f8;
    box-shadow: 0px 0px 5px rgba(0,0,0,0);
    transition: all .5s ease;
    opacity:0.9;
}
.aboutHistory th {
    width:30%;
}
/**/
.googleMaps {
    position: relative;
    padding-bottom: 75%;
    height: 0;
    overflow: hidden;
}
.googleMaps iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
}
.businessContents {
    display:flex;
    flex-wrap: wrap;
}
.businessList {
    width:40%;
    padding:0 20px 20px 20px
}
.businessList ul {
    list-style-type: disc;
    font-size:14px;
    line-height:1.75;
}
.businessList ul li {
    margin-left:30px
}
.businessPhoto {
    width:60%;
    padding:10px;
}
.businessSubContents {
    display:flex;
    flex-wrap: wrap;  
}
.subContents {
    width:50%;
}
.subContents .businessPhoto {
    width:100%;
}
.navbar-end .navbar-item.current {
	background-color:#e0e0e0;
    color:var(--main-logo-color)!important;
}
/**/
.topicPath {
    font-size:14px;
    color:#999;
}
.cmsContents {
    line-height:1.75;
    padding:10px;
}
.cmsDate {
    font-size:14px;
    font-weight:400;
}
.cmsTitle {
    font-size:20px;
    font-weight:500;
    margin-bottom:10px;
}
.cmsBody {
    font-size:14px;
    font-weight:400;
}
.backBtn {
    padding:30px;
    margin:0 auto;
}
.backBtn a {
    background-color:var(--main-logo-color);
    color:#fff;
    border-radius: 10px;
    display:block;
    padding:5px 10px;
    width:80px;
    font-size:14px;
    font-weight:400;
    text-align:center;
    margin:0 auto;
}
.nameTitle {
    width:5em;
    display:inline-block;
}
.attention {
    color:#900;
}
/**/

.formTable {
    margin:20px 1em 30px 1em;
    width:100%;
    border-collapse: collapse;
    font-size:14px;
    line-height:1.75;
}
.formTable th {
    border: solid 1px #ddd;
    padding:10px;
    background-color:#f7f7f7;
}
.formTable td {
    border: solid 1px #ddd;
    padding:10px;
    background-color:#fff;
}
.btn {
    text-align: center;
}
.message {
    text-align:center;
    padding-top:120px;
    padding-bottom:120px;
    font-size:30px;
    font-weight:300;
}

.needs {
    font-size:12px;
    font-weight:400;
    padding-left:1em;
    color:#900;
}
.querryName {
    padding-right:20px;
}

@media screen and (min-width: 769px) and (max-width: 1023px) {
    a.navbar-item.logo {
        padding-right:0px!important;
        padding-left:10px!important;
        border-right:none;
    }
    .navbar-end {
        padding-bottom:20px;
    }
    .navbar-end a {
        color:#000!important;
        background-color:#fff!important;
    }
    .navbar-end a:hover {
        color:#fff!important;
        background-color:var(--main-logo-color)!important;
    }
    .bnrContents {
        flex-wrap: wrap;
    }
    /*
    .bnrItem {
        width:48%;
        margin-bottom:20px;
    }
    */
    .imageRightArea,.imageLeft {
        float:none;
        padding-bottom:20px;
    }
    .topicPath {
        display:none;
    }
}

@media screen and (max-width: 768px) {
        a.navbar-item.logo {
        padding-right:0px!important;
        padding-left:10px!important;
        border-right:none;
    }
    .navbar-end {
        padding-bottom:20px;
    }
    .navbar-end a {
        color:#000!important;
        background-color:#fff!important;
    }
    .navbar-end a:hover {
        color:#fff!important;
        background-color:var(--main-logo-color)!important;
    }
    .infoList a .yymmdd {
        float:none;
        display:block;
        width:100%;
    }
    .infoList a .summary {
        display:block;
        margin-left:0px;
    }
    .infoList li {
        border-top:1px dotted #999;
        padding:10px;
    }
    .infoList li {
        display:block;
        padding:10px;
        border:solid 1px #ddd;
        width:100%;
        background-color:#fff;
        margin-bottom:5px;
        margin:.25%;
    }
    .bnrContents {
        flex-wrap: wrap;
    }
    /*
    .bnrItem {
        width:48%;
        margin-bottom:20px;
    }
    */
    .bnrTitle {
        position: absolute;
        left: 0;
        right:0;
        bottom: 20px;
        margin-left: auto;
        margin-right: auto;
        text-align:center;
    }
    .imageRightArea,.imageLeft {
        float:none;
        padding-bottom:20px;
    }
    .aboutTable {
        display:flex;
        flex-wrap: wrap;
        width:98%;
        margin:0 auto;
    }
    .aboutTable tbody {
        display:block;
        width:100%;  
    }
    .aboutTable tr {
        display:block;
        width:100%;
    }
    .aboutTable th {
        display:block;
        width:100%;
    }
    .aboutTable td {
        display:block;
        width:100%;
    }
    .topicPath {
        display:none;
    }
    .businessList {
        width:100%;
    }
    .businessPhoto {
        width:100%;
    }
    .subContents {
        width:100%;
    }
    .indexBusinessInfo .slick-prev:before,
    .businessInfo .slick-prev:before {
        margin-left:-7px;
    }
    .indexBusinessInfo .slick-next:before,
    .businessInfo .slick-next:before {
        margin-left:4px;
    }
    .slick-prev, .slick-next {
        width:20px;
        height:20px;
    }
    .slick-prev:before, .slick-next:before {
        font-size:20px;
    }

    .formTable {
        display:flex;
        flex-wrap: wrap;
        width:98%;
        margin:0 auto;
    }
    .formTable tbody {
        display:block;
        width:100%;  
    }
    .formTable tr {
        display:block;
        width:100%;
    }
    .formTable th {
        display:block;
        width:100%;
    }
    .formTable td {
        display:block;
        width:100%;
    }
    .querryName {
        padding-right:0px;
        display:block;
        margin-bottom: 10px;
    }
}