@charset "UTF-8";
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, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background-color: transparent
}

body {
  line-height: 1
}

article, aside, dialog, figure, footer, header, hgroup, nav, section {
  display: block
}

ul {
  list-style: none
}

blockquote, q {
  quotes: none
}

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

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

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

input, button, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: 0;
  border-radius: 0
}

select {
  outline: 0;
  border-radius: 0
}

input, textarea {
  padding: 0;
  background-color: inherit;
  border: none
}

iframe[name=google_conversion_frame] {
  height: 0!important;
  width: 0!important;
  line-height: 0!important;
  font-size: 0!important;
  margin-top: -13px
}

noscript p {
  font-size: 20px;
  line-height: 1.5;
  color: red
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

select::-ms-expand {
  display: none
}

h1, h2, h3, h4, h5 {
  font-weight: 400
}

html, body {
  height: 100%;
  min-height: 100%
}

input[type=text]:focus, a:focus, button:focus {
  outline: 0
}

.wrapper {
  position: relative;
  min-height: 100%;
  height: auto!important;
  height: 100%
}

.wrap {
  position: relative
}

body {
  font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, Segoe UI, sans-serif;
  background-color: #fff;
  transition: opacity .6s cubic-bezier(.25, .1, .25, 1);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  color: #444
}

body.is--load {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

.clearfix:after {
  height: 0;
  visibility: hidden;
  content: ".";
  display: block;
  clear: both;
  font-size: 0;
  line-height: 0;
  overflow: hidden
}

.clearfix {
  _height: 1px;
  min-height: 1px
}

.show_pc {
  display: block
}

@media only screen and (max-width:1100px) {
  .show_pc {
    display: none
  }
}

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

.show_pctb {
  display: block
}

@media only screen and (max-width:1100px) {
  .show_pctb {
    display: block
  }
}

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

.show_pctb_inline {
  display: inline
}

@media only screen and (max-width:1100px) {
  .show_pctb_inline {
    display: inline
  }
}

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

.show_tbsp {
  display: none
}

@media only screen and (max-width:1100px) {
  .show_tbsp {
    display: block
  }
}

@media only screen and (max-width:768px) {
  .show_tbsp {
    display: block
  }
}

.show_tb {
  display: none
}

@media only screen and (max-width:1100px) {
  .show_tb {
    display: block
  }
}

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

.show_tb_inline {
  display: none
}

@media only screen and (max-width:1100px) {
  .show_tb_inline {
    display: inline
  }
}

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

.show_sp {
  display: none
}

@media only screen and (max-width:1100px) {
  .show_sp {
    display: none
  }
}

@media only screen and (max-width:768px) {
  .show_sp {
    display: block
  }
}

.show_sp_inline {
  display: none
}

@media only screen and (max-width:1100px) {
  .show_sp_inline {
    display: none
  }
}

@media only screen and (max-width:768px) {
  .show_sp_inline {
    display: inline
  }
}

.fadeinup {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 60px);
  transition: 600ms ease
}

.fadeInUp {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.fadein {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transition: 800ms ease
}

.fadeIn {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

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

::-moz-selection {
  background: #eee
}

::selection {
  background: #eee
}

::-moz-selection {
  background: #eee
}

input:-webkit-autofill {
  box-shadow: 0 0 0 1000px #fff inset
}

input, textarea {
  background-color: #eee
}

input:focus, textarea:focus {
  background-color: #eee
}

a {
  color: #444;
  text-decoration: none;
  transition: color .5s cubic-bezier(.25, .1, .25, 1);
  transition: opacity 500ms
}

@media screen and (min-width:1100px) {
  a:hover {
    opacity: .5;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"
  }
}

img {
  -webkit-backface-visibility: hidden
}

label {
  width: 100%;
  cursor: pointer
}

input[type=radio], input[type=checkbox] {
  display: inline-block;
  margin-right: 6px
}

input[type=radio]+label, input[type=checkbox]+label {
  position: relative;
  display: inline-block;
  margin-right: 12px;
  font-size: 12px;
  line-height: 30px;
  color: #261357;
  cursor: pointer
}

@media(min-width:1px) {
  input[type=radio], input[type=checkbox] {
    display: none;
    margin: 0
  }
  input[type=radio]+label, input[type=checkbox]+label {
    padding: 0 0 0 30px;
    display: block!important
  }
  input[type=radio]+label:before, input[type=checkbox]+label:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 2px;
    box-sizing: border-box;
    display: block;
    width: 18px;
    height: 18px;
    margin-top: -9px;
    background: #fff
  }
  input[type=radio]+label:before {
    border: 1px solid #bbb;
    border-radius: 30px
  }
  input[type=checkbox]+label:before {
    border: 1px solid #bbb;
    display: block!important
  }
  input[type=radio]:checked+label:after, input[type=checkbox]:checked+label:after {
    content: "";
    position: absolute;
    top: 50%;
    box-sizing: border-box;
    display: block!important
  }
  input[type=radio]:checked+label:after {
    left: 7px;
    width: 8px;
    height: 8px;
    margin-top: -4px;
    background: #241754;
    border-radius: 8px
  }
  input[type=checkbox]:checked+label:after {
    left: 5px;
    width: 12px;
    height: 6px;
    margin-top: -4px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg)
  }
  input[type=radio]:checked+label:before {
    background-color: #fff
  }
  input[type=checkbox]:checked+label:before {
    background: #241754
  }
}

@media only screen and (max-width:767px) and (min-width:1px) {
  input[type=radio]+label, input[type=checkbox]+label {
    padding: 0 0 0 30px
  }
  input[type=radio]+label:before, input[type=checkbox]+label:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    box-sizing: border-box;
    display: block;
    width: 21px;
    height: 21px;
    margin-top: -10px;
    background: #FFF
  }
  input[type=radio]+label:before {
    border: 1px solid #ccc;
    border-radius: 30px
  }
  input[type=checkbox]+label:before {
    border: 1px solid #ccc
  }
  input[type=radio]:checked+label:after, input[type=checkbox]:checked+label:after {
    content: "";
    position: absolute;
    top: 50%;
    box-sizing: border-box;
    display: block
  }
  input[type=radio]:checked+label:after {
    left: 7px;
    width: 6px;
    height: 6px;
    margin-top: -3px;
    background: #000;
    border-radius: 8px
  }
  input[type=checkbox]:checked+label:after {
    left: 3px;
    width: 16px;
    height: 8px;
    margin-top: -8px;
    border-left: 3px solid #fff;
    border-bottom: 3px solid #fff;
    transform: rotate(-45deg)
  }
}

label.original_select, label.original_select * {
  font-family: YakuHanJP, sans-serif
}

label.original_select {
  position: relative;
  display: inline-block;
  background: #fff;
  font-size: 1em;
  overflow: hidden;
  z-index: 0;
  border: solid 1px #e8e8e8;
  border-radius: 26px
}

label.original_select:after {
  content: "";
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  top: 50%;
  right: 17px;
  margin-top: -.2em;
  border-width: .45em .3em;
  border-style: solid;
  border-color: #cdcdcd transparent transparent;
  z-index: -1
}

label.original_select select {
  width: 94%;
  height: auto;
  box-sizing: border-box;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: .4em 3em .4em 1.5em;
  margin: 0;
  color: #727272;
  background: transparent;
  border: none;
  border-radius: 0;
  font-size: 1em;
  outline: none
}

label.original_select select::-ms-expand {
  display: none
}

label.original_select select::-moz-focus-inner {
  border: 0
}

label.original_select select * {
  background: #fff;
  color: #727272;
  text-shadow: none
}



#loadingWrap {
  width: 100%;
  height: 100vh;
  background: #fff;
  position: fixed;
  top: -100vh;
  left: 0;
  z-index: 999999999999;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 0;
}

.now--load #loadingWrap {
  opacity: 0.8;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  top: 0;
  transition: opacity 1200ms ease 0ms;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  width: 100%;
  background-color: #fff; 
}
#loading{
	width: 32px;
	height: 32px;
}
#loading img{
	width: 100%;
	height: 100%;
}

.wrapper {
  padding-top: 80px
}

@media only screen and (max-width:768px) {
  .wrapper {
    padding-top: 52px
  }
}

.error404 .wrap {
  min-height: calc(100vh - 340px)
}

@media only screen and (max-width:768px) {
  .error404 .wrap {
    min-height: 0
  }
}

.is--sticky .globalHeader {
  height: 50px
}

@media only screen and (min-width:769px) {
  .is--sticky .globalHeader__logo img {
    width: 180px;
    height: auto
  }
}

.is--sticky .globalHeader__searchText,
.is--sticky .globalHeader__mypageText
{
  display: none
}

@media only screen and (min-width:769px) {
  .is--sticky .globalHeader__nav {
    right: 280px;
    transform: translate(0, -50%)
  }
}

.is--sticky .globalHeader__lang {
  height: 24px
}

.is--sticky .globalHeader__langIcon img {
  width: 14px;
  height: auto
}

.is--sticky .globalHeader__langText {
  font-size: 12px
}

.globalHeader {
  width: 100%;
  height: 80px;
  padding: 0 30px 0 36px;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  transition: all 300ms ease;
  border-bottom: 1px solid #ddd
}

@media screen and (min-width:769px) and (max-width:1140px) {
  .globalHeader {
    padding: 0 15px 0 18px
  }
}

@media only screen and (max-width:768px) {
  .globalHeader {
    height: 52px;
    padding: 0 20px;
    border-bottom: 1px solid #d5d5d5;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    background-color: #fff
  }
}

.globalHeader__logo img {
  height: 24px;
  display: block;
  transition: all 300ms ease
}

@media screen and (min-width:769px) and (max-width:1140px) {
  .globalHeader__logo img {
    width: 170px
  }
}

@media only screen and (max-width:768px) {
  .globalHeader__logo img {
    width: 170px;
    height: auto
  }
}

@media only screen and (max-width:768px) {
  .is--spMenuOpen .globalHeader__nav {
    transform: translate(0, 0)
  }
}

.globalHeader__nav {
  position: absolute;
  top: 50%;
  right: 50%;
  transform: translate(50%, -50%);
  transition: all 300ms ease
}

@media only screen and (max-width:768px) {
  .globalHeader__nav {
    position: fixed;
    top: -20px;
    right: 0;
    background-color: #fff;
    max-width: 338px;
    width: 90.13%;
    height: calc(100% + 40px);
    transform: translate(100%, 0);
    z-index: 1003;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    transition: all 600ms ease
  }
}

.is--spMenuOpen .spNavoverlay {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  visibility: visible;
  z-index: 1002;
  transition: opacity 600ms ease 0ms, visibility 0ms ease 0ms
}

.spNavoverlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, .7);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  visibility: hidden;
  z-index: -1;
  transition: opacity 600ms ease 0ms, visibility 0ms ease 600ms
}

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

.globalHeader__navClose {
  position: absolute;
  top: 30px;
  right: 15px;
  padding: 10px;
  background-color: #fff;
  z-index: 2
}

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

.globalHeader__navClose span {
  color: #333;
  font-size: 13px;
  letter-spacing: .03em;
  padding-left: 18px;
  position: relative
}

.globalHeader__navClose span:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -6px;
  width: 13px;
  height: 13px;
  background-image: url(/assets/img/common/icon_close.png);
  background-repeat: no-repeat;
  background-size: 100% auto
}

@media only screen and (max-width:768px) {
  .globalHeader__navInner {
    width: 100%;
    margin: 0 auto;
    max-height: 100vh;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    padding: 60px 11.24%;
    box-sizing: border-box
  }
}

.globalHeader__navList {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .globalHeader__navList {
    display: block
  }
}

.globalHeader__navItem {
  margin-left: 25px;
  position: relative;
  display: inline-block;
  height: 19.5px
}

@media screen and (min-width:769px) and (max-width:1140px) {
  .globalHeader__navItem {
    margin-left: 13px
  }
}

@media only screen and (max-width:768px) {
  .globalHeader__navItem {
    display: block;
    margin-left: 0;
    border-bottom: 1px solid #c7c7c7;
    height: auto
  }
  .globalHeader__navItem.no-border {
    border-width: 0px;
  }
}

.globalHeader__navItem:first-child {
  margin-left: 0
}

.globalHeader__navItem:after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #df7094;
  transition: width 600ms ease
}

.globalHeader__navItem.is--current:after {
  width: 100%
}

@media only screen and (max-width:768px) {
  .globalHeader__navItem.is--current span {
    padding-left: 20px;
    position: relative
  }
  .globalHeader__navItem.is--current span:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 12px;
    height: 2px;
    margin-top: -1px;
    background-color: #e04175
  }
}

@media only screen and (min-width:769px) {
  .globalHeader__navItem:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
  .globalHeader__navItem:hover:after {
    width: 100%
  }
}

.globalHeader__navLink {
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .075em;
  color: #666;
  font-feature-settings: "palt";
  color: #444;
  font-weight: 500;
  position: relative;
  z-index: 2;
  display: block
}

.globalHeader__navLink.show_sp {
  display: none;
}

.globalHeader__navItem.show_sp {
  display: none;
}

@media screen and (min-width:769px) and (max-width:1140px) {
  .globalHeader__navLink {
    font-size: 10px
  }
}

