@import url(css/normalize.css);
@import url(css/set.css);
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,900");
@import url("https://fonts.googleapis.com/css?family=M+PLUS+1p:100");
@import url(css/lity.min.css);

html {
    font-size: 24px
}

@media (min-width: 1000px) {
    html {
        font-size: 28px
    }
}

body {
    font-size: .583rem;
    line-height: 1rem
}

html {
    box-sizing: border-box
}

*,
*:before,
*:after {
    box-sizing: inherit
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
dl,
figure,
figcaption,
blockquote,
pre,
table,
caption,
hr,
form,
fieldset {
    margin: 1rem 0 0
}

ul,
ol {
    padding-left: 1.166rem
}

body {
    margin: 0 auto;
    padding: 0 .583rem;
    font-weight: 400;
    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
    font-kerning: normal
}

h1 {
    margin: 1rem 0 0;
    font-size: .95rem;
    line-height: 1.05rem
}

h2 {
    margin: 1rem 0 0;
    font-size: .8rem;
    line-height: .9rem
}

h3 {
    margin: 1rem 0 0;
    font-size: .75rem;
    line-height: .85rem
}

h4 {
    margin: 1rem 0 0;
    font-size: .7rem;
    line-height: .8rem
}

h5 {
    margin: 1rem 0 0;
    font-size: .65rem;
    line-height: .7rem
}

h6 {
    margin: 1rem 0 0;
    font-size: .6rem;
    line-height: .7rem
}

p {
    margin: .5rem 0 0
}

@media screen and (max-width: 640px) {
    h1 {
        margin: 1rem 0 0;
        font-size: .9rem;
        line-height: 1.2rem
    }

    h2 {
        margin: 1rem 0 0;
        font-size: .8rem;
        line-height: 1rem
    }

    h3 {
        margin: 1rem 0 0;
        font-size: .7rem;
        line-height: .9rem
    }

    h4 {
        margin: 1rem 0 0;
        font-size: .7rem;
        line-height: .8rem
    }

    h5 {
        margin: 1rem 0 0;
        font-size: .7rem;
        line-height: .7rem
    }

    h6 {
        margin: 1rem 0 0;
        font-size: .7rem;
        line-height: .7rem
    }
}

@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 100
}

@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 200
}

@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 300
}

@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Medium");
    font-weight: 400
}

@font-face {
    font-family: "Yu Gothic";
    src: local("Yu Gothic Bold");
    font-weight: bold
}

@font-face {
    font-family: 'icomoon';
    src: url("../minnanoseikotu/img/fonts/icomoon.eot?8k7db6");
    src: url("../minnanoseikotu/img/fonts/icomoon.eot?8k7db6#iefix") format("embedded-opentype"), url("../minnanoseikotu/img/fonts/icomoon.ttf?8k7db6") format("truetype"), url("../minnanoseikotu/img/fonts/icomoon.woff?8k7db6") format("woff"), url("../minnanoseikotu/img/fonts/icomoon.svg?8k7db6#icomoon") format("svg");
    font-weight: normal;
    font-style: normal;
    font-display: block
}

[class^="icon-"],
[class*=" icon-"] {
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.icon-line:before {
    content: "\e900"
}

html {
    box-sizing: border-box
}

@media all and (-ms-high-contrast: none) {
    html {
        font-family: Verdana, Meiryo, sans-serif
    }
}

@media all and (-ms-high-contrast: active) {
    html {
        font-family: Verdana, Meiryo, sans-serif
    }
}

body {
    margin: 0;
    padding: 0;
    font-family: -apple-system, "Helvetica Neue", "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, sans-serif;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 300;
    color: #0a0a0a;
    -ms-word-break: break-all;
    word-break: break-all
}

@media screen and (max-width: 768px) {
    body {
        font-weight: normal
    }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
    body {
        font-weight: 300
    }
}

a {
    color: #1a230d;
    text-decoration: none;
    -webkit-transition: all .5s;
    transition: all .5s
}

a::before,
a::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

a:hover,
a:focus,
a:active {
    color: #6c9435;
    outline: none;
    text-decoration: none;
    -webkit-transition: all .5s;
    transition: all .5s
}

a:hover::before,
a:hover::after,
a:focus::before,
a:focus::after,
a:active::before,
a:active::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

a.block-link {
    display: block;
    position: static;
    z-index: 0;
    color: #0a0a0a
}

a.block-link:hover {
    color: #516e28;
    cursor: pointer;
    opacity: .70;
    -webkit-transition: all .5s;
    transition: all .5s
}

a.block-link:hover::before,
a.block-link:hover::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

img.brightness:hover {
    filter: brightness(1.2);
    -webkit-transition: all .5s;
    transition: all .5s
}

img.brightness:hover::before,
img.brightness:hover::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

.common-btn {
    clear: both;
    background: none;
    display: block;
    margin: 2rem auto 0;
    width: 200px;
    text-align: center;
    color: #040502;
    line-height: 1;
    font-weight: normal;
    background: #3c2310;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    -webkit-box-shadow: 0 4px 16px 4px rgba(125, 170, 62, 0.08);
    box-shadow: 0 4px 16px 4px rgba(125, 170, 62, 0.08)
}

@media screen and (max-width: 768px) {
    .common-btn {
        margin-top: 1rem
    }
}

.common-btn a {
    display: block;
    padding: 0.5rem 0;
    position: relative;
    color: #fff;
    -webkit-transition: all .5s;
    transition: all .5s
}

.post-body .common-btn a {
    text-decoration: none
}

.common-btn a::before,
.common-btn a::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

.common-btn:hover {
    -webkit-transition: all .5s;
    transition: all .5s;
    background: #643a1b
}

.common-btn:hover::before,
.common-btn:hover::after {
    -webkit-transition: all .5s;
    transition: all .5s
}

.common-btn.white {
    border: 2px solid #fff
}

.common-btn.white a {
    color: #FFF;
    font-weight: normal
}

.common-btn.white a:after {
    color: #FFF
}

.common-btn.white:hover {
    background: rgba(4, 5, 2, 0.1)
}

@media screen and (max-width: 768px) {
    .pc-only {
        display: none !important
    }
}

@media screen and (max-width: 768px) {
    .tb-over {
        display: none !important
    }
}

@media screen and (min-width: 769px) {
    .sp-only {
        display: none !important
    }
}

@media screen and (max-width: 768px) {
    .tb-under {
        display: none !important
    }
}

.center {
    text-align: center
}

.right {
    float: right
}

.left {
    float: left
}

.red {
    color: #cf4444
}

.yellow {
    color: #e5d53c
}

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

img.right {
    margin: 0 0 1em 1em
}

@media screen and (max-width: 768px) {
    img.right {
        float: none;
        margin: 1em 0;
        width: 100%
    }
}

img.left {
    margin: 0 1em 1em 0
}

.clear {
    clear: both
}

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

.inner {
    margin: 0 auto;
    padding: 2rem 2rem 4rem;
    width: 1080px;
    overflow: hidden
}

@media screen and (max-width: 768px) {
    .inner {
        padding: 2rem 1rem;
        width: 100%
    }

    .common-lower .inner {
        padding: 1rem
    }
}

.index .container .inner {
    width: 100%;
    padding-bottom: 4rem
}

@media screen and (max-width: 768px) {
    .index .container .inner {
        padding-bottom: 2rem
    }
}

.m-0 {
    margin: 0 !important
}

.m-t-1 {
    margin-top: 1rem !important
}

.m-t-0 {
    margin-top: 0rem !important
}

.m-t-2 {
    margin-top: 2rem !important
}

.m-t-3 {
    margin-top: 3rem !important
}

.m-b-0 {
    margin-bottom: 0rem !important
}

.m-b-1 {
    margin-bottom: 1rem !important
}

.m-b-2 {
    margin-bottom: 2rem !important
}

.m-b-4 {
    margin-bottom: 4rem !important
}

.note {
    padding-left: 1em;
    text-indent: -1em
}

.t-shadow,
.feature .text {
    text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.8)
}

.t-shadow-black {
    text-shadow: 1px 1px 0 rgba(4, 5, 2, 0.3)
}

.img-hover {
    overflow: hidden;
    display: block
}

.img-hover img {
    transition-duration: 0.3s
}

.img-hover img:hover {
    transform: scale(1.05);
    transition-duration: 0.5s;
    opacity: .9
}

.object-fit-img {
    object-fit: cover;
    font-family: 'object-fit: cover'
}

.semitransparent {
    background: rgba(255, 255, 255, 0.8)
}

.atsign:before {
    content: "@"
}

.module-2 {
    width: 50%;
    display: block;
    float: left
}

@media screen and (max-width: 768px) {
    .module-2 {
        width: 100%;
        float: none
    }
}

.module-3 {
    width: 33.33333%;
    display: block;
    float: left
}

@media screen and (max-width: 768px) {
    .module-3 {
        width: 100%;
        float: none
    }
}

.module-4 {
    width: 25%;
    display: block;
    float: left
}

@media screen and (max-width: 768px) {
    .module-4 {
        width: 50%
    }
}

.page {
    overflow: hidden
}

.container {
    margin: 0 auto;
    width: 100%
}

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

@media screen and (max-width: 768px) {
    .container.index {
        margin-top: 118px
    }

    .lower .container {
        margin-top: 60px
    }
}

