@charset "UTF-8";

/*------------------------------------------------------
resetcss
------------------------------------------------------*/

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

body {
    line-height: 1;
}

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

nav ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}


/* change colours to suit your needs */

ins {
    background-color: #ff9;
    color: #000;
    text-decoration: none;
}


/* change colours to suit your needs */

mark {
    background-color: #ff9;
    color: #000;
    font-style: italic;
    font-weight: bold;
}

del {
    text-decoration: line-through;
}

abbr[title],
dfn[title] {
    border-bottom: 1px dotted;
    cursor: help;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}


/* change border colour to suit your needs */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #cccccc;
    margin: 1em 0;
    padding: 0;
}

input,
select {
    vertical-align: middle;
}


/*------------------------------------------------------
ページcss
------------------------------------------------------*/


/* font*/

body {
    /*font-family: 'Noto Sans JP', sans-serif;*/
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

@media screen and (max-width: 768px) {
    body {
        font-size: 3vw;
    }
}

.selif {
    font-family: 'Noto Serif JP', serif;
}

.sans {
    font-family: 'Noto Sans JP', sans-serif;
}


/*　共通　*/

.flex {
    display: flex;
}

.justify {
    justify-content: space-between;
}

a {
    color: #222;
    text-decoration: underline;
}

p {
    line-height: 1.5;
    color: #666;
    letter-spacing: 2px;
}

.sp {
    display: none;
}

.pc {
    display: block;
}

.logo {
    max-width: 282px;
}

.logo img {
    width: 100%;
}


/* header */

.header-inner {
    /*height:48px;*/
    padding: 26px 20px;
    max-width: 1240px;
    margin: 0 auto;
}

@media screen and (max-width: 768px) {
    .header-inner {
        padding: 12px 10px;
    }
}

.header-info {
    list-style: none;
    font-size: 0.6em;
    display: table-cell;
    vertical-align: middle;
    padding-right: 20px;
}

.header-info li {
    margin-bottom: 10px;
}

.right-menu {
    display: table;
    right: 0;
    margin-right: 0;
    margin-left: 20px;
    table-layout: fixed;
    /*
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);*/
}

.head-contact-button {
    display: table-cell;
    vertical-align: middle;
    padding-right: 30px;
}

@media screen and (max-width: 768px) {
    .header-info {
        display: none;
    }
    .head-contact-button {
        display: none;
    }
}

.menu-button {
    display: table-cell;
    vertical-align: middle;
    cursor: pointer;
}

.menu-button img {
    width: 100%;
}


/* main visual */


/*.mv{
  background:url('../img/mv.jpg');
  background-size:cover;
  height:65vw;
  background-position:top;
}*/

.mv-contents-slider {
    overflow: hidden;
}

.mv-contents-slider img {
    width: 100%;
    max-width: 100%;
    height: 65vw;
    object-fit: cover;
}

.mv-img {
    width: 48.5%;
    line-height: 0;
}

.mv-img img {
    width: 100%;
}

.mv-contents {
    position: relative;
}

.mv-contents-slider-caption {
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    position: absolute;
    top: 50%;
    margin-top: -10px;
    left: 180px;
}

.mv-contents .slick-initialized .slick-slide {
    position: relative;
}

.mv-contents .slick-dots li button:before {
    content: "";
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: #fff;
    opacity: 1;
}

.mv-contents .slick-dots {
    bottom: 200px;
}

@media screen and (max-width: 768px) {
    .mv-contents-slider-caption {
        left: 0;
        width: 100%;
        text-align: center;
        font-size: 18px;
        display: none;
    }
    .mv-contents-slider img {
        height: 110vw;
    }
    .mv-contents .slick-dots {
        bottom: 30px;
    }
}


/*
.mv-contents h2{
  position: absolute;
  top: 200px;
  left: 80px;
}
@media screen and (max-width: 768px){
  .mv-contents h2{
    width: 80%;
    top: 100px;
    left: 30px;
  }
}
.mv-contents h2 img{
  width: 100%;
}
*/


/* menu */

menu {
    position: fixed;
    background: #fff;
    width: 100%;
    height: 100%;
    z-index: 1000;
    display: none;
}

menu .menu-inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 26px 20px;
    height: 100%;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

menu .menu-head {
    display: flex;
    justify-content: space-between;
}

menu .menu-logo {
    width: auto;
    width: 282px;
}

menu .menu-logo img {
    width: 100%;
}

menu .close {
    width: auto;
    cursor: pointer;
    margin-left: 20px;
}

menu .close img {
    width: 100%;
}

@media screen and (max-width: 768px) {
    menu .menu-inner {
        padding: 12px 10px;
    }
    menu .menu-logo {
        max-width: 282px;
    }
    menu .close {
        /*width: 25vw;*/
    }
}

menu .menu-box {
    clear: both;
    display: flex;
    justify-content: center;
}

menu .menu-box ul {
    list-style-type: none;
    margin-top: 40px;
}

menu .menu-box ul+ul {
    margin-left: 230px;
}

menu .menu-box ul li {
    margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
    menu .menu-box ul {
        margin-top: 20px;
    }
    menu .menu-box ul+ul {
        margin-left: 10vw;
    }
    menu .menu-box ul li {
        margin-bottom: 40px;
    }
}

menu .menu-box ul li a {
    font-weight: bold;
    text-decoration: none;
}

menu .menu-box ul li .sub-cont {
    margin-top: 30px;
}

menu .menu-box ul li .sub-cont li {
    list-style-type: disc;
    list-style-position: inside;
    margin-bottom: 20px;
}

menu .menu-box ul li .sub-cont li a {
    font-size: 0.8em;
    font-weight: normal;
}

menu .menu-btn {
    display: flex;
    justify-content: center;
    margin-bottom: 40px;
    text-align: center;
    margin: 0 auto;
}

menu .menu-btn p+p {
    margin: 0 0 0 60px;
}

menu .phone {
    display: none;
}

@media screen and (max-width: 768px) {
    menu .menu-btn {
        display: block;
        max-width: 300px;
    }
    menu .menu-btn p+p {
        margin: 30px 0 0 0;
    }
    menu .phone {
        display: block;
        margin: 40px 0;
        text-align: center;
    }
}

.stiky-menu {
    position: fixed;
    right: 0;
    bottom: 100px;
    z-index: 100;
    display: block;
}

@media screen and (max-width: 768px) {
    .stiky-menu {
        display: none;
    }
}

.stiky-menu p {
    text-align: center;
    margin-bottom: 23px;
}

.stiky-menu p.mt60 {
    margin-top: 60px;
}


/* campaign */

.campaign-box {}

.top-mar {
    margin-bottom: -200px;
}

.campaign-inner {
    margin: 0 auto;
    max-width: 1189px;
}

.top-float {
    border-radius: 10px;
    background: #fff;
    position: relative;
    top: -200px;
    right: 0;
    left: 0;
}

@media screen and (max-width: 768px) {
    .top-mar {
        margin-bottom: 0px;
    }
    .top-float {
        top: -50px;
    }
}

.campaign-box h3 {
    text-align: center;
    padding: 55px 0 40px 0;
    width: 214px;
    margin: 0 auto;
}

.campaign-box h3 img {
    width: 100%;
}

.campaign-box ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    list-style-type: none;
    padding: 0 54px;
}