@media only screen and (max-width:768px) {
  .globalHeader__navLink {
    padding: 20px 0;
    display: block;
    box-sizing: border-box;
    font-size: 15px;
    letter-spacing: .025em;
    font-weight: 600;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 5px 8px;
    background-position: right center
  }
  .globalHeader__navLink.search {
    background-image: url(/assets/img/common/icon_search_pink.svg);
    background-repeat: no-repeat;
    background-size: 24px 24px;
    background-position: right center
  }
  .globalHeader__navLink.small {
    padding: 10px 0;
    display: block;
    box-sizing: border-box;
    font-size: 12px;
    letter-spacing: .025em;
    font-weight: 600;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 5px 8px;
    background-position: right center
  }
}

@media only screen and (min-width:769px) {
  .globalHeader__navLink:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
}

.globalHeader__navLink--pulldown {
  padding-right: 15px;
  background-image: url(/assets/img/common/arr_nav.png);
  background-repeat: no-repeat;
  background-size: 8px 6px;
  background-position: 100% center
}

.globalHeader__navLink--pulldown.show_sp {
  display: none
}

@media only screen and (max-width:768px) {
  .globalHeader__navItem.show_sp {
    display: block;
  }
  .globalHeader__navLink.show_sp {
    display: block;
  }
  .globalHeader__navLink.show_pctb {
    display: none;
  }
  .globalHeader__navLink--pulldown {
    padding-right: 0;
    position: relative;
    background-image: none !important;
  }
  .globalHeader__navLink--pulldown.show_pctb {
    display: none
  }
  .globalHeader__navLink--pulldown.show_sp {
    display: block
  }
  .globalHeader__navLink--pulldown:before, .globalHeader__navLink--pulldown:after {
    content: "";
    position: absolute;
    top: 50%;
    background-color: #a1a1a1;
    transform: translate(0, -50%)
  }
  .globalHeader__navLink--pulldown:before {
    width: 11px;
    height: 1px;
    right: 0
  }
  .globalHeader__navLink--pulldown:after {
    width: 1px;
    height: 11px;
    right: 5px
  }
  .globalHeader__navLink--pulldown.is--openSpNavPulldown:after {
    display: none
  }
}

.globalHeader__pulldownList {
  position: absolute;
  top: 100%;
  left: -42px;
  padding: 35px 42px;
  box-sizing: border-box;
  background-color: #f6f6f6;
  display: none
}

@media only screen and (max-width:768px) {
  .globalHeader__pulldownList {
    position: relative;
    top: 0;
    left: 0;
    padding: 0;
    background-color: #fff;
    padding-bottom: 20px
  }
}

.globalHeader__pulldownListItem {
  margin-top: 10px
}

@media only screen and (max-width:768px) {
  .globalHeader__pulldownListItem {
    margin-top: 20px
  }
}

.globalHeader__pulldownListItem:first-child {
  margin-top: 0
}

.globalHeader__pulldownListLink {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .075em;
  font-weight: 500;
  padding-left: 20px;
  position: relative;
  white-space: nowrap
}

@media only screen and (max-width:768px) {
  .globalHeader__pulldownListLink {
    font-size: 14px;
    letter-spacing: .025em;
    display: block;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 5px 8px;
    background-position: right center
  }
  .globalHeader__pulldownListLink.small {
    font-size: 12px;
    margin-top: 15px;
  }
}

.globalHeader__pulldownListLink:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 1px;
  background-color: #b9b9b9;
  transform: translate(0, -50%)
}

.globalHeader__pulldownSubList {
  margin-bottom: 5px;
  padding-left: 10px
}

.globalHeader__pulldownSubListItem {
  margin-top: 10px
}

@media only screen and (max-width:768px) {
  .globalHeader__pulldownSubListItem {
    margin-top: 20px
  }
  .globalHeader__pulldownSubListItem.small {
    margin-top: 5px
  }
}

.globalHeader__pulldownSubListLink {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .075em;
  padding-left: 20px;
  white-space: nowrap
}

@media only screen and (max-width:768px) {
  .globalHeader__pulldownSubListLink {
    display: block;
    font-size: 14px;
    color: #666;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 5px 8px;
    background-position: right center
  }

  .globalHeader__pulldownSubListLink.small {
    margin-top: 15px;
    font-size: 12px;
  }
}

.globalHeader__subNav {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  position: relative
}

.globalHeader__mypage {
    margin-right: 10px;
    cursor: pointer;
}

@media only screen and (max-width:768px) {
  .globalHeader__search {
    margin-right: 70px
  }
}

.globalHeader__searchIcon {
  text-align: center;
  width: 26px;
  height: 26px;
  background-image: url(/assets/img/common/icon_search.svg);
  background-repeat: no-repeat;
  background-size: 26px 26px;
  display: block;
  margin: 0 auto
}

.globalHeader__mypageIcon {
  text-align: center;
  width: 26px;
  height: 26px;
  background-image: url(/assets/img/common/icon_mypage.png);
  background-repeat: no-repeat;
  background-size: auto 26px;
  background-position: center;
  display: block;
  margin: 0 auto
}

@media only screen and (max-width:768px) {
  .globalHeader__searchIcon {
    background-image: url(/assets/img/common/icon_search_pink.svg)
  }
  .globalHeader__mypageIcon {
    background-image: url(/assets/img/common/icon_mypage_pink.png)
  }
}

.globalHeader__searchText,
.globalHeader__mypageText {
  font-size: 11px;
  letter-spacing: .025em;
  display: block;
  color: #666;
  font-feature-settings: "palt"
}

@media only screen and (max-width:768px) {
  .globalHeader__searchText,
  .globalHeader__mypageText {
    display: none
  }
}

.mypageMenu {
    position: absolute;
    top: 50px;
    right: 10px;
    background: #fdfdfd;
    border-radius: 5px;
    box-shadow: 1px 1px 5px 2px rgba(0,0,0,0.1);
    overflow: hidden;
}

.is--sticky .mypageMenu {
    top: 60px;
}

.mypageMenu__listLink {
    color: black;
}

.mypageMenu__listItem {
    padding: 6px;
    min-width: 200px;
    text-align: center;
    cursor: pointer;
}

.mypageMenu__listItem a {
    padding: 10px 0px;
    display: block;
}
.mypageMenu__listItem:hover {
    background-color: #efebeb;
}

.mypageMenu__listLink.name {
    font-size: 1.2rem;
}

.mypageMenu__listLink.email {
    font-size: 0.9rem;
}

.mypageMenu__listItem.border {
    border-top: 1px solid #e8e8e8;
    padding: 0;
}

#header-mypageMenu-name,
#header-mypageMenu-singup {
}

#header-mypageMenu-logout,
#header-mypageMenu-login {
}

.globalHeader__lang {
  margin-left: 13px;
  height: 35px;
  border: 1px solid #888;
  padding: 0 13px;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  transition: all 200ms ease;
  position: relative
}

.globalHeader__lang.show_sp {
  display: none
}

@media only screen and (max-width:768px) {
  .globalHeader__lang {
    width: 100%;
    height: 50px;
    position: relative;
    -ms-flex-pack: center;
    justify-content: center;
    margin-left: 0;
    margin-bottom: 20px
  }
  .globalHeader__lang.show_pctb {
    display: none
  }
  .globalHeader__lang.show_sp {
    display: -ms-flexbox;
    display: flex
  }
  .globalHeader__lang:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 8px;
    height: 5px;
    margin-top: -2.5px;
    background-image: url(/assets/img/common/arr_anc_gray.png);
    background-size: 100% auto;
    background-repeat: no-repeat
  }
}

.globalHeader__langText {
  font-size: 13px;
  letter-spacing: .025em;
  margin-left: 8px
}

@media screen and (min-width:769px) and (max-width:1140px) {
  .globalHeader__langText {
    font-size: 10px
  }
}

.selsect_lang {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  font-size: 16px;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"
}

.langMenu__list {
  min-width: 215px;
  position: absolute;
  top: calc(100% + 1px);
  right: -15px;
  padding: 30px 42px 30px 47px;
  box-sizing: border-box;
  background-color: #f6f6f6;
  display: none
}

@media only screen and (max-width:768px) {
  .langMenu__list {
    position: relative;
    top: 0;
    left: 0;
    padding: 0;
    background-color: #fff;
    padding-bottom: 20px
  }
}

.langMenu__listItem {
  margin-top: 10px
}

@media only screen and (max-width:768px) {
  .langMenu__listItem {
    margin-top: 20px
  }
}

.langMenu__listItem:first-child {
  margin-top: 0
}

.langMenu__listLink {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .075em;
  font-weight: 500;
  padding-left: 20px;
  position: relative;
  white-space: nowrap;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transition: opacity 500ms ease 0ms
}

@media only screen and (max-width:768px) {
  .langMenu__listLink {
    font-size: 14px;
    letter-spacing: .025em;
    display: block;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 5px 8px;
    background-position: right center
  }
}

.langMenu__listLink:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 1px;
  background-color: #b9b9b9;
  transform: translate(0, -50%)
}

.langMenu__listLink:hover {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"
}

.hamburgerWrapper {
  position: fixed;
  top: 18px;
  right: 13px;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transition: opacity ease 500ms;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  z-index: 102;
  display: none
}

@media only screen and (max-width:768px) {
  .hamburgerWrapper {
    display: -ms-flexbox;
    display: flex
  }
}

.menuText {
  font-size: 13px;
  letter-spacing: .025em;
  font-feature-settings: "palt";
  margin-right: 5px;
  color: #e04175;
  font-weight: 700;
  transition: all .4s
}

.hamburger, .hamburger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box
}

.hamburger {
  position: relative;
  width: 21px;
  height: 14px;
  cursor: pointer
}

.hamburger span {
  position: absolute;
  right: 0;
  width: 100%;
  height: 2px;
  background-color: #e04175
}

.hamburger span:nth-of-type(1) {
  top: 0
}

.hamburger span:nth-of-type(2) {
  top: calc(50% - 1px);
  width: 16px
}

.hamburger span:nth-of-type(3) {
  bottom: 0;
  width: 11px
}

.hamburger.is--on span:nth-of-type(1) {
  animation: menu-bar01 .75s forwards
}

.hamburger.is--on span:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

.hamburger.is--on span:nth-of-type(3) {
  animation: menu-bar02 .75s forwards
}

@keyframes menu-bar01 {
  0% {
    transform: translateY(6px) rotate(45deg)
  }
  50% {
    transform: translateY(6px) rotate(0)
  }
  100% {
    transform: translateY(0) rotate(0)
  }
}

@keyframes menu-bar02 {
  0% {
    transform: translateY(-6px) rotate(-45deg)
  }
  50% {
    transform: translateY(-6px) rotate(0)
  }
  100% {
    transform: translateY(0) rotate(0)
  }
}

.hamburger.is--on.is--active span:nth-of-type(1) {
  animation: active-menu-bar01 .75s forwards
}

@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0)
  }
  50% {
    transform: translateY(6px) rotate(0)
  }
  100% {
    transform: translateY(6px) rotate(45deg)
  }
}

.hamburger.is--on.is--active span:nth-of-type(2) {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  width: 100%
}

.hamburger.is--on.is--active span:nth-of-type(3) {
  animation: active-menu-bar03 .75s forwards;
  width: 100%
}

@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0)
  }
  50% {
    transform: translateY(-6px) rotate(0)
  }
  100% {
    transform: translateY(-6px) rotate(-45deg)
  }
}

.p-contact .contact {
  display: none
}

.contact {
  width: 100%;
  padding: 65px 0;
  background-color: #e0e0e0
}

@media only screen and (max-width:768px) {
  .contact {
    padding: 60px 0
  }
}

.contact__inner {
  max-width: 970px;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .contact__inner {
    padding: 0;
    width: 79.73%;
    margin: 0 auto;
    display: block
  }
}

.contact__detail {
  width: calc(100% - 300px)
}

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

.contact__heading {
  font-size: 22px;
  line-height: 1.272;
  letter-spacing: .05em;
  font-feature-settings: "palt";
  font-weight: 600;
  margin-bottom: 30px
}

@media only screen and (max-width:768px) {
  .contact__heading {
    margin-bottom: 20px;
    text-align: center
  }
}

.contact__heading:after {
  content: "";
  display: block;
  margin-top: 10px;
  width: 18px;
  height: 1px;
  background-color: #003
}

@media only screen and (max-width:768px) {
  .contact__heading:after {
    margin: 10px auto 0
  }
}

.contact__text {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em
}

.contact__button {
  width: 300px;
  margin: 0 auto
}

@media only screen and (max-width:768px) {
  .contact__button {
    width: 80%;
    margin: 20px auto 0
  }
}

.contact__button a {
  display: block;
  font-size: 18px;
  letter-spacing: .025em;
  line-height: 60px;
  position: relative;
  color: #fff;
  background-color: #df7094;
  text-align: center
}