@media screen and (min-width: 769px) {
    .lower .container {
        margin-top: 80px
    }
}

@media screen and (max-width: 768px) {
    .common-lower .main-col {
        padding-top: 2.5rem
    }
}

.common-lower {
    margin-top: 80px
}

@media screen and (max-width: 768px) {
    .common-lower {
        margin-top: 152px
    }
}

#conts-start {
    background: #FFF
}

.common-lower #conts-start {
    background: #fafaf2;
    padding: 2rem 0 1rem
}

@media screen and (max-width: 768px) {
    .common-lower #conts-start {
        padding: 1rem
    }
}

.common-bg-white {
    background: #FFF;
    box-shadow: 0 0 20px -6px rgba(0, 0, 0, 0.2);
    padding-bottom: 2rem
}

.wrap {
    clear: both;
    overflow: hidden
}

@media screen and (min-width: 769px) {
    .wrap {
        margin-top: 1rem
    }
}

.post-body {
    margin-top: 2rem;
    -ms-word-wrap: break-word;
    word-wrap: break-word;
    -ms-word-break: normal;
    word-break: normal
}

.post-body h1,
.post-body h2,
.post-body h3,
.post-body h4,
.post-body h5 {
    font-weight: 500;
    clear: both
}

.post-body h1,
.post-body h2 {
    padding-bottom: 0.25rem;
    border-bottom: 1px solid #88b943;
    position: relative
}

.post-body h2 {
    border-bottom: none
}

.post-body h2:after {
    content: "";
    display: block;
    height: 1px;
    width: 2rem;
    background: #88b943;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: -1
}

.post-body a {
    text-decoration: underline
}

.post-body a:hover {
    text-decoration: none
}

.post-body ul,
.post-body ol {
    margin: 10px;
    margin-left: 20px
}

.post-body ul li,
.post-body ol li {
    margin-top: .25em
}

.tab-conts.event .post-body ul,
.tab-conts.event .post-body ol {
    margin-left: 0
}

.post-body table {
    margin: 1rem 0;
    border-left: 1px solid #C9CACA;
    border-bottom: 1px solid #C9CACA
}

.post-body table th,
.post-body table td {
    text-align: left;
    padding: .5em 1em
}

.post-body table th {
    border-top: 1px solid #C9CACA;
    border-right: 1px solid #C9CACA
}

.post-body table td {
    border-top: 1px solid #C9CACA;
    border-right: 1px solid #C9CACA
}

.post-body blockquote {
    display: block;
    margin: 20px 10px;
    padding: 10px 20px;
    border-left: 4px solid #C9CACA
}

.post-body pre {
    display: block;
    margin: 20px 10px;
    padding: 10px 20px;
    border: 1px solid #C9CACA
}

.post-body hr {
    display: block;
    margin: 10px 0;
    height: 1px;
    background: #C9CACA
}

.post-body sub,
.post-body sup {
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

.post-body sup {
    top: -0.5em
}

.post-body sub {
    bottom: -0.25em
}

.post-body dl {
    margin-top: 0.75rem
}

.post-body dt {
    margin-top: 0.25rem;
    font-weight: 400
}

.post-body dd {
    margin-left: 1em
}

.border {
    display: block;
    margin: 0 2rem;
    height: 1px;
    background: #ddd
}

@media screen and (max-width: 768px) {
    .border {
        margin: 0
    }
}

.section-title {
    margin-top: 2rem;
    margin-bottom: 0;
    font-weight: 100;
    font-size: 1.4rem;
    line-height: 1.6rem;
    text-align: center;
    text-transform: uppercase;
    position: relative
}

.section-title span {
    display: block
}

@media screen and (max-width: 768px) {
    .section-title {
        margin-top: 2rem;
        font-size: 1rem;
        line-height: 1.2rem
    }

    .section-title .element {
        font-size: 0.45rem
    }
}

@media screen and (min-width: 768px) and (max-width: 769px) {
    .common-lower .section-title {
        font-weight: 300;
        font-size: 2.4rem;
        line-height: 2.4rem
    }
}

@media screen and (max-width: 320px) {
    .section-title {
        font-size: 0.9rem
    }
}

.section-title .element {
    display: block;
    margin-top: 0.1rem;
    margin-right: 0.25rem;
    font-size: 0.6rem;
    font-weight: 300;
    line-height: 1.2;
    color: #fff;
    display: inline-block;
    padding: 0 .5rem;
    background: #3c2310;
    line-height: 1.2rem;
    -webkit-border-radius: .6rem;
    border-radius: .6rem
}

.section-title .element:last-child {
    margin-right: 0
}

@media screen and (max-width: 768px) {
    .section-title .element {
        font-weight: 500
    }
}

.section-title .element a {
    color: #FFF
}

.section-title .blog-cat-nav .element {
    background: #88b943
}

.section-title .blog-cat-nav .element:hover {
    background: #a0c867
}

.content-title,
.post-body .content-title {
    font-weight: 500;
    text-align: center;
    text-align: left;
    display: inline-block;
    width: auto
}

.content-title.center,
.post-body .content-title.center {
    text-align: center;
    display: table;
    margin-left: auto;
    margin-right: auto
}

.section-heading {
    font-weight: 300 !important;
    text-align: center;
    position: relative;
    padding-bottom: 10px
}

.section-heading:after {
    content: "";
    font-size: 1rem;
    color: #88b943;
    display: block;
    width: 2rem;
    height: 1px;
    background: #88b943;
    position: absolute;
    left: calc(50% - 1rem);
    bottom: 0
}

.top-slider {
    height: 100vh;
    margin: 0 auto;
    position: relative;
    overflow: hidden
}

.top-slider ul {
    margin: 0;
    padding: 0;
    list-style: none
}

.top-slider ul li {
    background-size: cover;
    width: 100%;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    animation-iteration-count: infinite;
    animation-duration: 24s
}

.top-slider ul li:nth-child(1) {
    background-image: url("../minnanoseikotu/img/slide-img-1.jpg");
    animation-name: slider-zoomin;
    animation-delay: -3s
}

.top-slider ul li:nth-child(2) {
    background-image: url("../minnanoseikotu/img/slide-img-2.jpg");
    animation-name: slider-zoomout;
    opacity: 0;
    animation-delay: 5s
}

.top-slider ul li:nth-child(3) {
    background-image: url("../minnanoseikotu/img/slide-img-3.jpg");
    animation-name: slider-zoomin;
    opacity: 0;
    animation-delay: 13s
}

.top-slider ul li img {
    width: 130%
}

@keyframes slider-zoomin {
    0% {
        opacity: 0;
        transform: scale(1)
    }

    20.83% {
        opacity: 1
    }

    33.33% {
        opacity: 1
    }

    45.83% {
        opacity: 0
    }

    100% {
        opacity: 0;
        transform: scale(1.3)
    }
}

@keyframes slider-zoomout {
    0% {
        opacity: 0;
        transform: scale(1.3)
    }

    20.83% {
        opacity: 1
    }

    33.33% {
        opacity: 1
    }

    45.83% {
        opacity: 0
    }

    100% {
        opacity: 0;
        transform: scale(1)
    }
}

.tume {
    letter-spacing: -.5em
}

.main-img {
    position: relative;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100vh;
    overflow: hidden
}

@media screen and (max-width: 768px) {
    .main-img {
        height: 61.8vh
    }
}

.main-img .catchphrase {
    z-index: 2;
    bottom: -54%;
    left: 2rem;
    font-weight: 100;
    font-size: .7rem;
    color: #333;
    position: relative;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.4)
}

@media screen and (max-width: 1366px) {
    .main-img .catchphrase {
        font-size: 0.6rem
    }
}

@media screen and (max-width: 768px) {
    .main-img .catchphrase {
        font-size: 0.4rem;
        font-weight: 500;
        bottom: -38%;
        width: calc(100% - 1rem);
        left: 1rem
    }
}

.main-img .catchphrase b {
    display: block;
    color: #FFF;
    font-size: 2.4rem;
    font-weight: normal;
    line-height: 1.8;
    text-indent: -.25rem
}

@media screen and (max-width: 1366px) {
    .main-img .catchphrase b {
        font-size: 2rem;
        font-weight: 500
    }
}

@media screen and (max-width: 768px) {
    .main-img .catchphrase b {
        font-size: 1.4rem;
        font-weight: 500;
        margin-bottom: 0.2rem;
        white-space: nowrap
    }
}

@media screen and (max-width: 320px) {
    .main-img .catchphrase b {
        font-size: 1.2rem
    }
}

.main-img .catchphrase .element {
    position: relative;
    z-index: 1;
    color: #040502;
    line-height: 2;
    background: rgba(255, 255, 255, 0.9);
    text-shadow: 1px 1px 0 rgba(136, 185, 67, 0.1);
    font-size: 1rem
}

@media screen and (max-width: 768px) {
    .main-img .catchphrase .element {
        font-size: .7rem
    }
}

.swiper-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0
}

.swiper-wrapper,
.swiper-slide,
.swiper-slide img {
    width: 100%;
    height: 100vh
}

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

    .swiper-wrapper,
    .swiper-slide,
    .swiper-slide img {
        height: 61.8vh
    }
}

.index .swiper-slide img {
    transform-origin: center top;
    transform: scale(1.05);
    transition: 6s ease-out
}

