@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+TC:100&subset=japanese');

* {
    box-sizing: border-box;
    list-style: none;
}

html,
body,
h1,
h2,
h3,
h4,
p,
ul,
li,
img,
a,
header,
section,
footer,
nav {
    margin: 0;
    padding: 0;
}

html {
    font-size: 62.5%;
}

body {
    color: #333;
    text-align: left;
    letter-spacing: 0.08rem;
    font-weight: 400;
    font-size: 1.6rem;
    font-family: serif;
    line-height: 1.5;
    /*    background: #496a57; */
    line-height: 1.5;
}

body {
    padding: 0;
    border: 10px solid #496a57;
}

#wrap {
    overflow: hidden;
    background: #fff;
}

img {
    border: 0;
    border-style: none;
    vertical-align: middle;
}

a {
    text-decoration: none;
}

p {
    padding-bottom: 1.5rem;
}

.clearfix:after {
    display: block;
    clear: both;
    content: "";
}

.mycontainer {
    margin: 0 auto;
}

header {
    padding: 17px 20px 0 20px;
    background: #fff;
}

.sp-only {
    display: none;
}

.z-idx {
    position: relative;
    z-index: 10;
}

/*** 各小見出し設定（左の線など） *********/

h2 {
    position: relative;
    top: 55px;
    padding-right: 34px;
    text-align: right;
    font-weight: normal;
    font-size: 1.8rem;
}

h2:before {
    display: inline-block;
    margin-right: 12px;
    height: 1px;
    background: url(../images/line.png);
    background-position: left auto;
    content: '';
    vertical-align: middle;
}

#philosophy h2:before {
    width: 440px;
}

#gallery h2:before {
    width: 490px;
}

#gallery h2 {
    margin-bottom: 130px;
}

#map h2 {
    position: relative;
    top: 0;
    margin-bottom: 35px;
}

#map h2:before {
    width: 340px;
}

/*** ヘッダー設定 *********/

nav {
    display: flex;
    padding: 0 16px 0 23px;
    width: 100%;

    justify-content: space-between;
    align-items: baseline;
}

#sp-btn {
    display: none;
}

.navbar {
    display: inline-flex;
    align-items: center;
}

.navbar li:last-child {
    padding: 20px 0 22px 18px;
}

.navbar li a {
    padding: 19px 9px;
    color: #333;
    text-decoration: none;
    font-weight: 100;
    font-size: 1.7rem;
}

.navbar li a:hover {
    text-decoration: underline;
}

.navbar.open {
    display: block;
}

/*** ヘッドイメージ設定 *********/

#head-wrap {
    width: 100%;
    height: 674px;
}

#head-visual {
    position: relative;
    top: 156px;
    left: 38%;
    width: 592px;
    height: 416px;
    background: url(../images/headimg.jpg) no-repeat;
}

#head-visual p {
    display: block;
    padding-top: 250px;
    letter-spacing: 0;
    font-weight: bold;
    font-size: 1.8rem;
    line-height: 3rem;
}

/*** 福寿草のこだわり設定 *********/

#philosophy .mycontainer {
    display: flex;
    margin: 0;
    max-width: 1420px;

    justify-content: flex-end;
}

#philosophy .phl-left {
    padding-top: 143px;
    padding-left: 55px;
    width: 51%;
    background: url(../images/phl-l-bg.png) no-repeat;
    background-position: 0 82px;
}

#philosophy .phl-left h3 {
    margin-bottom: 24px;
    padding: 0;
    font-weight: lighter;
    font-size: 4.1rem;
}

#philosophy .phl-left p {
    margin-left: 42px;
    letter-spacing: 0.1rem;
    font-size: 1.4rem;
    font-family: serif;
    line-height: 2.6;
}

tt {
    width: 100%;
    font-family: serif !important;
}

p.name {
    margin-bottom: 50px;
    padding-bottom: 0;
    font-weight: bold;
    font-size: 1.8rem;
}

#philosophy .phl-right {
    max-width: 640px;
    width: 45%;
    height: 960px;
    background: url(../images/main-img01.jpg);
    background-position: 88% 0;
}

.phl-mimg {
    max-width: 450px;
    width: 100%;
}