@media only screen and (min-width:769px) {
  .contact__button a {
    position: relative;
    border: 1px solid #df7094;
    box-sizing: border-box
  }
  .contact__button a:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .contact__button a:hover {
    color: #df7094;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .contact__button a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

@media only screen and (max-width:768px) {
  .contact__button a {
    font-size: 17px;
    line-height: 50px
  }
}

.contact__button a:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 20px;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_btn_white.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

@media only screen and (min-width:769px) {
  .contact__button a:hover:after {
    background-image: url(/assets/img/common/arr_text_pink.png)
  }
}

.footer {
  background-color: #fff;
  padding: 40px 65px 20px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .footer {
    padding: 40px 10.135% 20px
  }
}

.footer__inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between
}

@media only screen and (max-width:768px) {
  .footer__inner {
    display: block
  }
}

@media only screen and (max-width:768px) {
  .footer__logoWrap {
    text-align: center;
    margin-bottom: 40px
  }
}

.footer__logo {
  display: inline-block
}

@media only screen and (max-width:768px) {
  .footer__logo {
    margin-left: auto;
    margin-right: auto
  }
}

.footer__logo img {
  height: 26px;
  vertical-align: top
}

@media only screen and (max-width:768px) {
  .footer__logo img {
    height: 20px;
    width: auto
  }
}

.footer__info {
  margin-top: 35px;
  margin-bottom: 15px
}

@media only screen and (max-width:768px) {
  .footer__info {
    margin-top: 25px;
    margin-bottom: 25px
  }
}

.footer__infoList {
  display: table
}

.footer__infoList:not(:first-child) {
  margin-top: 4px
}

@media only screen and (max-width:768px) {
  .footer__infoList:not(:first-child) {
    margin-top: 10px
  }
}

@media only screen and (max-width:768px) {
  .footer__infoList {
    margin-left: auto;
    margin-right: auto
  }
}

.footer__infoTtl {
  display: table-cell;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #666;
  width: 165px
}

@media only screen and (max-width:768px) {
  .footer__infoTtl {
    width: auto;
    font-size: 13px
  }
}

.footer__infoText {
  display: table-cell;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #666
}

@media only screen and (max-width:768px) {
  .footer__infoText {
    font-size: 13px
  }
}

.footer__contact {
  width: 180px;
  margin-top: 15px
}

@media only screen and (max-width:768px) {
  .footer__contact {
    margin-top: 0;
    width: 170px;
    margin-left: auto;
    margin-right: auto
  }
}

.footer__contact a {
  display: block;
  line-height: 38px;
  padding-left: 12px;
  position: relative;
  font-size: 13px;
  color: #666;
  background-color: transparent;
  text-align: center;
  border: 1px solid #a4a1a2;
  text-align: left
}

@media only screen and (min-width:769px) {
  .footer__contact a {
    position: relative;
    box-sizing: border-box
  }
  .footer__contact a:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #a4a1a2;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .footer__contact a:hover {
    color: #fff;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .footer__contact a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

@media only screen and (max-width:768px) {
  .footer__contact a {
    font-size: 13px
  }
}

.footer__contact a:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 20px;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_btn_gray.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

@media only screen and (min-width:769px) {
  .footer__contact a:hover:after {
    background-image: url(/assets/img/common/arr_btn_white.png)
  }
}

.footer__linkWrap {
  padding-top: 10px
}

@media only screen and (max-width:768px) {
  .footer__linkWrap {
    padding-top: 0
  }
}

.footer__sns {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: end;
  justify-content: flex-end
}

.footer__sns.show_sp {
  display: none
}

@media only screen and (max-width:768px) {
  .footer__sns {
    margin-top: 19px;
    -ms-flex-pack: center;
    justify-content: center
  }
  .footer__sns.show_pctb {
    display: none
  }
  .footer__sns.show_sp {
    display: -ms-flexbox;
    display: flex
  }
}

.footer__linkWrap .footer__sns {
  display: -ms-flexbox;
  display: flex
}

@media only screen and (max-width:768px) {
  .footer__linkWrap .footer__sns {
    display: none
  }
}

.footer__sns a {
  width: 18px;
  height: 18px;
  margin-left: 14px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center
}

.footer__sns a img {
  display: block
}

.footer__twitter img {
  width: 16px
}

.footer__facebook img {
  width: 10px
}

.footer__instagram img {
  width: 16px
}

.footer__areaLink {
  margin-top: 25px;
  letter-spacing: .025em;
  font-size: 13px;
  line-height: 1.5
}

@media only screen and (max-width:768px) {
  .footer__areaLink {
    border: 1px solid #ddd;
    box-sizing: border-box;
    margin: 0 -5.06%
  }
}

.footer__areaLinkTitle {
  border-bottom: 1px solid #ddd;
  padding-bottom: 6px;
  color: #888
}

@media only screen and (max-width:768px) {
  .footer__areaLinkTitle {
    border-bottom: none;
    line-height: 30px;
    letter-spacing: .03em;
    box-sizing: border-box;
    position: relative;
    cursor: pointer;
    font-size: 13px;
    padding: 10px 4.57%
  }
  .footer__areaLinkTitle.is--openAreaLinkTitle:after {
    display: none
  }
}

@media only screen and (max-width:768px) {
  .footer__areaLinkTitle:before, .footer__areaLinkTitle:after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    background-color: #a1a1a1
  }
}

@media only screen and (max-width:768px) {
  .footer__areaLinkTitle:before {
    height: 1px;
    width: 11px;
    left: calc(94.12% - 5px)
  }
}

@media only screen and (max-width:768px) {
  .footer__areaLinkTitle:after {
    width: 1px;
    height: 11px;
    left: 94.12%
  }
}

@media only screen and (max-width:768px) {
  .footer__areaLinkInner {
    display: none;
    padding: 0 4.57% 20px 35px
  }
}

.footer__areaLinkSubTitle {
  margin-top: 14px
}

.footer__areaLinkSubTitle:nth-of-type(1) {
  margin-top: 10px
}

@media only screen and (max-width:768px) {
  .footer__areaLinkSubTitle {
    position: relative
  }
  .footer__areaLinkSubTitle:before {
    content: "";
    position: absolute;
    top: 50%;
    right: calc(100% + 6px);
    width: 11px;
    height: 1px;
    background-color: #b9b9b9;
    transform: tranlate(0, -50%)
  }
}

.footer__areaLinkSubTitle a {
  color: #666
}

@media only screen and (max-width:768px) {
  .footer__areaLinkSubTitle a {
    display: block;
    position: relative
  }
  .footer__areaLinkSubTitle a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    margin-top: -4px;
    width: 5px;
    height: 8px;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 100% auto
  }
}

.footer__areaLinkList {
  font-size: 13px;
  line-height: 1.5;
  margin-left: 28px
}

@media only screen and (max-width:768px) {
  .footer__areaLinkList {
    display: block;
    margin-left: 19px
  }
}

.footer__areaLinkList tbody, .footer__areaLinkList tr {
  display: block
}

.footer__areaLinkItem {
  padding-top: 10px
}

@media only screen and (max-width:768px) {
  .footer__areaLinkItem {
    display: block
  }
}

.footer__areaLinkItem:nth-of-type(2n) {
  padding-left: 25px
}

@media only screen and (max-width:768px) {
  .footer__areaLinkItem:nth-of-type(2n) {
    padding-left: 0
  }
}

.footer__areaLinkItem a {
  color: #666;
  white-space: nowrap
}

@media only screen and (max-width:768px) {
  .footer__areaLinkItem a {
    display: block;
    position: relative
  }
  .footer__areaLinkItem a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    margin-top: -4px;
    width: 5px;
    height: 8px;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 100% auto
  }
}

.footer__nav {
  display: -ms-flexbox;
  display: flex;
  margin-top: 40px
}

@media only screen and (max-width:768px) {
  .footer__nav {
    position: relative;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: 30px
  }
}

.footer_navList:not(:first-child) {
  margin-left: 20px
}

@media only screen and (max-width:768px) {
  .footer_navList:not(:first-child) {
    margin-left: 0
  }
}

@media only screen and (max-width:768px) {
  .footer_navList:nth-of-type(2n) {
    margin-left: 5vw
  }
}

@media only screen and (max-width:768px) {
  .footer_navList {
    margin-left: 0;
    width: calc((100% - 5vw)/2)
  }
  .footer_navList:nth-child(n+3) {
    margin-top: 20px
  }
}

.footer__navLink {
  font-size: 12px;
  letter-spacing: .025em;
  color: #666
}

@media only screen and (max-width:768px) {
  .footer__navLink {
    font-size: 12px;
    line-height: 1.5;
    display: block;
    position: relative;
    letter-spacing: 0
  }
  .footer__navLink:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    margin-top: -4px;
    width: 5px;
    height: 8px;
    background-image: url(/assets/img/common/arr_btn_gray.png);
    background-repeat: no-repeat;
    background-size: 100% auto
  }
}

.footer__copy {
  margin-top: 40px;
  font-size: 10px;
  letter-spacing: .025em;
  color: #a1a1a1;
  line-height: 1.5
}

@media only screen and (max-width:768px) {
  .footer__copy {
    text-align: left;
    margin-top: 45px;
    margin-left: -5.06%;
    margin-right: -5.06%
  }
}

.cookiePolicy {
  padding: 15px 30px;
  background-color: #a1a1a1;
  box-sizing: border-box;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 99;
  width: 100%;
  display: none
}

.cookiePolicy__inner {
  max-width: 1040px;
  width: 100%;
  margin: 0 auto;
  padding-right: 65px;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

.cookiePolicy__text {
  width: calc(100% - 65px);
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .04em;
  color: #fff
}

.cookiePolicy__text a {
  color: #ddd;
  border-bottom: 1px solid #ddd;
  padding-bottom: 1px
}

.cookiePolicy__buttonWrapper {
  width: 65px;
  box-sizing: border-box;
  text-align: right
}

.cookiePolicy__button {
  color: #fff;
  border-bottom: 1px solid #fff;
  padding-bottom: 1px
}

.pagetop {
  display: none;
  position: fixed;
  bottom: 10px;
  right: 20px;
  text-align: right;
  box-sizing: border-box;
  z-index: 99
}

@media only screen and (max-width:768px) {
  .pagetop {
    padding: 0 10px;
    bottom: 20px;
    right: 0
  }
}

.pagetop.nofixed {
  position: absolute;
  z-index: 1
}

.pagetop__link {
  float: right
}

.pagetop__icon {
  display: block;
  text-align: center;
  margin-bottom: 8px
}

@media only screen and (max-width:768px) {
  .pagetop__icon {
    margin-bottom: 10px
  }
}

.pagetop__icon .pagetop__img {
  height: auto
}

@media only screen and (max-width:768px) {
  .pagetop__icon .pagetop__img {
    width: 40px
  }
}

.searchMenu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #f6f6f6;
  transform: translate(0, 100%);
  transition: transform 500ms ease;
  z-index: 1000;
  box-sizing: border-box
}

.searchMenu.is--searchMenu {
  transform: translate(0, 0)
}

.searchMenu form {
  padding-bottom: 100px;
  position: relative
}

.searchMenu__inner {
  overflow: scroll;
  -webkit-overflow-scrolling: touch;
  height: 100%
}

.searchMenu__closeWrapper {
  box-sizing: border-box;
  position: absolute;
  top: 15px;
  right: 30px;
  background-color: #f6f6f6;
  padding: 10px;
  z-index: 2
}

@media only screen and (max-width:768px) {
  .searchMenu__closeWrapper {
    top: 10px;
    right: 10px
  }
}

.searchMenu__close {
  display: inline-block;
  color: #333;
  cursor: pointer;
  padding-left: 26px;
  position: relative;
  font-size: 14px;
  letter-spacing: .03em;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .searchMenu__close {
    font-size: 13px
  }
}

.searchMenu__close:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  background-image: url(/assets/img/common/icon_close.png);
  background-repeat: no-repeat;
  background-size: 16px 16px
}

@media only screen and (max-width:768px) {
  .searchMenu__close:before {
    width: 14px;
    height: 14px;
    background-size: 14px 14px
  }
}

.searchMenu__heading {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: .075em;
  font-weight: 700;
  color: #333;
  margin: 95px 0 60px;
  text-align: center
}

@media only screen and (max-width:768px) {
  .searchMenu__heading {
    font-size: 22px;
    margin: 55px 0 30px
  }
}

.searchMenu__mainBlock {
  margin-bottom: 60px
}

@media only screen and (max-width:768px) {
  .searchMenu__mainBlock {
    margin-bottom: 50px
  }
}

.searchMenu__calendar {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  max-width: 780px;
  width: 100%;
  margin: 0 auto 30px
}

@media only screen and (max-width:768px) {
  .searchMenu__calendar {
    margin-bottom: 20px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 85.33%
  }
}

.searchMenu__checkin, .searchMenu__checkout {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .searchMenu__checkin, .searchMenu__checkout {
    width: 38%;
    margin-right: 0;
    display: block
  }
}

.searchMenu__checkin span, .searchMenu__checkout span {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .025em;
  font-feature-settings: "palt";
  margin-right: 5px;
  color: #333
}

@media only screen and (max-width:768px) {
  .searchMenu__checkin span, .searchMenu__checkout span {
    display: block;
    margin-bottom: 5px;
    font-size: 13px;
    margin-right: 0
  }
}

.searchMenu__checkin input, .searchMenu__checkout input {
  width: 182px;
  height: 40px;
  border: 1px solid #ddd;
  background-color: #fff;
  box-sizing: border-box;
  padding: 0 30px 0 15px;
  line-height: 38px;
  background-image: url(/assets/img/common/icon_calender.svg);
  background-repeat: no-repeat;
  background-size: 30px 30px;
  background-position: right 15px center;
  font-size: 16px;
  letter-spacing: .025em;
  color: #333
}

@media only screen and (max-width:768px) {
  .searchMenu__checkin input, .searchMenu__checkout input {
    width: 100%;
    height: 35px;
    line-height: 33px;
    padding: 0 30px 0 10px;
    font-size: 14px;
    background-position: right 4px center
  }
}

.searchMenu__person {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .searchMenu__person {
    display: block;
    width: 24%
  }
}