.index .swiper-slide-active img {
    transform: scale(1)
}

.float {
    animation: float_2849 4s linear infinite;
    transform-origin: 50% 50%
}

@keyframes float_2849 {
    0% {
        transform: translateY(0)
    }

    25% {
        transform: translateY(-6px)
    }

    50% {
        transform: translateY(0)
    }

    100% {
        transform: translateY(0)
    }
}

.btn-scroll {
    position: absolute;
    bottom: 2rem;
    left: calc(50% - 1.5rem);
    text-align: center;
    z-index: 2;
    width: 3rem;
    height: 3rem;
    background: rgba(255, 255, 255, 0.3);
    border: 1px solid #fff;
    -webkit-border-radius: 50%;
    border-radius: 50%;
    opacity: .8;
    filter: alpha(opacity=80)
}

@media screen and (max-width: 768px) {
    .btn-scroll {
        bottom: 1rem;
        left: calc(50% - 1.4rem)
    }
}

@media screen and (max-width: 320px) {
    .btn-scroll {
        bottom: 2rem
    }
}

.btn-scroll a {
    display: block;
    height: 1.6em;
    position: relative
}

.btn-scroll a:after {
    content: "\002193";
    font-family: "M PLUS 1p", sans-serif;
    font-size: 1.2rem;
    color: #fff;
    line-height: 3rem
}

.g-header {
    width: 100%;
    z-index: 99;
    position: fixed;
    top: 0;
    left: 0;
    background: rgba(255, 255, 255, 0.9)
}

@media screen and (max-width: 768px) {
    .g-header {
        position: absolute
    }
}

.g-header.fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: rgba(255, 255, 255, 0.95);
    -webkit-backface-visibility: hidden;
    -webkit-animation: fixed-nav 4s linear 1 0s forwards;
    -moz-animation: fixed-nav 4s linear 1 0s forwards;
    -o-animation: fixed-nav 4s linear 1 0s forwards;
    -ms-animation: fixed-nav 4s linear 1 0s forwards;
    animation: fixed-nav 4s linear 1 0s forwards
}

@keyframes fixed-nav {
    0% {
        opacity: .2;
        animation-timing-function: ease-in
    }

    10% {
        opacity: .4;
        animation-timing-function: ease-out
    }

    20% {
        opacity: 1
    }

    100% {
        opacity: 1
    }
}

@media screen and (min-width: 769px) {
    .lower .g-header {
        background: #040502
    }
}

@media screen and (max-width: 768px) {
    .g-header {
        overflow: visible
    }
}

.g-header .logo {
    float: left;
    margin: 0;
    margin-left: 1rem;
    margin-top: 10px;
    padding: 0;
    width: 270px;
    height: 58px;
    font-size: 0;
    background-image: url("../minnanoseikotu/img/logo-01.svg");
    background-repeat: no-repeat;
    background-position: left center;
    -webkit-background-size: contain;
    -o-background-size: contain;
    background-size: contain
}

@media screen and (min-width: 1366px) {
    .g-header .logo {
        margin-left: 2rem
    }
}

@media screen and (max-width: 768px) {
    .g-header .logo {
        float: none;
        width: 224px;
        height: 48px;
        white-space: nowrap;
        margin-top: 0;
        margin-left: .5rem;
        margin-left: auto;
        margin-right: auto
    }
}

@media screen and (min-width: 769px) and (max-width: 1366px) {
    .g-header .logo {
        margin-left: 1rem
    }
}

.g-header .logo a {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center
}

@media screen and (min-width: 769px) and (max-width: 1028px) {
    .g-header .logo {
        width: 248px
    }
}

@media screen and (min-width: 769px) {
    .g-nav {
        background: none;
        float: right
    }

    .g-nav ul {
        width: auto;
        list-style: none;
        margin: 0;
        height: 80px;
        margin-right: 1rem;
        padding: 0
    }
}

@media screen and (min-width: 769px) and (min-width: 1366px) {
    .g-nav ul {
        margin-right: 2rem
    }
}

@media screen and (min-width: 769px) {
    .g-nav li {
        display: table-cell;
        height: 60px;
        vertical-align: bottom;
        white-space: nowrap;
        font-size: .5rem;
        line-height: .55rem;
        text-align: center;
        text-transform: uppercase;
        position: relative
    }
}

@media screen and (min-width: 769px) and (min-width: 1366px) {
    .g-nav li {
        font-size: 0.55rem
    }
}

@media screen and (min-width: 769px) {

    .fixed-nav .g-nav li,
    .lower .g-nav li {
        color: #fff
    }

    .g-nav li a {
        display: block;
        padding: 0 .25rem;
        position: relative
    }
}

@media screen and (min-width: 769px) and (min-width: 1366px) {
    .g-nav li a {
        padding: 0 .35rem
    }
}

@media screen and (min-width: 769px) {

    .fixed-nav .g-nav li a,
    .lower .g-nav li a {
        color: #fff
    }

    .g-nav li a:hover {
        -webkit-transition: all .2s;
        transition: all .2s;
        color: #88b943
    }

    .g-nav li a:hover::before,
    .g-nav li a:hover::after {
        -webkit-transition: all .2s;
        transition: all .2s
    }

    .g-nav li a:after {
        content: "";
        display: block;
        margin-top: 0.2rem;
        width: 0;
        height: 8px;
        -webkit-border-radius: 4px;
        border-radius: 4px;
        transform: scale(0);
        background: #88b943;
        position: absolute;
        bottom: -.5rem;
        left: calc(50% - 4px)
    }

    .g-nav li a:hover:after {
        width: 8px;
        transform: scale(1)
    }

    .g-nav li.active a:after {
        width: 8px;
        transform: scale(1)
    }

    .g-nav li.parent {
        position: relative
    }

    .g-nav li.parent:hover {
        cursor: pointer
    }

    .g-nav li.parent:after {
        position: absolute;
        left: calc(50% - .25em);
        bottom: .75rem;
        content: "\f105";
        font-family: 'fontAwesome';
        margin-left: .1rem;
        display: inline-block;
        line-height: 0;
        -webkit-transition: all .04s;
        transition: all .04s;
        -webkit-transform: rotate(90deg);
        -moz-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        -o-transform: rotate(90deg);
        transform: rotate(90deg)
    }

    .g-nav li.parent:after::before,
    .g-nav li.parent:after::after {
        -webkit-transition: all .04s;
        transition: all .04s
    }

    .g-nav li:nth-child(8) a {
        padding-right: 0
    }

    .g-nav ul.upper {
        position: absolute;
        top: 2px;
        right: 80px;
        height: 30px;
        z-index: 1;
        background: #88b943;
        padding-left: 0.5rem
    }

    .g-nav ul.upper li {
        height: 30px;
        vertical-align: baseline
    }

    .g-nav ul.upper li a {
        padding-left: .1rem;
        height: 30px;
        line-height: 30px;
        font-size: 0.5rem;
        display: inline-block;
        color: #FFF
    }

    .g-nav ul.upper li a:after {
        content: none
    }

    .g-nav ul.upper li a:hover {
        text-decoration: underline
    }

    .g-nav ul.upper li:before {
        font-family: 'fontAwesome';
        font-size: 0.5rem;
        color: #FFF
    }

    .g-nav ul.upper li:nth-child(1):before {
        content: "\f041"
    }

    .g-nav ul.upper li:nth-child(2):before {
        content: "\f040"
    }

    .g-nav ul.upper li:nth-child(3):before {
        content: "\f27a"
    }

    .g-nav ul.upper li:nth-child(4):before {
        content: "\f0e0"
    }

    .g-nav ul.upper-right {
        position: absolute;
        top: 2px;
        right: .5rem;
        height: 30px;
        z-index: 1;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-align-items: baseline;
        align-items: baseline
    }

    .g-nav ul.upper-right li {
        height: 30px;
        vertical-align: top
    }

    .g-nav ul.upper-right li a {
        padding-left: .1rem;
        height: 30px;
        line-height: 30px;
        font-size: 1rem;
        display: inline-block;
        color: #88b943
    }

    .g-nav ul.upper-right li a:after {
        content: none
    }

    .g-nav ul.upper-right li a.instagram:before {
        position: absolute;
        top: 3px;
        left: 0;
        content: "\f16d";
        font-family: 'fontAwesome'
    }

    .g-nav ul.child {
        display: none;
        position: absolute;
        margin: 0;
        padding: 0;
        top: 70px;
        left: -1rem;
        list-style: none;
        background: rgba(136, 185, 67, 0.8);
        z-index: 99
    }

    .g-nav ul.child li a {
        color: #FFF;
        display: block;
        width: 100%;
        height: 100%;
        line-height: 80px
    }

    .g-nav ul.child li a:after {
        content: "";
        display: block;
        margin-top: -1rem;
        width: 0;
        height: 1px;
        transform: scaleX(0);
        background: #fff
    }

    .g-nav ul.child li a:hover:after {
        width: 100%;
        transform: scaleX(1)
    }
}

@media screen and (min-width: 769px) and (max-width: 1028px) {
    .g-nav li {
        font-size: 0.5rem;
        padding: 0
    }

    .g-nav li a {
        padding: 0 .25rem
    }
}

.button-menu {
    position: fixed;
    bottom: 0;
    right: 0;
    width: 64px;
    height: 64px;
    text-align: center;
    background: #88b943;
    z-index: 99
}

