@charset "utf-8";

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
figcaption,
figure,
section,
footer,
header,
main,
hgroup,
menu,
nav,
summary {
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    outline: 0;
    font-size: 1em;
    box-sizing: border-box
}

html {
    font-size: 62.5%
}

@media all and (min-width:897px) and (max-width:1100px) {
    html {
        font-size: calc(1000vw / 1100)
    }
}

body,
table,
input,
textarea,
select,
option {
    font-family: "Noto Sans JP", serif
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
main,
hgroup,
menu,
nav,
section,
summary {
    display: block
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

chrome_annotation {
    border: none !important
}

:focus {
    outline: 0
}

ins {
    text-decoration: none
}

del {
    text-decoration: line-through
}

img {
    vertical-align: top;
    max-width: 100%;
    height: auto
}

address {
    font-style: normal
}

a,
a:link {
    color: #000;
    text-decoration: none;
    transition: 0.3s
}

a:visited {
    color: #000
}

a:hover {
    color: #000
}

a:active {
    color: #000
}

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

.flex,
.flexA,
.flexB,
.flexC {
    display: flex;
    flex-wrap: wrap
}

.flexA {
    justify-content: space-around
}

.flexB {
    justify-content: space-between
}

.flexC {
    justify-content: center;
    gap: 3.2rem;
}

.serif {
    font-weight: 700;
    font-family: "Noto Serif JP", serif
}

body {
    color: #000;
    font-size: 1.8rem;
    line-height: 1.6;
    font-weight: 400;
    text-size-adjust: none;
    -webkit-text-size-adjust: none;
    background-color: #FFF
}

.fixed {
    position: fixed;
    width: 100%;
    height: 100%
}

#container {
    position: relative;
    text-align: left
}

a[href^="tel:"] {
    cursor: default;
    pointer-events: none
}

@media all and (min-width:897px) {
    .sp {
        display: none !important
    }
}

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

    a:hover,
    a:hover img {
        opacity: 1 !important
    }
}

#gFooter {
    padding: 4rem 2rem 9.1rem;
    color: #FFF;
    text-align: center;
    background-color: #2A2110
}

#gFooter .fBox {
    max-width: 102.4rem;
    margin: 0 auto
}

#gFooter .fLogo {
    margin: 0 auto 2.5rem;
    width: 22.1rem
}

#gFooter .name {
    margin-bottom: 0.1rem;
    font-weight: 500;
    font-size: 1.6rem
}

#gFooter .add {
    margin-bottom: 2.3rem;
    font-size: 1.4rem;
    line-height: 1.8
}

#gFooter .add a {
    color: #FFF
}

#gFooter address {
    padding-top: 2.3rem;
    font-size: 1.2rem;
    font-weight: 300;
    border-top: 0.1rem solid rgba(255, 255, 255, 0.3)
}

.comAmazonBox {
    padding-bottom: 1.2rem;
    background-color: #F5B467
}

.comAmazonBox .midImg {
    margin: 0 auto;
    max-width: 1000px;
}

.comVisitBox {
    padding: 5.8rem 0 6rem;
    position: relative;
    background: url(../img/index/visit_bg.webp) no-repeat left top / 100%
}

.comVisitBox::before {
    width: 44rem;
    height: 24rem;
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    background: url(../img/index/visit_img01.webp) no-repeat left top;
    background-size: 100%
}

.comVisitBox::after {
    width: 44rem;
    height: 24rem;
    position: absolute;
    top: 0;
    right: 0;
    content: "";
    background: url(../img/index/visit_img02.webp) no-repeat left top;
    background-size: 100%
}

.comVisitBox .title {
    margin-bottom: 2.3rem;
    color: #306437;
    text-align: center;
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1.68;
    letter-spacing: 0.144rem
}

.comVisitBox .title span {
    display: block;
    font-size: 2rem;
    letter-spacing: 0
}

.content {
    margin: 0 auto;
    max-width: 102.5rem
}