.searchMenu__person span {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .025em;
  font-feature-settings: "palt";
  margin-right: 5px;
  color: #333
}

@media only screen and (max-width:768px) {
  .searchMenu__person span {
    display: block;
    margin-right: 0;
    font-size: 13px;
    margin-bottom: 5px
  }
}

.searchMenu__person select {
  width: 175px;
  height: 40px;
  border: 1px solid #ddd;
  background-color: #fff;
  box-sizing: border-box;
  padding: 0 18px;
  line-height: 38px;
  background-image: url(/assets/img/common/arr_selectbox.png);
  background-repeat: no-repeat;
  background-size: 8px 8px;
  background-position: right 15px center;
  color: #333;
  font-size: 16px
}

@media only screen and (max-width:768px) {
  .searchMenu__person select {
    width: 100%;
    height: 35px;
    line-height: 33px;
    padding: 0 18px 0 5px
  }
}

.searchMenu__button {
  max-width: 630px;
  width: 100%;
  margin: 0 auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between
}
.searchMenu__button a{
  display:block;
  width: 47.61%;
}
.menu-map-area-search a{
  width: auto;
}

@media only screen and (max-width:768px) {
  .searchMenu__button {
    width: 85.33%
  }
}

.searchMenu__button .searchMenu__buttonSearch_quick,
.searchMenu__button .searchMenu__buttonSearch {
  color: #fff;
  background-color: #df7094;
  text-align: center
}

@media only screen and (min-width:769px) {
  .searchMenu__button .searchMenu__buttonSearch_quick,
  .searchMenu__button .searchMenu__buttonSearch {
    position: relative;
    border: 1px solid #df7094;
    box-sizing: border-box
  }
  .searchMenu__button .searchMenu__buttonSearch_quick:before,
  .searchMenu__button .searchMenu__buttonSearch:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .searchMenu__button .searchMenu__buttonSearch_quick:hover,
  .searchMenu__button .searchMenu__buttonSearch:hover {
    color: #df7094;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .searchMenu__button .searchMenu__buttonSearch_quick:hover:before,
  .searchMenu__button .searchMenu__buttonSearch:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.searchMenu__button .searchMenu__buttonMap {
  color: #fff;
  background-color: #666;
  text-align: center
}

@media only screen and (min-width:769px) {
  .searchMenu__button .searchMenu__buttonMap {
    position: relative;
    border: 1px solid #666;
    box-sizing: border-box
  }
  .searchMenu__button .searchMenu__buttonMap:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .searchMenu__button .searchMenu__buttonMap:hover {
    color: #666;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .searchMenu__button .searchMenu__buttonMap:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.searchMenu__button .searchMenu__buttonMap span {
  padding-left: 20px;
  position: relative
}

.searchMenu__button .searchMenu__buttonMap span:after {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  width: 14px;
  height: 22px;
  margin-top: -11px;
  background-image: url(/assets/img/common/icon_map_white.png);
  background-repeat: no-repeat;
  background-size: 14px 22px
}

@media only screen and (max-width:768px) {
  .searchMenu__button .searchMenu__buttonMap span:after {
    width: 12px;
    height: 20px;
    background-size: 100% auto
  }
}

@media only screen and (min-width:769px) {
  .searchMenu__button .searchMenu__buttonMap:hover span:after {
    background-image: url(/assets/img/common/icon_map_gray.png)
  }
}

.searchMenu__button .searchMenu__buttonSearch_quick,
.searchMenu__button .searchMenu__buttonSearch, .searchMenu__button .searchMenu__buttonMap {
  width: 100%;
  height: 50px;
  line-height: 50px;
  text-align: center;
  font-size: 18px;
  letter-spacing: .075px;
  transition: all 400ms ease;
  position: relative
}

@media only screen and (max-width:768px) {
  .searchMenu__button .searchMenu__buttonSearch_quick,
  .searchMenu__button .searchMenu__buttonSearch, .searchMenu__button .searchMenu__buttonMap {
    width: 100%;
    font-size: 15px;
    margin-top: 0;
    height: 40px;
    line-height: 40px
  }
}

.searchMenu__ano {
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 20px;
  text-align: center;
  color: #333
}

@media only screen and (max-width:768px) {
  .searchMenu__ano {
    font-size: 14px
  }
}

.searchMenu__choiseBlock {
  max-width: 910px;
  width: 100%;
  border: 1px solid #a1a1a1;
  box-sizing: border-box;
  margin: 0 auto
}

@media only screen and (max-width:768px) {
  .searchMenu__choiseBlock {
    width: 90%
  }
}

.choiseBlock__heading {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .03em;
  padding: 35px 7.14%;
  box-sizing: border-box;
  text-align: center;
  position: relative;
  cursor: pointer
}

@media only screen and (max-width:768px) {
  .choiseBlock__heading {
    font-size: 14px;
    padding: 20px 5.88%
  }
}

.choiseBlock__heading.is--openAdvancedSearch:after {
  display: none
}

.choiseBlock__heading:before, .choiseBlock__heading:after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  background-color: #a1a1a1
}

.choiseBlock__heading:before {
  width: 22px;
  height: 1px;
  left: 92.86%
}

@media only screen and (max-width:768px) {
  .choiseBlock__heading:before {
    width: 11px;
    left: calc(94.12% - 5px)
  }
}

.choiseBlock__heading:after {
  width: 1px;
  height: 22px;
  left: calc(92.86% + 11px)
}

@media only screen and (max-width:768px) {
  .choiseBlock__heading:after {
    height: 11px;
    left: 94.12%
  }
}

.choiseBlock__inner {
  padding: 0 7.14% 35px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .choiseBlock__inner {
    padding: 0 5.88% 20px
  }
}

.choiseBlock__item {
  margin-top: 25px
}

.choiseBlock__item:nth-of-type(1) {
  margin-top: 0
}

.choiseBlock__itemTtl {
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .05em;
  font-feature-settings: "palt";
  margin-bottom: 4px
}

.choiseBlock__itemDetail input {
  width: 100%;
  height: 36px;
  line-height: 34px;
  font-size: 14px;
  letter-spacing: .025em;
  border: 1px solid #ddd;
  box-sizing: border-box;
  padding: 0 15px;
  background-color: #fff
}

.choiseBlock__itemCheckWrapper {
  margin-bottom: 20px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

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

.js-checkPulldown {
  position: relative;
  width: 25px;
  height: 11px
}

@media only screen and (max-width:768px) {
  .js-checkPulldown {
    width: 15px;
    height: 11px
  }
}

.js-checkPulldown:after {
  content: "";
  position: absolute;
  top: 1px;
  right: 0;
  width: 11px;
  height: 11px;
  background-image: url(/assets/img/common/icon_plus.png);
  background-repeat: no-repeat;
  background-size: 11px 11px
}

.js-checkPulldown.is--openCheckList:after {
  background-image: url(/assets/img/common/icon_minus.png)
}

.choiseBlock__itemDetail {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.choiseBlock__itemDetail label {
  width: 50%;
  position: relative
}

.choiseBlock__itemDetail label.choiseBlock__itemCheck {
  width: auto
}

@media only screen and (min-width:769px) {
  .choiseBlock__itemDetail label:nth-child(n+3) {
    margin-top: 20px
  }
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail label {
    width: 100%
  }
  .choiseBlock__itemDetail label:nth-child(n+2) {
    margin-top: 20px
  }
}

.choiseBlock__itemDetail.choiseBlock__itemDetail--label4 label {
  width: 25%
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail.choiseBlock__itemDetail--label4 label {
    width: 50%
  }
  .choiseBlock__itemDetail.choiseBlock__itemDetail--label4 label:nth-child(2) {
    margin-top: 0
  }
}

.choiseBlock__itemDetail.choiseBlock__itemDetail--label4 label:nth-child(n+3) {
  margin-top: 0
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail.choiseBlock__itemDetail--label4 label:nth-child(n+3) {
    margin-top: 20px
  }
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail.choiseBlock__itemDetail--spClm2 {
    width: 50%
  }
  .choiseBlock__itemDetail.choiseBlock__itemDetail--spClm2:nth-child(2) {
    margin-top: 0
  }
}

.choiseBlock__itemDetail .radio01-input, .choiseBlock__availableCheck .radio01-input {
  display: none
}

.choiseBlock__itemDetail .radio01-parts, .choiseBlock__availableCheck .radio01-parts {
  padding-left: 32px;
  position: relative;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .03em;
  color: #333;
  display: inline-block;
  color: #666
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail .radio01-parts, .choiseBlock__availableCheck .radio01-parts {
    word-break: break-all
  }
}

.choiseBlock__itemDetail .radio01-parts:first-child, .choiseBlock__availableCheck .radio01-parts:first-child {
  margin-left: 0
}

.choiseBlock__itemDetail .radio01-parts:before, .choiseBlock__availableCheck .radio01-parts:before {
  content: "";
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  width: 24px;
  height: 24px;
  border: 1px solid #ddd;
  box-sizing: border-box;
  background-color: #fff
}

@media only screen and (max-width:768px) {
  .choiseBlock__itemDetail .radio01-parts:before, .choiseBlock__availableCheck .radio01-parts:before {
    top: -1px
  }
}

.choiseBlock__itemDetail .radio01-input:checked+.radio01-parts:after, .choiseBlock__availableCheck .radio01-input:checked+.radio01-parts:after {
  content: "";
  display: block;
  position: absolute;
  top: 1px;
  left: 8px;
  width: 6px;
  height: 12px;
  transform: rotate(40deg);
  border-bottom: 2px solid #333;
  border-right: 2px solid #333
}

.choiseBlock__itemCheckBlock {
  width: 100%;
  margin-top: 20px
}

.choiseBlock__itemCheckBlock:first-child {
  margin-top: 0
}

.choiseBlock__itemPulldown {
  margin-top: 20px;
  display: none
}

.choiseBlock__itemPulldown label {
  padding-left: 8.33%;
  box-sizing: border-box
}

.choiseBlock__itemPulldownInner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.choiseBlock__availableCheck {
  padding: 25px 0 20px;
  border-top: 1px solid #a1a1a1;
  margin: 30px 0 0
}

.searchMenu__buttonWrapper {
  width: 100%;
  padding: 25px 0;
  background-color: #f6f6f6;
  position: -webkit-sticky;
  position: sticky;
  bottom: 0
}

@media only screen and (max-width:768px) {
  .searchMenu__button.searchMenu__button--pl {
    width: 100%
  }
}

.graphBlock {
  display: block
}

.choiseBlock__graph {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-align: center;
  align-items: center
}

.choiseBlock__graph .choiseBlock__item {
  margin-top: 25px
}

.graphBlock__imageWrap {
  width: 350px;
  position: relative
}

@media only screen and (max-width:768px) {
  .graphBlock__imageWrap {
    width: 290px
  }
}

.graphBlock__image {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
  align-items: flex-end
}

.graphBlock__image span {
  width: 5%;
  background-color: #a1a1a1
}

.graphBlock__controllerWrap {
  position: absolute;
  bottom: -10px;
  left: 0;
  margin-top: 1px;
  width: 100%
}

.graphBlock__controller {
  position: relative;
  width: 100%;
  height: 20px;
  margin: 0 auto;
  overflow: hidden
}

.graphBlock__controller:before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #ddd;
  z-index: -1
}

.graphBlock__box {
  position: absolute;
  top: 0;
  width: 20px;
  height: 20px;
  background-image: url(/assets/img/common/icon_controller.png);
  background-repeat: no-repeat;
  background-size: 100% auto
}

.graphBlock__box1 {
  left: 0
}

.graphBlock__box2 {
  left: calc(100% - 20px)
}

.graphBlock__line {
  position: absolute;
  top: 10px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #a1a1a1
}

.graphBlock__price {
  font-size: 12px;
  letter-spacing: .025em;
  color: #666;
  margin-top: 5px;
  margin-bottom: 20px
}

.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0
}

.slick-list:focus {
  outline: none
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand
}

.slick-slider .slick-track, .slick-slider .slick-list {
  transform: translate3d(0, 0, 0)
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto
}

.slick-track:before, .slick-track:after {
  display: table;
  content: ''
}

.slick-track:after {
  clear: both
}

.slick-loading .slick-track {
  visibility: hidden
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px
}

[dir=rtl] .slick-slide {
  float: right
}

.slick-slide img {
  display: block
}

.slick-slide.slick-loading img {
  display: none
}

.slick-slide.dragging img {
  pointer-events: none
}

.slick-initialized .slick-slide {
  display: block
}

.slick-loading .slick-slide {
  visibility: hidden
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent
}

.slick-arrow.slick-hidden {
  display: none
}

.slick-prev, .slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 20px;
  padding: 0;
  transform: translate(0, -50%);
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent
}

.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
  color: transparent;
  outline: none;
  background: transparent
}

.slick-prev:hover:before, .slick-prev:focus:before, .slick-next:hover:before, .slick-next:focus:before {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before {
  opacity: .25;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=25)"
}

.slick-prev:before, .slick-next:before {
  font-family: slick;
  font-size: 20px;
  line-height: 1;
  opacity: .75;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=75)";
  color: white;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

.slick-prev {
  left: -25px
}

[dir=rtl] .slick-prev {
  right: -25px;
  left: auto
}

.slick-prev:before {
  content: '←'
}

[dir=rtl] .slick-prev:before {
  content: '→'
}

.slick-next {
  right: -25px
}

[dir=rtl] .slick-next {
  right: auto;
  left: -25px
}