.button-menu button {
    display: block;
    border: none;
    padding: 0;
    width: 38px;
    color: #333;
    letter-spacing: 0.1em;
    cursor: pointer;
    position: fixed;
    position: absolute;
    top: 6px;
    left: 12px;
    z-index: 1001;
    text-align: center;
    outline: none;
    font-size: 0.4rem;
    background: none
}

.button-menu button:after {
    content: "menu";
    font-size: 0.4rem;
    color: #FFF;
    white-space: nowrap;
    text-transform: uppercase
}

.button-menu button span.bar {
    display: block;
    height: 2px;
    background-color: #fff;
    margin: 8px 0;
    transition: all 0.2s;
    transform-origin: 0 0
}

.button-menu button .close {
    letter-spacing: 0.08em;
    display: none
}

.button-menu button .menu {
    display: block;
    color: #88b943
}

.button-menu button.active span.bar {
    width: 45px
}

.button-menu button.active .bar1 {
    transform: rotate(26deg)
}

.button-menu button.active .bar2 {
    opacity: 0
}

.button-menu button.active .bar3 {
    transform: rotate(-26deg)
}

.button-menu span.bar.bar3 {
    margin-bottom: 6px
}

.button-menu button.active:after {
    content: "Close"
}

.sp-nav {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
    width: 100%;
    background: #fff;
    position: fixed;
    left: 0;
    bottom: 0;
    height: 85%;
    -ms-overflow-y: scroll;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    box-shadow: 0 0 40px -20px #000;
    -webkit-border-radius: 8px 8px 0 0;
    border-radius: 8px 8px 0 0
}

.sp-nav.active {
    opacity: 1;
    visibility: visible;
    z-index: 99
}

.sp-nav>ul {
    list-style: none;
    margin: 0 .5rem 1rem;
    padding: 0;
    border-top: 1px solid #fafaf2;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.sp-nav>ul li {
    width: 50%;
    border-bottom: 1px solid #fafaf2;
    padding-left: .75rem;
    text-indent: -.75rem
}

.sp-nav>ul li a {
    display: block;
    padding: 0.3rem .5rem;
    font-weight: 500;
    line-height: 1.3
}

.sp-nav>ul li a:before {
    content: "・";
    margin-right: 0.25rem;
    color: #88b943;
    font-weight: bold
}

.sp-nav>ul.child {
    margin-bottom: 0
}

.sp-nav>ul.child li {
    padding-left: .5rem
}

.sp-nav>ul.child li a {
    font-weight: 300
}

.sp-nav .logo {
    padding: .5rem 0
}

.sp-nav .logo a {
    display: block;
    width: 100%;
    height: 30px;
    font-size: 0;
    background-image: url("../minnanoseikotu/img/logo-01.svg");
    background-repeat: no-repeat;
    background-position: center;
    -webkit-background-size: contain;
    -o-background-size: contain;
    background-size: contain
}

body.open {
    position: fixed;
    width: 100%;
    top: 0
}

.w100 {
    width: 100%
}

.path {
    margin-top: 1rem;
    padding: 0 1rem;
    font-weight: 300;
    font-size: .5rem
}

.path ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: table
}

.path ul li {
    display: table-cell;
    padding-right: 1rem;
    position: relative
}

.path ul li:after {
    content: "\f054";
    font-size: 0.3rem;
    font-family: 'fontAwesome';
    color: #6c786e;
    position: absolute;
    top: .05rem;
    right: .4rem
}

.path ul li:first-child {
    font-weight: 500
}

.path ul li:last-child:after {
    display: none
}

@media screen and (max-width: 768px) {
    .path {
        width: 100%;
        padding: 0.25rem 0
    }

    .path ul {
        margin-bottom: 0;
        font-size: 0.45rem;
        overflow-y: hidden;
        overflow-x: scroll;
        display: flex;
        -webkit-overflow-scrolling: touch;
        overflow-scrolling: touch
    }

    .path ul li {
        flex: none;
        padding: 0 8px
    }

    .path ul li:after {
        right: -0.1rem
    }
}

.g-footer {
    padding: 2rem 0 3rem;
    border-top: 1px solid #ececcd;
    text-transform: uppercase;
    position: relative
}

@media screen and (max-width: 768px) {
    .g-footer {
        padding: 0 0 2rem
    }
}

.g-footer .inner {
    padding: 0;
    position: relative;
    overflow: visible
}

@media screen and (max-width: 768px) {
    .g-footer .inner {
        padding: 0
    }
}

.g-footer .wrap {
    width: 100%;
    margin-top: 0;
    padding-bottom: 1rem;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.g-footer .wrap::after {
    content: "";
    display: block;
    clear: both
}

@media screen and (max-width: 768px) {
    .g-footer .wrap {
        display: block;
        padding: 1rem
    }
}

.g-footer .left,
.g-footer .right {
    width: 38.2%
}

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

    .g-footer .left,
    .g-footer .right {
        display: block;
        width: 100%
    }
}

.g-footer .right {
    width: 61.8%;
    margin-top: 0.5rem;
    padding: 0 0 0 5rem
}

@media screen and (min-width: 769px) and (max-width: 1366px) {
    .g-footer .right {
        padding: 0 8rem 0 2rem
    }
}

@media screen and (max-width: 768px) {
    .g-footer .right {
        width: 100%;
        padding: 0
    }
}

.g-footer .right p {
    margin-bottom: 0;
    line-height: 1
}

.g-footer .right i {
    color: #3B5998;
    margin-right: 0.1rem
}

.g-footer .logo a {
    display: block;
    width: 390px;
    height: 56px;
    font-size: 0;
    background-image: url("../minnanoseikotu/img/logo-01.svg");
    background-repeat: no-repeat;
    background-position: left center;
    -webkit-background-size: contain;
    -o-background-size: contain;
    background-size: contain
}

@media screen and (max-width: 768px) {
    .g-footer .logo {
        padding: 1rem 0 0
    }

    .g-footer .logo a {
        width: 61.8%;
        margin: auto
    }
}

.g-footer address {
    font-style: normal;
    font-size: 0.55rem;
    line-height: 1.2
}

.g-footer address p {
    margin-bottom: 0.25rem
}

.g-footer address img {
    width: 240px
}

@media screen and (max-width: 768px) {
    .g-footer address img {
        margin-top: 0.5rem;
        width: 61.8%
    }
}

.g-footer .copy {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: #fafaf2;
    background: #88b943;
    color: #FFF;
    padding: .5rem;
    text-align: center;
    text-transform: none
}

.g-footer .copy b {
    font-weight: 500
}

@media screen and (max-width: 768px) {
    .g-footer .copy {
        font-size: .4rem;
        height: 64px
    }
}

.address {
    line-height: 1.3
}

.address b {
    font-weight: 400
}

@media screen and (max-width: 768px) {
    .address b {
        font-weight: bold;
        font-size: 0.5rem
    }
}

@media screen and (max-width: 768px) {
    .address {
        line-height: 1.5
    }

    .address p {
        margin-top: 0;
        font-size: 0.55rem
    }

    .address .tel {
        font-size: 0.6rem
    }
}

.prof {
    width: 100%;
    display: flex;
    margin: .75rem 0 0
}

.prof .photo {
    width: 80px;
    height: 80px;
    overflow: hidden;
    -webkit-border-radius: 80px;
    border-radius: 80px;
    border: 1px solid #fafaf2
}

.prof .text {
    width: calc(100% - 80px);
    font-size: .425rem
}

.prof .text b {
    color: #88b943;
    display: block;
    font-size: .5rem;
    font-weight: 400;
    padding-bottom: 0.1rem
}

.prof .name {
    margin-top: 0.1rem;
    font-weight: 400;
    font-size: 0.8rem
}

.prof .name small {
    margin-right: 1em;
    font-weight: 300
}

.partner {
    margin-top: .75rem
}

.partner dl,
.partner dt,
.partner dd {
    margin: 0;
    padding: 0;
    line-height: 1;
    font-size: 0
}

.partner dt {
    font-weight: normal;
    margin-top: 0.25rem;
    font-size: 0.55rem
}

@media screen and (max-width: 768px) {
    .partner dt {
        font-weight: 500
    }
}

.partner dd {
    margin: .2rem 1px 0;
    font-size: 0.525rem;
    font-size: 0.45rem;
    display: inline-block
}

@media screen and (max-width: 768px) {
    .partner dd {
        font-weight: 300
    }
}

.partner a {
    display: block;
    padding: .2rem .2rem;
    color: #FFF;
    font-weight: normal;
    text-align: center;
    vertical-align: middle;
    -webkit-border-radius: 1px;
    border-radius: 1px
}

.partner a:hover {
    background: #88b943
}