.headLine01 {
    margin: 0 0 -3.4rem -1rem;
    z-index: 3;
    top: 4.8rem;
    left: 0;
    font-size: 20rem;
    font-weight: 400;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: rl;
    /* opacity: 0.5; */
    /* background: linear-gradient(to right, #306437, #a5b9a7); */
    background: linear-gradient(to right, #306437, rgba(48, 100, 55, 0));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    mix-blend-mode: multiply
}

/* @media all and (min-width:897px) and (max-width:1400px) {
    .headLine01 {
        font-size: 11vw
    }
    .caption .caption_jp{
        margin-left: 10rem;
    }
} */

.comInnerBox {
    margin-bottom: 3.9rem
}

.comInnerBox h3 {
    padding: 0 0.7rem 0 0.9rem;
    margin-bottom: 1.2rem;
    width: fit-content;
    height: 3.1rem;
    color: #FFF;
    font-weight: 500;
    /* background: linear-gradient(to right, #306437, #fff); */
    background: linear-gradient(to right, #306437, rgba(48, 100, 55, 0));
}

.comInnerBox .ttl {
    color: #223040;
    font-size: 3.2rem;
    font-weight: 500;
    line-height: 1.8;
}

.comBtn {
    margin: 0 auto;
    width: 32rem;
    border-radius: 10rem;
    background-color: #298F45
}

.comBtn a {
    padding: 0.4rem;
    min-height: 6rem;
    display: block
}

.comBtn span {
    width: 31.2rem;
    min-height: 5.2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #FFF;
    font-weight: 700;
    border-radius: 10rem;
    border: 0.1rem solid #FFF;
    background: url(../img/common/icon03.webp) no-repeat right 2rem center / 1.6rem
}

.comBtn a:hover {
    opacity: 0.7
}

.caption{
    max-width: 1440px;
    margin: 0 auto;
}
.caption .caption_jp{
    margin-left: 22rem;
    overflow: hidden;
}
@media all and (min-width:897px) and (max-width:1400px) {
    .headLine01 {
        font-size: 11vw
    }
    .caption .caption_jp{
        margin-left: 10rem;
    }
}

.caption .caption_jp h3 {
    width: calc(100vw - 22rem);
}

.slideBox .foo {
    margin: 0 auto;
    width: 100%
}

.slideBox .foo .slick-slide>div {
    margin: 0 1.6rem;
    transform-origin: right bottom;
    transition: all 0.5s
}

.slideBox .foo .slick-slide.slick-center>div {
    transform: scale(1) !important
}

.slideBox .foo .slick-slide.slick-center+.slick-slide>div {
    transform-origin: left bottom
}

.slideBox .foo .slick-track {
    display: flex;
    align-items: flex-end
}

.slideBox .foo .slick-slide li {
    opacity: 0.4
}

.slideBox .foo .slick-slide.slick-center li {
    opacity: 1
}

.slideBox .foo .slick-slide img {
    width: 100%
}

.slick-dots {
    margin: 0 auto;
    position: absolute;
    left: 50%;
    bottom: -6.7rem;
    transform: translateX(-50%);
    width: fit-content;
    text-align: center
}

.slick-dots li {
    position: relative;
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin: 0 0.6rem;
    padding: 0;
    cursor: pointer;
    background-color: #DEE0E2;
    border-radius: 100%
}

.slick-dots li button {
    display: none
}

.slick-dots li.slick-active {
    background-color: #223040
}

.fixedBox {
    min-height: 116px;
    padding: 3.2rem 0;
    width: 100%;
    position: fixed;
    bottom: 0;
    z-index: 9;
    opacity: 0;
    visibility: hidden;
    transition: 0.4s;
}
.fixedBox.active {
    opacity: 1;
    visibility: visible;
}

.fixedBox .comBtn {
    width: 49.6rem;
    background-color: #298F45;
}

.fixedBox .comBtn a {
    min-height: 5.2rem
}

.fixedBox .comBtn span {
    width: 48.8rem;
    min-height: 4.4rem;
    color: #fff;
    font-size: 2rem;
    border-color: #fff;
    background-image: url(../img/common/icon09.webp)
}

.fixedBox .innerBox {
    position: relative
}

.fixedBox .innerBox .text {
    padding: 0.1rem 1.4rem 0.1rem 2rem;
    text-align: center;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 900;
    position: absolute;
    top: -2rem;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 10rem;
    background-color: #298F45
}

.fixedBox .innerBox .text::after {
    width: 0.8rem;
    height: 0.6rem;
    position: absolute;
    bottom: -0.6rem;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    background: url(../img/common/icon10.webp) no-repeat top left;
    background-size: 100%
}

.fixedBox .innerBox .num {
    margin-left: 0.5rem;
    display: inline-block;
    font-size: 1.6rem
}

.fixedBox .innerBox .txt {
    font-size: 1.2rem
}

.mainVisual {
    position: relative;
    height: auto !important;
}
.mainVisual .img img {
    width: 100%;
}
.mainVisual .container {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: calc(208vw / 1440 * 100);
}
.mainVisual .container .logo {
    width: calc(117vw / 1440 * 100);
    margin: 0 0 calc(40vw / 1440 * 100);
}
.mainVisual .container .ttl {
    font-family: "Noto Serif JP", serif;
    color: #fff;
    font-size: calc(48vw / 1440 * 100);
    font-weight: 600;
    line-height: 1.5;
    margin: 0 0 calc(95vw / 1440 * 100);
}
.mainVisual .container .txt {
    width: calc(320vw / 1440 * 100);
    margin: 0 0 calc(24vw / 1440 * 100);
}
.mainVisual .container .btn {
    background: #298F45;
    width: calc(320vw / 1440 * 100);
    padding: calc(4vw / 1440 * 100);
    filter: drop-shadow(0 0.4rem 1.6rem rgba(93, 68, 54, 0.2));
    border-radius: 9999rem;
    transition: 0.4s;
}
.mainVisual .container .btn:hover {
    opacity: 0.7;
}
.mainVisual .container .btn a {
    border: calc(1vw / 1440 * 100) solid #fff;
    border-radius: 9999rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(52vw / 1440 * 100);
    padding: 0 0 calc(2vw / 1440 * 100);
    position: relative;
    background: url(../img/common/icon03.webp) no-repeat right calc(20vw / 1440 * 100) center / calc(16vw / 1440 * 100);
}
.mainVisual .container .btn a span {
    color: #fff;
    font-size: calc(20vw / 1440 * 100);
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1;
}

#main .trouble {
    padding: 10.2rem 0 36.4rem;
    position: relative;
    background: linear-gradient(180deg, #EFECEB 0%, #FFF 55%)
}

#main .trouble::after {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    left: 0;
    bottom: 0;
    content: "";
    background: url(../img/index/trouble_bg.webp) no-repeat left bottom;
    background-size: 100%;
    pointer-events: none
}

#main .trouble .content {
    position: relative;
    z-index: 2
}