.slick-next:before {
  content: '→'
}

[dir=rtl] .slick-next:before {
  content: '←'
}

.slick-dotted.slick-slider {
  margin-bottom: 30px
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent
}

.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none
}

.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

.slick-dots li button:before {
  font-family: slick;
  font-size: 6px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: '•';
  text-align: center;
  opacity: .25;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=25)";
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

.slick-dots li.slick-active button:before {
  opacity: .75;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=75)";
  color: black
}

.pageTitle {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: .075em;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  font-feature-settings: "palt";
  color: #333
}

@media only screen and (max-width:768px) {
  .pageTitle {
    font-size: 22px
  }
}

.mainVisual img {
  width: 100%;
  height: auto;
  display: block
}

.mainVisual__imgWrapper {
  width: 100%;
  height: auto;
  position: relative
}

.mainVisual__imgWrapper:before {
  content: "";
  display: block;
  width: 100%;
  height: 0;
  padding-top: 36.92%
}

@media only screen and (max-width:768px) {
  .mainVisual__imgWrapper:before {
    padding-top: 100%
  }
}

.mainVisual__imgWrapper img {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
  font-family: 'object-fit: cover;'
}

.mainVisual__TextBlock {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  background: #fff;
  margin: -100px auto 0;
  z-index: 1;
  position: relative;
  width: calc(1170/1300*100%);
  max-width: 1100px;
  padding: 30px 0;
  box-shadow: 5px 5px 7px -2px rgba(0, 0, 0, .4)
}

@media only screen and (max-width:768px) {
  .mainVisual__TextBlock {
    width: 90%;
    display: block
  }
}

.mainVisual__TextBlock .mainVisual__overview {
  width: calc(490/1300*100%);
  padding: 20px calc(45/1300*100%);
  border-right: 1px solid #ddd
}

@media only screen and (max-width:768px) {
  .mainVisual__TextBlock .mainVisual__overview {
    width: 80%;
    margin: 0 auto;
    border-right: none;
    padding: 0
  }
}

.mainVisual__TextBlock .mainVisual__Ttl {
  font-size: 32px;
  line-height: 48px;
  letter-spacing: .075em;
  font-weight: 700;
  text-align: center;
  width: calc(490/1300*100%);
  padding: 30px 50px;
  border-right: 1px solid #ddd;
  word-break: break-all;
  box-sizing: border-box;
  color: #333;
  text-transform: uppercase
}

@media only screen and (max-width:768px) {
  .mainVisual__TextBlock .mainVisual__Ttl {
    font-size: 22px;
    line-height: 33px;
    letter-spacing: .05em;
    width: 80%;
    margin: 0 auto;
    border-right: none;
    border-bottom: 1px solid #ddd;
    padding: 0 0 10px
  }
}

.mainVisual__TextBlock .mainVisual__Text {
  width: calc(680/1300*100%);
  padding: 0 calc(65/1300*100%);
  line-height: 25.5px;
  letter-spacing: .025em;
  font-size: 15px
}

@media only screen and (max-width:768px) {
  .mainVisual__TextBlock .mainVisual__Text {
    width: 80%;
    margin: 0 auto;
    padding: 10px 0 0;
    line-height: 25px;
    font-size: 14px
  }
}

.mainVisual__TextBlock .mainVisual__Text .mainVisual__Text--link {
  color: #df7094;
  display: block;
  text-align: right;
  margin-top: 10px;
  position: relative;
  padding-right: 20px
}

.mainVisual__TextBlock .mainVisual__Text .mainVisual__Text--link:before {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_mv_link_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.mainVisual__detail {
  width: calc(680/1300*100%);
  padding: 0 calc(65/1300*100%)
}

@media only screen and (max-width:768px) {
  .mainVisual__detail {
    width: 90%;
    padding: 40px 0;
    margin: 0 auto
  }
}

.breadcrumbs {
  margin: 10px auto 0;
  width: 90%
}

.breadcrumbs ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
  justify-content: flex-end
}

.breadcrumbs ul li {
  font-size: 12px;
  line-height: 18px;
  color: #a4a1a2
}

@media only screen and (max-width:768px) {
  .breadcrumbs ul li {
    font-size: 10px;
    line-height: 15px
  }
}

.p-newsDetail .breadcrumbs ul li:last-of-type {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 270px
}

@media only screen and (max-width:768px) {
  .p-newsDetail .breadcrumbs ul li:last-of-type {
    max-width: 170px
  }
}

.breadcrumbs ul li a {
  color: #a4a1a2
}

.breadcrumbs ul li a:after {
  content: "/";
  margin: 0 3px
}

.card {
  margin-top: 80px
}

.home .card {
  margin-top: 0;
  padding-bottom: 80px;
}

.card:first-child {
  margin-top: 0
}

.card.card--small .slick-dots {
  margin-left: -.423vw;
  padding: 0
}

@media only screen and (max-width:768px) {
  .card.card--small .slick-dots {
    margin-left: 0
  }
}

.card.card--small .card__slide {
  margin-left: .423vw
}

@media only screen and (max-width:768px) {
  .card.card--small .card__slide {
    margin-left: 0
  }
}

.card.card--small .card__slide .slick-prev {
  left: calc(-19px + .423vw)
}

.card.card--small .card__slide .slick-next {
  right: calc(-17px + .423vw)
}

.card.card--small .card__slideItem {
  width: 19.23vw;
  width: 248.232px!important;
  margin-right: .846vw;
}

@media only screen and (max-width:768px) {
  .card.card--small .card__slideItem {
    width: 224px;
    width: 224px!important;
    margin-right: 10px;
  }
}

.card.card--small .card__slideItem:first-child {
  margin-left: 0;
}

.card.card--small .card__slideInner {
  padding: 20px;
  padding-bottom: 68px;
}

.card.card--small .card__statusTime {
  display: block;
  margin-left: 0;
}

.card.card--small .card__ttl {
  font-size: 14px;
  line-height: 21px;
}

.card.card--small .card__gender {
  font-size: 11px;
  line-height: 16px
}

.card.card--small .card__text {
  font-size: 12px;
  line-height: 20px
}

.card.card--small .card__price {
  font-size: 14px;
  line-height: 21px
}

.card.card--small .card__price span {
  font-size: 11px
}

.card.card--small .card__button {
  margin: 10px auto 0;
  bottom: 20px;
  padding: 0 20px;
  width: calc(78.09% - 40px)
}

.card.card--small .card__buttonDetail {
  width: 100%;
  font-size: 14px;
  letter-spacing: .05em;
  line-height: 36px;
  color: #fff;
  background-color: #df7094;
  text-align: center
}

.force_gray_button {
  background-color: #ddd !important;
  border: 1px solid #ddd !important;
  color: #555 !important;
}
@media only screen and (min-width:769px) {
  .card.card--small .card__buttonDetail {
    position: relative;
    border: 1px solid #df7094;
    box-sizing: border-box
  }
  .card.card--small .card__buttonDetail:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .card.card--small .card__buttonDetail:hover {
    color: #df7094;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .card.card--small .card__buttonDetail:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.card__inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .card__inner {
    padding: 0
  }
}

.card__heading {
  text-align: center;
  font-size: 28px;
  letter-spacing: .05em;
  color: #333;
  font-feature-settings: "palt";
  line-height: 42px;
  margin-bottom: 30px;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .card__heading {
    font-size: 22px;
    line-height: 33px;
    letter-spacing: .05em;
    margin-bottom: 20px
  }
}

.card__heading:after {
  content: "";
  display: block;
  margin: 9px auto 0;
  background-color: #333;
  width: 18px;
  height: 1px
}

@media only screen and (max-width:768px) {
  .card__heading:after {
    margin-top: 4px
  }
}

.card__slide {
  width: 100%;
  margin-left: .346vw
}

@media only screen and (max-width:768px) {
  .card__slide {
    margin-left: 0;
    width: 100%
  }
}

.card__slide .slick-track {
  display: -ms-flexbox;
  display: flex
}

.card__slide .slick-dots {
  margin-left: -.346vw;
  text-align: center
}

@media only screen and (max-width:768px) {
  .card__slide .slick-dots {
    margin-left: 0;
    top: 100%
  }
}

.card__slide .slick-dots li {
  width: 5px;
  height: 5px;
  background-color: #ccc;
  margin: 0 5px;
  border-radius: 50%
}

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

.card__slide .slick-dots button {
  width: 5px;
  height: 5px
}

.card__slide .slick-dots button:before {
  display: none
}

.card__slide .slick-arrow {
  z-index: 1
}

.card__slide .slick-next {
  width: 34px;
  height: 34px;
  right: calc(-17px + .346vw);
  background-image: url(/assets/img/common/arr_slide.png);
  background-repeat: no-repeat;
  background-size: 34px 34px
}

.card__slide .slick-next:before {
  display: none
}

.card__slide .slick-prev {
  width: 34px;
  height: 34px;
  left: calc(-18px + .346vw);
  background-image: url(/assets/img/common/arr_slide_l.png);
  background-repeat: no-repeat;
  background-size: 34px 34px
}

.card__slide .slick-prev:before {
  display: none
}

.card__slideItem {
  margin-right: .692vw;
  float: none!important;
  background-color: #fff;
  height: auto;
  box-shadow: 5px 5px 7px -2px rgba(0, 0, 0, .4);
  margin-top: 5px;
  margin-bottom: 10px;
  position: relative
}

@media only screen and (max-width:768px) {
  .card__slideItem {
    width: 318px;
    margin-right: 10px
  }
}

.card__slideItem:first-child {
  margin-left: 0
}

.card_iconNew {
  position: absolute;
  top: -4px;
  right: 15px;
  background-color: #f3bdd1;
  line-height: 24px;
  padding: 0 12px;
  box-sizing: boder-box;
  border-radius: 0 0 5px 5px;
  font-size: 12px;
  letter-spacing: .025em;
  color: #fff;
  font-weight: 700;
  z-index: 2
}

@media only screen and (max-width:768px) {
  .card_iconNew {
    right: 26px;
    padding: 0 10px;
    line-height: 24px;
    font-size: 12px
  }
}

.card_iconNew:after {
  content: "";
  position: absolute;
  left: 100%;
  top: 0;
  border-top: 2px solid transparent;
  border-right: 2px solid transparent;
  border-bottom: 2px solid #e692b1;
  border-left: 2px solid #e692b1
}

.card__slideInner {
  padding: 25px;
  box-sizing: border-box;
  padding-bottom: 82px;
  position: relative
}

@media only screen and (max-width:768px) {
  .card__slideInner {
    padding-bottom: 77px
  }
}

.card__fig {
  width: 100%;
  height: auto;
  position: relative
}

.card__fig:before {
  content: "";
  width: 100%;
  height: 0;
  padding-top: 68.23%;
  display: block
}

.card__img {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
  font-family: 'object-fit: cover;'
}

.card__statusBlock {
  margin-bottom: 10px
}

@media only screen and (max-width:768px) {
  .card__statusBlock {
    margin-bottom: 4px
  }
}

.card__statusBlock.is--gray .card__status {
  color: #999;
  border-bottom: 1px solid #999
}

.card__statusBlock.is--gray .card__statusTime {
  color: #999
}

.card__status {
  color: #ba4245;
  font-weight: 700;
  font-size: 13px;
  line-height: 1.5;
  border-bottom: 1px solid #ba4245;
  padding-bottom: 2px;
  letter-spacing: .025em
}

@media only screen and (max-width:768px) {
  .card__status {
    font-size: 11px
  }
}

.card__statusTime {
  color: #ba4245;
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .025em;
  margin-left: 7px
}

@media only screen and (max-width:768px) {
  .card__statusTime {
    font-size: 11px
  }
}

.card__catgory {
  margin-bottom: 4px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-align: center;
  align-items: center
}

.card__slide--featuredRoom .card__catgory {
  margin-bottom: 0;
}

.card__type {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

.card__type .card__typeIcon {
  width: 30px;
  height: 30px;
  background-size: 100% auto
}

.card__type.card__type--sharehouse .card__typeText span {
  color: #819a5e
}

.card__type.card__type--sharehouse .card__typeIcon {
  background-image: url(/assets/img/common/icon_cat_share_house.svg)
}

.card__type.card__type--vacationrental .card__typeText span {
  color: #b36c63
}

.card__type.card__type--vacationrental .card__typeIcon {
  background-image: url(/assets/img/common/icon_cat_vacation_rental.svg)
}

.card__type.card__type--apartment .card__typeText span {
  color: #ad9d37
}

.card__type.card__type--apartment .card__typeIcon {
  background-image: url(/assets/img/common/icon_cat_apartment.svg)
}

.card__type.card__type--guesthouse .card__typeText span {
  color: #417692
}

.card__type.card__type--guesthouse .card__typeIcon {
  background-image: url(/assets/img/common/icon_cat_guest_house.svg)
}

.card__typeText {
  font-size: 13px;
  letter-spacing: .025em;
  line-height: 28px;
  margin-left: 5px;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .card__typeText {
    font-size: 13px
  }
}

.card__typeText.is--gray span {
  color: #999!important;
  border-bottom: 1px solid #999!important
}

.card__typeText span {
  padding-bottom: 2px
}

.card__typeIcon {
  background-repeat: no-repeat;
  display: block
}

.card__slide--featuredRoom .card__option {
  margin-top: 10px;
  margin-bottom: 10px;
}

.card__area {
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .025em;
  word-break: break-all;
  font-weight: 500
}

@media only screen and (max-width:768px) {
  .card__area {
    font-size: 13px
  }
}

.card__areaText {
  padding-left: 19px;
  position: relative;
  color: #555;
  word-break: break-all;
  box-sizing: border-box;
  display: block
}

.card__areaText:before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 20px;
  height: 20px;
  background-image: url(/assets/img/common/icon_mapsearch.svg);
  background-repeat: no-repeat;
  background-size: 100% auto
}