.campaign-box ul li {
    position: relative;
    max-width: 340px;
    margin: 0 10px 40px 10px;
    /*flex-basis: calc(33% - 20px);*/
}

@media screen and (max-width: 768px) {
    .campaign-box h3 {
        width: 50vw;
        max-width: 214px;
    }
    .campaign-box ul {
        display: block;
        padding: 0 20px;
    }
    .campaign-box ul li {
        margin: 0 auto 40px auto;
    }
    .campaign-box ul li+li {
        margin-left: auto;
    }
}

.campaign-box ul li::after {
    content: "キャンペーン";
    background: #c2a1a1;
    color: #fff;
    padding: 10px 30px;
    font-size: 12px;
    font-weight: bold;
    /*background:url('../img/tag-cp.png') no-repeat;
  background-size:100% auto;*/
    position: absolute;
    top: 0;
    left: 0;
}

.campaign-box ul li img {
    width: 100%;
}


.campaign-box ul li dl {
    margin-top: 12px;
}
.campaign-box ul li dl dd {
    line-height: 1.5em;
    word-break: break-word;
}
.campaign-box ul li dt {
    line-height: 1.8em;
    font-weight: bold;
    letter-spacing: 0px;
    font-size: 1.2em;
    margin: 15px 0;
}
.campaign-box ul li dt a {
    color: #666;
    text-decoration: none;
}
.campaign-box ul li dt span,
.event-box ul li dt span {
    margin-right: 10px;
    background: #c2a1a1;
    color: #fff;
    padding: 5px 10px;
    font-size: 12px;
    width: fit-content;
    letter-spacing: 0;
}
.event-box ul li dt span {
    margin-right: 10px;
    background: #e3dd95;
    color: #fff;
    padding: 5px 10px;
    font-size: 12px;
    width: fit-content;
    letter-spacing: 0;
}
@media screen and (max-width: 768px) {
    .campaign-box ul li::after {
        font-size: 2vw;
    }
    
    .campaign-box ul li dt {
        font-size: 4vw;
        margin: 2vw 0;
        line-height: 8vw;
    }
    
    .campaign-box ul li dt span {
        font-size: 2vw;
    }
}
.event-box {
    margin-bottom: 120px;
}
.event-inner {
    background: #fff;
    margin: 0 auto;
    max-width: 1189px;
}
.event-box h3 {
    text-align: center;
    padding: 120px 0 40px 0;
    width: 125px;
    margin: 0 auto;
}
.event-box h3 img {
    width: 100%;
}
.event-box ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    list-style-type: none;
    padding: 0 54px;
}
.event-box ul li {
    position: relative;
    max-width: 340px;
    margin: 0 10px 40px 10px;
    /*flex-basis: calc(33% - 20px);*/
}
.event-box ul li::after {
    content: "イベント";
    background: #e3dd95;
    color: #222;
    padding: 10px 30px;
    font-size: 12px;
    font-weight: bold;
    /*background:url('../img/tag-ev.png') no-repeat;
  background-size:100% auto;*/
    
    position: absolute;
    top: 0;
    left: 0;
}
.event-box ul li img {
    width: 100%;
}
.event-box ul li dl {
    margin-top: 12px;
}
.event-box ul li dl dt {
    font-weight: bold;
    line-height: 1.5em;
}
.event-box ul li dl dd {
    margin-top: 20px;
    line-height: 1.5em;
}
.event-box ul li dl p {
    margin-bottom: 20px;
    background: #e3dd95;
    color: #222;
    padding: 10px 30px;
    font-size: 12px;
    font-weight: bold;
    width: fit-content;
    line-height: 1;
    letter-spacing: 0;
    font-weight: bold;
}
@media screen and (max-width: 768px) {
    .event-box h3 {
        padding: 16vw 0 10vw 0;
        max-width: 125px;
        width: 30vw;
    }
    
    .event-box ul {
        display: block;
        padding: 0 20px;
    }
    
    .event-box ul li {
        margin: 0 auto 40px auto;
    }
    
    .event-box ul li+li {
        margin-left: auto;
    }
    
    .event-box ul li::after {
        font-size: 2vw;
    }
    
    .event-box ul li dl p {
        font-size: 2vw;
    }
}
.concept-box {
    margin-bottom: 120px;
    padding-bottom: 80px;
    background: #b1c4c9;
}
.concept-inner {
    margin: 0 auto;
    max-width: 1189px;
    padding: 0 20px;
}
.concept-box h3 {
    text-align: center;
    padding: 80px 0 40px 0;
}
.concept-box h4 {
    color: #ffffff;
    font-size: 20px;
    text-align: center;
    font-weight: bold;
    padding-bottom: 40px;
    line-height: 2em;
}
.concept-box ul {
    display: flex;
    justify-content: space-around;
    list-style-type: none;
    margin-bottom: 40px;
}
.concept-box ul li {
    min-width: 100px;
}
.concept-box ul li+li {
    padding-left: 2vw;
}
@media screen and (max-width: 768px) {
    .concept-box ul {
        flex-wrap: wrap;
    }
    
    .concept-box ul li {
        max-width: 130px;
        margin-bottom: 20px;
    }
    
    .concept-box ul li+li {
        padding-left: 0;
    }
}
.concept-box ul li img {
    width: 100%;
}
.concept-box p {
    text-align: center;
}

/* 仮plan */

/*
.plan-box-kari{
}

.plan-inner-kari{
  border-radius:10px;
  background:#fff;
  margin:0 auto;
  max-width: 1189px;
  position: relative;
  top: -200px;
  right: 0;
  left: 0;
  margin-bottom: 120px;
}
@media screen and (max-width: 768px){
  .plan-inner-kari{
    top: -50px;
  }
}
.plan-box-kari h3{
  text-align: center;
  padding: 40px 0;
}
.plan-box-kari .plan-list{
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  list-style-type: none;
}
.plan-box-kari .plan-list .plan-desc{
  position: relative;
  max-width: 520px;
  margin-bottom: 60px;
}
.plan-box-kari ul li img{
  width: 100%;
}
.plan-box-kari  ul li dt{
  text-align: center;
  font-weight: bold;
  margin: 20px 0;
}
.plan-box-kari  ul li dd .tag-list{
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  list-style-type: none;
}
*/