.foot-nav ul {
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (max-width: 768px) {
    .foot-nav ul {
        margin-top: .75rem
    }
}

.foot-nav li {
    width: 50%;
    margin-top: 0.25rem;
    padding-left: .5rem;
    text-indent: -.5rem;
    line-height: 1.4
}

.foot-nav li:before {
    content: "・";
    color: #88b943;
    font-weight: bold
}

.foot-nav a:hover {
    color: #88b943
}

.recruit-bn {
    margin-top: .5rem;
    box-shadow: 0 0 20px -5px rgba(0, 0, 0, 0.2);
    width: 405px
}

@media screen and (max-width: 768px) {
    .recruit-bn {
        width: 100%
    }
}

.recruit-bn img:hover {
    opacity: .95
}

.sp-nav .recruit-bn {
    width: 61.8%;
    margin: .5rem auto;
    box-shadow: 0 0 10px -5px #000
}

.fixed-contact {
    text-align: center;
    box-shadow: 0 0 10px -5px #000;
    color: #fff
}

@media screen and (min-width: 769px) {
    .fixed-contact {
        position: fixed;
        right: 2rem;
        bottom: 2rem;
        z-index: 1
    }
}

@media screen and (max-width: 768px) {
    .fixed-contact {
        width: 61.8%;
        margin: auto;
        box-shadow: 0 0 8px -5px #000;
        background: #3c2310
    }
}

.fixed-contact p {
    margin-top: 0;
    letter-spacing: .028em
}

@media screen and (max-width: 320px) {
    .fixed-contact p {
        font-size: 0.5rem;
        white-space: nowrap
    }
}

.fixed-contact .tel {
    font-weight: 900;
    font-size: 0.84rem;
    color: #e5d53c
}

@media screen and (max-width: 320px) {
    .fixed-contact .tel {
        font-size: 0.6rem
    }
}

.fixed-contact .tel a {
    color: #e5d53c
}

.fixed-contact .mail {
    font-size: 0.57rem;
    line-height: 1
}

@media screen and (max-width: 320px) {
    .fixed-contact .mail {
        font-size: 0.45rem;
        white-space: nowrap
    }
}

.fixed-contact .upper a {
    display: block;
    padding: .5rem;
    line-height: 1.4;
    background: #80ae3f;
    font-weight: 500;
    color: #3c2310;
    color: #FFF
}

.fixed-contact .upper a:hover {
    background: rgba(136, 185, 67, 0.8)
}

.fixed-contact .lower {
    padding: .5rem;
    background: #3c2310
}

.fixed-contact.houmon {
    margin: 1rem auto 0
}

@media screen and (min-width: 769px) {
    .fixed-contact.houmon {
        position: relative;
        right: auto;
        bottom: auto;
        width: 320px
    }
}

@media screen and (max-width: 768px) {
    .fixed-contact.houmon {
        width: 80%
    }
}

.fixed-contact.houmon .upper a {
    background: #fafaf2;
    color: #040502
}

.fixed-contact.houmon .upper a img {
    margin: .5rem 0
}

.g-footer .fixed-contact.houmon {
    width: 240px;
    margin-top: .25rem
}

.g-footer .fixed-contact .upper a {
    padding: 0 .5rem
}

.g-footer .fixed-contact .tel {
    font-size: 0.7rem
}

.g-footer .fixed-contact .lower {
    padding: .25rem .5rem
}

.info p small {
    font-size: 0.525rem;
    line-height: 1.2;
    display: block
}

.info p small img {
    width: 12px
}

.info ul {
    list-style: none;
    margin: .25rem 0 0;
    padding: 0;
    width: 100%;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    font-size: 0.525rem
}

.info li {
    width: calc(50% - 1px);
    line-height: 1.2;
    padding: 2px;
    background: #fff;
    color: #3c2310;
    font-weight: 400;
    text-align: center
}

header .info {
    text-align: center
}

header .info p {
    margin: 0
}

header .info ul {
    padding: 0 1rem
}

header .info li {
    background: #6c786e;
    color: #fff
}

header .info .tel-wrap .tel {
    font-weight: 900;
    font-size: 0.84rem;
    letter-spacing: .2em;
    color: #3c2310;
    padding: 0.5rem 0
}

header .info .tel-wrap .tel a {
    color: #3c2310
}

header .info .tel-wrap .tel a i {
    color: #88b943
}

header .info .tel-wrap .icon {
    display: inline-block;
    width: 2rem;
    text-align: left;
    vertical-align: middle
}

header .info .tel-wrap .icon a {
    color: #88b943;
    position: relative;
    font-size: 1rem;
    padding-left: 5px
}

header .info .tel-wrap .icon a.instagram:before {
    position: absolute;
    top: 4px;
    left: 5px;
    content: "\f16d";
    font-family: 'fontAwesome'
}

.page-top {
    position: absolute;
    top: -3rem;
    right: calc(50% - 26px);
    width: 52px;
    height: 52px;
    text-align: center;
    background: #88b943;
    z-index: 9;
    -webkit-border-radius: 26px;
    border-radius: 26px
}

@media screen and (max-width: 768px) {
    .page-top {
        display: none
    }
}

.page-top a {
    color: #FFF;
    display: block;
    width: 100%;
    height: 100%;
    line-height: 70px;
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0
}

.page-top a:before {
    content: "\f106";
    font-family: 'fontAwesome';
    font-size: .8rem;
    position: absolute;
    right: calc(50% - .3em);
    top: -8px
}

.page-top a:hover {
    -webkit-transition: all .6s;
    transition: all .6s;
    color: #e5d53c
}

.page-top a:hover::before,
.page-top a:hover::after {
    -webkit-transition: all .6s;
    transition: all .6s
}

.page-top a:hover:before {
    color: #FFF;
    color: #6c786e
}

.loading {
    width: 100%;
    height: 100%;
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 20000
}

.loading img {
    width: 200px;
    height: 200px;
    position: absolute;
    top: 42%;
    left: calc(50% - 80px);
    margin-top: -20px;
    margin-left: -20px
}

@media screen and (max-width: 768px) {
    .loading img {
        width: 100px;
        height: 100px;
        top: 40%;
        left: calc(50% - 25px)
    }
}

.sentence {
    text-align: center
}

@media screen and (max-width: 768px) {
    .sentence {
        text-align: left
    }
}

.sentence .text {
    text-align: left
}

.sentence ol {
    border: 1px solid #6c786e;
    margin: 1rem 0 0;
    padding: 1rem 2rem 1rem 3rem
}

@media screen and (max-width: 768px) {
    .sentence ol {
        padding: .5rem 1rem .5rem 1.5rem;
        font-size: 0.55rem;
        line-height: 1.4
    }
}

.sentence ol li {
    margin: 0.25rem 0 0
}

.sentence ol li:first-child {
    margin-top: 0
}

.bg-cover {
    background-repeat: no-repeat;
    -webkit-background-size: cover;
    -o-background-size: cover;
    background-size: cover
}

.index .flow.bg-cover {
    background-image: url("../minnanoseikotu/img/bg-sky-1.jpg");
    background-position: top center
}

@media screen and (max-width: 768px) {
    .index .flow.bg-cover {
        -webkit-background-size: contain;
        -o-background-size: contain;
        background-size: contain
    }
}

.index .flow .post-body {
    padding: 0 2rem 2rem
}

@media screen and (max-width: 768px) {
    .index .flow .post-body {
        padding: 0 1rem 1rem
    }
}

@media screen and (min-width: 769px) {
    .index .flow .post-body.service {
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-align-items: flex-start;
        align-items: flex-start;
        -webkit-justify-content: space-between;
        justify-content: space-between
    }
}

@media screen and (min-width: 769px) {
    .index .flow .item {
        width: 48%
    }
}

.flow .wrap {
    background: #FFF;
    box-shadow: 0 0 20px -6px rgba(0, 0, 0, 0.2)
}

.flow .pic {
    overflow: hidden;
    padding: 0 .25rem .25rem
}

@media screen and (max-width: 768px) {
    .flow .pic {
        padding: 0 0 0.25rem
    }
}

.flow .module-3 {
    padding: 0 .25rem
}

.flow .module-3 img {
    box-shadow: 0 0 10px -5px #000
}

@media screen and (max-width: 768px) {
    .flow .module-3 {
        width: 33.33333%;
        display: block;
        float: left
    }
}

.flow .flow-title {
    font-size: 0.8rem;
    line-height: 0.8rem;
    padding-bottom: 0;
    border: none
}

.flow .flow-title:before {
    content: "1";
    display: inline-block;
    margin-right: 0.25rem;
    width: 1.6rem;
    height: 1.6rem;
    line-height: 1.6rem;
    background: #88b943;
    color: #FFF;
    text-align: center;
    -webkit-border-radius: .8rem;
    border-radius: .8rem
}

.flow .item:nth-child(2) .flow-title:before {
    content: "2"
}

.flow .item:nth-child(3) .flow-title:before {
    content: "3"
}

.flow .item:nth-child(4) .flow-title:before {
    content: "4"
}

.flow .item:nth-child(5) .flow-title:before {
    content: "5"
}

.flow .item:nth-child(6) .flow-title:before {
    content: "6"
}

.flow .item:nth-child(7) .flow-title:before {
    content: "7"
}

.index .flow .conts .pic {
    width: 100%;
    margin-top: 0.5rem
}

.index .flow .conts .text {
    margin-top: 0;
    line-height: 1.4
}

@media screen and (min-width: 769px) {
    .index .flow .conts {
        display: flex;
        -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse
    }

    .index .flow .conts .pic {
        padding-left: 0
    }

    .index .flow .conts .text {
        margin-top: 0.25rem;
        font-size: 0.55rem
    }
}

@media screen and (max-width: 768px) {
    .index .feature .section-title {
        margin-top: 0
    }
}

.feature .wrap {
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: center;
    justify-content: center
}

.feature .wrap .conts {
    width: calc(33.3333% - 1rem);
    margin: 0.5rem;
    text-align: left;
    line-height: 1.4;
    border: 1px solid #ddd;
    background: rgba(255, 255, 255, 0.8);
    -webkit-border-radius: 4px;
    border-radius: 4px;
    -webkit-box-shadow: 0 0 20px -5px rgba(0, 0, 0, 0.2);
    box-shadow: 5px 5px 0 0 #f3f4f5
}

@media screen and (max-width: 768px) {
    .feature .wrap .conts {
        margin: .25rem;
        width: calc(50% - .5rem)
    }
}

.feature .wrap h3 {
    display: block;
    margin-top: 0;
    text-align: center;
    font-size: 0.7rem;
    font-weight: 500;
    line-height: 3
}

@media screen and (max-width: 768px) {
    .feature .wrap h3 {
        font-size: 0.6rem;
        line-height: 1.4;
        margin-top: .5rem
    }
}

@media screen and (max-width: 320px) {
    .feature .wrap h3 {
        line-height: 1.3;
        font-weight: bold;
        margin-bottom: 0.5rem
    }
}

.feature .wrap span {
    display: block;
    padding: 0 1rem .5rem
}

@media screen and (max-width: 768px) {
    .feature .wrap span {
        padding: 0 0 .5rem;
        margin-top: .5rem
    }
}

.feature .wrap a {
    display: block;
    padding: 0.5rem
}

.feature .wrap a h3 {
    color: #88b943
}

.feature .wrap.upper .conts {
    width: calc(50% - 1rem);
    padding: 0.5rem
}

@media screen and (max-width: 768px) {
    .feature .wrap.upper .conts {
        margin: .25rem;
        width: calc(100% - .5rem)
    }
}

.feature .wrap.upper h3 {
    line-height: 1.4;
    text-align: left;
    font-size: 0.6rem;
    font-weight: 500;
    color: #7aa63c
}

@media screen and (min-width: 769px) {
    .feature .wrap.upper h3 {
        height: 2rem;
        margin-top: 0
    }
}

.feature .wrap.upper span {
    margin-top: .5rem;
    padding: 0
}

@media screen and (max-width: 768px) {
    .feature .wrap.upper span {
        margin-top: .5rem
    }
}

@media screen and (max-width: 768px) {
    .feature .wrap.upper .pic {
        margin-top: 0.5rem
    }
}

.feature .text {
    margin-top: 1rem;
    color: #000
}

.index-news {
    border-top: 1px solid #ececcd;
    background: #fafaf2
}

@media screen and (max-width: 768px) {
    .index-news .section-title {
        margin-top: 0
    }
}

.news>ul {
    list-style: none;
    margin: 1rem auto;
    padding: 0
}

@media screen and (max-width: 768px) {
    .news>ul {
        width: 100%
    }
}

.news>ul li {
    margin-top: .5rem;
    padding: .25rem 1rem;
    border-bottom: 1px dotted #ececcd
}

@media screen and (max-width: 768px) {
    .news>ul li {
        padding: 0 .5rem .5rem
    }

    .common-lower .news>ul li {
        padding: 0 0 .5rem
    }
}

.news>ul li:first-child {
    margin-top: 0;
    padding-top: 0.5rem;
    border-top: 1px dotted #ececcd
}

.news>ul .date {
    display: inline-block;
    font-weight: normal;
    color: #6c786e;
    vertical-align: top;
    line-height: 1;
    padding-right: 0.5rem;
    width: 13%
}

@media screen and (max-width: 768px) {
    .news>ul .date {
        width: 100%;
        display: block;
        line-height: 2
    }
}

.news>ul a.article-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
    width: 87%;
    vertical-align: top;
    line-height: 1
}