.card__ttl {
  font-size: 16px;
  line-height: 24px;
  letter-spacing: .025em;
  margin-bottom: 6px;
  color: #333;
  font-weight: 500
}

.card__gender {
  display: block;
  margin-left: 1px
}

.card__gender span {
  font-size: 12px;
  line-height: 18px;
  letter-spacing: .025em;
  font-weight: 500;
  text-transform: uppercase;
  color: #555
}

.card__gender.card__gender--men span:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 18px;
  height: 18px;
  margin-top: -3px;
  background-image: url(/assets/img/common/icon_gender_men.svg);
  background-size: 100% auto;
  background-repeat: no-repeat
}

.card__gender.card__gender--women span:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 18px;
  height: 18px;
  margin-top: -3px;
  background-image: url(/assets/img/common/icon_gender_women.svg);
  background-size: 100% auto;
  background-repeat: no-repeat
}

.card__text {
  font-size: 13px;
  line-height: 22px;
  letter-spacing: .025em;
  color: #555;
  margin-top: 6px;
  margin-bottom: 5px
}

.card__priceWrapper {
  display: flex;
  justify-content: flex-end;
}

@media only screen and (max-width:1011px) {
  .card__priceWrapper {
    display: block;
    justify-content: flex-start;
  }
}

@media only screen and (max-width:768px) {
  .card__priceWrapper {
    display: flex;
    justify-content: flex-end;
  }
}


.card__price {
  font-size: 16px;
  line-height: 28px;
  letter-spacing: .02em;
  color: #555
}

.card__price span {
  font-size: 12px;
  line-height: 24px
}

.card__price.card__price--original {
  text-align: right;
  width: 100%;
}

@media only screen and (max-width:1011px) {
  .card__price.card__price--original {
    text-align: left;
  }
}

@media only screen and (max-width:768px) {
  .card__price.card__price--original {
    text-align: right;
  }
}

.card__price.card__price--dis {
  color: #a1a1a1;
  text-decoration: line-through
}

.card__slide--featuredRoom .card__price.card__price--dis {
  margin-right: 10px;
}

.card__price.card__price--sale {
  color: #ba4245
}

.card__button {
  margin-top: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: absolute;
  bottom: 25px;
  left: 50%;
  width: calc(100% - 50px);
  padding: 0 25px;
  transform: translate(-50%, 0)
}

.card__buttonBook, .card__buttonDetail {
  width: calc(78.09% - 40px);
  margin: 0 auto;
  line-height: 40px;
  font-size: 15px;
  letter-spacing: .025em
}

.card__buttonBook.w100, .card__buttonDetail.w100 {
  width: 100%
}

.post-type-archive-ai1ec_event .card__buttonBook, .post-type-archive-ai1ec_event .card__buttonDetail {
  width: 49.31%
}

.card__buttonBook, .card__buttonDetail {
  color: #fff;
  background-color: #df7094;
  text-align: center
}