/* plan */
.plan-box {
    margin-bottom: 130px;
}
.plan-inner {
    margin: 0 auto;
    max-width: 1189px;
    padding: 0 20px;
}
.plan-box h3 {
    text-align: center;
    padding-bottom: 40px;
}
.plan-box .plan-list {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    list-style-type: none;
}
.plan-box .plan-list .plan-desc {
    position: relative;
    max-width: 520px;
    margin-bottom: 60px;
}
.plan-desc a:hover {
    opacity: 0.8;
}
.plan-box ul li img {
    width: 100%;
}
.plan-box ul li dt {
    text-align: center;
    font-weight: bold;
    margin: 20px 0;
}
.plan-box ul li dd .tag-list {
    display: flex;
    justify-content: space-evenly;
    flex-wrap: wrap;
    list-style-type: none;
}
.tag-list li {
    width: 120px;
    height: 34px;
    line-height: 34px;
    text-align: center;
    color: #fff;
    font-size: 13px;
    font-weight: bold;
    background: #74746f;
    margin-bottom: 2vw;
}
@media screen and (max-width: 768px) {
    .plan-box {
        margin-bottom: 15vw;
    }
    
    .tag-list li {
        width: 120px;
        height: 34px;
        line-height: 34px;
        font-size: 2vw;
    }
}
.ph-gallery-box {
    margin-bottom: 130px;
}
.plan-gallery {
    flex-wrap: wrap;
    justify-content: flex-start;
}
.plan-gallery-inner {
    width: 16%;
    margin: 2%;
}
.plan-gallery h3 {
    text-align: center;
    padding-bottom: 70px;
}
.plan-gallery img {
    width: 100%;
}
.ph-gallery-inner {
    margin: 0 auto;
    max-width: 1365px;
    padding: 0 20px;
}
.ph-gallery-box .photo-list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    list-style-type: none;
}
.ph-gallery-box .photo-list li {
    width: 273px;
}
.ph-gallery-box .photo-list li img {
    width: 100%;
    height: 273px;
    max-height: 273px;
    object-fit: cover;
}
@media screen and (max-width: 768px) {
    .ph-gallery-box h3 {
        padding-bottom: 40px;
    }
    
    .ph-gallery-box h3 img {
        width: 100%;
        max-width: 305px;
    }
    
    .ph-gallery-box .photo-list li {
        width: 28vw;
        max-height: 273px;
    }
    
    .ph-gallery-box .photo-list li img {
        width: 100%;
        height: 28vw;
        max-height: 273px;
        object-fit: cover;
    }
}
.studio-box {
    margin-bottom: 130px;
    padding-bottom: 40px;
    background: #b1c4c9;
}
.studio-inner {
    margin: 0 auto;
    max-width: 1189px;
    padding: 0 20px;
}
.studio-box h3 {
    text-align: center;
    padding: 55px 0 40px 0;
}
.studio-box .studio-list {
    display: flex;
    justify-content: space-between;
    list-style-type: none;
}
@media screen and (max-width: 768px) {
    .studio-box {
        margin-bottom: 15vw;
        padding-bottom: 5vw;
    }
    
    .studio-box .studio-list {
        display: block;
    }
    
    .plan-gallery-inner {
        width: 48%;
    }
    
    .plan-gallery img {
        width: 100%;
    }
}
.studio-box .studio-list .studio-desc {
    max-width: 340px;
    margin: 0 auto 40px auto;
}
.studio-box ul li+li {
    padding-left: 2vw;
}
.studio-box ul li dl dt {
    text-align: center;
    font-weight: bold;
    margin: 20px 0;
}
.studio-box ul li dl dd {
    line-height: 1.5;
    color: #444;
    letter-spacing: 2px;
}
.info-box {
    margin-bottom: 120px;
}
.info-inner {
    margin: 0 auto;
    max-width: 1050px;
    padding: 0 20px;
}
.info-box h3 {
    text-align: center;
    padding: 55px 0 40px 0;
}
.info-box .info-list {
    list-style-type: none;
    padding: 0 20px;
}
.info-box .info-list .info-arc {
    margin-bottom: 22px;
    display: flex;
}
.info-box ul li p {}
.info-box ul li .info-tag ul {
    display: flex;
    list-style: none;
    align-items: center;
}
.info-box ul li .info-tag ul li {
    margin: 0 40px 0 20px;
    padding: 8px 15px;
    background: #c3a1a1;
    font-size: 0.8em;
    text-align: center;
    width: 100px;
}
.info-box ul li .info-tag ul li a {
    color: #fff;
    text-decoration: none;
    display: block;
}
@media screen and (max-width: 768px) {
    .info-box h3 {
        width: 60vw;
        padding-bottom: 10vw;
        margin: 0 auto;
    }
    
    .info-box h3 img {
        width: 100%;
        max-width: 262px;
    }
    
    .info-box .info-list .info-arc {
        display: block;
    }
    
    .info-box ul li .info-tag ul li {
        margin: 10px 0 0 0;
        width: auto;
    }
    
    .info-box ul li p.page-title {
        display: block;
        margin: 10px 0 40px 0;
    }
}
.other-box {
    margin-bottom: 40px;
}
.other-inner {
    margin: 0 auto;
    max-width: 1189px;
    padding: 0 20px;
}
.other-box h3 {
    text-align: center;
    padding-bottom: 40px;
}
.other-box .other-list {
    display: flex;
    justify-content: space-between;
    list-style-type: none;
}
.other-box .other-list .other-desc {
    margin-bottom: 40px;
}
.other-box .other-list .other-desc+li {
    padding-left: 2vw;
    text-align: center;
}
.other-box ul li dl dt {
    text-align: center;
    margin: 40px 0 20px 0;
}
.other-box ul li dl dd {
    line-height: 1.5;
    color: #444;
    letter-spacing: 2px;
}
.other-box ul li p {
    margin-top: 20px;
}
.info-date {
    width: 150px;
}
@media screen and (max-width: 768px) {
    .other-box .other-list {
        display: block;
    }
    
    .other-box .other-list .other-desc {
        margin: 0 auto 10vw auto;
    }
    
    .other-box .other-list .other-desc+li {
        padding-left: 0;
    }
    
    .other-box ul li dl dt img {
        max-width: 100%;
    }
}
.footer-btn {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    list-style-type: none;
}
.footer-reserv {
    background: #e3dd95;
    background-image: url("../img/icon-reserv.png");
    background-size: 80px;
    background-repeat: no-repeat;
    background-position: center center;
    border: solid 2px #e3dd95;
    height: 70px;
    width: calc(33% - 4px);
    margin: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
.footer-contact {
    background: #fff;
    background-image: url("../img/icon-contact.png");
    background-size: 120px;
    background-repeat: no-repeat;
    background-position: center center;
    border: solid 2px #e3dd95;
    height: 70px;
    width: calc(34% - 4px);
    margin: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
.footer-line {
    background: #2db620;
    background-image: url("../img/icon-line.png");
    background-size: 85px;
    background-repeat: no-repeat;
    background-position: center center;
    border: solid 2px #2db620;
    height: 70px;
    width: calc(33% - 4px);
    margin: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
.footer-reserv a,
.footer-contact a,
.footer-line a {
    display: block;
    width: 100%;
    height: 100%;
}
@media screen and (max-width: 768px) {
    .footer-reserv {
        background-size: 43%;
        height: 14vw;
    }
    
    .footer-contact {
        background-size: 60%;
        height: 14vw;
    }
    
    .footer-line {
        background-size: 48%;
        height: 14vw;
    }
}
.footer-menu {
    background: #b1c4c9;
    padding: 10vw 20px 220px 20px;
}
.footer-menu .footer-menu-list a {
    text-decoration: none;
    font-weight: bold;
}
.footer-menu .footer-menu-list {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    list-style-type: none;
    padding-bottom: 6vw;
    margin: 0 auto;
    max-width: 1189px;
    border-bottom: solid #fff 2px;
}
.footer-menu .footer-menu-list .sub-menu-list {
    list-style-type: none;
    margin-top: 15px;
    line-height: 2.5;
}
@media screen and (max-width: 768px) {
    .footer-menu {
        padding: 10vw 20px 40vw 20px;
    }
    
    .footer-menu .footer-menu-list {
        justify-content: left;
    }
    
    .footer-menu .footer-menu-list li {
        margin: 0 0 30px 30px;
    }
    
    .footer-menu .footer-menu-list .sub-menu-list li {
        list-style-type: none;
        line-height: 1.5em;
        margin: 0;
    }
}
.footer-menu .footer-menu-list .sub-menu-list a {
    font-weight: normal;
}
.footer-menu .footer-info {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    list-style-type: none;
    padding: 6vw 0 0 0;
    margin: 0 auto;
    max-width: 1189px;
}
.footer-menu .footer-info .banner-list {
    list-style-type: none;
    max-width: 324px;
}
.footer-menu .footer-info .banner-list img {
    width: 100%;
    margin-bottom: 20px;
}
.footer-menu .footer-info .footer-logo {
    padding: 0 30px 30px 0;
}
.footer-menu .footer-info .shop-info {
    list-style-type: none;
    line-height: 1.5em;
    margin-bottom: 40px;
}
.footer-menu .footer-info .shop-info img {
    margin: 20px 0;
}
.footer-menu .footer-info .shop-info a {
    display: block;
}
.footer-menu .footer-info .shop-info .info-hour {
    display: table-cell;
    padding-right: 10px;
    border-right: solid 1px #222;
}
.footer-menu .footer-info .shop-info .info-week {
    display: table-cell;
    padding-left: 10px;
}
.footer-menu .campany-link {
    display: flex;
    justify-content: center;
    list-style-type: none;
    margin: 0 auto;
}
.footer-menu .campany-link li+li {
    border-left: solid 1px #222;
    margin-left: 20px;
    padding-left: 20px;
}
.footer-menu .campany-link a {
    text-decoration: none;
}
.footer-menu .copy {
    text-align: center;
    font-size: 0.8em;
    margin: 20px 0;
    line-height: 1.5em;
}
@media screen and (max-width: 768px) {
    .footer-menu .footer-info .footer-logo {
        padding: 0 4vw 8vw 4vw;
    }
    
    .footer-menu .footer-info .footer-logo img {
        width: 100%;
        max-width: 282px;
    }
    
    .footer-menu .footer-info .shop-info .info-hour {
        display: block;
        padding-right: 0;
        border-right: none;
    }
    
    .footer-menu .footer-info .shop-info .info-week {
        display: block;
        padding-left: 0;
    }
}

/* float */
.float-box {
    position: fixed;
    right: 0;
    left: 0;
    bottom: 0;
}

/*
.float-box .banner-list{
  list-style-type: none;
  max-width: 324px;
}
.float-box .banner-list img{
  width: 100%;
  margin-bottom: 20px;
}
*/
.float-box .top-btn {
    display: none;
}
@media screen and (max-width: 768px) {
    /*.float-box{
    position: fixed;
    right: 0;
    left: 0;
    bottom: 0;
  }*/
    /*
  .float-box .banner-list{
    list-style-type: none;
    width: 80%;
  }
  .float-box .banner-list img{
    width: 100%;
    margin-bottom: 3vw;
  }
  */
    /*.float-box .top-btn{
    position: fixed;
    bottom: 0;
    right: 0;
  }*/
    
    .float-box .top-btn {
        display: block;
    }
    
    .float-box .top-btn img {
        max-width: 47px;
        width: 10vw;
    }
}
.second-mv h1 img {
    width: 100%;
}
.bread-list ul {
    max-width: 1189px;
    margin: 0 auto;
    padding: 15px 20px 60px 20px;
    line-height: 2em;
}
.bread-list ul li {
    display: inline-block;
    list-style-type: none;
    border-right: solid 1px #222;
    padding-right: 20px;
    margin-right: 20px;
    margin-bottom: 10px;
}
.bread-list ul li:last-child {
    border-right: none;
    padding-right: 0;
    margin-right: 0;
}
@media screen and (max-width: 768px) {
    .bread-list ul {
        padding: 15px 20px 30px 20px;
        line-height: 2em;
    }
}

/* common */
.common-box {}
.common-inner {
    margin: 0 auto;
    max-width: 1189px;
}
.common-box h3 {
    text-align: center;
    padding: 55px 0 40px 0;
}
.common-box .common-list {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    list-style-type: none;
    padding: 0 54px;
}
.common-box .common-list .common-desc {
    position: relative;
    max-width: 340px;
    margin-bottom: 60px;
}
.common-box ul li p {
    text-align: center;
    margin-top: 15px;
}
.common-box ul li dl dd {
    line-height: 1.5;
    color: #444;
    letter-spacing: 2px;
}

/* plan */
.plan-detail-box {}
.plan-detail-inner {
    margin: 0 auto;
    max-width: 1189px;
    padding: 0 20px;
}
.plan-detail-box h3 {
    color: #c3a1a1;
    font-size: 2em;
    text-align: center;
    padding: 55px 0 40px 0;
}
.plan-detail-box .plan-cap {
    text-align: center;
    line-height: 2em;
}
.plan-detail-box h4 {
    margin: 120px 0 60px 0;
    font-size: 1.5em;
    text-align: center;
}
.plan-detail-box .plan-detail-list {
    list-style-type: none;
}
.plan-detail-box .plan-detail-list .plan-detail {
    margin-bottom: 40px;
    display: flex;
}
@media screen and (max-width: 768px) {
    .plan-detail-box .plan-detail-list .plan-detail {
        margin-bottom: 40px;
        display: block;
    }
    
    .top-btn {
        text-align: right;
        margin: 0 20px 30px 0;
    }
}
.plan-detail-box .plan-detail-list .plan-detail .sumb {
    max-width: 360px;
    margin: 0 auto;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc {
    width: 100%;
    max-width: 790px;
    padding-left: 40px;
}
@media screen and (max-width: 768px) {
    .plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc {
        width: 100%;
        max-width: 790px;
        padding: 4vw 0 0 0;
        text-align: center;
    }
}
.plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc h5 {
    color: #c3a1a1;
    background: #f9f5f5;
    font-size: 1.5em;
    padding: 30px 40px;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc .price {
    color: #c3a1a1;
    font-size: 2em;
    font-weight: bold;
    padding-left: 40px;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc .ans {
    color: #666666;
    font-size: 0.8em;
    padding-left: 40px;
}
@media screen and (max-width: 768px) {
    .plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc .price {
        padding-left: 0;
    }
    
    .plan-detail-box .plan-detail-list .plan-detail .plan-detail-desc .ans {
        padding-left: 0;
    }
}
.plan-detail-box .plan-detail-list .plan-detail .sumb img {
    width: 100%;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-set {
    padding-left: 40px;
    margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
    .plan-detail-box .plan-detail-list .plan-detail .plan-set {
        padding-left: 0;
    }
}
.plan-detail-box .plan-detail-list .plan-detail .plan-set p {
    color: #666666;
    margin: 40px 0 15px 0;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-set ul {
    list-style-type: none;
    display: flex;
    flex-wrap: wrap;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-set ul li {
    width: 64px;
    margin-right: 10px;
}
.plan-detail-box .plan-detail-list .plan-detail .plan-set ul li img {
    width: 100%;
}
@media screen and (max-width: 768px) {
    .plan-detail-box .plan-detail-list .plan-detail .plan-set ul {
        justify-content: start;
    }
    
    .plan-detail-box .plan-detail-list .plan-detail .plan-set ul li {
        width: 18%;
        margin-right: 2%;
        margin-bottom: 10px;
    }
}
.plan-common-sumb {
    max-width: 1189px;
    margin: 70px auto 120px auto;
}
.plan-common-sumb img {
    width: 100%
}

/* studio */
.studio-map-box {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 20px;
}
.studio-map-box .google-map {
    text-align: center;
}
.studio-map-box .google-map iframe {
    width: 100%;
}
.studio-map-box .map-cap {
    margin: 40px 0 80px 0;
}
.studio-route-box {
    max-width: 1080px;
    margin: 0 auto 120px auto;
    padding: 0 20px;
}
.studio-route-box h3 {
    text-align: center;
    font-weight: bold;
    font-size: 1.5em;
    margin-bottom: 40px;
}
.studio-route-box .select-tab {
    display: flex;
    justify-content: center;
    list-style-type: none;
    margin-bottom: 15px;
}
.studio-route-box .select-tab li {
    position: relative;
    padding: 20px;
    border: solid 2px #b1c4c9;
    text-align: center;
    width: calc(50% - 8px);
}
.studio-route-box .select-tab li {
    background: #fff;
    color: #b1c4c9;
    cursor: pointer;
}
.studio-route-box .select-tab .is-active {
    background: #b1c4c9;
    color: #fff;
    cursor: auto;
}
.studio-route-box .select-tab .is-active:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -8px;
    border: 8px solid transparent;
    border-top: 12px solid #b1c4c9;
}
.studio-route-box .route-guide {
    background: #e7edef;
    padding: 50px 60px;
    display: none;
}
@media screen and (max-width: 768px) {
    .studio-route-box .route-guide {
        padding: 5vw 6vw;
    }
}
.studio-route-box .is-show {
    display: block;
}
.studio-route-box .route-guide ul {
    display: flex;
    justify-content: left;
    flex-wrap: wrap;
    list-style-type: none;
}
.studio-route-box .route-guide ul+ul {
    margin-top: 40px;
}
.studio-route-box .route-guide ul li {
    width: calc(25% - 18px);
    padding-right: 24px;
}
.studio-route-box .route-guide ul li:last-child {
    padding-right: 0;
}
@media screen and (max-width: 768px) {
    .studio-route-box .route-guide ul {
        display: block;
    }
    
    .studio-route-box .route-guide ul li {
        width: 100%;
        margin-bottom: 6vw;
    }
}
.studio-route-box .route-guide ul li img {
    width: 100%;
    margin-bottom: 12px;
}
.studio-info-box {
    max-width: 1080px;
    margin: 0 auto 120px auto;
    padding: 0 20px;
}
.studio-info-box h3 {
    text-align: center;
    font-weight: bold;
    font-size: 1.5em;
    margin-bottom: 40px;
}
.studio-info-box ul li {
    list-style-type: none;
    margin-bottom: 120px;
}
.studio-info-box p {
    padding: 0 20px;
}
.studio-info-box h4 {
    text-align: center;
    margin: 23px 0;
}

/* flow */
.flow-box {
    max-width: 1080px;
    margin: 0 auto 120px auto;
    padding: 0 20px;
}
.flow-box h2 {
    text-align: center;
    font-weight: bold;
    font-size: 1.5em;
    margin-bottom: 40px;
}
.flow-box .flow-guide {
    background: #e7edef;
    padding: 50px 60px;
    display: none;
}
.flow-box .flow-guide ol li {
    display: flex;
    list-style-type: none;
    margin-bottom: 60px;
}
.flow-box .flow-guide ol li:last-child {
    margin-bottom: 0;
}
.flow-box .flow-guide ol p {
    text-align: center;
}
.flow-box .flow-guide ol li dl {
    padding: 20px 0 0 60px;
}
.flow-box .flow-guide ol li dl dt {
    font-weight: bold;
    margin-bottom: 20px;
}
.flow-box .flow-guide ol li dl dd {
    line-height: 1.6em;
}
@media screen and (max-width: 768px) {
    .flow-box {
        margin: 0 auto 20vw auto;
    }
    
    .flow-box .flow-guide {
        padding: 10vw 6vw;
    }
    
    .flow-box .flow-guide ol li {
        display: block;
        margin-bottom: 60px;
    }
    
    .flow-box .flow-guide ol li dl {
        padding: 20px 0 0 0;
    }
    
    .flow-box .flow-guide ol li dl dt {
        text-align: center;
    }
}

/* faq */
.faq-box {
    max-width: 1080px;
    margin: 0 auto 120px auto;
    padding: 0 20px;
}
.faq-box h2 {
    text-align: center;
    font-weight: bold;
    font-size: 1.5em;
    margin-bottom: 40px;
}
.faq-box dl dt {
    background: url("../img/icon-q.png") no-repeat;
    background-size: 64px;
    background-position: left center;
    padding-left: 80px;
    line-height: 64px;
    font-weight: bold;
    margin-bottom: 25px;
    position: relative;
    cursor: pointer;
}
.faq-box dl dt:before {
    content: "";
    position: absolute;
    top: calc(50% - 10px);
    right: 0;
    width: 24px;
    height: 24px;
    background: url("../img/btn-faq-open.png") no-repeat;
    background-size: 24px 24px;
    background-position: right center;
}
.faq-box dl .faq-open:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 24px;
    height: 4px;
    background: url("../img/btn-faq-close.png") no-repeat;
    background-size: 24px 8px;
    background-position: right center;
}
.faq-box dl dd {
    background: url("../img/icon-a.png") no-repeat;
    background-size: 64px;
    background-position: left center;
    padding-left: 80px;
    line-height: 64px;
    font-weight: normal;
    margin-bottom: 25px;
    display: none;
}
@media screen and (max-width: 768px) {
    .faq-box {
        margin: 0 auto 20vw auto;
    }
    
    .faq-box dl dt {
        background-size: 7vw;
        padding: 0 6vw 0 9vw;
        line-height: 8vw;
        margin-bottom: 25px;
    }
    
    .faq-box dl dt:before {
        top: calc(50% - 2vw);
        width: 4vw;
        height: 4vw;
        background-size: 4vw 4vw;
    }
    
    .faq-box dl .faq-open:before {
        width: 4vw;
        height: 0.6vw;
        background-size: 4vw 1.3vw;
    }
    
    .faq-box dl dd {
        background-size: 7vw;
        padding-left: 9vw;
        line-height: 8vw;
    }
}

/* campaign detail */
.campaign-detail {
    max-width: 1080px;
    margin: 0 auto 150px auto;
    padding: 0 20px;
}
.campaign-detail .camp-img {
    margin-bottom: 40px;
}
.campaign-detail h1 img {
    width: 100%;
}
.campaign-detail .camp-ttl {
    color: #222;
    font-weight: bold;
    font-size: 1.5em;
    margin-bottom: 40px;
    position: relative;
    line-height: 2em;
}
.campaign-detail .camp-ttl span {
    background: #c2a1a1;
    color: #fff;
    padding: 10px 20px;
    font-size: 12px;
    font-weight: bold;
    margin-right: 20px;
}
.campaign-detail .detail p {
    margin-bottom: 60px;
    line-height: 1.8;
    min-height: 20px;
}
.campaign-detail .detail h1 {
    font-size: 1.8em;
    margin-bottom: 15px;
}
.campaign-detail .detail h2 {
    font-size: 1.6em;
    margin-bottom: 15px;
}
.campaign-detail .detail h3 {
    font-size: 1.4em;
    margin-bottom: 15px;
}
.campaign-detail .detail h4 {
    font-size: 1.2em;
    margin-bottom: 15px;
}
.campaign-detail .detail h5 {
    font-size: 1em;
    margin-bottom: 15px;
}
.campaign-detail .detail ul,
.campaign-detail .detail ol {
    list-style-position: inside;
    line-height: 1.5em;
    margin-bottom: 30px;
}
.campaign-detail .detail blockquote {
    border-left: 4px solid #999;
    margin-bottom: 30px;
    padding-left: 1em;
}
.campaign-detail .detail blockquote p {
    margin-bottom: 0;
    color: #999;
}
.campaign-detail .detail figure {
    margin-bottom: 60px;
}
.campaign-detail .detail figcaption {
    text-align: center;
    font-size: 0.8em;
    color: #999;
    margin-top: 20px;
}
@media screen and (max-width: 768px) {
    .campaign-detail {
        margin: 0 auto 18vw auto;
    }
    
    .campaign-detail .camp-img {
        margin-bottom: 6vw;
    }
    
    .campaign-detail .camp-ttl {
        padding: 0;
        margin-bottom: 6vw;
        line-height: 1.5em;
    }
    
    .campaign-detail .camp-ttl span {
        display: block;
        padding: 0 20px;
        width: fit-content;
        margin-bottom: 10px;
        line-height: 3em;
        font-size: 2vw;
    }
    
    .campaign-detail .detail p {
        margin-bottom: 40px;
        line-height: 1.4;
        min-height: 10px;
    }
    
    .campaign-detail .detail figure {
        margin-bottom: 40px;
    }
    
    .campaign-detail .detail figcaption {
        text-align: center;
        font-size: 0.8em;
        color: #999;
        margin-top: 10px;
    }
}

/* photo gallery */
.photo-search-box {
    max-width: 1080px;
    margin: 0 auto 150px auto;
    padding: 0 20px;
}
.photo-search-box .photo-search-select {
    display: flex;
    margin-bottom: 70px;
}
.photo-search-box .photo-search-select p {
    max-width: 280px;
    width: 100%;
    font-weight: bold;
}
.photo-search-box .photo-search-select ul {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
}
.photo-search-box .photo-search-select ul li a {
    margin: 0 25px 20px 0;
    text-align: center;
    padding: 8px 20px 10px 20px;
    font-weight: bold;
    color: #fff;
    background: #ccc;
    text-decoration: none;
    border-radius: 3px;
    display: block;
}

/*
.radio-box{
  display: flex;
  flex-wrap: wrap;
}
.radio-input{
  display: none;
}
.radio-input + label{
  padding-left: 34px;
  position:relative;
  margin:0 40px 20px 0;
  color: #999;
  line-height: 24px;
  font-weight: bold;
}
.radio-input + label::before{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  background: #999;
  border-radius: 50%;
}
.radio-input:checked + label{
  color: #c3a1a1;
}
.radio-input:checked + label::after{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  background: #c3a1a1;
  border-radius: 50%;
}
.keyword-select{
  display: flex;
}
.keyword-select p{
  max-width: 280px;
  width: 100%;
  font-weight: bold;
}
.check-box{
  display: flex;
  flex-wrap: wrap;
}
input[type=checkbox] {
display: none;
}
input[type="checkbox"]:checked + label {
background: #c3a1a1;
}
.label {
display: block;
margin: 0 25px 20px 0;
text-align: center;
padding:8px 20px 10px 20px;
cursor: pointer;
font-weight: bold;
color: #fff;
background: #ccc;
border-radius: 3px;
}
*/
.photo-list-box {
    max-width: 1080px;
    margin: 0 auto 150px auto;
    padding: 0 20px;
}
.photo-list-box .photo-thumb {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin-bottom: 40px;
}
.photo-list-box .photo-thumb li {
    margin: 10px;
    width: calc(20% - 20px);
}
.photo-list-box .photo-thumb li img {
    width: 100%;
    height: 16vw;
    max-height: 196px;
    object-fit: cover;
}
.photo-list-box h3 {
    text-align: center;
    padding-bottom: 70px;
}
.pager .pagination {
    text-align: center;
}
.pager .pagination li {
    display: inline;
    margin: 0 2px;
    padding: 0;
    display: inline-block;
    width: 32px;
    height: 32px;
    text-align: center;
    position: relative;
    border-radius: 32px;
}
.pager .pagination li a {
    vertical-align: middle;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    display: table;
    text-decoration: none;
}
.pager .pagination li span {
    display: table-cell;
    vertical-align: middle;
}
.pager .pagination li .dots {
    vertical-align: middle;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    display: table;
    text-decoration: none;
}
.pager .pagination li a:hover,
.pager .pagination li a.active {
    color: #fff;
    background: #b1c4c9;
    border-radius: 10px;
    border-radius: 32px;
}
@media screen and (max-width: 768px) {
    .photo-search-box {
        margin: 0 auto 15vw auto;
    }
    
    .photo-search-box .photo-search-select {
        display: block;
        margin-bottom: 10vw;
    }
    
    .photo-search-box .photo-search-select p {
        margin-bottom: 20px;
    }
    
    .photo-search-box .photo-search-select ul {
        display: flex;
        flex-wrap: wrap;
        list-style: none;
    }
    
    .photo-search-box .photo-search-select ul li a {
        margin: 0 4vw 4vw 0;
        text-align: center;
        padding: 3vw 4vw 3vw 4vw;
        font-weight: bold;
        color: #fff;
        background: #ccc;
        text-decoration: none;
        border-radius: 3px;
        display: block;
    }
    /*
  .plan-select{
    display: block;
    margin-bottom: 7vw;
  }
  .plan-select p{
    margin-bottom: 20px;
  }
  .keyword-select{
    display: block;
  }
  .keyword-select p{
    margin-bottom: 20px;
  }
  */
    
    .photo-list-box {
        margin: 0 auto 15vw auto;
    }
    
    .photo-list-box .photo-thumb {
        margin-bottom: 4vw;
    }
    
    .photo-list-box .photo-thumb li {
        margin: 1vw;
        width: calc(33% - 2vw);
    }
    
    .photo-list-box .photo-thumb li img {
        height: 26vw;
        max-height: 196px;
        object-fit: cover;
    }
    
    .photo-list-box h3 {
        padding-bottom: 10vw;
        width: 60vw;
        margin: 0 auto;
    }
    
    .photo-list-box h3 img {
        width: 100%;
        max-width: 305px;
    }
}

/* blog */
.blog-box {
    max-width: 1080px;
    margin: 60px auto 150px auto;
    padding: 0 20px;
}
.blog-box::after {
    content: "";
    clear: both;
    overflow: hidden;
    display: block;
}
.article-list {
    float: left;
    width: calc(70% - 50px);
    margin-right: 50px;
}
.article-list .article-box {
    display: flex;
    justify-content: space-between;
    ;
    flex-wrap: wrap;
}
.article-list .article-box .article-detail {
    list-style: none;
    width: 48%;
    margin-bottom: 70px;
}
.article-list .article-box .article-detail a {
    text-decoration: none;
}
.article-list .article-box .article-detail img {
    width: 100%;
}
.article-info {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 10px 0 20px 0;
}
.article-info p {
    color: #ccc;
    letter-spacing: 1px;
    font-size: 0.8em;
    padding: 5px 15px 5px 0;
    margin-bottom: 10px;
}
.article-info ul {
    display: flex;
}
.article-info ul li {
    list-style: none;
    margin-bottom: 10px;
}
	.article-info ul li + li {
		margin-left: 10px;
	}
.article-info ul li a {
    color: #fff;
    padding: 5px 15px;
    background: #c3a1a1;
    font-size: 0.8em;
    text-decoration: none;
}
.blog-date span.red {
    background: #c3a1a1;
}
.blog-date span.blue {
    background: #a2d0dd;
}
.blog-date span.yellow {
    background: #e3dd95;
}
.blog-date span.green {
    background: #8db580;
}
.article-list .article-box .article-detail h2 {
    margin-bottom: 15px;
}
.article-list .article-box .article-detail .detail {
    letter-spacing: 1px;
    font-size: 0.9em;
}
.side-menu {
    float: right;
    width: 30%;
}
.category-list {
    padding-bottom: 60px;
    border-bottom: solid 1px #eee;
    margin-bottom: 60px;
}
.category-list p {
    text-align: center;
    font-weight: bold;
    margin-bottom: 35px;
}
.category-list ul {
    list-style: none;
    width: 72%;
    margin: 0 auto;
}
.category-list ul li {
    background: #c3a1a1;
    padding: 8px;
    border-radius: 3px;
    margin: 0 auto 16px auto;
    text-align: center;
}
.category-list ul li a {
    color: #fff;
    letter-spacing: 2px;
    text-decoration: none;
    display: block;
}

/*
.category-list p{
  max-width: 245px;
  width: 90%;
  margin: 0 auto;
  padding: 20px 0;
  text-align: center;
  color: #666;
  border: solid 1px #666;
  cursor: pointer;
  display: block;
  position: relative;
  font-weight: bold;
}
.category-list p:after{
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 25px;
	width: 0;
	height: 0;
	margin-top: -2px;
	border: 5px solid transparent;
	border-top: 7px solid #666;
}
.category-list p.drop:after{
  border-top: none;
	border-bottom: 7px solid #666;
}

.category-list ul{
  display: none;
  max-width: 245px;
  width: 90%;
  margin: 0 auto;
  list-style: none;
  text-align: center;
  border: solid 1px #666;
  border-top: none;
}
.category-list ul li{
  border-top: solid 1px #ddd;
}
.category-list ul li:first-child{
  border-top: none;
}
.category-list ul li a{
  color: #666;
  padding: 20px 0;
  display: block;
  text-decoration: none;
}
*/
.keyword-list {
    padding-bottom: 60px;
    border-bottom: solid 1px #eee;
    margin-bottom: 60px;
}
.keyword-list p {
    text-align: center;
    font-weight: bold;
    margin-bottom: 35px;
}
.keyword-list ul {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
}
.keyword-list ul li {
    background: #ccc;
    padding: 8px 20px;
    border-radius: 3px;
    margin: 0 16px 16px 0;
}
.keyword-list:not(.articles) ul li:first-child {
    margin: 0 0 16px 0;
}
.keyword-list ul li a {
    color: #fff;
    letter-spacing: 2px;
    text-decoration: none;
}

/* コンテンツタイトル（h2） > キーワードタグ */
.keyword-list.articles {
  padding-bottom: 0;
  border-bottom: none;
  margin-bottom: 1rem;
  font-size: 0.8em;
}
	.keyword-list.articles ul li {
		margin: 0 12px 12px 0;
	}

.archive-list {}
.archive-list p {
    text-align: center;
    font-weight: bold;
    margin-bottom: 35px;
}
.archive-list ul {
    list-style: none;
    text-align: center;
}
.archive-list ul li {
    margin-bottom: 20px;
}
.archive-list ul li a {
    color: #c3a1a1;
}
.blog-detail {
    float: left;
    width: calc(70% - 50px);
    margin-right: 50px;
}
.blog-detail a {
    color: #c3a1a1;
}
.blog-detail img {
    width: 100%;
	height: auto;
}
.blog-detail .article-title {
    margin-bottom: 20px;
    font-size: 1.5em;
    line-height: 1.5em;
}
.blog-detail .detail {}
.blog-detail .detail p {
    margin-bottom: 60px;
    line-height: 1.8;
    min-height: 20px;
}
.blog-detail .detail h1 {
    font-size: 1.8em;
    margin-bottom: 15px;
}
.blog-detail .detail h2 {
    font-size: 1.6em;
    margin-bottom: 15px;
}
.blog-detail .detail h3 {
    font-size: 1.4em;
    margin-bottom: 15px;
}
.blog-detail .detail h4 {
    font-size: 1.2em;
    margin-bottom: 15px;
}
.blog-detail .detail h5 {
    font-size: 1em;
    margin-bottom: 15px;
}
.blog-detail .detail ul,
.blog-detail .detail ol {
    list-style-position: inside;
    line-height: 1.5em;
    margin-bottom: 30px;
}
.blog-detail .detail blockquote {
    border-left: 4px solid #999;
    margin-bottom: 30px;
    padding-left: 1em;
}
.blog-detail .detail blockquote p {
    margin-bottom: 0;
    color: #999;
}
.blog-detail .detail figure {
    margin-bottom: 60px;
}
.blog-detail .detail figcaption {
    text-align: center;
    font-size: 0.8em;
    color: #999;
    margin-top: 20px;
}
@media screen and (max-width: 768px) {
    .blog-box {
        margin: 6vw auto 15vw auto;
    }
    
    .article-list {
        float: none;
        width: 100%;
        margin-right: 0;
    }
    
    .article-list .article-box .article-detail {
        width: 100%;
        margin-bottom: 15vw;
    }
    
    .side-menu {
        float: none;
        width: 100%;
    }
    
    .category-list {
        padding-bottom: 6vw;
        margin-bottom: 6vw;
    }
    
    .category-list ul {
        max-width: 50%;
    }
    
    .category-list ul li {
        padding: 2vw;
    }
    
    .keyword-list {
        padding-bottom: 6vw;
        margin-bottom: 6vw;
    }
    
    .keyword-list:not(.articles) ul {
        justify-content: center;
    }
		.keyword-list:not(.articles) ul li:first-child {
			margin: 0 12px 12px 0;
		}
    
    .keyword-list p {
        margin-bottom: 5vw;
    }
    
    .archive-list p {
        margin-bottom: 5vw;
    }
    
    .blog-detail {
        float: none;
        width: 100%;
        margin-right: 0;
        margin-bottom: 15vw;
    }
    
    .blog-detail .detail p {
        margin-bottom: 40px;
        line-height: 1.4;
        min-height: 10px;
    }
    
    .blog-detail .detail figure {
        margin-bottom: 40px;
    }
    
    .blog-detail .detail figcaption {
        text-align: center;
        font-size: 0.8em;
        color: #999;
        margin-top: 10px;
    }
}

/* select-tab */
.select-tab {
    display: flex;
    justify-content: center;
    list-style-type: none;
    margin-bottom: 15px;
}
.select-tab li {
    position: relative;
    padding: 20px;
    border: solid 2px #b1c4c9;
    text-align: center;
    width: calc(50% - 8px);
}
.select-tab li {
    background: #fff;
    color: #b1c4c9;
    cursor: pointer;
}
.select-tab .is-active {
    background: #b1c4c9;
    color: #fff;
    cursor: auto;
}
.select-tab .is-active:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -8px;
    border: 8px solid transparent;
    border-top: 12px solid #b1c4c9;
}
.is-show {
    display: block!important;
}
.center-btn {
    text-align: center;
    margin-top: 40px;
}
@media screen and (max-width: 768px) {
    .center-btn img {
        width: 100%;
        max-width: 360px;
    }
}
.twocul-btn {
    display: flex;
    justify-content: center;
    margin-bottom: 120px;
    padding: 0 20px;
    text-align: center;
}
.twocul-btn p+p {
    margin-left: 40px;
}
@media screen and (max-width: 768px) {
    .twocul-btn {
        display: block;
        margin-bottom: 120px;
    }
    
    .twocul-btn p+p {
        margin-left: 0;
        margin-top: 30px;
    }
}
.twocul-btn img {
    width: 100%;
    max-width: 360px;
}
.btn {
    max-width: 400px;
    height: 64px;
    line-height: 64px;
    margin: 40px auto 0 auto;
}
.btn-min {
    min-width: 280px;
    height: 48px;
    line-height: 48px;
    margin: 0;
}
.btn a,
.btn-min a {
    display: block;
    height: 100%;
    margin: 0 20px;
    text-decoration: none;
    background: #E3DD95;
    text-align: center;
    color: #222222;
    font-size: 16px;
    font-weight: bold;
    border-radius: 50px;
    -webkit-border-radius: 50px;
    -moz-border-radius: 50px;
}

/*
.btn a:hover,
.btn-min a:hover{
    background:#DBD690;
    color:#222222;
    margin-left:0px;
    margin-top:0px;
    box-shadow:none;
}
*/
.btn a span,
.btn-min a span {
    background-image: url("../img/icon-btn-arw.png");
    background-repeat: no-repeat;
    background-position: right bottom 46%;
    padding-right: 20px;
}
@media screen and (max-width: 768px) {
    .btn {
        max-width: 450px;
        height: 15vw;
        line-height: 15vw;
        margin: 0 auto;
    }
    
    .btn-min {
        height: 15vw;
        line-height: 15vw;
        margin: 0;
    }
    
    .btn a,
    .btn-min a {
        margin: 0 20px;
        font-size: 1.2em;
    }
}
.thumb {
    width: 100%;
}

/* contact */
.contact-box {
    max-width: 880px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
}
.contact-box dt {
    width: calc(25% - 20px);
    line-height: 40px;
    font-size: 16px;
    font-weight: bold;
    margin-right: 20px;
}
span.star {
    color: red;
}
.contact-box dd {
    width: 75%;
    margin-bottom: 20px;
    font-size: 16px;
}
.contact-box dd.camp-ttl {
    line-height: 45px;
}
.contact-box dd input {
    width: 100%;
    height: 20px;
    font-size: 16px;
    border: 1px solid #ccc;
    padding: 10px;
}
.contact-box dd textarea {
    width: 100%;
    border: 1px solid #ccc;
    padding: 10px;
}
.contact-button {
    display: block;
    width: 360px;
    margin: 30px auto 0;
}
.contact-button input {
    background: #e3dd95;
    cursor: pointer;
    width: 360px;
    height: 64px;
    border-radius: 40px;
    border: none;
    font-size: 16px;
    font-weight: bold;
    background-image: url("http://cleex.xsrv.jp/studio/wp-content/themes/studiojellish/img/sankaku.png");
    background-size: 8px 8px;
    background-repeat: no-repeat;
    background-position: right 40px bottom 50%;
}
.complete-message p {
    text-align: center;
}

/*
.contact-button input::after{
  content:"";
  background:url("http://cleex.xsrv.jp/studio/wp-content/themes/studiojellish/img/icon-btn-arw.png");
  background-size:100% 100%;
  display:block;
  width:8px;
  height:8px;
  z-index:99;
}
*/
@media screen and (max-width: 768px) {
    .contact-box {
        max-width: 100%;
        margin: 0 auto;
        display: block;
        flex-wrap: wrap;
    }
    
    .contact-box dd.camp-ttl {
        line-height: 1;
        margin-bottom: 10px;
    }
    
    .contact-box dd input {
        width: 90%;
        height: 20px;
        font-size: 16px;
        border: 1px solid #ccc;
        padding: 10px;
    }
    
    .contact-box dd textarea {
        width: 90%;
        border: 1px solid #ccc;
        padding: 10px;
    }
    
    .contact-button,
    .contact-box dt,
    .contact-box dd {
        width: 90%;
        margin: 0 auto;
    }
    
    .contact-button {
        margin: 30px auto;
    }
    
    .contact-button input {
        width: 100%;
        font-size: 14px;
        height: 44px;
        background-position: right 20px bottom 50%;
    }
}
.mw_wp_form {
    margin-bottom: 80px;
}
.complete-message {
    margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
    .mw_wp_form {
        margin-bottom: 10vw;
    }
    
    .complete-message {
        margin-bottom: 10vw;
    }
}

/* 2020/12/15 追記（池田） */
.rental_img {
    width: 100%;
}
.navigation {
    
}
ul.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
}
ul.pagination li a {
    font-size: 25px;
    text-decoration: none;
    width: 39px;
    height: 39px;
    background: #B4C4C8;
    color: #ffffff;
    margin-left: 3px;
    margin-right: 3px;
    display: flex;
    justify-content: center;
    align-items: center;
}
ul.pagination li.active a {
    background: #c3a1a1;
}