@media screen and (max-width: 768px) {
    .news>ul a.article-title {
        width: 100%
    }
}

.news>ul a.article-title:hover {
    color: #88b943
}

.common-lower .news>ul li {
    padding-bottom: 0.5rem
}

.common-lower .news>ul a {
    display: block;
    white-space: normal;
    line-height: 1.4
}

.common-lower .news-article .post-body {
    margin-top: 2rem;
    padding: 0
}

.lity-wrap:hover {
    cursor: pointer
}

.lity-image img:hover {
    cursor: default
}

.company .post-body table,
.contact .post-body table {
    border: none;
    margin-top: .5rem
}

.company .post-body table dl,
.contact .post-body table dl {
    margin-top: 0
}

.company .post-body table dt,
.contact .post-body table dt {
    margin-top: 0.5rem
}

.company .post-body table dt:first-child,
.contact .post-body table dt:first-child {
    margin-top: 0
}

.company .post-body table dd,
.contact .post-body table dd {
    margin-left: .25rem
}

.company .post-body table ul,
.contact .post-body table ul {
    margin: 0;
    padding: 0;
    padding-left: .75rem
}

.company .post-body table th,
.company .post-body table td,
.contact .post-body table th,
.contact .post-body table td {
    padding: 1rem 0.5rem;
    border: none;
    border-bottom: 1px solid #ddd;
    vertical-align: top
}

.company .post-body table th,
.contact .post-body table th {
    font-weight: normal
}

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

    .company .post-body table th,
    .company .post-body table td,
    .contact .post-body table th,
    .contact .post-body table td {
        display: block;
        width: 100%;
        padding: .25rem 0.25rem
    }

    .company .post-body table th,
    .contact .post-body table th {
        font-weight: 900
    }
}

.contact .post-body table {
    width: 100%
}

@media screen and (min-width: 769px) {
    .contact .post-body table {
        width: 72%;
        margin: auto
    }
}

@media screen and (max-width: 768px) {
    .contact .post-body table th {
        border-bottom: none;
        padding-bottom: 0;
        line-height: 1.2
    }
}

.contact .post-body .common-btn {
    margin-top: 1rem
}

.contact .post-body small {
    line-height: 1.4
}

.contact .post-body input,
.contact .post-body select {
    padding: 0.2rem;
    border: 1px solid #fafaf2;
    font-weight: 300;
    background: #fafaf2;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    border-radius: 0
}

.contact .post-body input,
.contact .post-body textarea {
    padding: 0.25rem;
    border: 1px solid #fafaf2;
    background: #fafaf2
}

.contact .post-body input[type="submit"] {
    background: none;
    padding: 0.5rem;
    width: 100%
}

.contact .post-body input[type="submit"]:hover {
    cursor: pointer
}

.contact .post-body textarea:focus,
.contact .post-body input:focus,
.contact .post-body select:focus,
.contact .post-body input[type]:focus,
.contact .post-body .uneditable-input:focus {
    outline: 0;
    box-shadow: none;
    border: 1px solid #fafaf2;
    background-color: rgba(250, 250, 242, 0.4)
}

.contact .post-body input:focus:placeholder-shown {
    color: transparent
}

.contact .post-body input:focus::-webkit-input-placeholder {
    color: transparent
}

.contact .post-body input:focus::-moz-placeholder {
    color: transparent
}

.contact .post-body input:focus:-ms-input-placeholder {
    color: transparent
}

.contact .post-body input:focus::-ms-input-placeholder {
    color: transparent
}

.contact input::-webkit-input-placeholder {
    color: #999
}

.contact input::-moz-placeholder {
    color: #999
}

.contact input:-ms-input-placeholder {
    color: #999
}

.privacy {
    width: 100%;
    font-size: 0.5rem;
    line-height: 1.4
}

@media screen and (min-width: 769px) {
    .privacy {
        width: 72%;
        margin: auto
    }
}

.privacy dl {
    margin-top: .5rem;
    padding: .5rem 1rem;
    background: #fafaf2;
    height: 240px;
    -ms-overflow-y: scroll;
    overflow-y: scroll
}

.privacy dt {
    margin-top: .5rem;
    font-weight: 400
}

.privacy dd {
    margin-top: 0.25rem;
    padding-left: .5rem
}

.news-article header {
    margin-top: 1rem;
    padding: 2rem 1rem 1.5rem;
    color: #FFF;
    background: #88b943;
    -webkit-border-radius: 4px;
    border-radius: 4px
}

.news-article header h1 {
    font-size: 1rem;
    margin-top: 0;
    font-weight: normal
}

@media screen and (min-width: 769px) {
    .news-article header h1 {
        text-align: center
    }
}

.news-article header .date {
    margin: .5rem auto 0;
    text-align: center;
    font-weight: 500
}

.blog-cat-nav {
    margin-top: .5rem;
    padding: .5rem
}

.blog-cat-nav a {
    color: #FFF
}

.blog-cat-nav a:hover {
    font-weight: 400
}

.blog>ul .date {
    line-height: 1.4
}

.blog>ul .cat-title {
    display: inline-block;
    font-weight: normal;
    vertical-align: top;
    line-height: 1;
    width: auto;
    font-size: 0.45rem;
    color: #3c2310;
    border: 1px solid #3c2310;
    padding: 0 .5rem;
    margin-right: 0.25rem;
    line-height: 1.6;
    -webkit-border-radius: .5rem;
    border-radius: .5rem
}

.blog>ul .cat-title a {
    color: #3c2310;
    line-height: 1.6
}

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

    .blog>ul .date,
    .blog>ul .cat-title {
        display: inline-block;
        width: auto
    }
}

.voice ul .date {
    width: auto
}