#philosophy .mycontainer {
    max-width: 1440px;
}


/*** ギャラリー設定 *********/

#gallery {
    padding-top: 25px;
    padding-bottom: 100px;
}

.gllry-roop {
    display: flex;
    height: 491px;

    flex-wrap: nowrap;
}

.gllry {
    display: flex;

    flex-wrap: nowrap;
}

.gllry-box1 {
    display: none;
}

.gllry-box {
    display: flex;
    margin-right: 15px;
    width: 607px;

    justify-content: space-between;
    flex-wrap: nowrap;
}

.gllry-box a:hover {
    opacity: .7;
}

.gllry-l {
    width: 238px;
}

.gllry-l img:first-child {
    margin-bottom: 11px;
}

.gllry-r {
    width: 358px;
}

.gllry-r img:first-child {
    margin-bottom: 15px;
}


/*** マップ設定 *********/


#map .inner {
    width: 100%;
}

#gMap {
    height: 555px;
}

.map-adrs {
    position: relative;
    top: -192px;
    margin: 0 auto;
    margin-bottom: -46px;
    padding: 54px 91px 0 102px;
    max-width: 1107px;
    width: 100%;
    height: 582px;
    background: #fff;
    box-shadow: 0 0 25px #666;
    text-align: left;
}

adress,
.map-adrs h3,
.map-adrs span {
    font-style: normal;
}

.map-adrs h3 {
    margin-bottom: 62px;
    text-align: center;
    font-weight: lighter;
    font-size: 2.3rem;
}

.map-adrs div {
    margin-bottom: 33px;
}

.map-adrs span {
    display: inline-block;
    font-size: 1.8rem;
}

.col-1 {
    margin-right: 59px;
    width: 96px;
}

/*** フッター設定 *********/

footer {
    padding-top: 36px;
    height: 223px;
    background: #496a57;
    color: #fff;
    text-align: center;
}

.f-logo {
    margin-bottom: 21px;
}

.f-fb {
    margin-bottom: 24px;
}

p#cpyrt {
    margin-bottom: 34px;
    padding-bottom: inherit !important;
    color: #fff;
    letter-spacing: 0.1rem;
    font-weight: 100;
    font-size: 1.3rem;
    font-family: 'Noto Sans TC', sans-serif;
}


/*===========================
    タブレット設定
=============================*/

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

    /*** ヘッダー設定 *********/

    nav {
        display: inherit;
        padding-top: 8px;
    }

    #sp-btn {
        position: absolute;
        right: 50px;
        display: inline-block;
        font-weight: 400;
        font-size: 3.5rem;
    }

    #sp-btn a {
        color: #000;
    }

    .navbar {
        display: none;
        width: 100%;
    }

    .navbar li {
        width: 100% background: #fff;
        border-bottom: 1px solid #ccc;
    }

    .navbar li:last-child {
        display: none;
    }

    .navbar li a {
        display: block;
        padding: 19px 9px;
        font-weight: 100;
        font-size: 1.7rem;
    }

    .navbarli a:hover {
        background: #eee;
    }

    /*** ヘッドイメージ設定 *********/

    #head-visual {
        position: relative;
        left: 27%;
        width: 592px;
        height: 416px;
        background: url(../images/headimg.jpg) no-repeat;
    }

    /*** 福寿草のこだわり設定 *********/

    #philosophy .mycontainer {
        max-width: 1024px;
        width: 100%;
    }

    #philosophy .phl-left {
        margin-left: 20px;
        padding-top: 110px;
        padding-right: 10px;
        padding-left: 30px;
        width: calc(100% - 45% - 20px);
        background-position: 0 82px;
    }

    #philosophy .phl-left h3 {
        margin-bottom: 18px;
        padding: 0;
        font-weight: 400;
        font-size: 3rem;
    }

    #philosophy .phl-left p {
        margin-left: 30px;
        letter-spacing: 0.1rem;
        font-size: 1.2rem;
        font-family: serif;
        line-height: 2;
    }

    #philosophy .phl-left img {
        width: 85%;
    }

    #philosophy .phl-right {
        width: 45%;
        height: 737px;
        background-position: 82% 0;
        background-size: cover;
    }

    /*** マップ設定 *********/

    #gMap {
        height: 426px;
    }

    .map-adrs {
        position: relative;
        top: -147px;
        margin-bottom: -35px;
        padding: 41px 35px 0 50px;
        width: 76.8%;
        height: 347px;
    }

    .map-adrs h3 {
        margin-bottom: 48px;
        font-weight: lighter;
        font-size: 1.8rem;
    }

    .map-adrs div {
        margin-bottom: 25px;
    }

    .map-adrs span {
        font-size: 1.2rem;
    }

    .col-1 {
        margin-right: 25px;
        width: 74px;
    }

}