#main .trouble h2 {
    margin: 0 auto 6.2rem;
    width: fit-content;
    color: #223040;
    text-align: center;
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1.7;
    border-bottom: 0.1rem solid #000
}

#main .trouble .textList {
    margin: -2rem 0 18rem
}

#main .trouble .textList li {
    margin-top: 2rem;
    width: 32rem;
    height: 20.8rem;
    line-height: 1.8;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    text-align: center;
    background-color: #FFF
}

#main .trouble .textList li:not(:nth-child(3n)) {
    margin-right: 3.2rem
}

#main .trouble .textList .icon {
    width: 4rem;
    position: absolute;
    top: -1.2rem;
    left: -1.2rem
}

#main .trouble .text {
    text-align: center;
    color: #306437;
    font-size: 3.6rem;
    font-weight: 600;
    line-height: 1.8
}

#main .trouble .text span {
    font-size: 2.8rem
}

#main .design {
    padding: 9.8rem 0 0;
    position: relative;
    border-bottom: 0.1rem solid #9FA5B6
}

#main .design .comInnerBox {
    margin-left: calc(100%-102.5rem)
}

#main .design .imgBox {
    position: relative
}

#main .design .imgBox:not(:last-of-type) {
    margin-bottom: 25.4rem
}

#main .design .imgBox02,
#main .design .imgBox03 {
    margin-bottom: 21.3rem !important
}