.price th {
    font-weight: 400;
    background: rgba(136, 185, 67, 0.2)
}

.price th.bg1, .biyouprice th.bg1 {
    background: rgba(60, 35, 16, 0.2);
    font-weight: normal
}

.price th.bg2 , .biyouprice th.bg2{
    background: rgba(136, 185, 67, 0.05)
}

.price .off .biyouprice .off{
    display: inline-block;
    margin-top: 10px;
    padding: 5px 10px;
    font-size: .8rem;
    color: #fff;
    background: #e2d026
}

.price .shokai {
    margin-right: 10px;
    display: inline-block;
    border-bottom: 3px solid #c42727
}

@media screen and (max-width: 768px) {
    .scroll-table {
        padding-bottom: 5px;
        overflow-x: scroll;
        -webkit-overflow-scrolling: touch;
        overflow-scrolling: touch
    }

    .scroll-table::-webkit-scrollbar {
        height: 6px
    }

    .scroll-table::-webkit-scrollbar-track {
        margin: 0;
        background: #f9f9f9
    }

    .scroll-table::-webkit-scrollbar-thumb {
        background: #ddd
    }
}

.post-body .trial-list {
    margin: 0;
    padding: 2rem 2.5rem;
    list-style: none;
    font-weight: 500;
    font-size: 0.7rem;
    border: 2px solid #88b943;
    -webkit-border-radius: 5px;
    border-radius: 5px
}

@media screen and (max-width: 768px) {
    .post-body .trial-list {
        padding: 1rem 1rem;
        font-size: .6rem;
        line-height: 1.4
    }
}

.post-body .trial-list li {
    color: #333;
    margin-top: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px dotted #88b943
}

@media screen and (max-width: 768px) {
    .post-body .trial-list li {
        padding-left: 1.2rem;
        text-indent: -1.2rem
    }
}

.post-body .trial-list li:first-child {
    margin-top: 0
}

.post-body .trial-list li:before {
    content: "\f00c";
    font-family: 'fontAwesome';
    font-size: .8rem;
    color: #88b943;
    margin-right: 0.5rem
}

.trial-contact {
    margin: 1rem auto 0;
    padding: .5rem;
    display: block;
    width: 250px;
    text-align: center;
    background: rgba(60, 35, 16, 0.8);
    box-shadow: 0 0 10px -5px #000;
    color: #FFF
}

@media screen and (max-width: 320px) {
    .trial-contact {
        width: 220px
    }
}

.trial-contact p {
    margin-top: 0;
    letter-spacing: .028em
}

@media screen and (max-width: 320px) {
    .trial-contact p {
        font-size: 0.5rem;
        white-space: nowrap
    }
}

.trial-contact .tel {
    font-weight: 900;
    font-size: 0.84rem;
    letter-spacing: .2em;
    color: #e5d53c
}

@media screen and (max-width: 320px) {
    .trial-contact .tel {
        font-size: 0.6rem
    }
}

.trial-contact .tel a {
    color: #88b943
}

.trial-contact .mail {
    font-size: 0.575rem
}

@media screen and (max-width: 320px) {
    .trial-contact .mail {
        font-size: 0.45rem;
        white-space: nowrap
    }
}

.recruit-table {
    width: 100%
}

.recruit-table th {
    width: 20%
}

.recruit-table td {
    width: 80%
}

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

    .recruit-table th,
    .recruit-table td {
        display: block;
        width: 100%
    }

    .recruit-table th {
        color: #88b943
    }
}

.recruit .post-body h1 {
    margin-top: 3rem
}

.recruit .post-body h1:before {
    content: "";
    margin-top: -80px;
    height: 80px;
    display: block;
    visibility: hidden
}

.recruit-sp-menu form {
    margin: 0
}

.recruit-sp-menu input,
.recruit-sp-menu select {
    width: 100%;
    padding: 0.2rem;
    border: 1px solid #fafaf2;
    font-weight: 300;
    background: #fafaf2;
    -webkit-appearance: none;
    -webkit-border-radius: 0;
    border-radius: 0
}

.recruit-sp-menu input {
    padding: 0.25rem;
    border: 1px solid #fafaf2;
    background: #fafaf2
}

.recruit-sp-menu select:focus {
    outline: 0;
    box-shadow: none;
    border: 1px solid #fafaf2;
    background-color: rgba(250, 250, 242, 0.4)
}

.recruit-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: table;
    width: 100%
}

.recruit-menu li {
    display: table-cell;
    text-align: center;
    background: #88b943
}

.recruit-menu li a {
    width: 100%;
    padding: 0.5rem;
    display: block;
    color: #040502;
    text-decoration: none;
    font-weight: 500
}

.recruit-menu li a:hover {
    color: #7aa63c
}

.pdf-download {
    clear: both;
    overflow: hidden;
    margin-top: 2rem
}

.pdf-download a {
    border: 1px solid #D41B01;
    display: block;
    padding: .2rem;
    width: 250px;
    height: 60px;
    font-weight: 400;
    position: relative;
    padding-left: 60px;
    line-height: 1.2;
    font-size: 0.6rem;
    text-decoration: none
}

@media screen and (max-width: 768px) {
    .pdf-download a {
        padding: .4rem;
        padding-left: 60px
    }
}

.pdf-download a:before {
    content: "\f1c1 ";
    font-family: 'fontAwesome';
    color: #fff;
    position: absolute;
    top: .5rem;
    left: .5rem;
    width: 1.2rem;
    height: 1.2rem;
    text-align: center;
    line-height: 1.2rem;
    background: #D41B01;
    -webkit-border-radius: .6rem;
    border-radius: .6rem
}

.pdf-download a b {
    font-weight: 900;
    display: block;
    font-size: 0.7rem
}