/*===========================
    モバイル設定
=============================*/

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

    /*** 各小見出し設定（左の線など） *********/
    h2 {
        position: relative;
        top: 40px;
        padding-right: 20px;
        font-size: 1.5rem;
    }

    h2:before {
        display: inline-block;
        margin-right: 12px;
        height: 1px;
        background: url(../images/line.png);
        background-position: left auto;
        content: '';
        vertical-align: middle;
    }

    #philosophy h2:before {
        width: 120px;
    }

    #gallery h2:before {
        width: 170px;
    }

    #gallery h2 {
        margin-bottom: 60px;
    }

    #map h2 {
        position: relative;
        top: 0;
        margin-bottom: 20px;
    }

    #map h2:before {
        width: 50px;
    }

    /*** ヘッダー設定 *********/

    header {
        padding: 5px 5px 0 5px;
    }

    nav {
        padding: 5px;
    }

    #sp-btn {
        position: absolute;
        right: 25px;
        font-weight: 400;
        font-size: 3rem;
    }

    #logo {
        width: 70px;
    }

    /*** ヘッドイメージ設定 *********/

    #head-wrap {
        width: 100%;
        height: 320px;
    }

    #head-visual {
        position: relative;
        top: 80px;
        width: 296px;
        height: 208px;
        background-size: 100% auto;
    }

    #head-visual p {
        position: relative;
        top: -120px;
        letter-spacing: 0;
        font-weight: bold;
        font-size: .9rem;
        line-height: 1.6rem;
    }

    /*** 福寿草のこだわり設定 *********/

    #philosophy .mycontainer {
        width: 100%;
    }

    #philosophy .phl-left {
        margin-left: 10px;
        padding-top: 70px;
        padding-right: 10px;
        padding-left: 10px;
        width: 70%;
        background: url(../images/phl-l-bg.png) no-repeat;
        background-position: 0 40px;
    }

    #philosophy .phl-left h3 {
        margin-bottom: 18px;
        letter-spacing: 0;
        font-weight: bold;
        font-size: 1.8rem;
    }

    #philosophy .phl-left p {
        margin-left: 10px;
        letter-spacing: 0.1rem;
        font-size: 1.2rem;
        font-family: serif;
        line-height: 2;
    }

    #philosophy .phl-right {
        width: 30%;
        height: 700px;
        background: url(../images/main-img01.jpg);
        background-position: 82% 0;
        background-size: cover;
    }

    /*** マップ設定 *********/

    #gMap {
        height: 400px;
    }

    .sp-only {
        display: block;
    }

    .map-adrs {
        position: relative;
        top: inherit;
        margin-bottom: 0;
        padding: 35px 5px 30px 10px;
        width: 100%;
        height: auto;
        box-shadow: none;
    }

    .map-adrs h3 {
        margin-bottom: 30px;
        font-weight: lighter;
        font-size: 1.8rem;
    }

    .map-adrs div {
        display: flex;
        margin-bottom: 20px;
    }

    .map-adrs span {
        vertical-align: top;
        font-size: 1.2rem;
    }

    .col-1 {
        margin-right: 0;
        width: 55px;
        font-weight: bold;
    }

    /*** フッター設定 *********/

    footer {
        padding-top: 36px;
        background: #496a57;
        color: #fff;
        text-align: center;
    }

    .f-logo {
        margin-bottom: 15px;
        width: 100px;
    }

    .f-fb {
        margin-bottom: 18px;
    }

    p#cpyrt {
        margin-bottom: 10px;
        letter-spacing: 0;
        font-size: 1.1rem;
    }


}