#main .design .imgBox:nth-of-type(2n) {
    justify-content: right
}

#main .design .imgBox .photoBox {
    max-width: 84.8rem;
    position: relative;
    z-index: 2
}

#main .design .imgBox:nth-of-type(2n) .photoBox {
    text-align: right
}

#main .design .imgBox .photoBox img {
    box-shadow: 0 0.4rem 2.4rem 0 rgba(93, 68, 54, 0.20)
}

#main .design .imgBox .photoBox::after {
    position: absolute;
    z-index: -1;
    content: "";
    bottom: -7.6rem;
    background: url(../img/index/design_bg01.webp) no-repeat left top;
    background-size: 100%
}

#main .design .imgBox01 .photoBox::after {
    width: 76rem;
    height: 45.6rem;
    right: -8.8rem
}

#main .design .imgBox02 .photoBox::after,
#main .design .imgBox03 .photoBox::after {
    width: 84.8rem;
    height: 41.6rem;
    left: -3.2rem;
    bottom: -1.6rem;
    background-image: url(../img/index/design_bg02.webp)
}

#main .design .imgBox03 .photoBox::after {
    left: auto;
    right: -3.2rem;
    background-image: url(../img/index/design_bg03.webp)
}

#main .design .imgBox04 .photoBox::after {
    width: 76rem;
    height: 45.6rem;
    left: -8.8rem;
    background-image: url(../img/index/design_bg04.webp)
}

#main .design .imgBox .textBox {
    position: absolute;
    z-index: 3;
    top: 46rem
}

#main .design .imgBox:nth-of-type(2n) .textBox {
    left: 0
}

#main .design .imgBox:nth-of-type(2n) .textBox {
    text-align: right;
    right: 0
}

#main .design .imgBox .textBox h4 {
    margin-bottom: 0.8rem
}

#main .design .imgBox .textBox h4 img {
    box-shadow: 0 0.4rem 1.6rem 0 rgba(93, 68, 54, 0.20)
}

#main .design .imgBox .textBox .ttl {
    margin-bottom: 1.6rem;
    color: #223040;
    font-size: 1.4rem;
    line-height: 2
}

#main .design .imgBox01 .textBox .ttl {
    margin-bottom: 2.8rem
}

#main .floor {
    padding: 10rem 0 5.9rem;
    position: relative;
    border-bottom: 0.1rem solid #9FA5B6
}

#main .floor .content {
    max-width: 84.8rem
}

#main .floor .photoBox {
    margin-bottom: 4rem
}

#main .floor .photoBox01 {
    box-shadow: 0 0.4rem 3.2rem 0 rgba(93, 68, 54, 0.20)
}

#main .floor .photoBox02 {
    margin-left: -8.8rem;
    position: relative
}

#main .floor .photoBox02 .txt {
    padding: 3.2rem 4rem;
    position: absolute;
    top: 50%;
    right: 7.8rem;
    transform: translateY(-15%);
    line-height: 1.8;
    background-color: #FFF
}

#main .floor .photoBox03 {
    margin-right: -8.4rem;
    text-align: right
}

#main .hiraya {
    padding: 10rem 0 46.6rem;
    position: relative;
    border-bottom: 0.1rem solid #fff
}

#main .hiraya::after {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    left: 0;
    bottom: 0;
    content: "";
    background: url(../img/index/hiraya_bg.webp) no-repeat left bottom;
    background-size: 100%;
    pointer-events: none
}

#main .hiraya .content {
    max-width: 84.8rem
}

#main .hiraya .comInnerBox .ttl {
    margin-bottom: 1.2rem
}

#main .hiraya .slideBox {
    margin-bottom: 18.2rem;
    position: relative;
    z-index: 2
}