.pdf-wrap {
    width: 100%;
    margin-top: .5rem;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.pdf-wrap .pdf-download {
    margin-top: 0;
    margin: 0 0 .2rem .2rem
}

@media screen and (max-width: 768px) {
    .pdf-wrap .pdf-download {
        width: calc(50% - .2rem)
    }
}

.pdf-wrap .pdf-download:nth-child(odd) {
    margin-left: 0
}

@media screen and (min-width: 769px) {
    .pdf-wrap .pdf-download a {
        width: 200px;
        height: 50px;
        font-size: 0.5rem
    }

    .pdf-wrap .pdf-download a b {
        font-size: 0.6rem
    }

    .pdf-wrap .pdf-download a:before {
        top: 0.3rem;
        width: 1rem;
        height: 1rem;
        line-height: 1rem;
        -webkit-border-radius: .5rem;
        border-radius: 0.5rem
    }
}

@media screen and (max-width: 768px) {
    .pdf-wrap .pdf-download a {
        width: 100%;
        padding-left: 50px
    }

    .pdf-wrap .pdf-download a b {
        font-size: 0.6rem;
        white-space: nowrap
    }
}

@media screen and (max-width: 320px) {
    .pdf-wrap .pdf-download a {
        font-size: 0.45rem
    }

    .pdf-wrap .pdf-download a b {
        font-size: 0.5rem
    }
}

.pdf-wrap .pdf-download.print a:before {
    content: "\f02f"
}

.pdf-wrap .pdf-download.fax a:before {
    content: "\f1ac"
}

.pdf-wrap-title {
    font-weight: 900;
    color: #6c786e
}

.common-lower .post-body {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 2px dotted #ececcd
}

.common-lower .news-article .post-body {
    border-top: none
}

.access ol {
    margin-left: 0;
    padding-left: 0
}

.access ol li {
    list-style: none
}

.access ol li:before {
    content: "1";
    display: inline-block;
    margin-right: 0.25rem;
    width: 1.6rem;
    height: 1.6rem;
    line-height: 1.6rem;
    background: #88b943;
    color: #FFF;
    text-align: center;
    -webkit-border-radius: .8rem;
    border-radius: .8rem
}

.access ol li:nth-child(2):before {
    content: "2"
}

.access ol li:nth-child(3):before {
    content: "3"
}

.access ol li:nth-child(4):before {
    content: "4"
}

.access ol li:nth-child(5):before {
    content: "5"
}

.access ol li:nth-child(6):before {
    content: "6"
}

.access ol .thumb {
    width: 61.8%;
    padding: .5rem 1rem 1rem
}

@media screen and (max-width: 768px) {
    .access ol .thumb {
        width: 100%
    }
}

.qa dt {
    margin-top: 1.5rem;
    padding-bottom: 0.25rem;
    font-size: 0.65rem;
    font-weight: 400;
    border-bottom: 1px solid #ececcd
}

.qa dt:before {
    content: "Q";
    margin-right: 0.25rem;
    font-weight: 900;
    font-size: .7rem;
    color: #3c2310
}

.qa dd {
    margin-top: 0.5rem
}

.qa dd:before {
    content: "A";
    margin-right: 0.25rem;
    margin-left: 0.1rem;
    font-weight: 900;
    font-size: .7rem;
    color: #3c2310
}

.check-list ul {
    list-style: none;
    padding-left: 0
}

.check-list li:before {
    content: "\f058 ";
    font-family: 'fontAwesome';
    color: #88b943;
    margin-right: 0.5rem
}

.ganban {
    margin: auto
}

@media screen and (min-width: 769px) {
    .ganban {
        padding: 0 1rem 1rem;
        border: 1px solid #88b943;
        width: calc(640px + 2rem)
    }
}

.ganban h3 {
    padding: .25rem .5rem;
    color: #FFF;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    background: #88b943
}

.ganban .ems {
    padding: 0 .5rem .5rem;
    border: 1px solid #88b943;
    background: #fafaf2
}

.ganban .osusume {
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    background: #fafaf2;
    list-style: none;
    margin: 1rem 0 0;
    padding: .5rem .5rem 1rem
}

.ganban .osusume li {
    width: 25%;
    border-bottom: 1px solid #3c2310;
    padding-left: 1em;
    text-indent: -1em
}

.ganban .osusume li:before {
    content: "●";
    margin-right: 0.2em;
    font-size: 0.4rem;
    color: #88b943
}

@media screen and (max-width: 768px) {
    .ganban .osusume li {
        width: 50%
    }
}

.ganban .ryokin {
    margin: 1rem;
    padding: 1rem;
    background: #fafaf2;
    border: 8px solid #3c2310;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    font-weight: 500;
    text-align: center;
    font-size: .8rem
}

.ganban .ryokin b {
    padding: 1rem;
    font-size: 1.4rem
}

.ganban .ryokin b span {
    color: #c42727;
    font-size: 1.6rem
}

@media screen and (max-width: 768px) {
    .ganban .ryokin {
        margin: 1rem 0;
        padding: 0.5rem;
        font-size: 0.5rem
    }

    .ganban .ryokin b {
        padding: .5rem;
        font-size: .6rem
    }

    .ganban .ryokin b span {
        font-size: .8rem
    }
}

.ganban .price table th,
.ganban .price table td {
    text-align: center
}

.jiko-flow {
    margin: 2rem 2rem 0;
    padding: 0 .5rem .5rem;
    border: 1px solid #88b943;
    background: #fafaf2
}

@media screen and (max-width: 768px) {
    .jiko-flow {
        margin: 1rem 0 0
    }
}

.jiko-flow dl {
    margin: 0
}

.jiko-flow dt {
    margin-top: 1rem;
    font-weight: 500
}

@media screen and (max-width: 768px) {
    .jiko-flow dt {
        font-size: 0.55rem
    }
}

.jiko-flow dt span {
    color: #7aa63c
}

.jiko-flow dd {
    margin: 0;
    font-size: 0.525rem;
    line-height: 1.4;
    padding: .5rem .75rem;
    background: #FFF;
    border: 1px solid #fafaf2
}

@media screen and (max-width: 768px) {
    .jiko-flow dd {
        font-size: 0.525rem;
        padding: .5rem .5rem
    }
}

.jiko-flow dd ul {
    margin: 0
}

.tnblow-logo-01 {
    width: 240px;
    padding: 0.5rem;
    border: 1px solid #ccc
}

@media screen and (max-width: 768px) {
    .tnblow-logo-01 {
        width: 80%
    }
}

.aruku {
    width: 61.8%;
    text-align: center;
    display: block;
    margin: auto
}

@media screen and (max-width: 768px) {
    .aruku {
        width: 80%
    }
}

.greenbox {
    display: inline-block;
    padding: 0 1rem .5rem;
    border: 1px solid #88b943;
    background: #fafaf2
}

.greenbox ul {
    margin: 0
}

.map {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    overflow: hidden;
    margin: 0
}

.map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.fixed-contact.asakashinkyu {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    width: 300px;
    margin: auto;
    margin-top: 2rem
}

@media screen and (max-width: 768px) {
    .fixed-contact.asakashinkyu {
        width: 220px
    }
}

.fixed-contact.asakashinkyu .upper {
    display: block;
    padding: .5rem;
    line-height: 1.4;
    background: #80ae3f;
    font-weight: 500;
    color: #3c2310;
    color: #FFF
}

.greenbox.asakashinkyu {
    width: 61.8%;
    margin-left: auto;
    margin-right: auto;
    display: block;
    overflow: hidden
}

@media screen and (max-width: 768px) {
    .greenbox.asakashinkyu {
        width: 100%
    }

    .greenbox.asakashinkyu b {
        line-height: 1.2;
        display: block
    }
}

.sp-flex-2 {
    display: flex
}

@media screen and (min-width: 769px) {
    .sp-flex-2 {
        float: right;
        width: 40%
    }
}

.sp-flex-2>div {
    width: 50%;
    border: 1px solid #fff
}

.price.asakashinkyu table th,
.price.asakashinkyu table td {
    line-height: 1.4
}

@media screen and (max-width: 768px) {
    .price.asakashinkyu table {
        width: 100%
    }

    .price.asakashinkyu table th,
    .price.asakashinkyu table td {
        display: block;
        width: 100%
    }
}

.price.asakashinkyu table small {
    line-height: 1.4;
    display: block;
    margin-top: 0.25rem
}

.contel {
    font-size: 1.2em;
    color: #FF0000;
}

.contel .telnum {
    font-size: 1.5em;
    color: #FF0000;
}

.line-ann {
    font-size: 1.1em;
}

.lineicon {
    width: 30%;
}

@media(max-width: 600px) {
    .lineicon {
        width: 90%;
        margin: 1em 5%;
    }
}

/*　　症例      */
.s-wrapper {
    width: 100%;
    margin: 2em auto;
}

.s-flex {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
}

.s-box {
    width: 32%;
    border: 2px solid #88b943;
    margin: 1em auto;
    text-align: center;
    padding: 1em;
}

@media(max-width:599px) {
    .s-box {
        width: 90%;
    }
}

.s-box h2 {
    font-weight: 400;
}

.s-box h2 span {
    font-size: 0.8em;
    font-weight: 300;
}

.s-box .btn-border {
    border-radius: 0;
    background: #88b943;
    font-weight: 400;
    text-align: center;
    margin: 1em auto;
    padding: 0.5em;
    color: #FFF;
}

.s-box .btn-border a {
    color: #FFF;
}

.btn-border:hover {
    color: #88b943 !important;
    background: transparent;
    border: 1px solid #88b943;
}

.btn-border a:hover {
    color: #88b943 !important;
}

/*---------------------------------
    自費鍼灸ページ
---------------------------------*/

/* メインコンテンツ */
.main-content {
    padding: 40px 0;
}

.section {
    margin-bottom: 60px;
    border-bottom: 1px solid #eee;
    padding-bottom: 40px;
}

.section:last-child {
    border-bottom: none;
}

.section-title {
    color: #4CAF50;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #4CAF50;
}

.section-content {
    margin-top: 30px;
}

.section-text {
    line-height: 1.8;
    margin-bottom: 30px;
    color: #555;
}

/* 画像ギャラリー */
.image-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 15px;
    margin-top: 20px;
}

.image-item {
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
    background: #f9f9f9;
    min-height: 180px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.image-placeholder {
    color: #999;
    font-size: 0.9rem;
    text-align: center;
    padding: 20px;
}

/* 効果リスト */
.effects-title {
    font-size: 1.3rem;
    color: #333;
    margin-bottom: 20px;
    font-weight: 600;
}

.effects-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin: 20px 0;
}

.effect-item {
    background: #f8f9fa;
    padding: 15px;
    border-radius: 4px;
    border-left: 4px solid #4CAF50;
    color: #555;
}

/* 注意事項 */
.notice {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 4px;
    padding: 20px;
    margin-top: 20px;
}

.notice-title {
    color: #856404;
    font-weight: bold;
    margin-bottom: 10px;
}

.notice p {
    color: #856404;
    line-height: 1.6;
}

/* 料金表 */
.pricing-section {
    margin-top: 30px;
}

.pricing-category {
    margin-bottom: 40px;
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
}

.pricing-category:last-child {
    margin-bottom: 0;
}

.pricing-header {
    background: #4CAF50;
    color: white;
    padding: 15px 20px;
    font-weight: bold;
    text-align: center;
}

.pricing-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
}

.pricing-table tr {
    border-bottom: 1px solid #eee;
}

.pricing-table tr:last-child {
    border-bottom: none;
}

.pricing-table td {
    padding: 15px 20px;
    vertical-align: top;
}

.service-name {
    font-weight: 600;
    color: #333;
    margin-bottom: 5px;
}

.service-details {
    color: #666;
}

.price {
    font-weight: bold;
    color: #e74c3c;
    font-size: 1rem;
    text-align: right;
}

.special-offer {
    background: #ff9800;
    color: white;
    padding: 12px 20px;
    text-align: center;
    font-weight: bold;
    font-size: 0.95rem;
}

.pricing-note {
    background: #f8f9fa;
    padding: 12px 20px;
    font-size: 0.85rem;
    color: #666;
    border-top: 1px solid #eee;
}

.pricing-note::before {
    content: "★ ";
    color: #ff9800;
    font-weight: bold;
}

/* レスポンシブ */
@media (max-width: 768px) {
    .page-title {
        font-size: 2rem;
    }

    .nav-menu ul {
        flex-direction: column;
        gap: 5px;
        text-align: center;
    }

    .container {
        padding: 0 15px;
    }

    .image-gallery {
        grid-template-columns: 1fr;
    }

    .effects-list {
        grid-template-columns: 1fr;
    }

    .pricing-table td {
        padding: 12px 15px;
    }

    .service-name {
        font-size: 0.95rem;
    }

    .price {
        font-size: 1rem;
    }
}

/*# sourceMappingURL=style.css.map */