@media only screen and (min-width:769px) {
  .card__buttonBook, .card__buttonDetail {
    position: relative;
    border: 1px solid #df7094;
    box-sizing: border-box
  }
  .card__buttonBook:before, .card__buttonDetail:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .card__buttonBook:hover, .card__buttonDetail:hover {
    color: #df7094;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .card__buttonBook:hover:before, .card__buttonDetail:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.post-type-archive-ai1ec_event .card__buttonDetail {
  color: #555;
  background-color: #ddd;
  text-align: center
}

@media only screen and (min-width:769px) {
  .post-type-archive-ai1ec_event .card__buttonDetail {
    position: relative;
    border: 1px solid #ddd;
    box-sizing: border-box
  }
  .post-type-archive-ai1ec_event .card__buttonDetail:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .post-type-archive-ai1ec_event .card__buttonDetail:hover {
    color: #ddd;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .post-type-archive-ai1ec_event .card__buttonDetail:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.card__allLink {
  width: 300px;
  margin: 60px auto 0
}

@media only screen and (max-width:768px) {
  .card__allLink {
    width: 80%;
    margin: 70px auto 0
  }
}

.card__allLink a {
  display: block;
  font-size: 18px;
  letter-spacing: .025em;
  line-height: 60px;
  position: relative;
  color: #fff;
  background-color: #eb96b6;
  text-align: center
}

@media only screen and (min-width:769px) {
  .card__allLink a {
    position: relative;
    border: 1px solid #eb96b6;
    box-sizing: border-box
  }
  .card__allLink a:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .card__allLink a:hover {
    color: #eb96b6;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .card__allLink a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

@media only screen and (max-width:768px) {
  .card__allLink a {
    font-size: 17px;
    line-height: 50px
  }
}

.card__allLink a:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 20px;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_btn_white.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

@media only screen and (min-width:769px) {
  .card__allLink a:hover:after {
    background-image: url(/assets/img/common/arr_text_pink.png)
  }
}

.eventCard .card__catgory {
  margin-bottom: 0
}

.eventCard .card__typeText {
  margin-left: 0
}

.eventCard .card__typeText span {
  color: #ba4245;
  border-bottom: 1px solid #ba4245
}

.eventCard .card__slideItem {
  width: 245px
}

.card__date {
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #666
}

@media only screen and (max-width:768px) {
  .card__date {
    font-size: 13px
  }
}

.card__ttl {
  color: #333;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .025em
}

@media only screen and (max-width:768px) {
  .card__ttl {
    font-size: 14px
  }
}

.card__place {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #999;
  margin-bottom: 10px
}

@media only screen and (max-width:768px) {
  .card__place {
    font-size: 11px
  }
}

.card__place:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 16px;
  height: 1px;
  background-color: #999;
  margin-right: 7px
}

.card__informationList {
  display: -ms-flexbox;
  display: flex
}

.card__informationTtl {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #555;
  width: 67px
}

.card__informationText {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #555;
  width: calc(100% - 67px)
}

@media only screen and (max-width:768px) {
  .single-building .carouselLR__slide .slick-list, .single-ai1ec_event .carouselLR__slide .slick-list {
    padding-bottom: 10px!important
  }
}

.carouselLR__slide .slick-arrow {
  top: 50%;
  max-width: 31px;
  max-height: 91px;
  width: 2.38vw;
  height: 7vw;
  z-index: 1;
  background-repeat: no-repeat;
  background-size: 100% auto;
  transform: translate(0, -50%)
}

.carouselLR__slide .slick-arrow:before {
  display: none
}

.carouselLR__slide .slick-prev {
  background-image: url(/assets/img/common/arr_slide_event_l.png);
  left: 19%
}

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

.carouselLR__slide .slick-next {
  background-image: url(/assets/img/common/arr_slide_event_r.png);
  right: 19%
}

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

.carouselLR__slide .slick-dots li {
  width: 5px;
  height: 5px;
  margin: 0 5px;
  border-radius: 50%;
  background-color: #ccc
}

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

.carouselLR__slide .slick-dots button {
  width: 5px;
  height: 5px
}

.carouselLR__slide .slick-dots button:before {
  display: none
}

.carouselLR__slide .slick-list {
  padding-bottom: 40px!important
}

.carouselLR__slideItem {
  padding: 0 3.73vw;
  box-sizing: border-box;
  position: relative
}

@media only screen and (max-width:768px) {
  .carouselLR__slideItem {
    padding: 0 1.33vw
  }
}

.carouselLR__slideItem img {
  width: 100%;
  height: auto;
  display: block
}

@media only screen and (min-width:769px) {
  .carouselLR__slideLink:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
  .carouselLR__slideLink:hover .carouselLR__slideFig, .carouselLR__slideLink:hover .carouselLR__slideImg {
    transform: scale(1.1, 1.1)
  }
}

.carouselLR__slideFigWrapper {
  width: 100%;
  height: 0;
  padding-top: 66.61%;
  overflow: hidden;
  position: relative
}

.carouselLR__slideFig {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.carouselLR__slideImg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.carouselLR__slideDetail {
  position: absolute;
  bottom: -40px;
  left: 3.73vw;
  padding: 20px 20px 0 0;
  box-sizing: border-box;
  background-color: #e6e6e6;
  width: 60%;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 40px);
  transition: opacity 700ms ease-in, transform 700ms ease-out;
  z-index: 2
}

@media only screen and (max-width:768px) {
  .carouselLR__slideDetail {
    left: 1.33vw;
    width: 87.45%;
    padding: 10px 10px 0 0
  }
}

.slick-current .carouselLR__slideDetail {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.slick-current .carouselLR__slideTtl {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.slick-current .carouselLR__slideText {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.slick-current .carouselLR__slideText2 {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.slick-current .carouselLR__slideText3 {
  opacity: 1.0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  transform: translate(0, 0)
}

.carouselLR__slideTtl {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .03em;
  color: #666;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 40px);
  transition: opacity 700ms ease-in, transform 700ms ease-out
}

@media only screen and (max-width:768px) {
  .carouselLR__slideTtl {
    font-size: 11px
  }
}

.carouselLR__slideText {
  margin-top: 5px;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .03em;
  color: #555;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 40px);
  transition: opacity 700ms ease-in, transform 700ms ease-out
}

@media only screen and (max-width:768px) {
  .carouselLR__slideText {
    font-size: 12px;
    line-height: 1.7
  }
}

.carouselLR__slideText2 {
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #999;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 40px);
  transition: opacity 700ms ease-in, transform 700ms ease-out
}

@media only screen and (max-width:768px) {
  .carouselLR__slideText2 {
    font-size: 11px
  }
}

.carouselLR__slideText2:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 16px;
  height: 1px;
  background-color: #999;
  margin-right: 10px
}

@media only screen and (max-width:768px) {
  .carouselLR__slideText2:before {
    width: 12px;
    margin-right: 6px
  }
}

.carouselLR__slideText3 {
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #999;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transform: translate(0, 40px);
  transition: opacity 700ms ease-in, transform 700ms ease-out
}

@media only screen and (max-width:768px) {
  .carouselLR__slideText3 {
    font-size: 11px
  }
}

.archiveContents__list {
  max-width: 1100px;
  width: 100%;
  padding: 0 60px;
  margin: 0 auto;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .archiveContents__list {
    width: 90%;
    padding: 0
  }
}

.archiveContents__listItem {
  background-color: #fff;
  margin-bottom: 10px;
  box-shadow: 5px 5px 7px -2px rgba(0, 0, 0, .4)
}

.archiveContents__listItemLink {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .archiveContents__listItemLink {
    display: block
  }
}

.archiveContents__listItemLink:hover {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
}

@media only screen and (min-width:769px) {
  .archiveContents__listItemLink:hover .archiveContents__img {
    transform: scale(1.1, 1.1)
  }
}

.archiveContents__ImgWrapper {
  width: 50%;
  overflow: hidden
}

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

.archiveContents__img {
  width: 100%;
  background-repeat: no-repeat;
  background-size: cover
}

@media only screen and (min-width:769px) {
  .archiveContents__img {
    min-height: 348px;
    height: 100%;
    transform: scale(1, 1);
    transition: transform 500ms ease 0ms
  }
}

@media only screen and (max-width:768px) {
  .archiveContents__img {
    padding-top: 66.92%;
    height: 0
  }
}

.archiveContents__detail {
  width: 50%;
  padding: 40px 6.25%;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .archiveContents__detail {
    width: 100%;
    padding: 20px 5.88% 15px
  }
}

.archiveContents__label {
  margin-bottom: 4px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

.archiveContents__date {
  display: inline-block;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #999
}

@media only screen and (max-width:768px) {
  .archiveContents__date {
    font-size: 14px
  }
}

.archiveContents__category {
  margin-left: 8px;
  display: inline-block;
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .02em;
  padding-bottom: 1px;
  color: #999;
  border-bottom: 1px solid #999
}

@media only screen and (max-width:768px) {
  .archiveContents__category {
    font-size: 11px
  }
}

.archiveContents__ttl {
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: .025em;
  margin-bottom: 15px;
  color: #333
}

@media only screen and (max-width:768px) {
  .archiveContents__ttl {
    font-size: 16px
  }
}

.archiveContents__text {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  color: #555
}

@media only screen and (max-width:768px) {
  .archiveContents__text {
    font-size: 14px
  }
}

.archiveContents__more {
  margin-top: 25px;
  text-align: right
}

.archiveContents__more a, .archiveContents__more span {
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #e04175;
  font-feature-settings: "palt";
  padding-right: 15px;
  position: relative
}

.archiveContents__more a:after, .archiveContents__more span:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_text_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.gallery {
  background-color: #a1a1a1;
  padding: 80px 0
}

@media only screen and (max-width:768px) {
  .gallery {
    padding: 50px 0 60px
  }
}

.gallery__inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between
}

@media only screen and (max-width:768px) {
  .gallery__inner {
    padding: 0;
    display: block
  }
}

.gallery__textBlock {
  width: 31.25%
}

@media only screen and (max-width:768px) {
  .gallery__textBlock {
    width: 76%;
    margin: 0 auto 20px
  }
}

.gallery__heading {
  font-size: 28px;
  letter-spacing: .05em;
  margin-bottom: 30px;
  color: #fff;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .gallery__heading {
    text-align: center;
    font-size: 22px;
    line-height: 1.5;
    font-weight: 600;
    margin-bottom: 20px
  }
}

.gallery__heading:after {
  content: "";
  display: block;
  margin-top: 10px;
  width: 18px;
  height: 1px;
  background-color: #fff
}

@media only screen and (max-width:768px) {
  .gallery__heading:after {
    margin: 4px auto 0
  }
}

.gallery__text {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  color: #fff;
  margin-bottom: 30px
}

@media only screen and (max-width:768px) {
  .gallery__text {
    margin-bottom: 20px
  }
}

.gallery__button {
  width: 300px
}

@media only screen and (max-width:768px) {
  .gallery__button {
    width: 80%;
    margin: 60px auto 0
  }
}

.gallery__button a {
  line-height: 58px;
  display: block;
  width: 100%;
  position: relative;
  color: #fff;
  background-color: transparent;
  text-align: center;
  border: 1px solid #fff
}

@media only screen and (min-width:769px) {
  .gallery__button a {
    position: relative;
    box-sizing: border-box
  }
  .gallery__button a:before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    transform-origin: right top;
    transform: scale(0, 1);
    z-index: -1;
    transition: transform 400ms ease 0ms
  }
}

@media only screen and (min-width:769px) {
  .gallery__button a:hover {
    color: #a1a1a1;
    opacity: .99;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)"
  }
  .gallery__button a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1)
  }
}

.gallery__button a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_btn_white.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

@media only screen and (min-width:769px) {
  .gallery__button a:hover:after {
    background-image: url(/assets/img/common/arr_btn_gray.png)
  }
}

.gallery__slideWrap {
  width: 60.09%
}

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

.gallery__slide {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

@media only screen and (max-width:768px) {
  .gallery__slide {
    display: block
  }
}

@media only screen and (max-width:768px) {
  .gallery__slide .slick-track {
    left: 5%
  }
}

.gallery__slide .slick-dots li {
  width: 5px;
  height: 5px;
  background-color: #ccc;
  margin: 0 5px;
  border-radius: 50%
}

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

.gallery__slide .slick-dots button {
  width: 5px;
  height: 5px
}

.gallery__slide .slick-dots button:before {
  display: none
}

.gallery__slideItem {
  width: 47.84%
}

@media only screen and (max-width:768px) {
  .gallery__slideItem {
    width: 44.8vw;
    margin-left: 1.06vw
  }
  .gallery__slideItem:first-child {
    margin-left: 0
  }
}

@media only screen and (min-width:769px) {
  .gallery__slideItem:nth-child(even) {
    margin-left: 4.32%
  }
}

@media only screen and (min-width:769px) {
  .gallery__slideItem:nth-child(n+3) {
    margin-top: 20px
  }
}

@media only screen and (min-width:769px) {
  .gallery__slideLink:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
  .gallery__slideLink:hover .gallery__slideFig, .gallery__slideLink:hover .gallery__slideImg {
    transform: scale(1.1, 1.1)
  }
}

.gallery__slideFigWrapper {
  width: 100%;
  padding-top: 66.66%;
  position: relative;
  overflow: hidden;
  margin-bottom: 10px
}

.gallery__slideFig {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.gallery__slideImg {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(1, 1);
  transition: transform 500ms ease;
  object-fit: cover;
  font-family: 'object-fit: cover;'
}

.gallery__slideDate {
  color: #fff;
  font-size: 13px;
  line-height: 1.46;
  letter-spacing: .03em
}

@media only screen and (max-width:768px) {
  .gallery__slideDate {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: .025em
  }
}

.gallery__slideTtl {
  color: #fff;
  font-size: 13px;
  line-height: 19px;
  letter-spacing: .03em
}

@media only screen and (max-width:768px) {
  .gallery__slideTtl {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: .025em
  }
}

.gallery__slideText {
  color: #fff;
  font-size: 13px;
  line-height: 19px;
  letter-spacing: .03em;
  padding-left: 40px;
  box-sizing: border-box;
  position: relative;
  margin-top: 2px
}

.gallery__slideText:before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  width: 30px;
  height: 1px;
  background-color: #fff;
  margin-right: 9px
}

@media only screen and (max-width:768px) {
  .gallery__slideText:before {
    width: 26px;
    margin-right: 6px
  }
}

@media only screen and (max-width:768px) {
  .gallery__slideText {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: .025em
  }
}

.relatedArchives {
  max-width: 1100px;
  width: 100%;
  padding: 0 30px;
  box-sizing: border-box;
  margin: 0 auto 100px
}

@media only screen and (max-width:768px) {
  .relatedArchives {
    padding: 0;
    margin-bottom: 60px
  }
}

.relatedArchives__headding {
  font-size: 26px;
  line-height: 1.5;
  letter-spacing: .05em;
  font-feature-settings: "palt";
  margin-bottom: 30px;
  color: #333;
  text-align: center;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .relatedArchives__headding {
    font-size: 18px;
    margin-bottom: 20px
  }
}

.relatedArchives__headding:after {
  content: "";
  display: block;
  margin: 10px auto 0;
  width: 30px;
  height: 1px;
  background-color: #333
}

@media only screen and (max-width:768px) {
  .relatedArchives__headding:after {
    width: 18px;
    margin-top: 4px
  }
}

.relatedArchives__slide {
  width: calc(100% + .58vw);
  margin-left: -.58vw
}

@media only screen and (max-width:768px) {
  .relatedArchives__slide {
    width: 94.67%;
    margin-left: 5.33%
  }
}

.relatedArchives__slide .slick-dots {
  width: calc(100% - .58vw)
}

@media only screen and (max-width:768px) {
  .relatedArchives__slide .slick-dots {
    width: 100%
  }
}

.relatedArchives__slide .slick-dots li {
  width: 5px;
  height: 5px;
  background-color: #ccc;
  margin: 0 5px;
  border-radius: 50%
}

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

.relatedArchives__slide .slick-dots button {
  width: 5px;
  height: 5px
}

.relatedArchives__slide .slick-dots button:before {
  display: none
}

.relatedArchives__slide .slick-arrow {
  z-index: 1
}

.relatedArchives__slide .slick-next {
  width: 34px;
  height: 34px;
  right: -8px;
  background-image: url(/assets/img/common/arr_slide.png);
  background-repeat: no-repeat;
  background-size: 34px 34px;
  top: 42%;
  transform: translate(0, 0)
}

.relatedArchives__slide .slick-next:before {
  display: none
}

.relatedArchives__slide .slick-prev {
  width: 34px;
  height: 34px;
  left: -14px;
  background-image: url(/assets/img/common/arr_slide_l.png);
  background-repeat: no-repeat;
  background-size: 34px 34px;
  top: 42%;
  transform: translate(0, 0)
}

.relatedArchives__slide .slick-prev:before {
  display: none
}

.relatedArchives__slideItem {
  margin-right: 1.16vw;
  margin-bottom: 10px;
  background-color: #fff;
  box-shadow: 5px 5px 7px -2px rgba(0, 0, 0, .4)
}

@media only screen and (max-width:768px) {
  .relatedArchives__slideItem {
    width: 90.06vw;
    margin-right: 2.66vw;
    margin-left: 0;
    height: 165px
  }
}

.relatedArchives__link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

@media only screen and (max-width:768px) {
  .relatedArchives__link {
    height: 100%
  }
}

@media only screen and (min-width:769px) {
  .relatedArchives__link:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
  .relatedArchives__link:hover .relatedArchives__fig {
    transform: scale(1.1, 1.1)
  }
}

.relatedArchives__figWrapper {
  width: 37.93%;
  padding-top: 42.21%;
  height: 0;
  position: relative;
  overflow: hidden
}

@media only screen and (max-width:768px) {
  .relatedArchives__figWrapper {
    width: 39.11%;
    height: 100%;
    padding-top: 0
  }
}

.relatedArchives__fig {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.relatedArchives__textWrap {
  width: 62.07%;
  padding: 0 5.44%;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .relatedArchives__textWrap {
    width: 60.89%
  }
}

.relatedArchives__date {
  font-size: 14px;
  line-height: 1.5;
  color: #666;
  letter-spacing: .025em
}

@media only screen and (max-width:768px) {
  .relatedArchives__date {
    font-size: 13px
  }
}

.relatedArchives__ttl {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .025em;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .relatedArchives__ttl {
    font-size: 15px;
    line-height: 1.3
  }
}

.relatedArchives__text {
  font-size: 13px;
  line-height: 1.5;
  letter-spacing: .025em
}

.relatedArchives__more {
  text-align: right
}

.relatedArchives__more span {
  font-size: 14px;
  letter-spacing: .03em;
  color: #e04175;
  font-feature-settings: "palt";
  padding-right: 13px;
  position: relative
}

@media only screen and (max-width:768px) {
  .relatedArchives__more span {
    font-size: 13px
  }
}

.relatedArchives__more span:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_text_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.pagerDetail {
  padding: 60px 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: center;
  justify-content: center
}

.pagerDetail a {
  font-size: 14px;
  line-height: 18px;
  letter-spacing: .025em;
  color: #eb96b6;
  padding: 0 30px
}

.pagerDetail a.next {
  border-left: 1px solid #eb96b6
}

.pagerDetail a.next span {
  position: relative
}

.pagerDetail a.next span:before {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(100% + 10px);
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_text_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.pagerDetail a.prev {
  border-right: 1px solid #eb96b6
}

.pagerDetail a.prev span {
  position: relative
}

.pagerDetail a.prev span:before {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(100% + 10px);
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_back_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.areaInfomation {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .areaInfomation {
    padding: 0;
    width: 89.86%
  }
}

.areaInfomation__areaHeading {
  text-align: center;
  position: relative;
  margin-bottom: 20px;
  font-weight: 600
}

.areaInfomation__areaHeading:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #5c5c5c;
  z-index: -1
}

.areaInfomation__areaHeading span {
  font-size: 18px;
  letter-spacing: .05em;
  color: #333;
  padding: 0 15px;
  background-color: #f6f6f6
}

.areaInfomation__areaList {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between
}

@media only screen and (max-width:768px) {
  .areaInfomation__areaList {
    display: block
  }
}

.areaInfomation__areaListItem {
  width: 49.42%
}

@media only screen and (max-width:768px) {
  .areaInfomation__areaListItem {
    width: 100%;
    margin-top: 10px
  }
  .areaInfomation__areaListItem:first-child {
    margin-top: 0
  }
}

.areaInfomation__areaLink {
  display: block;
  position: relative
}

@media only screen and (min-width:769px) {
  .areaInfomation__areaLink:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"
  }
  .areaInfomation__areaLink:hover .areaInfomation__areaFig, .areaInfomation__areaLink:hover .areaInfomation__areaImg {
    transform: scale(1.1, 1.1)
  }
}

.areaInfomation__areaTtl {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 18px;
  letter-spacing: .025em;
  font-feature-settings: "palt";
  color: #fff
}

@media only screen and (max-width:768px) {
  .areaInfomation__areaTtl {
    font-size: 14px
  }
}

.areaInfomation__areaFigWrapper {
  width: 100%;
  padding-top: 31.11%;
  overflow: hidden;
  position: relative
}

.areaInfomation__areaFig {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.areaInfomation__areaImg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  transform: scale(1, 1);
  transition: transform 500ms ease
}

.articleContents {
  padding: 50px 0;
  border-top: 1px solid #ddd
}

@media only screen and (max-width:768px) {
  .articleContents {
    padding: 30px 0;
    width: 80%;
    margin: 0 auto
  }
}

.articleContents__container .card__heading {
  font-weight: 600
}

.articleContents__container h2 {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .05em;
  color: #333;
  margin-bottom: 6px;
  padding-left: 18px;
  position: relative;
  font-weight: 500
}

.articleContents__container h2:before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 12px;
  height: 2px;
  margin-top: -1px;
  background-color: #df7094
}

.articleContents__container h3 {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .05em;
  margin-bottom: 15px;
  padding: 10px 15px;
  color: #333;
  box-sizing: border-box;
  background-color: #e6e6e6;
  font-weight: 500
}

@media only screen and (max-width:768px) {
  .articleContents__container h3 {
    font-size: 14px
  }
}

.articleContents__container h4 {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .05em;
  font-weight: 700;
  color: #333;
  margin-bottom: 6px;
  font-weight: 500
}

@media only screen and (max-width:768px) {
  .articleContents__container h4 {
    font-size: 14px;
    margin-bottom: 10px
  }
}

.articleContents__container p {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container p {
    font-size: 13px;
    margin-bottom: 30px
  }
}

.articleContents__container p:last-child {
  margin-bottom: 0
}

.articleContents__container a {
  color: #eb96b6;
  padding-bottom: 1px;
  border-bottom: 1px solid #eb96b6
}

.articleContents__container a.link--blank {
  position: relative
}

.articleContents__container a.link--blank:after {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(100% + 6px);
  width: 11px;
  height: 11px;
  background-image: url(/assets/img/common/icon_blank_gray.svg);
  background-repeat: no-repeat;
  background-size: 11px 11px
}

.articleContents__container figure {
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container figure {
    margin-bottom: 30px
  }
}

.articleContents__container figure:last-child {
  margin-bottom: 0
}

.articleContents__container figure+figure {
  margin-top: -20px
}

.articleContents__container figcaption {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #a1a1a1;
  margin-top: 5px
}

.articleContents__container figcaption:last-child {
  margin-bottom: 0
}

.articleContents__container img {
  max-width: 100%;
  height: auto;
  display: block
}

.articleContents__container small {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #a1a1a1;
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container small {
    margin-bottom: 30px
  }
}

.articleContents__container small:last-child {
  margin-bottom: 0
}

.articleContents__container ul {
  padding-left: 1em;
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container ul {
    margin-bottom: 30px
  }
}

.articleContents__container ul:last-child {
  margin-bottom: 0
}

.articleContents__container ul li {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  position: relative
}

@media only screen and (max-width:768px) {
  .articleContents__container ul li {
    font-size: 13px
  }
}

.articleContents__container ul li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: -1em
}

.articleContents__container blockquote {
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  border-left: 3px solid #ddd;
  padding-left: 17px;
  box-sizing: border-box;
  color: #666;
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container blockquote {
    font-size: 13px;
    margin-bottom: 30px
  }
}

.articleContents__container blockquote:last-child {
  margin-bottom: 0
}

.articleContents__container .frame {
  border: 1px solid #ddd;
  box-sizing: bordr-box;
  padding: 20px;
  font-size: 15px;
  line-height: 1.7;
  letter-spacing: .025em;
  margin-bottom: 40px
}

@media only screen and (max-width:768px) {
  .articleContents__container .frame {
    font-size: 13px
  }
}

.articleContents__container .frame:last-child {
  margin-bottom: 0
}

.articleSlideBlock {
  max-width: 1100px;
  width: 100%;
  margin: 80px auto 0;
  margin-bottom: 40px;
  background-color: #fff;
  padding: 0;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .articleSlideBlock {
    background-color: transparent;
    padding: 0
  }
}

.articleSlideBlock:last-child {
  margin-bottom: 0
}

.articleSlideBlock .card__inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
.articleSlideBlock {
	max-width: 100%;
	width: 100%;
}
  .articleSlideBlock .card__inner {
    padding: 0;
	max-width: 100%;
	width: 100%;
  }
}