#main .hiraya .slideBox .slick-list {
    height: 48rem
}

#main .hiraya .slideBox .foo .slick-slide>div {
    width: 84.8rem;
    transform: scale(0.8)
}

#main .hiraya .text {
    text-align: center;
    color: #306437;
    font-size: 3.6rem;
    font-weight: 600;
    line-height: 1.8;
    position: relative;
    z-index: 2
}

#main .home {
    padding: 12rem 0 20rem;
    position: relative;
    background: url(../img/index/home_bg02.webp) no-repeat left top / cover
}

#main .home::after {
    position: absolute;
    z-index: 1;
    width: 100%;
    height: 100%;
    left: 0;
    bottom: 0;
    content: "";
    background: url(../img/index/home_bg01.webp) no-repeat left bottom;
    background-size: 100%;
    pointer-events: none
}

#main .home .content {
    position: relative;
    z-index: 2
}

#main .home h2 {
    margin: 0 auto 6rem;
    width: 56rem;
    position: relative
}

#main .home h2::after {
    width: 20rem;
    height: 6.4rem;
    position: absolute;
    top: -6rem;
    left: -14rem;
    content: "";
    background: url(../img/index/home_img01.webp) no-repeat left top;
    background-size: 100%
}

#main .home .midImg {
    padding: 4rem 4.6rem;
    margin: 0 auto 3.2rem;
    width: fit-content;
    background-color: rgba(255, 255, 255, 0.8)
}

#main .home .text {
    margin-bottom: 3.2rem;
    text-align: center
}

#main .home .line {
    margin: 0 auto 3.2rem;
    width: 2.4rem;
    height: 0.1rem;
    background-color: #306437
}

#main .home h3 {
    margin-bottom: 4rem;
    color: #306437;
    text-align: center;
    font-size: 3.2rem;
    font-weight: 600
}

#main .home .photoList {
    margin: 0 -1.5rem 17.1rem -0.4rem
}

#main .home .photoList li {
    width: 24rem
}

#main .home .photoList li:not(:nth-of-type(4n)) {
    margin-right: 2.8rem
}

#main .home .subText {
    color: #FFF;
    text-align: center;
    font-size: 3.6rem;
    font-weight: 700;
    line-height: 1.8
}

#main .reason {
    padding: 10rem 0 6rem
}

#main .reason .content {
    max-width: 67.2rem
}

#main .reason h2 {
    height: fit-content;
    padding: 1.5rem 0.9rem 0.8rem 0.8rem;
    position: relative;
    color: #FFF;
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: 0.7rem;
    background-color: #223040;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl
}

#main .reason h2::after {
    width: 0.1rem;
    height: 11.1rem;
    position: absolute;
    background-color: #223040;
    left: 50%;
    top: 17.3rem;
    transform: translateX(-50%);
    content: ""
}

#main .reason .textBox {
    width: 58.4rem
}

#main .reason .ttl {
    margin-bottom: 4.8rem;
    color: #223040;
    font-size: 4.7rem;
    font-weight: 700
}

#main .reason .txt {
    color: #000
}

#main .reward {
    padding: 2.8rem 0 3.7rem;
    background: url(../img/index/reward_bg.webp) no-repeat center top /cover
}

#main .reward .photoBox {
    margin: 0 auto;
    width: 73.6rem
}

#main .promise {
    padding: 6rem 0 49.2rem;
    position: relative;
    z-index: 1;
    border-bottom: 0.1rem solid #fff;
    background: #F9F7E6 url(../img/index/promise_bg.webp) no-repeat bottom center / 100% auto
}

#main .promise h2 {
    margin-bottom: 2.8rem;
    text-align: center;
    color: #B8912C;
    font-size: 3.2rem;
    font-weight: 700
}

#main .promise .photoBox {
    margin: 0 auto;
    width: 67.2rem
}

#main .tour {
    padding: 10.2rem 0 3rem;
    border-top: 0.1rem solid #BDC1C6
}

#main .tour h2 {
    margin-bottom: 5.8rem;
    position: relative;
    text-align: center;
    color: #223040;
    font-size: 4.8rem;
    font-weight: 700;
    line-height: 1.5
}

#main .tour h2::before {
    width: 17.2rem;
    height: 17.5rem;
    position: absolute;
    top: 50%;
    left: -4.3rem;
    content: "";
    transform: translateY(-53%);
    background: url(../img/index/tour_img01.webp) no-repeat top left;
    background-size: 100%
}

#main .tour h2::after {
    width: 7.8rem;
    height: 12.8rem;
    position: absolute;
    bottom: 0;
    right: 5.7rem;
    content: "";
    transform: translateY(71%);
    background: url(../img/index/tour_img02.webp) no-repeat top left;
    background-size: 100%
}

#main .tour .text {
    margin-bottom: 4.7rem;
    text-align: center
}

#main .tour .text span {
    margin-bottom: 2.9rem;
    display: block
}

#main .tour .bgBox {
    margin: 0 auto 2.8rem;
    padding: 2.4rem 4rem 3rem;
    width: 67.2rem;
    border-radius: 0.4rem;
    background-color: #FAF2E6
}

#main .tour .bgBox h3 {
    margin-bottom: 1.7rem;
    padding: 0.4rem 1rem 0.1rem;
    text-align: center;
    color: #fff;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.7;
    background-color: #306437
}

#main .tour .bgBox .textList {
    margin: -1.5rem 1.4rem 0
}

#main .tour .bgBox .textList li {
    margin-top: 1.5rem;
    padding: 0.5rem 0 0 4.5rem;
    font-size: 2rem;
    background: url(../img/common/icon04.webp) no-repeat top 0.2rem left / 3.2rem
}

#main .tour .bgBox .textList li:nth-of-type(2n-1) {
    width: 25rem
}

#main .tour .bgBox .textList li:nth-of-type(2n) {
    margin-right: -0.8rem;
    width: 29rem
}

#main .tour .subText {
    margin-bottom: 9.5rem;
    text-align: center;
    color: #2A2110;
    font-size: 2.4rem;
    font-weight: 700
}

#main .tour .content>h3 {
    margin-bottom: 8rem;
    padding: 2.8rem 0 3.8rem;
    position: relative;
    text-align: center;
    color: #306437;
    font-size: 3.2rem;
    font-weight: 700;
    line-height: 1.05;
    border-top: 0.2rem solid #306437;
    border-bottom: 0.2rem solid #306437
}

#main .tour .content>h3::after {
    width: 2.1rem;
    height: 1.5rem;
    position: absolute;
    bottom: -1.4rem;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    background: url(../img/common/icon05.webp) no-repeat top left;
    background-size: 100%
}

#main .tour .content>h3 .txt {
    margin-left: 0.6rem;
    display: inline-block;
    font-size: 4rem
}

#main .tour .content>h3 .num {
    margin-left: 0.6rem;
    display: inline-block;
    font-size: 6rem
}

#main .tour .flowList {
    margin-bottom: 7.8rem
}

#main .tour .flowList li {
    width: 32rem
}

#main .tour .flowList li:not(:nth-of-type(3n)) {
    margin-right: 3.2rem;
    position: relative
}

#main .tour .flowList .photoBox {
    margin-bottom: 2rem;
    width: 32rem
}

#main .tour .flowList .textBox {
    padding: 1.6rem 1rem;
    min-height: 11rem;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: 1.6rem;
    background-color: #F3F3F3
}

#main .tour .flowList li:not(:nth-of-type(3n)) .textBox::after {
    width: 4rem;
    height: 1.2rem;
    position: absolute;
    z-index: 2;
    top: 50%;
    right: -3.7rem;
    transform: translateY(-50%);
    content: "";
    background: url(../img/common/icon06.webp) no-repeat top left;
    background-size: 100%
}

#main .tour .subImg {
    margin: 0 auto;
    width: 45rem
}