.articleSlideBlock a {
  color: inherit;
  padding-bottom: 0;
  border-bottom-style: none
}

.articleSlideBlock .card__area a {
  padding-left: 16px;
  position: relative
}

.articleSlideBlock p {
  margin-bottom: 0
}

.articleSlideBlock h2 {
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: .05em;
  margin-bottom: 25px;
  padding-left: 0
}

.articleSlideBlock h2:before {
  display: none
}

.articleSlideBlock .card__fig {
  margin-bottom: 0
}

.articleSlideBlock .card__slide {
  width: 100%;
  margin-left: 0;
  padding-left: 0
}

.articleSlideBlock .card__ttl {
  color: #333;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .025em;
  margin-bottom: 0;
  padding: 0;
  background-color: transparent
}

.articleSlideBlock li:before {
  display: none
}

.articleDetailPager {
  text-align: center;
  padding: 35px 0 100px
}

@media only screen and (max-width:768px) {
  .articleDetailPager {
    padding: 0 0 60px
  }
}

.articleDetailPager a {
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #de7094;
  padding-left: 15px;
  position: relative
}

@media only screen and (max-width:768px) {
  .articleDetailPager a {
    font-size: 14px
  }
}

.articleDetailPager a:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_back_pink.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

.mainContainer {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto 50px;
  padding: 80px 30px 0;
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: space-betwween;
  justify-content: space-betwween
}

@media only screen and (max-width:768px) {
  .mainContainer {
    padding: 40px 0 0;
    display: block
  }
}

.mainContainer .articleBlock {
  width: calc(100% - 325px);
  padding: 0 6.25% 0 0;
  box-sizing: border-box
}

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

.mainContainer .articleContents {
  border-top-style: none;
  padding-top: 0
}

.mainContainer .sideNavWrapper {
  width: 325px
}

@media only screen and (max-width:768px) {
  .mainContainer .sideNavWrapper {
    width: 100%;
    border-top: 1px solid #ddd
  }
}

.sideNav__areaWrapper {
  border: 1px solid #ddd;
  box-sizing: border-box;
  padding: 30px 8.98% 30px 13.31%
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper {
    padding: 0;
    width: 90vw;
    margin-left: -5vw
  }
}

.sideNav__areaWrapper .sideNav__heading:after {
  display: none
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper .sideNav__heading {
    padding: 15px 0;
    margin-bottom: 0
  }
  .sideNav__areaWrapper .sideNav__heading.is--areaOpenBtn:after {
    display: none
  }
  .sideNav__areaWrapper .sideNav__heading:before, .sideNav__areaWrapper .sideNav__heading:after {
    display: block;
    content: "";
    position: absolute;
    z-index: 1;
    top: 50%;
    left: auto;
    background-color: #a1a1a1;
    transform: translate(0, -50%);
    margin-top: 0
  }
  .sideNav__areaWrapper .sideNav__heading:before {
    width: 11px;
    height: 1px;
    right: 5.88%
  }
  .sideNav__areaWrapper .sideNav__heading:after {
    width: 1px;
    height: 11px;
    right: calc(5.88% + 5px)
  }
}

.sideNav__areaWrapper .sideNav__areaList {
  width: 44.66%
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper .sideNav__areaList:before {
    display: none
  }
}

.sideNav__areaWrapper .sideNav__areaList:nth-child(even) {
  margin-left: 10.68%
}

.sideNav__areaWrapper .sideNav__areaList:nth-child(1), .sideNav__areaWrapper .sideNav__areaList:nth-child(2) {
  margin-top: 0
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper .sideNav__areaLink {
    border-bottom-style: none
  }
}

.sideNav__areaWrapper .sideNav__area {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  padding: 0
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper .sideNav__area {
    padding-left: 6.73%;
    box-sizing: border-box
  }
}

.sideNav__areaWrapper .sideNav__areaContainer {
  display: block
}

@media only screen and (max-width:768px) {
  .sideNav__areaWrapper .sideNav__areaContainer {
    display: none;
    padding: 15px 11.76% 30px;
    box-sizing: border-box
  }
}

.sideNav__areaBlock {
  margin-top: 25px
}

.sideNav__areaBlock:first-child {
  margin-top: 0
}

.sideNav__areaTtl {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #df7094;
  margin-bottom: 15px;
  position: relative
}

.sideNav__areaTtl:before {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(100% + 10px);
  width: 10px;
  height: 1px;
  background-color: #b9b9b9;
  transform: translate(0, -50%)
}

.sideNav__heading {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #333;
  margin-bottom: 30px;
  text-align: center;
  text-transform: uppercase;
  font-weight: 600
}

@media only screen and (max-width:768px) {
  .sideNav__heading {
    padding-top: 50px;
    margin-bottom: 35px
  }
}

.sideNav__heading:after {
  content: "";
  display: block;
  margin: 10px auto 0;
  width: 18px;
  height: 1px;
  background-color: #404040
}

@media only screen and (max-width:768px) {
  .sideNav__heading:after {
    margin-top: 4px
  }
}

.sideNav__area {
  width: 196px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  .sideNav__area {
    width: 80%;
    padding: 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
}

.sideNav__areaList {
  margin-top: 20px
}

@media only screen and (max-width:768px) {
  .sideNav__areaList {
    margin-top: 25px;
    width: 43.33%
  }
  .sideNav__areaList:nth-child(even) {
    margin-left: 13.34%
  }
  .sideNav__areaList:nth-child(1), .sideNav__areaList:nth-child(2) {
    margin-top: 0
  }
}

.sideNav__areaList:first-child {
  margin-top: 0
}

.sideNav__areaLink {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .05em;
  display: block;
  width: 100%;
  position: relative;
  font-weight: 500;
  color: #333!important
}

@media only screen and (max-width:768px) {
  .sideNav__areaLink {
    font-size: 13px
  }
}

.sideNav__areaLink:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 5px;
  height: 8px;
  margin-top: -4px;
  background-image: url(/assets/img/common/arr_btn_gray.png);
  background-repeat: no-repeat;
  background-size: 5px 8px
}

#toc_container {
  border: 1px solid #b9b9b9;
  margin-bottom: 40px;
  padding: 40px 10%;
  box-sizing: border-box
}

@media only screen and (max-width:768px) {
  #toc_container {
    width: 100%;
    padding: 25px 10%
  }
}

#toc_container .toc_title {
  text-align: center;
  font-size: 18px;
  line-height: 1.5;
  margin-bottom: 30px;
  font-weight: 500
}

@media only screen and (max-width:768px) {
  #toc_container .toc_title {
    font-size: 16px;
    margin-bottom: 15px
  }
}

#toc_container .toc_list {
  padding-left: 0
}

#toc_container .toc_list li {
  margin-top: 15px;
  padding-left: 22px;
  box-sizing: border-box;
  position: relative
}

@media only screen and (max-width:768px) {
  #toc_container .toc_list li {
    padding-left: 20px;
    margin-top: 10px
  }
}

#toc_container .toc_list li:before {
  content: "";
  position: absolute;
  top: 11px;
  left: 0;
  width: 12px;
  height: 1px;
  background-color: #b9b9b9
}

@media only screen and (max-width:768px) {
  #toc_container .toc_list li:before {
    width: 10px;
    top: 10px
  }
}

#toc_container .toc_list li:first-child {
  margin-top: 0
}

#toc_container .toc_list li a {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: .025em;
  color: #de7094;
  border-bottom: 1px solid #de7094
}

@media only screen and (max-width:768px) {
  #toc_container .toc_list li a {
    font-size: 13px
  }
}

.articleSns {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 40px
}

@media only screen and (max-width:768px) {
  .articleSns {
    margin-top: 50px
  }
}

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

.articleSns.articleSns--sp {
  display: none
}

@media only screen and (max-width:768px) {
  .articleSns.articleSns--sp {
    display: -ms-flexbox;
    display: flex
  }
}

.articleSns__ttl {
  font-size: 13px;
  line-height: 1.846;
  letter-spacing: .025em;
  margin-right: 22px;
  font-weight: 600
}

.articleSns__icon {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center
}

.articleSns__icon a {
  margin-left: 19px
}

.articleSns__icon a:nth-child(1) {
  margin-left: 0
}

.articleSns__icon a:nth-child(1) img {
  width: 20px
}

@media only screen and (max-width:768px) {
  .articleSns__icon a:nth-child(1) img {
    width: 13px
  }
}

.articleSns__icon a:nth-child(2) img {
  width: 11px
}

@media only screen and (max-width:768px) {
  .articleSns__icon a:nth-child(2) img {
    width: 8px
  }
}

.articleSns__icon .clipBtn {
  margin-left: 19px
}

.articleSns__icon .clipBtn img {
  width: 19px
}

@media only screen and (max-width:768px) {
  .articleSns__icon .clipBtn img {
    width: 13px
  }
}

.ui-widget.ui-widget-content {
  border: 1px solid #ddd!important
}

.ui-widget-header {
  border-style: none!important;
  background: #fff!important;
  color: #333!important;
  font-weight: 500!important;
  font-size: 16px!important
}

.ui-datepicker th {
  color: #888!important
}

.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active {
  border-style: none!important;
  background: #fff!important;
  font-weight: 500!important;
  color: #333!important;
  text-align: center!important
}

.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {
  border-style: none!important;
  background: #fff!important;
  font-weight: 500!important;
  color: #333!important;
  text-align: center!important;
  font-size: 12px!important
}

.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active, a.ui-button:active, .ui-button:active, .ui-button.ui-state-active:hover {
  border-style: none!important;
  background: transparent!important;
  font-weight: 500!important;
  color: 333!important;
  text-align: center!important;
  border-radius: 50%!important;
  position: relative!important;
  font-size: 12px!important
}

.ui-state-active:before, .ui-widget-content .ui-state-active:before, .ui-widget-header .ui-state-active:before, a.ui-button:active:before, .ui-button:active:before, .ui-button.ui-state-active:hover:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 22px;
  transform: translate(-50%, -50%);
  background-color: #ddd;
  border-radius: 50%;
  z-index: -1
}

.ui-widget-header .ui-datepicker-prev .ui-icon {
  width: 15px;
  height: 15px;
  background-image: url(/assets/img/common/icon_arr_calendar_l.png);
  background-size: 15px auto;
  background-position: center
}

.ui-widget-header .ui-datepicker-next .ui-icon {
  width: 15px;
  height: 15px;
  background-image: url(/assets/img/common/icon_arr_calendar_r.png);
  background-size: 15px auto;
  background-position: center
}

.clipBtn {
  cursor: pointer;
  position: relative
}

.clipBtn img {
  transition: opacity 500ms
}

.clipBtn:hover img {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"
}

.tooltip:after {
  content: 'Copied!';
  background: #5b5b5b;
  display: inline-block;
  color: #fff;
  border-radius: .4rem;
  position: absolute;
  left: 150%;
  top: 50%;
  transform: translateY(-50%);
  font-size: .75rem;
  padding: 4px 10px 6px;
  animation: fade-tooltip .5s 1s 1 forwards
}

@keyframes fade-tooltip {
  to {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"
  }
}

#copyUrl {
  position: fixed;
  left: -100%
}

/*=======================================================*/
/*Loader*/
/*=======================================================*/
.loadBlock{
  position: relative;
  padding-top: 60px;
  padding-bottom: 60px;
  text-align: center;
}

.box-resetBt{
  text-align: center;
}
.box-resetBt span{
  display: inline-block;
  cursor: pointer;
  padding: 8px 0 4px 0;
  border-bottom:1px solid #444;
}