#main .exhibition h2 {
    padding: 2.7rem 1rem;
    text-align: center;
    color: #fff;
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: 0.12rem;
    border-top: 0.1rem solid #fff;
    background-color: #5D4436;
    cursor: pointer
}

#main .exhibition h2 span {
    font-size: 3.6rem;
    position: relative;
}

#main .exhibition h2 .kagoshima {
    left: 1.8rem;
}

#main .exhibition h2 span small {
    font-size: 2.4rem;
}

#main .exhibition small::after {
    position: absolute;
    width: 1.6rem;
    height: 0.9rem;
    top: 50%;
    left: 22rem;
    transform: translateY(-50%);
    content: "";
    background: url(../img/common/icon07.webp) no-repeat center right;
    background-size: 100%
}

#main .exhibition h2.on {
    background-color: rgba(93, 68, 54, 1)
}

#main .exhibition h2.on span::after {
    background-image: url(../img/common/icon08.webp)
}

#main .exhibition .subBox {
    display: none
}

#main .exhibition .innerBox {
    padding: 6rem 0
}

#main .exhibition .innerBox01 {
    border-top: 0.1rem solid #5D4436
}

#main .exhibition .slideBox {
    margin-bottom: 10rem
}

#main .exhibition .slideBox .foo .slick-slide>div {
    width: 67.2rem;
    transform: scale(0.74)
}

#main .exhibition .slick-dots {
    bottom: -6rem
}

#main .exhibition h3 {
    margin-bottom: 0.3rem;
    text-align: center;
    color: #5D4436;
    font-size: 3.2rem;
    font-weight: 700
}

#main .exhibition .ttl {
    margin-bottom: 2rem;
    text-align: center
}

#main .exhibition .add {
    margin: 0 auto 3.2rem;
    padding: 2rem 1rem;
    width: 49.6rem;
    color: #4C4C4C;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 300;
    line-height: 1.4;
    background-color: #F3F3F3
}

#main .exhibition .comBtn {
    box-shadow: 0 0.4rem 1.6rem 0 rgba(93, 68, 54, 0.20);
    border-radius: 0.4rem;
    width: 32rem;
    height: 4.8rem;
}

#main .exhibition .comBtn span {
    position: relative;
    border: none;
    width: 32rem;
    height: 4.8rem;
    top: -0.6rem;
    right: 0.5rem;
    background:url(../img/common/icon11.webp) no-repeat right 1.4rem center /2.4rem;
}

#main .comVisitBox01 {
    padding-bottom: 7.8rem;
    border-top: 0.1rem solid #fff;
    background: #FAF2E6
}

#main .comVisitBox01 .comBtn {
    margin-bottom: 8rem
}

#main .comVisitBox01 h3 {
    margin-bottom: 4rem;
    text-align: center;
    font-size: 2rem;
    font-weight: 500
}

#main .comVisitBox01 .textBox {
    padding-top: 8rem;
    border-top: 0.1rem solid #000
}

#main .comVisitBox01 .textList {
    margin-top: -0.85rem;
    width: 31.5rem;
    font-size: 1.6rem;
    font-weight: 300
}

#main .comVisitBox01 .textList>li {
    margin-top: 0.85rem;
    padding-left: 2rem;
    text-indent: -2rem
}

#main .comVisitBox01 .textList01 {
    width: 41rem
}

#main .comVisitBox01 .textList .li01 {
    padding-left: 0;
    text-indent: 0
}

#main .comVisitBox01 .subList {
    margin-left: 2.6rem
}

#main .comVisitBox01 .subList li {
    position: relative;
    line-height: 1.62
}

#main .comVisitBox01 .subList li::before {
    width: 0.4rem;
    height: 0.4rem;
    position: absolute;
    top: 1rem;
    left: -1.2rem;
    content: "";
    border-radius: 50%;
    background-color: #000
}

#main .lastly {
    text-align: center;
    font-size: 1.8rem;
    padding: 8rem 0;
    background: url(../img/index/bg_lastly.webp) no-repeat center bottom / cover !important;
}

#main .lastly .inner_Box {
    margin: 0 auto;
    max-width: 102.4rem;
    background: #fff;
    text-align: center;
    font-size: 1.8rem;
    padding: 6rem 0 2rem;
}

#main .lastly .ttl {
    color: #306437;
    font-size: 4.8rem;
    border-bottom: 1px solid #306437;
    padding-bottom: 4rem;
    margin: 0 10rem 4.6rem;
}

#main .lastly .txt {
    line-height: 160%;
    padding: 0 0 4rem;
}

    #main .lastly .txt span {
        color: #306437;
        font-weight: 700;
    }
#main .faq .ttl {
    text-align: center;
    font-size: 4.8rem;
    font-weight: bold;
}

@media all and (min-width:897px) and (max-width:1100px) {
    #main .home .photoList li {
        width: 22%
    }
}

/* .pad .mainVisual {
    padding-top: 2rem;
    margin-bottom: 0 !important;
    height: auto !important;
    min-height: inherit !important;
    background: url(../img/index/main_bg.webp) no-repeat center bottom / cover !important;
    align-items: flex-end !important
}

.pad .mainVisual .photo {
    max-width: 144rem !important
}

.pad .mainVisual img.pc {
    display: block !important
}

.pad .mainVisual img.sp {
    display: none !important
} */



.faq {
    border-top: 1px solid rgba(34,48,64, 0.3);
    padding: 10rem 0;
}

.faq__list {
    max-width: 67.2rem;
    margin: 0 auto;
    padding: 4.6rem 0 0;
}

.faq__item {
    border-bottom: 1px solid #306437;
}
.faq__item:first-child {
    border-top: 1px solid #306437;
}

.faq__item__ttl {
    position: relative;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.04em;
    padding: 2.5rem 4rem 2.5rem 4.8rem;
    cursor: pointer;
}

.faq__item__ttl::before {
    content: "Q";
    position: absolute;
    top: 2rem;
    left: 0;
    color: #fff;
    font-family: "Noto Serif JP", serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    min-width: 4rem;
    min-height: 4rem;
    background: #306437;
    border: 1px solid #306437;
    border-radius: 99rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.2rem 0rem 0.5rem;
    box-sizing: border-box;
}

.faq__item__ttl::after {
    content: "";
    position: absolute;
    top: 3.3rem;
    transform: rotate(-135deg);
    right: 1.5rem;
    padding: 0.4rem;
    border-top: 2px solid #306437;
    border-left: 2px solid #306437;
    transition: 0.4s;
}

.faq__item__ttl.active::after {
    top: 3.7rem;
    transform: rotate(45deg);
}

.faq__item__des {
    display: none;
}

.faq__item:first-child .faq__item__des {
    display: block;
}

.faq__item__txt {
    position: relative;
    /* padding: 18px 30px 18px 70px; */
    padding: 2.5rem 0 2.5rem 4.8rem;
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0.04em;
    border-top: 1px solid rgba(48, 100, 55, 0.3);
}
.faq__item__txt .note {
    display: block;
    font-size: 1.2rem;
    padding-top: 2rem;
}

.faq__item__txt::before {
    content: "A";
    position: absolute;
    top: 2rem;
    left: 0;
    color: #306437;
    font-family: "Noto Serif JP", serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    min-width: 4rem;
    min-height: 4rem;
    background: #fff;
    border: 1px solid #306437;
    border-radius: 99rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.2rem 0rem 0.5rem;
    box-sizing: border-box;
}

.company {
    background: #FAF2E6;

}

.company .content {
    padding: 8rem 2.5rem;
    font-weight: 300;
}

.company .content h3 {
    text-align: center;
    font-size: 2rem;
    font-weight: 500;
    padding: 0 0 4rem;
}

.company .content ul {
    line-height: 200%;
}

.company .content ul .subList {
    list-style-type: disc;
    line-height: 160%;
}

.company .content ul .subList li {
    position: relative;
    left: 2rem;
}