@charset "UTF-8";
/* ==========================================================================
INDEX
---- Base ----
*base
---- Layout ----
*header
*navigator
*main-layout
*modal
*footer
---- Object ----
*general-conponent
========================================================================== */
/************************* Utility *************************/
/* *** typography */
.u-td-ul {
  text-decoration: underline;
}

.u-td-ul:hover {
  text-decoration: none;
}

.u-td-n {
  text-decoration: none;
}

.u-td-lt {
  text-decoration: line-through;
}

.is-mobile .js-call-sp {
  cursor: pointer;
  text-decoration: underline;
}

.is-mobile .js-call-sp:hover {
  text-decoration: none;
}

.fs-10 {
  font-size: 1.0rem !important;
}

.fs-11 {
  font-size: 1.1rem !important;
}

.fs-12 {
  font-size: 1.2rem !important;
}

.fs-13 {
  font-size: 1.3rem !important;
}

.fs-14 {
  font-size: 1.4rem !important;
}

.fs-15 {
  font-size: 1.5rem !important;
}

.fs-16 {
  font-size: 1.6rem !important;
}

.fs-17 {
  font-size: 1.7rem !important;
}

.fs-18 {
  font-size: 1.8rem !important;
}

.fs-19 {
  font-size: 1.9rem !important;
}

.fs-20 {
  font-size: 2.0rem !important;
}

.fw-b {
  font-weight: bold !important;
}

.fw-n {
  font-weight: normal !important;
}

.fc-w {
  color: #fff;
}

.fc-b {
  color: #000;
}

.u-ta-c {
  text-align: center;
}

.u-ta-l {
  text-align: left;
}

.u-ta-r {
  text-align: right;
}

.u-ws-nw {
  white-space: nowrap;
}

.u-va-t {
  vertical-align: top;
}

.u-va-m {
  vertical-align: middle;
}

.u-va-b {
  vertical-align: bottom;
}

.u-lis-n {
  list-style: none;
}

.u-lis-d {
  list-style: decimal;
  padding-left: 28px;
}

/* *** margin */
.u-mt-zero {
  margin-top: 0 !important;
}

.u-mt-mcr {
  margin-top: 5px !important;
}

.u-mt-sml {
  margin-top: 13px !important;
}

.u-mt-mid {
  margin-top: 20px !important;
}

.u-mt-lrg {
  margin-top: 38px !important;
}

.u-mt-auto {
  margin-top: auto !important;
}

.u-mr-zero {
  margin-right: 0 !important;
}

.u-mr-mcr {
  margin-right: 5px !important;
}

.u-mr-sml {
  margin-right: 13px !important;
}

.u-mr-mid {
  margin-right: 20px !important;
}

.u-mr-lrg {
  margin-right: 38px !important;
}

.u-mr-auto {
  margin-right: auto !important;
}

.u-mb-zero {
  margin-bottom: 0 !important;
}

.u-mb-mcr {
  margin-bottom: 5px !important;
}

.u-mb-sml {
  margin-bottom: 13px !important;
}

.u-mb-mid {
  margin-bottom: 20px !important;
}

.u-mb-lrg {
  margin-bottom: 38px !important;
}

.u-mb-auto {
  margin-bottom: auto !important;
}

.u-ml-zero {
  margin-left: 0 !important;
}

.u-ml-mcr {
  margin-left: 5px !important;
}

.u-ml-sml {
  margin-left: 13px !important;
}

.u-ml-mid {
  margin-left: 20px !important;
}

.u-ml-lrg {
  margin-left: 38px !important;
}

.u-ml-auto {
  margin-left: auto !important;
}

@media screen and (max-width: 780px) {
  .u-sp-mb-zero {
    margin-bottom: 0 !important;
  }
  .u-sp-mb-mcr {
    margin-bottom: 5px !important;
  }
  .u-sp-mb-sml {
    margin-bottom: 13px !important;
  }
  .u-sp-mb-mid {
    margin-bottom: 20px !important;
  }
  .u-sp-mb-lrg {
    margin-bottom: 38px !important;
  }
  .u-sp-mb-auto {
    margin-bottom: auto !important;
  }
  .u-sp-ml-zero {
    margin-left: 0 !important;
  }
  .u-sp-ml-mcr {
    margin-left: 5px !important;
  }
  .u-sp-ml-sml {
    margin-left: 13px !important;
  }
  .u-sp-ml-mid {
    margin-left: 20px !important;
  }
  .u-sp-ml-lrg {
    margin-left: 38px !important;
  }
  .u-sp-ml-auto {
    margin-left: auto !important;
  }
  .u-sp-mr-zero {
    margin-right: 0 !important;
  }
  .u-sp-mr-mcr {
    margin-right: 5px !important;
  }
  .u-sp-mr-sml {
    margin-right: 13px !important;
  }
  .u-sp-mr-mid {
    margin-right: 20px !important;
  }
  .u-sp-mr-lrg {
    margin-right: 38px !important;
  }
  .u-sp-mr-auto {
    margin-right: auto !important;
  }
  .u-sp-mt-zero {
    margin-top: 0 !important;
  }
  .u-sp-mt-mcr {
    margin-top: 5px !important;
  }
  .u-sp-mt-sml {
    margin-top: 13px !important;
  }
  .u-sp-mt-mid {
    margin-top: 20px !important;
  }
  .u-sp-mt-lrg {
    margin-top: 38px !important;
  }
  .u-sp-mt-auto {
    margin-top: auto !important;
  }
}

/* *** layout */
.u-pos-r {
  position: relative;
}

.u-pos-a {
  position: absolute;
}

.u-dsp-b {
  display: block;
}

.u-dsp-ib {
  display: inline-block;
}

.u-dsp-n {
  display: none;
}

.u-dsp-tb {
  display: table;
}

.u-dsp-tbc {
  display: table-cell;
}

.u-dsp-f {
  display: flex;
  display: -webkit-flex;
}

.u-dsp-if {
  display: flex;
  display: -webkit-flex;
}

@media screen and (max-width: 780px) {
  .u-sp-dsp-b {
    display: block;
  }
  .u-sp-dsp-ib {
    display: inline-block;
  }
  .u-sp-dsp-n {
    display: none;
  }
}

.u-wid-full {
  width: 100% !important;
}

.u-wid-half--separate {
  width: calc(50% - 10px);
}

.u-wid-33per {
  width: 33.33% !important;
}

.u-wid-2em {
  width: calc(2em + 8px) !important;
}

.u-wid-3em {
  width: calc(3em + 6px) !important;
}

.u-wid-4em {
  width: calc(4em + 4px) !important;
}

.u-wid-5em {
  width: 5em !important;
}

.u-wid-6em {
  width: 6em !important;
}

.u-wid-num-select {
  min-width: 70px !important;
}

.u-maxw-600 {
  max-width: 600px !important;
}

@media screen and (min-width: 781px) {
  .u-pc-wid-full {
    width: 100% !important;
  }
  .u-pc-wid-half {
    width: 50% !important;
  }
}

@media screen and (max-width: 780px) {
  .u-sp-wid-full {
    width: 100% !important;
  }
  .u-sp-wid-half {
    width: 50% !important;
  }
}

.u-ba-c {
  margin-left: auto;
  margin-right: auto;
}

.u-sp-break {
  display: none;
}

@media screen and (max-width: 780px) {
  .u-sp-break {
    display: inherit;
  }
}

/* *** layout-flex */
.u-flex--as-fs {
  -webkit-align-self: flex-start !important;
  align-self: flex-start !important;
}

.u-flex--ai-end {
  -webkit-align-items: flex-end !important;
  align-items: flex-end !important;
}

.u-flex--ai-c {
  -webkit-align-items: center !important;
  -ms-align-items: center !important;
  align-items: center !important;
}

.u-flex--ai-bl {
  -webkit-align-items: baseline !important;
  -ms-align-items: baseline !important;
  align-items: baseline !important;
}

.u-flex--jc-sa {
  -webkit-justify-content: space-around !important;
  justify-content: space-around !important;
}

.u-flex--jc-sb {
  -webkit-justify-content: space-between !important;
  justify-content: space-between !important;
}

.u-flex--jc-end {
  -webkit-justify-content: flex-end !important;
  justify-content: flex-end !important;
}

.u-flex--jc-c {
  -webkit-justify-content: center !important;
  justify-content: center !important;
}

.u-flex--dir-col {
  -webkit-flex-direction: column !important;
  flex-direction: column !important;
}

.u-flex--wrap-w {
  -webkit-flex-wrap: wrap !important;
  flex-wrap: wrap !important;
}

.u-flex--frow-rre {
  -webkit-flex-flow: row-reverse !important;
  flex-flow: row-reverse !important;
}

@media screen and (max-width: 780px) {
  .u-sp-flex--as-fs {
    -webkit-align-self: flex-start !important;
    align-self: flex-start !important;
  }
  .u-sp-flex--ai-fs {
    -webkit-align-items: flex-start !important;
    -ms-align-items: flex-start !important;
    align-items: flex-start !important;
  }
  .u-sp-flex--ai-end {
    -webkit-align-items: flex-end !important;
    -ms-align-items: flex-end !important;
    align-items: flex-end !important;
  }
  .u-sp-flex--ai-c {
    -webkit-align-items: center !important;
    -ms-align-items: center !important;
    align-items: center !important;
  }
  .u-sp-flex--ai-bl {
    -webkit-align-items: baseline !important;
    -ms-align-items: baseline !important;
    align-items: baseline !important;
  }
  .u-sp-flex--jc-sa {
    -webkit-justify-content: space-around !important;
    justify-content: space-around !important;
  }
  .u-sp-flex--jc-sb {
    -webkit-justify-content: space-between !important;
    justify-content: space-between !important;
  }
  .u-sp-flex--jc-end {
    -webkit-justify-content: flex-end !important;
    justify-content: flex-end !important;
  }
  .u-sp-flex--jc-c {
    -webkit-justify-content: center !important;
    justify-content: center !important;
  }
  .u-sp-flex--dir-col {
    -webkit-flex-direction: column !important;
    flex-direction: column !important;
  }
  .u-sp-flex--wrap-w {
    -webkit-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
  }
  .u-sp-flex--frow-rre {
    -webkit-flex-flow: row-reverse !important;
    flex-flow: row-reverse !important;
  }
}

/* *** decoration */
.u-bdrs-sm {
  border-radius: 3px;
}

.u-bdrs-md {
  border-radius: 5px;
}

/* *** action */
.u-mc-p {
  cursor: pointer;
}

.u-mh-alpha:hover,.u-mh-alpha:hover img,.u-mh-alpha:hover span {
  -ms-filter: "alpha(opacity=80)";
  filter: alpha(opacity=80);
  opacity: 0.8;
}

.u-mh-ul:hover {
  text-decoration: underline;
}

.u-mh-block {
  display: block;
  height: 100%;
}

.u-mh-block:hover,.u-mh-block:hover img,.u-mh-block:hover span {
  -ms-filter: "alpha(opacity=80)";
  filter: alpha(opacity=80);
  opacity: 0.8;
}

.u-mh-block:hover .u-mh-block__headline {
  text-decoration: underline;
}

.u-ovf-h {
  overflow: hidden;
}

/* *** forr reader */
.u-spk-n {
  speak: none;
}

/* *** ime-mode */
.u-ime-a {
  ime-mode: active !important;
}

.u-ime-i {
  ime-mode: inactive !important;
}

.u-ime-d {
  ime-mode: disabled !important;
}

/* *** color */
@media screen and (max-width: 780px) {
  .u-sp-bgc-wh {
    background-color: #fff !important;
  }
}

@media screen and (max-width: 780px) {
  .u-bread-area-next {
    margin-top: 20px;
  }
}

.c-disc-list {
  list-style: none;
}

.c-disc-list__item {
  padding-left: 15px;
  position: relative;
}

.c-disc-list__item:before {
  background: #000;
  border-radius: 50%;
  content: "";
  height: 2px;
  left: 4px;
  position: absolute;
  top: 0.4em;
  width: 2px;
}

.c-circle-list {
  list-style: none;
}

.c-circle-list__item {
  padding-left: 1.5em;
  text-indent: -1.5em;
}

.c-circle-list__item:before {
  background: #d8d8d8;
  border-radius: 50%;
  content: "";
  display: inline-block;
  height: 1em;
  margin-right: 0.5em;
  vertical-align: middle;
  width: 1em;
}

.fc-r,.u-color-caution {
  color: #b4181c;
}

.u-form-required {
  font-size: 0.85em;
}

.u-caution-indent {
  display: table;
}

.u-caution-indent--inline {
  display: inline-flex;
  display: -webkit-inline-flex;
}

.u-caution-indent__icon {
  display: table-cell;
  padding-right: 5px;
  white-space: nowrap;
}

.u-caution-indent__icon img {
  max-width: inherit;
}

.u-caution-indent__text {
  display: table-cell;
  width: 100%;
}

a.u-link--has-underline,a .u-link--has-underline {
  text-decoration: underline;
}

a.u-link--has-underline:hover,a:hover .u-link--has-underline {
  text-decoration: none;
}

.u-icon-pdf {
  vertical-align: top;
  width: 18px;
}

.u-new-line {
  display: none;
}

@media screen and (max-width: 780px) {
  .u-new-line {
    display: inline;
  }
}

.u-fl-r {
  float: right;
  margin-bottom: 0.5em;
  margin-left: 0.5em;
}

.u-fl-l {
  float: left;
  margin-bottom: 0.5em;
  margin-right: 0.5em;
}

@media screen and (max-width: 780px) {
  .u-sp-fl-n {
    float: none;
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }
}

.u-maxw-150 {
  max-width: 150px;
}

.u-wb-ba {
  word-break: break-all;
}

.u-ow-bw {
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* ==========================================================================
Base
========================================================================== */
/************************* base *************************/
.fwWysiwygObj {
  position: relative;
}

html {
  font-size: 62.5%;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

*,*:before,*:after {
  box-sizing: border-box;
}

body,form {
  border: 0;
  color: #000;
  font-family: "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  margin: 0;
  outline: 0;
  padding: 0;
  -webkit-text-size-adjust: 100%;
  vertical-align: baseline;
}

button,input,optgroup,select,textarea {
  font-family: "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

table {
  border-collapse: collapse;
}

button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  padding: 0;
}

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

select,input,textarea,button {
  vertical-align: middle;
}

button {
  cursor: pointer;
}

ul {
  margin: 0;
  padding: 0;
}

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

a:hover {
  text-decoration: none;
}

a:focus,input:focus,button:focus,area:focus {
  outline: 1px dotted #ddd;
}

h1,h2,h3,h4 {
  margin-bottom: 0;
  margin-top: 0;
}

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

iframe {
  border: 0;
}

#fwCms_wrapper {
  margin-left: auto;
  margin-right: auto;
  min-width: 1200px;
  width: 100%;
}

/* ==========================================================================
.is-tablet #fwCms_wrapper {
  min-width: 1024px;
}

.is-tablet .header-wrapper--fixed {
  min-width: 1024px;
}
========================================================================== */

@media screen and (max-width: 780px) {
  #fwCms_wrapper {
    min-width: 320px;
  }
}

/* ==========================================================================
Layout
========================================================================== */
/************************* header *************************/
.header-wrapper--fixed {
  background-color: #fff;
  min-width: 1200px;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .header-wrapper--fixed {
    min-width: 320px;
  }
}

.header-wrapper {
  background-color: #fff;
  display: flex;
  display: -webkit-flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
  min-height: 90px;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .header-wrapper {
    min-height: 60px;
    min-width: 320px;
  }
}

.header {
  -webkit-align-items: center;
  align-items: center;
  -webkit-flex: 0 0 auto;
  flex: 0 0 auto;
  padding: 20px 0;
}

@media screen and (max-width: 780px) {
  .header {
    display: block;
    padding: 0;
  }
}

.header-contents {
  background-color: #fff;
  display: flex;
  display: -webkit-flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .header-contents {
    height: 60px;
  }
}

.header__logo-image {
  display: block;
  height: 50px !important;
  padding: 0;
  width: auto;
}

@media screen and (max-width: 780px) {
  .header__logo-image {
    height: 30px !important;
  }
}

.header-contents__left {
  -webkit-align-items: flex-end;
  align-items: flex-end;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

@media screen and (max-width: 780px) {
  .header-contents__left {
    padding-bottom: 15px;
    width: 65.5%;
  }
}

.header__official-link-wrapper {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  font-size: 1.4rem;
  margin-left: 10px;
  padding-left: 9px;
  padding-right: 9px;
  position: relative;
}

.header__official-link-wrapper::before,.header__official-link-wrapper::after {
  background-color: #b4b4b4;
  content: "";
  height: 1em;
  margin-top: -0.5em;
  position: absolute;
  top: 50%;
  width: 1px;
}

.header__official-link-wrapper::before {
  left: 0;
}

.header__official-link-wrapper::after {
  right: 0;
}

.header__blunk-icon {
  height: 9px;
  margin-right: 3px;
  width: 9px;
}

.header__official-link:hover {
  text-decoration: underline;
}

.header__button-link-wrapper {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
}

.header__official-link {
  line-height: 1;
}

.header__button-link {
  -webkit-align-items: center;
  align-items: center;
  border-radius: 3px;
  color: #fff;
  display: -webkit-flex;
  display: flex;
  font-size: 1.4rem;
  font-weight: bold;
  -webkit-justify-content: center;
  justify-content: center;
  line-height: 1;
  margin-left: 12px;
  padding: 10px;
  text-align: left;
}

@media screen and (max-width: 780px) {
  .header__button-link {
    margin-left: 0;
  }
}

.header__button-link:hover {
  opacity: 0.7;
}

.header__button-link-icon {
  height: 30px;
  margin-right: 6px;
  width: 30px;
}

.header__button-link-document {
  background-color: #3ca21b;
}

.header__button-link-procedure {
  background-color: #f69812;
}

.header__button-link-eclub {
  background-color: #ed777a;
}

.sp-menu-list__two-button-wrapper {
  display: flex;
  display: -webkit-flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

@media screen and (max-width: 780px) {
  .header__button-link-document,.header__button-link-procedure {
    margin-bottom: 10px;
    margin-left: 3px;
    margin-right: 3px;
    width: calc(50% - 6px);
  }
  .header__button-link-eclub {
    width: 100%;
  }
}

.sp-menu-list__two-button-wrapper {
  margin-left: -3px;
  margin-right: -3px;
}

.sp-menu-list__banner-image {
  background-color: #ccc;
  height: auto;
  width: 100%;
}

.sp-menu-list__banner-wrapper {
  padding: 10px 12px;
}

.header-contents__right {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

@media screen and (max-width: 780px) {
  .header-contents__right {
    width: auto;
  }
}

.header__logo {
  margin-right: 5px;
}

@media screen and (max-width: 780px) {
  .header__logo {
    margin-left: 12px;
    max-width: 105px;
    width: 43%;
  }
  .header__logo-image {
    width: 100%;
  }
}

.keyword-search__form {
  -webkit-align-items: center;
  align-items: center;
  background-color: #fff;
  border: 1px solid #b4b4b4;
  display: -webkit-flex;
  display: flex;
  font-size: 1.3rem;
  height: 42px;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 1px;
  width: 260px;
}

@media screen and (max-width: 780px) {
  .header__search-form {
    display: none;
  }
}

.keyword-search__form input[type="search"] {
  -webkit-appearance: textfield;
}

.keyword-search__form input[type="search"]::-webkit-input-placeholder {
  padding-top: 0.3em;
}

.keyword-search__text {
  border: none;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  height: 37px;
  min-width: 1%;
  padding: 0 8px;
  vertical-align: middle;
  width: 99%;
}

.keyword-search__submit {
  background-color: #fff;
  border: none;
  display: -webkit-flex;
  display: block;
  height: 18px;
  margin-right: 10px;
  min-width: 18px;
  text-align: center;
  width: 18px;
}

.header__search-wrapper {
  background-color: #fdf6f6;
}

@media screen and (max-width: 780px) {
  .header__search-wrapper {
    min-height: 50px;
  }
}

.header__search-contents {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 10px;
  padding-top: 10px;
  width: 980px;
}

@media screen and (max-width: 780px) {
  .header__search-contents {
    border-bottom: 3px solid #ed777a;
    min-width: 320px;
    width: 100%;
  }
}

.header__search-location {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

@media screen and (max-width: 780px) {
  .header__search-location {
    min-height: 50px;
  }
}

.header__search-location--min-height {
  min-height: 60px;
}

.header__search-location-image {
  max-height: 100px;
  vertical-align: bottom;
  width: auto;
}

.header__search-location-text {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  font-size: 1.4rem;
  line-height: 1.4;
  min-height: 40px;
  padding-left: 12px;
}

@media screen and (max-width: 780px) {
  .header__search-location-image {
    height: 30px;
    margin-left: 18px;
  }
  .header__search-location-text {
    display: none;
  }
}

.header__search-location-image-detail {
  max-height: 60px;
}

@media screen and (max-width: 780px) {
  .header__search-location-image-detail {
    max-height: 60px;
    width: 114px;
  }
}

.header__search-location--column {
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  -webkit-flex-direction: column;
  flex-direction: column;
  text-align: left;
}

@media screen and (max-width: 780px) {
  .header__search-location--column {
    min-height: 50px;
  }
}

.header__search-input {
  margin-left: 15px;
}

@media screen and (max-width: 780px) {
  .header__search-input {
    margin-left: 10px;
  }
}

.header__location-link-wrapper {
  -webkit-align-items: center;
  align-items: center;
  border-left: 1px solid #b4b4b4;
  display: flex;
  display: -webkit-flex;
  padding-right: 5px;
}

@media screen and (max-width: 780px) {
  .header__location-link-wrapper {
    display: none;
  }
}

.header__location-link {
  -webkit-align-items: center;
  align-items: center;
  border-right: 1px solid #b4b4b4;
  display: flex;
  display: -webkit-flex;
  padding-left: 5px;
  padding-right: 5px;
}

.sp-header__location-button {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-header__location-button {
    -webkit-align-items: center;
    align-items: center;
    border: 2px solid #ed777a;
    border-radius: 3px;
    color: #ed777a;
    display: flex;
    display: -webkit-flex;
    -webkit-justify-content: center;
    justify-content: center;
    min-height: 40px;
    padding: 10px 8px;
  }
}

.sp-header__location-open {
  display: block;
  padding-right: 12px;
  position: relative;
}

.sp-header__location-open.is-close::before {
  border-bottom: 3px solid #ed777a;
  border-right: 3px solid #ed777a;
  content: "";
  height: 9px;
  position: absolute;
  right: 0;
  top: calc(50% - 6px);
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 9px;
}

.sp-header__location-open.is-open::before {
  border-left: 3px solid #ed777a;
  border-top: 3px solid #ed777a;
  content: "";
  height: 9px;
  position: absolute;
  right: 0;
  top: calc(50% - 4px);
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 9px;
}

.location-toggle {
  display: none;
  position: relative;
}

@media screen and (max-width: 780px) {
  .location-toggle {
    display: block;
  }
}

.location-toggle__list {
  background-color: #fff;
  border: 2px solid #ed777a;
  border-radius: 5px;
  display: none;
  padding: 10px;
  padding-bottom: 5px;
  position: absolute;
  top: calc(100% + 12px);
  width: 100%;
  z-index: 10;
}

.location-toggle__list::before {
  border-bottom: 22px solid #ed777a;
  border-left: 17px solid transparent;
  border-right: 17px solid transparent;
  bottom: 100%;
  content: "";
  left: calc(50% - 20px);
  position: absolute;
}

.location-toggle__list::after {
  border-bottom: 22px solid #fff;
  border-left: 17px solid transparent;
  border-right: 17px solid transparent;
  bottom: calc(100% - 4px);
  content: "";
  left: calc(50% - 20px);
  position: absolute;
}

.location-toggle__item {
  -webkit-align-items: center;
  align-items: center;
  color: #ed777a;
  display: flex;
  display: -webkit-flex;
  margin-bottom: 5px;
}

.location-toggle__link {
  color: #ed777a;
  margin-right: 5px;
}

.sp-menu {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-menu {
    border-radius: 3px;
    display: block;
    height: 40px;
    margin-right: 12px;
    width: 40px;
  }
}

.sp-menu-list-wrapper {
  background-color: #fff;
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-menu-list-wrapper {
    height: 100vh;
    min-width: 320px;
    width: 100%;
    z-index: -10;
  }
}

.sp-menu-list {
  font-size: 1.6rem;
  height: calc(100% - 140px);
  overflow-y: auto;
  text-align: left;
}

.sp-menu-list__item {
  background-color: #fbe2e5;
  position: relative;
  width: 100%;
}

.sp-header__search-form-wrapper {
  padding: 12px 18px;
}

.sp-header__search-form {
  width: 100%;
}

.sp-menu__button-wrapper {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-menu__button-wrapper {
    display: block;
  }
}

.sp-menu-list__item-arrow::before {
  border-right: 4px solid #fff;
  border-top: 4px solid #fff;
  content: "";
  height: 15px;
  position: absolute;
  right: 15px;
  top: 35%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 15px;
}

.sp-menu-list__item {
  background-color: #ed777a;
}

.sp-menu-list__item.sp-menu-list__item-arrow.is-current::before {
  border-right: 4px solid #fff;
  border-top: 4px solid #fff;
}

.sp-menu-list__item-link {
  border-bottom: 1px solid #fff;
  color: #fff;
  display: block;
  height: 100%;
  padding: 18px;
  padding-left: 10px;
  width: 100%;
}

.sp-menu-list__item.is-current .sp-menu-list__item-link {
  color: #fff;
}

.sp-menu-list__item-toggle {
  border-bottom: 1px solid #fff;
  color: #fff;
  cursor: pointer;
  display: block;
  padding: 18px;
  padding-left: 10px;
}

.sp-toggle-menu-wrapper {
  display: none;
}

.sp-toggle-menu {
  list-style: none;
}

.sp-menu-list__item-toggle.is-close::before {
  border-bottom: 4px solid #fff;
  border-right: 4px solid #fff;
  content: "";
  height: 15px;
  position: absolute;
  right: 14px;
  top: 28%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 15px;
}

.sp-menu-list__item-toggle.is-open {
  background-color: #ed777a;
  color: #fff;
}

.sp-menu-list__item-toggle.is-open::before {
  border-left: 4px solid #fff;
  border-top: 4px solid #fff;
  content: "";
  height: 15px;
  position: absolute;
  right: 14px;
  top: 38%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 15px;
}

.sp-toggle-menu__item {
  background-color: #fff;
  border-bottom: 1px solid #ed777a;
  position: relative;
}

.sp-toggle-menu__item-link {
  color: #ed777a;
  display: block;
  padding: 18px;
  padding-left: 40px;
}

.sp-toggle-menu__item::before {
  border-right: 4px solid #ed777a;
  border-top: 4px solid #ed777a;
  content: "";
  height: 15px;
  position: absolute;
  right: 15px;
  top: 35%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 15px;
}

.sp-menu-list__button {
  padding: 10px 12px;
}

.navigation {
  -webkit-align-items: center;
  align-items: center;
  background-color: #fff;
  border-bottom: 3px solid #ed777a;
  display: -webkit-flex;
  display: flex;
  -webkit-flex: 1 1 60px;
  flex: 1 1 60px;
  height: auto;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .navigation {
    display: none;
  }
}

.navigation__list {
  display: -webkit-flex;
  display: flex;
  font-size: 1.4rem;
  height: 100%;
  -webkit-justify-content: space-around;
  justify-content: space-around;
  list-style: none;
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  min-height: 32px;
  position: relative;
  text-align: center;
  width: 100%;
}

.navigation__list-link {
  color: #3c3c3c;
  display: flex;
  display: -webkit-flex;
  font-weight: bold;
  text-align: center;
  width: 100%;
}

.navigation__list-item {
  display: flex;
  display: -webkit-flex;
  padding-bottom: 15px;
  padding-top: 15px;
}

.navigation__list-item--border {
  -webkit-align-items: center;
  align-items: center;
  border-left: 1px solid #d8d8d8;
  display: flex;
  display: -webkit-flex;
  height: 100%;
  -webkit-justify-content: center;
  justify-content: center;
  padding-left: 18px;
  padding-right: 18px;
  width: 100%;
}

.navigation__current-background {
  border-radius: 3px;
  padding: 4px 10px;
}

.navigation__current-background.is-current,.navigation__current-background.is-hover,.navigation__list-link:hover .navigation__current-background {
  background-color: #ed777a;
  color: #fff;
  position: relative;
}

.navigation__list-item.is-open .navigation__current-background {
  background-color: #ed777a;
  color: #fff;
  position: relative;
}

.navigation__list-item.is-open .navigation__list-link {
  color: #000;
}

.navigation__list-item--right-border {
  border-right: 1px solid #d8d8d8;
  display: inline-flex;
  display: -webkit-inline-flex;
}

.navigation__list-item--arrow {
  padding-right: 18px;
  position: relative;
}

.navigation__list-item.is-close .navigation__list-item--arrow::after {
  border-bottom: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #3c3c3c;
  content: "";
  position: absolute;
  right: 3px;
  top: 38%;
}

.navigation__list-item.is-close .navigation__list-item--arrow.is-current::after {
  border-bottom: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #fff;
  content: "";
  position: absolute;
  right: 3px;
  top: 38%;
}

.navigation__list-item.is-open .navigation__list-item--arrow::after,.navigation__list-item.is-open .navigation__list-item--arrow.is-current::after,.navigation__list-link:hover .navigation__list-item--arrow::after {
  border-bottom: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #fff;
  content: "";
  position: absolute;
  right: 3px;
  top: 38%;
}

.navigation-sub {
  border-top: 3px solid #ed777a;
  display: none;
  left: 0;
  list-style: none;
  position: absolute;
  top: 100%;
  width: 100%;
  z-index: 50;
}

.navigation-sub-wrapper {
  background-color: #fff;
  border: 3px solid #ed777a;
  border-top: none;
  margin-left: auto;
  margin-right: auto;
  padding: 18px;
  width: 980px;
}

.navigation-sub__headline {
  border-bottom: 1px solid #ed777a;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: left;
}

.navigation-sub__list {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  list-style: none;
  margin-left: auto;
  margin-right: auto;
  padding-top: 25px;
  width: 100%;
}

.navigation-sub__list-item {
  font-size: 1.4rem;
  margin-bottom: 15px;
  text-align: left;
  width: 25%;
}

.navigation-sub__list-item-link {
  color: #000;
  padding-left: 15px;
  position: relative;
}

.navigation-sub__list-item-link:hover {
  text-decoration: underline;
}

.navigation-sub__list-item-link::before {
  border-bottom: 3px solid transparent;
  border-left: 3px solid transparent;
  border-right: 3px solid #000;
  border-top: 3px solid #000;
  content: "";
  height: 12px;
  left: -2px;
  position: absolute;
  top: 4px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.navigation-sub__close-button {
  font-size: 1.4rem;
  font-weight: normal;
  position: absolute;
  right: 20px;
  top: 18px;
}

.navigation-sub__close-button::before {
  border-bottom: 2px solid transparent;
  border-left: 3px solid #3c3c3c;
  border-right: 2px solid transparent;
  border-top: 3px solid #3c3c3c;
  content: "";
  height: 12px;
  left: -1em;
  position: absolute;
  top: 3px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

@media screen and (max-width: 780px) {
  .header__pc_link_butons {
    display: none;
  }
}

/* Layout */
#contents {
  display: flex;
  display: -webkit-flex;
  font-size: 1.6rem;
  height: 100%;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
  width: 980px;
}

@media screen and (max-width: 780px) {
  #contents {
    display: block;
    margin-top: 0 !important;
    min-width: 320px;
    width: 100%;
  }
}

.mainArea {
  padding-bottom: 50px;
  padding-top: 40px;
}

@media screen and (max-width: 780px) {
  .mainArea {
    padding-bottom: 15px;
    padding-top: 10px;
  }
}

.frame_LM {
  display: none;
}

.frame_MB {
  color: #000;
  width: 980px;
}

@media screen and (max-width: 780px) {
  .frame_MB {
    padding-left: 12px;
    padding-right: 12px;
    width: 100%;
  }
}

.section {
  margin-bottom: 55px;
}

@media screen and (max-width: 780px) {
  .section {
    margin-bottom: 50px;
  }
}

/************************* modal *************************/
.modal-window {
  -webkit-align-items: center;
  align-items: center;
  display: none;
  -webkit-flex-direction: column;
  flex-direction: column;
  height: 100%;
  -webkit-justify-content: center;
  justify-content: center;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 200;
}

.modal-window__overlay {
  background-color: rgba(0, 0, 0, 0.75);
  height: 120%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 200;
}

.hidden-modal-contents {
  display: none;
}

.modal-window__wrapper {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  height: auto;
  max-height: calc(100% - 1px);
  position: relative;
  z-index: 300;
}

@media screen and (max-width: 780px) {
  .modal-window__wrapper {
    max-height: calc(100% - 20px);
    min-width: 296px;
    width: 90%;
  }
}

.modal-window__base {
  background-color: #fff;
  border-radius: 5px;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  -webkit-flex-direction: column;
  flex-direction: column;
  height: inherit;
  margin: 20px 0;
  min-height: 1%;
  padding: 20px 15px;
  position: relative;
}

@supports (-ms-ime-align: auto) {
  .modal-window__base {
    -webkit-flex: 1 1 100%;
    flex: 1 1 100%;
    height: 1px;
  }
}

.slider-modal-window__base {
  background-color: #fff;
  border-radius: 5px;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  -webkit-flex-direction: column;
  flex-direction: column;
  height: inherit;
  margin: 20px 0;
  min-height: 1%;
  padding: 20px 15px;
  position: relative;
}

@supports (-ms-ime-align: auto) {
  .slider-modal-window__base {
    -webkit-flex: 1 1 100%;
    flex: 1 1 100%;
    height: 1px;
  }
}

.modal-close {
  height: 38px;
  position: absolute;
  right: -18px;
  top: -20px;
  width: 38px;
}

.modal-close-image {
  width: 100%;
}

@media screen and (max-width: 780px) {
  .modal-close {
    position: absolute;
    right: -10px;
  }
}

.modal-lock {
  overflow: hidden;
}

.modal-window__contents-wrapper {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  max-width: 700px;
  overflow-x: hidden;
  overflow-y: auto;
}

.modal-select-week__wrapper {
  max-height: 100%;
  min-width: 700px;
}

@media screen and (max-width: 780px) {
  .modal-select-week__wrapper {
    min-width: 0;
    width: 100%;
  }
}

.modal-window__headline {
  /*
  margin-left: -15px;
  margin-right: -15px;
*/
  padding-left: 40px;
}

.modal-window__headline:before {
  left: 15px;
}

.modal-text {
  margin-bottom: 20px;
}

.modal-select-week__item {
  padding: 12px 10px;
}

.modal-select-week__headline {
  font-size: 1.6rem;
  font-weight: bold;
}

.modal-select-week__headline {
  border-bottom: 1px solid #dbd1d2;
  margin-bottom: 10px;
  margin-left: -10px;
  margin-right: -10px;
  padding-bottom: 10px;
  padding-left: 15px;
}

.modal-select-week__headline input[type="radio"] {
  margin-right: 8px;
}

.modal-select-week__item {
  background-color: #ffeced;
}

.modal-select-week__date {
  line-height: 1.6;
  width: 100%;
}

.modal-select-week__date--mb {
  margin-bottom: 10px;
}

.modal-select-week__date-head {
  width: 25%;
}

.modal-select-week__date-contents {
  width: 75%;
}

.modal-select-week__cart-button {
  padding: 5px;
  width: 100%;
}

.modal-cart-text__icon {
  display: block;
  height: 36px;
  margin-left: 5px;
  margin-right: 10px;
  margin-top: 4px;
  width: 36px;
}

.modal-cart-text__price {
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
}

.modal-cart-text__number {
  border-bottom: 1px solid #fff;
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 6px;
}

.modal-cart-text__info {
  background-color: #fff;
  border-radius: 3px;
  display: block;
  font-size: 1.5rem;
  font-weight: bold;
  padding: 14px 3px;
  padding-top: 17px;
  position: relative;
}

.modal-window__button {
  background-color: #fbe2e5;
  border-radius: 80px;
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  margin-left: auto;
  margin-right: auto;
  min-width: 125px;
  padding-bottom: 15px;
  padding-top: 15px;
}

.modal-window__submit-button {
  background-color: #b4181c;
  color: #fff;
}

/************************* footer *************************/
.footer {
  position: relative;
}

.footer__pc-page-top-button {
  bottom: -30px;
  position: absolute;
  right: 50px;
  z-index: 140;
}

.footer__pc-page-top-button img {
  vertical-align: top;
}

.footer__pc-page-top-button.is-fixed {
  bottom: 20px;
  position: fixed;
  right: 50px;
}

.is-tablet .footer__pc-page-top-button {
  bottom: -30px;
  position: absolute;
  right: 15px;
  z-index: 150;
}

@media screen and (max-width: 780px) {
  .footer__pc-page-top-button {
    display: none;
  }
}

.sp-page-top-button {
  color: #ed777a;
  display: none;
  font-size: 1.2rem;
  font-weight: bold;
  height: 0;
  line-height: 3.5;
  text-align: center;
}

@media screen and (max-width: 780px) {
  .sp-page-top-button {
    display: inline-block;
    height: auto;
    position: absolute;
    right: 10px;
    top: -30px;
  }
}

.pc-pagetop-wrapper {
  position: relative;
}

.page-top-image {
  height: 60px;
  width: 60px;
}

.footer__menu-wrapper {
  background-color: #fbe2e5;
  padding-bottom: 35px;
  padding-top: 35px;
}

@media screen and (max-width: 780px) {
  .footer__menu-wrapper {
    padding-bottom: 25px;
    padding-left: 15px;
    padding-top: 50px;
  }
}

.pc-footer__menu {
  display: flex;
  display: -webkit-flex;
  font-size: 1.4rem;
  margin-left: auto;
  margin-right: auto;
  width: 980px;
}

@media screen and (max-width: 780px) {
  .pc-footer__menu {
    display: none;
  }
}

.sp-footer__menu {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-footer__menu {
    display: flex;
    display: -webkit-flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    text-align: left;
  }
}

.footer__menu-block {
  width: 25%;
}

.footer__menu-headline {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 5px;
}

.footer__menu-item {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  margin-bottom: 6px;
}

.footer__menu-block {
  text-align: left;
}

.footer__menu-list--margin-bottom {
  margin-bottom: 25px;
}

.footer__menu-item-link-blunk {
  margin-left: 2px;
}

.footer__menu-single-link {
  margin-bottom: 10px;
}

@media screen and (max-width: 780px) {
  .footer__menu-headline-link {
    display: inline-block;
    font-size: 1.4rem;
    line-height: 1.3;
    padding-right: 10px;
  }
  .footer__menu-single-link {
    margin-bottom: 5px;
    width: 50%;
  }
}

.footer__menu-headline-link,.footer__menu-item-link {
  color: #3c3c3c;
}

.footer__menu-headline-link:hover,.footer__menu-item-link:hover {
  text-decoration: underline;
}

.footer__after-menu-wrapper {
  background-color: #fff;
  border-bottom: 3px solid #ed777a;
  padding-bottom: 15px;
  padding-left: 5px;
  padding-right: 5px;
  padding-top: 15px;
}

@media screen and (max-width: 780px) {
  .footer__after-menu-wrapper {
    padding-bottom: 5px;
  }
}

.footer__after-menu {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 1.4rem;
  -webkit-justify-content: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  width: 100%;
}

.footer__after-menu-item {
  margin-left: 8px;
  margin-right: 8px;
  text-align: left;
}

@media screen and (max-width: 780px) {
  .footer__after-menu-item {
    font-size: 1.5rem;
    margin-bottom: 10px;
    margin-left: 0;
    margin-right: 0;
    padding-left: 10px;
    padding-right: 10px;
    width: 50%;
  }
}

.footer__after-menu-link {
  display: inline-block;
  padding-left: 3px;
}

.footer__after-menu-link:hover {
  text-decoration: underline;
}

.footer__copyright {
  text-align: center;
}

.footer__copyright-image {
  padding-bottom: 30px;
  padding-top: 42px;
}

.footer__copyright-image-logo {
  height: auto;
  width: 183px;
}

@media screen and (max-width: 780px) {
  .footer__copyright-image {
    padding-bottom: 24px;
    padding-top: 24px;
  }
}

.footer__copyright-text {
  display: block;
  font-size: 1.2rem;
  padding-bottom: 30px;
}

@media screen and (max-width: 780px) {
  .footer__copyright-text {
    padding-bottom: 25px;
  }
}

/* ==========================================================================
Object
========================================================================== */
/* Component
----------------------------------------------------------------- */
/************************* general-conponent *************************/
/*リーダー系全般*/
.c-reader {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/*ヘッダーの最初のメインコンテンツへ行くリンクだけ、下記クラス*/
.c-skip-link:not(:focus) {
  border: 0;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  white-space: nowrap;
  width: 1px;
}

.c-skip-link {
  background-color: #d8d8d8;
  display: block;
  font-size: 1.2rem;
  height: auto;
  padding-bottom: 5px;
  padding-top: 5px;
  text-align: center;
}

.c-ignore {
  display: none;
}

.contents__primary-headline {
  border-bottom: 3px solid #8e816f;
  font-size: 2.4rem;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
  position: relative;
}

@media screen and (max-width: 780px) {
  .contents__primary-headline {
    padding-bottom: 8px;
  }
}

.contents__secondary-headline {
  border-bottom: 1px solid #8e816f;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
}

@media screen and (max-width: 780px) {
  .contents__secondary-headline {
    padding-bottom: 8px;
  }
}

.contents__sub-headline {
  border-bottom: 1px solid #8e816f;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 8px;
  position: relative;
}

.contents__primary-headline-h1 {
  border-bottom: 3px solid #ed777a;
  font-size: 2.4rem;
  margin-bottom: 20px;
  padding-bottom: 10px;
  padding-left: 3px;
  position: relative;
}

@media screen and (max-width: 780px) {
  .contents__primary-headline-h1 {
    padding-bottom: 5px;
  }
}

.contents__primary-arrow {
  display: inline-block;
  line-height: 1.2;
  padding-left: 17px;
  position: relative;
}

.contents__primary-arrow::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 3px solid #ed777a;
  border-top: 3px solid #ed777a;
  content: "";
  height: 12px;
  left: -2px;
  margin-top: -5px;
  position: absolute;
  top: 0.43em;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.c-link--blank {
  padding-left: 15px;
  position: relative;
}

.c-link--blank::before {
  background: url("/excludes/tokyo/img/blunk-link-icon.png") no-repeat center center;
  background-size: contain;
  content: "";
  height: 10px;
  left: 0;
  margin-top: -4px;
  position: absolute;
  top: 0.5em;
  width: 10px;
}

.c-submit-button {
  background-color: #ed777a;
  border-radius: 5px;
  box-sizing: border-box;
  color: #fff;
  display: block;
  font-size: 1.5rem;
  font-weight: bold;
  margin-left: auto;
  margin-right: auto;
  max-width: 350px;
  padding-bottom: 12px;
  padding-left: 35px;
  padding-right: 35px;
  padding-top: 14px;
  text-align: center;
  width: 100%;
}

.c-submit-button .contents__primary-arrow-b-sml::before {
  border-right-color: #fff;
  border-top-color: #fff;
  top: 3px;
}

.c-link-button {
  background-color: #fdf6f6;
  border: 2px solid #f5b6ba;
  border-radius: 5px;
  box-sizing: border-box;
  color: #000;
  display: block;
  font-size: 1.5rem;
  font-weight: bold;
  margin-left: auto;
  margin-right: auto;
  max-width: 350px;
  padding-bottom: 12px;
  padding-left: 35px;
  padding-right: 35px;
  padding-top: 14px;
  text-align: center;
  width: 100%;
}

.c-link-button span {
  margin-left: 10px;
  position: relative;
}

.c-link-button span::before {
  border-bottom: 5px solid transparent;
  border-left: 5px solid #231815;
  border-top: 5px solid transparent;
  content: "";
  left: -8%;
  margin-top: -1px;
  position: absolute;
  top: 0.43em;
}

.c-link-button--is-more span::before {
  border: none;
  border-bottom: 3px solid #000;
  border-right: 3px solid #000;
  height: 12px;
  left: -17px;
  margin-top: -10px;
  top: 50%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

@media screen and (max-width: 780px) {
  .c-link-button--sp-negative-color {
    background-color: #fff;
  }
}

/* *** arrow icon */
.contents__primary-arrow--black::before {
  border-right-color: #000;
  border-top-color: #000;
}

.contents__primary-arrow--gray::before {
  border-right-color: #747474;
  border-top-color: #747474;
}

.contents__primary-arrow-b {
  line-height: 1.2;
  margin-left: 0.8em;
  position: relative;
}

.contents__primary-arrow-b::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 3px solid #3c3c3c;
  border-top: 3px solid #3c3c3c;
  content: "";
  height: 12px;
  left: -1em;
  position: absolute;
  top: 5px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.contents__primary-arrow-b-sml {
  margin-left: 0.8em;
  position: relative;
}

.contents__primary-arrow-b-sml::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 2px solid #3c3c3c;
  border-top: 2px solid #3c3c3c;
  content: "";
  height: 10px;
  left: -1em;
  position: absolute;
  top: 6px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 10px;
}

.c-link-button .contents__primary-arrow-tri-r::before {
  border-left-color: #837e72;
}

.contents__primary-arrow-d {
  margin-left: 1em;
  position: relative;
}

.contents__primary-arrow-d::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 3px solid #ed777a;
  border-top: 3px solid #ed777a;
  content: "";
  height: 12px;
  left: -1em;
  position: absolute;
  top: 0.2em;
  -webkit-transform: rotate(135deg) scale(0.7);
  transform: rotate(135deg) scale(0.7);
  width: 12px;
}

.contents__primary-arrow-d--gray::before {
  border-right-color: #747474;
  border-top-color: #747474;
}

.contents__primary-arrow-tri-r {
  line-height: 1.2;
  margin-left: 1em;
  position: relative;
}

.contents__primary-arrow-tri-r::before {
  border-bottom: 5px solid transparent;
  border-left: 5px solid #ed777a;
  border-top: 5px solid transparent;
  content: "";
  left: -1.2em;
  position: absolute;
  top: 0.3em;
}

.contents__primary-arrow-tri-d {
  margin-left: 1em;
  position: relative;
}

.contents__primary-arrow-tri-d::before {
  border-bottom: 5px solid transparent;
  border-left: 5px solid #ed777a;
  border-top: 5px solid transparent;
  content: "";
  left: -0.8em;
  position: absolute;
  top: 0.4em;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.c-icon-blank--half-scale {
  vertical-align: middle;
  width: 9px;
}

/* *** decoration line */
.c-deco-diagonal-line {
  display: inline-block;
  position: relative;
}

.c-deco-diagonal-line::before {
  border-right: 1px solid #f6000b;
  content: "";
  height: 1.2em;
  left: -1.75em;
  position: absolute;
  top: 0.5em;
  -webkit-transform: rotateZ(-45deg);
  transform: rotateZ(-45deg);
  width: 1.2em;
}

.c-deco-diagonal-line::after {
  border-left: 1px solid #f6000b;
  content: "";
  height: 1.2em;
  position: absolute;
  right: -1.75em;
  top: 0.5em;
  -webkit-transform: rotateZ(45deg);
  transform: rotateZ(45deg);
  width: 1.2em;
}

@media screen and (max-width: 780px) {
  .c-deco-diagonal-line::before {
    height: 2.4em;
    left: -3.5em;
    top: 1em;
    width: 2.4em;
  }
  .c-deco-diagonal-line::after {
    height: 2.4em;
    right: -3.5em;
    top: 1em;
    width: 2.4em;
  }
}

.c-deco-dot-line-colorful {
  background-image: url(/excludes/tokyo/img/dot-line-colorful.png);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 75px 11px;
  margin-bottom: 10px;
  padding-bottom: 15px;
}

/* *** column-2 gutter-20px */
.two-column-block-list {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  list-style: none;
  margin-top: -20px;
}

.two-column-block-list--vmargin-lrg {
  margin-top: -40px;
}

@media screen and (max-width: 780px) {
  .two-column-block-list {
    margin-top: -15px;
  }
  .two-column-block-list--vmargin-lrg {
    margin-top: -30px;
  }
}

.two-column-block-list__item {
  margin-top: 20px;
  width: calc(50% - 10px);
}

.two-column-block-list--vmargin-lrg > .two-column-block-list__item {
  margin-top: 40px;
}

@media screen and (max-width: 780px) {
  .two-column-block-list__item {
    margin-top: 15px;
    width: 100%;
  }
  .two-column-block-list--vmargin-lrg > .two-column-block-list__item {
    margin-top: 30px;
    width: 100%;
  }
}

/* *** request block */
.request-block {
  background-color: #fff;
  border: 2px solid #eb4f64;
  border-radius: 5px;
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  overflow: hidden;
}

.frame_FT .request-block {
  margin-left: auto;
  margin-right: auto;
  width: 980px;
}

@media screen and (max-width: 780px) {
  .request-block {
    display: block;
  }
  .frame_FT .request-block {
    width: auto;
  }
}

.request-block__text-block {
  padding-bottom: 30px;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 30px;
  position: relative;
  text-align: center;
  width: calc(12 / 25 * 100%);
}

.request-block__text-block::before {
  border-bottom: 12px solid transparent;
  border-left: 12px solid #fff;
  border-top: 12px solid transparent;
  content: "";
  position: absolute;
  right: -12px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

@media screen and (max-width: 780px) {
  .request-block__text-block {
    padding-bottom: 20px;
    padding-top: 20px;
    width: 100%;
  }
  .request-block__text-block::before {
    bottom: -18px;
    right: 50%;
    top: auto;
    -webkit-transform: translateY(0) translateX(50%) rotateZ(90deg);
    transform: translateY(0) translateX(50%) rotateZ(90deg);
  }
}

.request-block__link-block {
  background-color: #fbe2e5;
  padding-bottom: 10px;
  padding-left: 30px;
  padding-right: 20px;
  padding-top: 20px;
  text-align: center;
  width: calc(13 / 25 * 100%);
}

@media screen and (max-width: 780px) {
  .request-block__link-block {
    padding-left: 10px;
    padding-right: 10px;
    width: 100%;
  }
}

.request-block__headline {
  color: #f6000b;
  font-size: 2.5rem;
  font-weight: bold;
}

@media screen and (max-width: 780px) {
  .request-block__headline {
    font-size: 1.8rem;
  }
}

.about-block__outer {
  border: solid 1px #b4b4b4;
}

.about-block {
  display: flex;
  display: -webkit-flex;
  padding: 20px;
}

@media screen and (max-width: 780px) {
  .about-block {
    -webkit-flex-direction: column;
    flex-direction: column;
  }
}

.about-block__text-block {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

.about-block__image-block {
  -webkit-flex: 0 0 120px;
  flex: 0 0 120px;
  margin-left: 20px;
}

@media screen and (max-width: 780px) {
  .about-block__image-block {
    -webkit-flex: 1 1 auto;
    flex: 1 1 auto;
    margin-left: 0;
    margin-top: 20px;
  }
  .about-block__image-block img {
    width: 100%;
  }
}

@media screen and (max-width: 780px) {
  .about-block__image-block--hide {
    display: none;
  }
}

/* *** accordion-box */
.c-accordion-box {
  border: 1px solid #ed777a;
  margin-bottom: 1px;
  overflow: hidden;
}

.c-accordion-box.first-child {
  border-radius: 5px 5px 0 0;
}

.c-accordion-box.last-child {
  border-radius: 0 0 5px 5px;
}

.c-accordion-box__headline {
  background-color: #ed777a;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  padding-bottom: 15px;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 15px;
  position: relative;
  text-align: left;
  width: 100%;
}

.c-accordion-box__headline:hover {
  opacity: 0.7;
}

.c-accordion-box__headline.is-open::before {
  border-left: 4px solid #fff;
  border-top: 4px solid #fff;
  content: "";
  height: 20px;
  position: absolute;
  right: 15px;
  top: 36%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 20px;
}

.c-accordion-box__headline.is-close::before {
  border-bottom: 4px solid #fff;
  border-right: 4px solid #fff;
  content: "";
  height: 20px;
  position: absolute;
  right: 15px;
  top: 26%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 20px;
}

/* *** image-link accordion内リスト */
.image-link-list {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: -1px;
}

@media screen and (max-width: 780px) {
  .image-link-list {
    display: block;
  }
}

.image-link-list__item {
  border-bottom: 1px solid #ed777a;
  width: 50%;
}

.image-link-list__item:nth-child(odd) {
  border-right: 1px solid #ed777a;
}

@media screen and (max-width: 780px) {
  .image-link-list__item {
    width: 100%;
  }
  .image-link-list__item:nth-child(odd) {
    border-right: none;
  }
}

.image-link-list__item-inner {
  display: flex;
  display: -webkit-flex;
  padding-bottom: 20px;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 20px;
}

.image-link-list__text-block {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  -webkit-order: 2;
  order: 2;
}

.image-link-list__image-block {
  -webkit-flex: 0 0 120px;
  flex: 0 0 120px;
  margin-right: 10px;
  -webkit-order: 1;
  order: 1;
}

.carousel__navi_next {
  height: 36px;
  margin-top: -23.5px;
  position: absolute;
  right: 30px;
  top: 51%;
  width: 36px;
  z-index: 2;
}

.carousel__navi_prev {
  height: 36px;
  left: 30px;
  margin-top: -23.5px;
  position: absolute;
  top: 51%;
  width: 36px;
  z-index: 2;
}

@media screen and (max-width: 780px) {
  .carousel__navi_next {
    right: 12px;
    top: 53%;
  }
  .carousel__navi_prev {
    left: 12px;
    top: 53%;
  }
}

.carousel-navigation {
  text-align: center;
}

.carousel__navigation-button-link {
  background-image: url("/excludes/tokyo/img/main-slide__navigation-button.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  border: none;
  border-radius: 50%;
  display: inline-block;
  height: 20px;
  margin-left: 6px;
  margin-right: 6px;
  opacity: 0.5;
  padding: 0;
  text-decoration: none;
  vertical-align: middle;
  width: 20px;
}

.current .carousel__navigation-button-link {
  background-image: url("/excludes/tokyo/img/main-slide__navigation-button--current.png");
  opacity: 1;
}

@media screen and (max-width: 780px) {
  .carousel__navigation-button-link {
    height: 16px;
    width: 16px;
  }
  .current .carousel__navigation-button-link {
    opacity: 1;
  }
}

.carousel__navi-button {
  height: 42px;
  position: absolute;
  top: 35%;
  width: 42px;
}

.carousel__navi-button-prev {
  left: 12px;
}

.carousel__navi-button-next {
  right: 12px;
}

.carousel-navigation-button {
  margin-top: 20px;
}

.c-border-table {
  border-top: 1px solid #d8d8d8;
}

.c-border-table tr {
  border-bottom: 1px solid #d8d8d8;
}

.c-border-table th,.c-border-table td {
  padding-bottom: 1em;
  padding-top: 1em;
  text-align: left;
  vertical-align: top;
}

.c-border-table th {
  font-weight: bold;
  padding-left: 0;
  padding-right: 1em;
  width: 6em;
}

.c-border-table--one-column th {
  padding-left: 6.5em;
  width: 14em;
}

@media screen and (max-width: 780px) {
  .c-border-table--one-column th {
    padding-left: 0;
    padding-right: 1em;
    width: 6em;
  }
}

.google-map {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  padding-top: 30px;
  position: relative;
}

.google-map iframe,.google-map object,.google-map embed {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.page-headline {
  font-size: 2.4rem;
  margin-bottom: 20px;
}

.page-headline__wrapper {
  margin-bottom: 20px;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .page-headline__image-wrapper {
    margin-left: -12px;
    margin-right: -12px;
    width: calc(100% + 24px);
  }
}

.page-headline__image {
  width: 100%;
}

.bread-area {
  font-size: 1.2rem;
  line-height: 2;
  margin-bottom: -34px;
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  padding-bottom: 20px;
  padding-top: 10px;
  width: 100%;
}

.bread-area__symbol {
  margin-left: 5px;
  margin-right: 5px;
}

@media screen and (max-width: 780px) {
  .bread-area {
    margin-bottom: -10px;
    padding-bottom: 12px;
    padding-left: 12px;
    padding-right: 12px;
  }
}

.c-video-container {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}

.c-video-container iframe {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.c-text-icon {
  background-color: #747474;
  border-radius: 3px;
  color: #fff;
  display: inline-block;
  font-size: 1.1rem;
  line-height: 1;
  min-width: 60px;
  padding: 4px 3px;
  text-align: center;
}

.c-text-icon--is-ec {
  background-color: #ed777a;
}

.c-text-icon--is-ec-negative {
  background-color: #fff;
  color: #ed777a;
}

.c-text-icon--is-sheet {
  background-color: #5795ce;
}

.c-text-icon--is-reserve {
  background-color: #79b321;
}

.c-text-icon--is-yoyaku {
  background-color: #3ca21b;
}

.c-text-icon--mid {
  font-size: 1.3rem;
  min-width: 75px;
  padding: 4px 5px;
}

.c-text-icon--fat {
  border-radius: 5px;
  font-size: 1.7rem;
  min-width: 70px;
  padding: 6px 5px;
}

/************************* index-page *************************/
.caution__wrapper {
  background-color: #faf7f2;
  border: 3px solid #b4181c;
  margin-bottom: 40px;
  padding: 10px;
}

.caution__icon {
  height: 15px;
  margin-right: 5px;
  width: 17px;
}

@media screen and (max-width: 780px) {
  .caution__wrapper {
    margin-bottom: 25px;
  }
}

.caution__date {
  bottom: 1px;
  color: #b4181c;
  display: inline-block;
  font-size: 1.2rem;
  margin-bottom: 3px;
  margin-right: 5px;
  position: relative;
}

.caution__headline-area {
  -webkit-align-items: center;
  align-items: center;
  color: #b4181c;
  display: flex;
  display: -webkit-flex;
  margin-bottom: 10px;
}

.caution__text {
  padding-left: 5px;
  padding-right: 5px;
  word-wrap: break-word;
}

.main-banner__wrapper {
  width: 100%;
}

@media screen and (max-width: 780px) {
  .main-banner__wrapper {
    margin-bottom: 25px;
  }
}

.main-banner {
  display: block;
  width: 100%;
}

.pc-main-banner {
  display: block;
}

.sp-main-banner {
  display: none;
}

@media screen and (max-width: 780px) {
  .pc-main-banner {
    display: none;
  }
  .sp-main-banner {
    display: block;
  }
}

.sp-index-menu-list__button {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-index-menu-list__button {
    display: block;
    padding: 0;
  }
}

.two-column-block {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
}

@media screen and (max-width: 780px) {
  .two-column-block {
    display: block;
    margin-left: -10px;
    margin-right: -10px;
  }
}

.two-column-item {
  margin-left: 12px;
  margin-right: 12px;
  width: calc(50% - 24px);
}

@media screen and (max-width: 780px) {
  .two-column-item {
    margin-left: auto;
    margin-right: auto;
    padding-left: 12px;
    padding-right: 12px;
    width: 100%;
  }
}

.two-column-item-inline {
  box-sizing: border-box;
  display: inline-block;
  margin: 0 !important;
  padding: 0 4px 20px;
  vertical-align: top;
  width: 486px;
}

@media screen and (max-width: 780px) {
  .two-column-item-inline {
    display: block;
    width: auto;
  }
}

.four-column-block {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
}

.four-column-item {
  margin-bottom: 20px;
  margin-left: 12px;
  margin-right: 12px;
  width: calc(25% - 24px);
}

@media screen and (max-width: 780px) {
  .four-column-block {
    margin-left: -6px;
    margin-right: -6px;
  }
  .four-column-item {
    margin-left: 6px;
    margin-right: 6px;
    width: calc(50% - 12px);
  }
}

.column-item__image-wrapper {
  display: block;
  margin-bottom: 10px;
  width: 100%;
}

.column-item__image {
  height: auto;
  vertical-align: bottom;
  width: 100%;
}

.column-item__title,.column-item__text {
  -webkit-align-items: flex-start;
  align-items: flex-start;
  display: flex;
  display: -webkit-flex;
  font-size: 1.6rem;
  margin-bottom: 5px;
}

.column-item__title .header__blunk-icon {
  margin-top: 6px;
}

.column-item__title::before {
  top: 6px;
}

.column-item__title {
  font-weight: bold;
}

.three-column-block {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px;
}

.three-column-item {
  margin-bottom: 20px;
  margin-left: 12px;
  margin-right: 12px;
  width: calc(33.33% - 24px);
}

@media screen and (max-width: 780px) {
  .three-column-item {
    margin-bottom: 5px;
    margin-left: 0;
    margin-right: 0;
    padding-left: 12px;
    padding-right: 12px;
    width: 100%;
  }
}

/* ニュース */
.news__date-tag-area {
  display: flex;
  display: -webkit-flex;
  margin-bottom: 15px;
}

.news__item-wrapper {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  height: 100%;
}

.news__date {
  -webkit-flex: 0 0 120px;
  flex: 0 0 120px;
  font-size: 1.4rem;
  margin-right: 10px;
  padding-bottom: 2px;
  padding-top: 2px;
}

@media screen and (max-width: 780px) {
  .news__date {
    font-size: 1.4rem;
  }
}

.news__tags {
  font-size: 0;
  margin-left: -8px;
  margin-top: -8px;
}

.news__tags > .news__tag {
  margin-left: 8px;
  margin-top: 8px;
}

.news__tag {
  border: 2px solid #ed777a;
  border-radius: 3px;
  color: #ed777a;
  display: inline-block;
  font-size: 1.2rem;
  min-width: 5em;
  padding-bottom: 0.2em;
  padding-left: 0.5em;
  padding-right: 0.5em;
  padding-top: 0.2em;
  text-align: center;
}

.news__tag:hover {
  opacity: 0.7;
}

.news__item {
  border-bottom: 1px solid #b4b4b4;
  display: flex;
  display: -webkit-flex;
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  margin-bottom: 18px;
  padding-bottom: 18px;
}

@media screen and (max-width: 780px) {
  .news__item {
    -webkit-align-items: flex-start;
    align-items: flex-start;
  }
}

.news__contents-image {
  display: block;
  height: 100px;
  width: 100px;
}

.news__contents-text {
  display: block;
  -webkit-flex: 1 1 78%;
  flex: 1 1 78%;
  overflow: hidden;
  width: 78%;
}

.news__text {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  padding-right: 20px;
  width: 100%;
  word-wrap: break-word;
}

.news__detail-text {
  display: block;
  font-size: 1.6rem;
  margin-top: 10px;
  padding-right: 20px;
  width: 100%;
  word-wrap: break-word;
}

@media screen and (max-width: 780px) {
  .event-block {
    margin-bottom: 50px;
  }
}

/* マップ */
.map__image-wrapper {
  text-align: center;
}

.block__text {
  font-size: 1.6rem;
  margin-bottom: 65px;
}

@media screen and (max-width: 780px) {
  .block__text {
    margin-bottom: 25px;
  }
}

.map__image-wrapper {
  position: relative;
}

.map__area {
  background-color: #fff;
  border: 1px solid #e5e5e5;
  padding: 10px;
  position: absolute;
  width: 330px;
}

.map__area::before {
  border-bottom: 30px solid #e5e5e5;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  bottom: calc(100% + 1px);
  content: "";
  left: 0;
  position: absolute;
}

.map__area::after {
  border-bottom: 30px solid #fff;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  bottom: 100%;
  content: "";
  left: 0;
  position: absolute;
}

.map__area-ichihara {
  bottom: -10px;
  left: 120px;
}

.map__area-ichihara::before,.map__area-ichihara::after {
  left: 36px;
}

.map__area-chiba {
  bottom: 180px;
  left: 80px;
}

.map__area-chiba::before,.map__area-chiba::after {
  left: 100px;
}

.map__area-sakura {
  bottom: 180px;
  left: 150px;
}

.map__area-sakura::before,.map__area-sakura::after {
  left: 100px;
}

.map__area-kashiwa {
  bottom: 280px;
  left: 90px;
}

.map__area-kashiwa::before,.map__area-kashiwa::after {
  left: 30px;
}

.map__area-bay {
  bottom: 200px;
  left: 65px;
}

.map__area-bay::before,.map__area-bay::after {
  left: 30px;
}

.map__area-matsudo {
  bottom: 250px;
  left: 80px;
}

.map__area-matsudo::before,.map__area-matsudo::after {
  left: 30px;
}

.sp-map-block {
  display: none;
}

@media screen and (max-width: 780px) {
  .sp-map-block {
    display: block;
  }
  .map-block {
    display: none;
  }
}

/* イベント */
@media screen and (max-width: 780px) {
  .event__link-button {
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 780px) {
  .calendar-block {
    margin-bottom: 50px;
  }
}

.calendar__wrapper {
  border: 1px solid #e0e0e0;
  padding: 15px;
  padding-top: 24px;
  speak: none;
}

.calendar__wrapper:focus {
  outline: 1px dotted #ddd;
}

.calendar__wrapper .ui-datepicker {
  padding: 0;
  width: 100%;
}

.calendar__control,.ui-datepicker .ui-datepicker-header {
  -webkit-align-items: center;
  align-items: center;
  border-bottom: 1px dotted #b4b4b4;
  display: flex;
  display: -webkit-flex;
  padding-bottom: 25px;
  padding-left: 10px;
  padding-right: 10px;
  padding-top: 0;
  width: 100%;
}

.calendar__control-date,.ui-datepicker-title {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}

.calendar__button,.ui-datepicker .ui-datepicker-prev,.ui-datepicker .ui-datepicker-next {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  cursor: pointer;
  height: 36px;
  position: relative;
  top: 0;
  width: 36px;
}

.ui-datepicker .ui-datepicker-prev {
  left: 0;
}

.ui-datepicker .ui-datepicker-next {
  right: 0;
}

.ui-datepicker .ui-datepicker-prev-hover,.ui-datepicker .ui-datepicker-next-hover {
  top: 0;
}

.ui-datepicker-next {
  -webkit-order: 3;
  order: 3;
}

.ui-datepicker-prev .ui-icon,.ui-datepicker-next .ui-icon {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.calendar__button:hover,.ui-datepicker-prev:hover,.ui-datepicker-next:hover {
  opacity: 0.7;
}

.calendar__button.is-disabled:hover {
  cursor: default;
  opacity: 1;
}

.calendar__prev-button,.ui-datepicker-prev {
  background-image: url("/excludes/tokyo/img/index/calendar__prev.png");
}

.calendar__next-button,.ui-datepicker-next {
  background-image: url("/excludes/tokyo/img/index/calendar__next.png");
}

.calendar__prev-button.is-disabled,.ui-datepicker-prev.is-disabled {
  background-image: url("/excludes/tokyo/img/index/calendar__prev-disabled.png");
}

.calendar__next-button.is-disabled,.ui-datepicker-next.is-disabled {
  background-image: url("/excludes/tokyo/img/index/calendar__next-disabled.png");
}

.calendar,.ui-datepicker-calendar {
  padding: 18px;
  width: 100%;
}

.ui-datepicker table {
  font-size: inherit;
  margin: 0;
}

.calendar th,.ui-datepicker-calendar th,.calendar td,.ui-datepicker-calendar td {
  font-size: 1.6rem;
  font-weight: bold;
  height: 64px;
  text-align: center;
  vertical-align: middle;
  width: 64px;
}

.ui-datepicker th {
  padding: 0;
}

.ui-datepicker td {
  padding: 0;
}

@media screen and (max-width: 780px) {
  .calendar th,.ui-datepicker-calendar th,.calendar td,.ui-datepicker-calendar td {
    height: 43px;
    width: calc(100% / 7);
  }
}

.calendar td,.ui-datepicker-calendar td {
  border: 1px solid #e0e0e0;
}

.calendar__sunday,.ui-datepicker-calendar th:first-child,.ui-datepicker-calendar td:first-child,.calendar__sunday .calendar__link,.ui-datepicker-calendar th:first-child a,.ui-datepicker-calendar td:first-child a {
  color: #c66;
}

.calendar__saturday,.ui-datepicker-calendar th:last-child,.ui-datepicker-calendar td:last-child,.calendar__saturday .calendar__link,.ui-datepicker-calendar th:last-child a,.ui-datepicker-calendar td:last-child a {
  color: #36c;
}

.ui-datepicker td span,.ui-datepicker td a {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 0;
  text-align: center;
}

a.calendar__link,.ui-datepicker td a {
  -webkit-align-items: center;
  align-items: center;
  background-color: #fbe2e5;
  display: flex;
  display: -webkit-flex;
  height: 100%;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 0.0;
  width: 100%;
}

a.calendar__link:hover,.calendar__link a:hover {
  opacity: 0.7;
}

/* 活動・とりくみ */
.sp-action-block {
  display: none;
}

@media screen and (max-width: 780px) {
  .pc-action-block {
    display: none;
  }
  .sp-action-block {
    display: block;
    margin-bottom: 20px;
  }
}

/* 消費材 */
.sp-products-group {
  display: none;
}

@media screen and (max-width: 780px) {
  .products-group {
    display: none;
  }
  .sp-products-group {
    display: flex;
    display: -webkit-flex;
    margin-bottom: 20px;
  }
}

.eclub-products {
  margin-bottom: 20px;
}

.products-group__item {
  -webkit-align-items: center;
  align-items: center;
  background-color: #fbe2e5;
  display: flex;
  display: -webkit-flex;
  min-height: 58px;
  padding: 5px;
  padding-right: 10px;
}

.products-group__item::before {
  left: 58px;
  top: calc(50% - 7px);
}

@media screen and (max-width: 780px) {
  .products-group__item::before {
    left: 36px;
  }
}

.products-group__icon {
  border-radius: 100px;
  display: block;
  height: 47px;
  overflow: hidden;
  width: 47px;
}

@media screen and (max-width: 780px) {
  .products-group__icon {
    border-radius: 100px;
    display: block;
    height: 28px;
    overflow: hidden;
    width: 28px;
  }
}

.products-group__name {
  -webkit-flex: 1;
  flex: 1;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.2;
  padding-left: 15px;
}

.products__more {
  display: flex;
  display: -webkit-flex;
  margin-left: 0;
  margin-right: 0;
}

.products__more-button {
  border: 1px solid #e0e0e0;
  margin-bottom: 25px;
  margin-left: 12px;
  margin-right: 12px;
  padding-bottom: 25px;
  padding-top: 10px;
  position: relative;
  text-align: center;
  width: 100%;
}

.products__more-button.is-close::after {
  border-bottom: 3px solid #3c3c3c;
  border-left: 3px solid transparent;
  border-right: 3px solid #3c3c3c;
  border-top: 3px solid transparent;
  bottom: 12px;
  content: "";
  height: 12px;
  left: 48%;
  position: absolute;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.products__more-button.is-open::after {
  border-bottom: 3px solid transparent;
  border-left: 3px solid #3c3c3c;
  border-right: 3px solid transparent;
  border-top: 3px solid #3c3c3c;
  bottom: 6px;
  content: "";
  height: 12px;
  left: 48%;
  position: absolute;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

/* キャンペーン */
.sp-campaign-block {
  display: none;
}

@media screen and (max-width: 780px) {
  .pc-campaign-block {
    display: none;
  }
  .sp-campaign-block {
    display: block;
  }
}

.sp-campaign-block .carousel-navigation-button {
  margin-bottom: 20px;
  margin-top: 0;
}

.sp-campaign-block .carousel__navi-button {
  top: 22%;
}

/* について */
.index-about-block {
  margin-bottom: 30px;
}

.index-banner-block__headline {
  border-top: 1px solid #8e816f;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .index-banner-block__headline {
    border-top: none;
  }
}

.index-banner-block {
  padding-top: 25px;
}

.index-banner-block .three-column-item {
  margin-bottom: 0;
}

@media screen and (max-width: 780px) {
  .index-about-item {
    margin-bottom: 20px;
    padding-left: 20px;
    padding-right: 20px;
  }
  .index-banner-item {
    padding-left: 30px;
    padding-right: 30px;
  }
  .index-banner-block .three-column-item {
    margin-bottom: 8px;
  }
}

/* SNSエリア */
.sns-block {
  -webkit-align-items: center;
  align-items: center;
  border: 3px solid #e0e0e0;
  display: flex;
  display: -webkit-flex;
  font-size: 1.6rem;
  height: 80px;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding-left: 15px;
  padding-right: 15px;
}

.frame_FT .sns-block {
  margin-left: auto;
  margin-right: auto;
  width: 980px;
}

@media screen and (max-width: 780px) {
  .sns-block {
    display: block;
    height: auto;
    padding-bottom: 20px;
    padding-top: 20px;
  }
  .frame_FT .sns-block {
    width: auto;
  }
}

.sns__text {
  font-weight: bold;
}

@media screen and (max-width: 780px) {
  .sns__text {
    margin-bottom: 20px;
  }
}

.sns__icon-wrapper,.sns__link {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
}

@media screen and (max-width: 780px) {
  .sns__link {
    -webkit-justify-content: center;
    justify-content: center;
  }
}

.sns__icon {
  height: 39px !important;
  margin-right: 10px;
}

.sns__item {
  padding-left: 25px;
  padding-right: 25px;
}

@media screen and (max-width: 780px) {
  .sns__item {
    padding-left: 5px;
    padding-right: 5px;
    width: 50%;
  }
}

.sns__item--border-right {
  border-right: 1px solid #e0e0e0;
}

/* 404ページ */
.section-notfound {
  margin-bottom: 80px;
}

.not-found__h1 {
  font-size: 2.4rem;
  margin-bottom: 30px;
  margin-top: 60px;
}

.not-found__text {
  line-height: 1.4;
  margin-bottom: 40px;
}

/************************* list-page-common *************************/
.search-option {
  display: flex;
  display: -webkit-flex;
  margin-bottom: 20px;
  width: 100%;
}

@media screen and (max-width: 780px) {
  .search-option {
    display: block;
    margin-bottom: 10px;
  }
}

.search-option__select-area {
  background-color: #fff;
  display: flex;
  display: -webkit-flex;
  width: auto;
}

@media screen and (max-width: 780px) {
  .search-option__select-area {
    display: inline-flex;
    display: -webkit-inline-flex;
    width: 100%;
  }
}

.search-option__sub-menu {
  background-color: #fff;
  border: 1px solid #b4b4b4;
  border-top: none;
  padding: 20px 15px;
  position: absolute;
  top: 100%;
  width: 100%;
  z-index: 20;
}

.search-option__sub-menu-heiadline {
  border-bottom: 2px solid #f7c1c3;
  font-size: 1.6rem;
  margin-bottom: 10px;
  padding-bottom: 5px;
}

.option-keyword-search__form {
  margin-bottom: 20px;
  width: 100%;
}

.search-option__checkbox-list {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 1.4rem;
}

.search-option__checkbox-item {
  margin-bottom: 15px;
  width: 50%;
}

.option__checkbox {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("/excludes/tokyo/img/checkbox__icon.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 20px;
  margin-right: 8px;
  width: 20px;
}

.option__checkbox:checked {
  background-image: url("/excludes/tokyo/img/checkbox__icon--checked.png");
}

input[type=checkbox].option__checkbox::-ms-check {
  display: none;
}

.search-option__button-area {
  margin-left: 20px;
  position: relative;
}

@media screen and (max-width: 780px) {
  .search-option__button-area {
    margin-left: 0;
  }
}

.c-common-select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url(/excludes/tokyo/img/select-allow--small.png) no-repeat right center;
  background-color: #fff;
  background-size: 32px 100%;
  border: 1px solid #d4d4d4;
  border-radius: 3px;
  display: inline-block;
  height: 38px;
  min-width: 75px;
  padding-bottom: 4px;
  padding-left: 8px;
  padding-right: 38px;
  padding-top: 4px;
}

.c-common-select::-ms-expand {
  display: none;
}

.c-common-select--is-important {
  font-size: 1.8rem;
  font-weight: bold !important;
  margin-right: auto;
  min-width: 75px;
}

@media screen and (max-width: 780px) {
  .c-common-select--sp-normal-input {
    background-color: #fff;
    background-image: none;
    padding-right: 8px;
    text-align: right;
    width: 48px;
  }
  .c-common-select-button--sp-hidden {
    display: none;
  }
}

.js-inputable-select {
  width: 75px;
}

.search-option__number-group {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

@media screen and (max-width: 780px) {
  .search-option__number-group {
    margin-bottom: 10px;
    margin-right: 0;
  }
}

.search-option__button {
  border: 1px solid #b4b4b4;
  font-size: 1.4rem;
  height: 38px;
  padding-bottom: 0;
  padding-left: 12px;
  padding-right: 20px;
  padding-top: 0;
  position: relative;
  text-align: left;
  width: 320px;
}

.search-option__button.is-open {
  border-bottom: 1px solid transparent;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

@media screen and (max-width: 780px) {
  .search-option__button {
    width: 100%;
  }
}

.search-option__button.is-modal::before {
  border-bottom: 2px solid #ed777a;
  border-left: 2px solid transparent;
  border-right: 2px solid #ed777a;
  border-top: 2px solid transparent;
  content: "";
  height: 12px;
  margin-top: -6px;
  position: absolute;
  right: 8px;
  top: 50%;
  -webkit-transform: rotate(-45deg) scale(0.7);
  transform: rotate(-45deg) scale(0.7);
  width: 12px;
  z-index: 1;
}

.search-option__button.is-close::before {
  border-bottom: 2px solid #ed777a;
  border-left: 2px solid transparent;
  border-right: 2px solid #ed777a;
  border-top: 2px solid transparent;
  content: "";
  height: 12px;
  margin-top: -9px;
  position: absolute;
  right: 8px;
  top: 50%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
  z-index: 1;
}

.search-option__button.is-open::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid #ed777a;
  border-right: 2px solid transparent;
  border-top: 2px solid #ed777a;
  content: "";
  height: 12px;
  margin-top: -5px;
  position: absolute;
  right: 8px;
  top: 50%;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
  z-index: 1;
}

.js-search-option-refine-icon {
  display: none;
  position: relative;
  z-index: 51;
}

.column-list {
  border-radius: 3px;
  margin-left: 0;
  margin-right: 0;
  padding-bottom: 12px;
  padding-top: 22px;
  width: 100%;
}

.news-list__date-tag-area {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  margin-bottom: 15px;
}

@media screen and (max-width: 780px) {
  .news-list__date-tag-area {
    display: flex;
    display: -webkit-flex;
    margin-bottom: 10px;
  }
}

.news-list__item {
  -webkit-align-items: flex-start;
  align-items: flex-start;
}

.news-list .two-column-item {
  padding-left: 0;
  padding-right: 0;
}

.pager {
  margin-bottom: 5px;
  margin-top: 20px;
}

.sp-pager {
  display: none;
}

@media screen and (max-width: 780px) {
  .pager {
    display: none;
  }
  .pager--pc-sp-shared,.sp-pager {
    display: flex;
    display: -webkit-flex;
    font-size: 1.35rem !important;
    line-height: 1.28;
    padding-bottom: 15px;
  }
}

.pager__item {
  background-color: #fbe2e5;
  border-radius: 3px;
  display: block;
  line-height: 1.15;
  margin-left: 2px;
  margin-right: 2px;
  min-width: 36px;
  padding: 8px 5px;
  text-align: center;
}

@media screen and (max-width: 780px) {
  .pager__item {
    padding-left: 3px;
    padding-right: 3px;
  }
}

a.pager__item:hover {
  opacity: 0.6;
}

.pager__item--disabled {
  opacity: 0.5;
}

.pager__current {
  background-color: #ed777a;
  color: #fff;
}

.pager__side {
  -webkit-flex: 0 0 20%;
  flex: 0 0 20%;
  margin: 0;
  max-width: 70px;
}

@media screen and (max-width: 780px) {
  .pager__side-prev {
    padding-right: 0;
  }
}

.pager__item-space {
  display: block;
  text-align: center;
  width: 58px;
}

@media screen and (max-width: 780px) {
  .pager__item-space {
    display: block;
    text-align: center;
    width: 18px;
  }
}

.pager__prev--arrow {
  margin-right: 4px;
}

.pager__next--arrow {
  margin-left: 4px;
}

.pager__prev--arrow::before {
  border-bottom: 2px solid #ed777a;
  border-left: 2px solid #ed777a;
  border-right: 2px solid transparent;
  border-top: 2px solid transparent;
  content: "";
  height: 12px;
  left: 5px;
  position: absolute;
  top: 10px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.pager__next--arrow::after {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 2px solid #ed777a;
  border-top: 2px solid #ed777a;
  content: "";
  height: 12px;
  position: absolute;
  right: 5px;
  top: 10px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

li.pager__side > span {
  color: #b4b4b4;
}

li.pager__side > span.pager__item {
  background-color: #d8d8d8;
  border-radius: 3px;
  display: block;
  margin-left: 2px;
  margin-right: 2px;
  min-width: 36px;
  padding: 8px 5px;
  text-align: center;
}

li.pager__side > span.pager__prev--arrow::before {
  border-bottom: 2px solid #b4b4b4;
  border-left: 2px solid #b4b4b4;
  border-right: 2px solid transparent;
  border-top: 2px solid transparent;
  content: "";
  height: 12px;
  left: 5px;
  position: absolute;
  top: 10px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

li.pager__side > span.pager__next--arrow::after {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 2px solid #b4b4b4;
  border-top: 2px solid #b4b4b4;
  content: "";
  height: 12px;
  position: absolute;
  right: 5px;
  top: 10px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}


.pager--max-min {
  opacity: 0.5;
}

/* イベント一覧ページ */
@media screen and (max-width: 780px) {
  .event-page-headline {
    margin-top: 20px;
  }
}

.section-event {
  display: flex;
  display: -webkit-flex;
}

.frame_RM .section-event {
  display: block;
}

@media screen and (max-width: 780px) {
  .section-event {
    display: block;
  }
}

.event-list__left {
  margin-right: 24px;
  width: 700px;
}

.event-list__right {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

.sp-event__menu {
  display: none;
}

@media screen and (max-width: 780px) {
  .event-list__left,.event-list__right {
    width: 100%;
  }
  .event-list__right {
    display: none;
  }
  .sp-event__menu {
    display: block;
  }
}

.event-list {
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -8px;
  margin-right: -8px;
}

@media screen and (max-width: 780px) {
  .event-list {
    margin-left: -5px;
    margin-right: -5px;
  }
}

.event-item {
  border: 1px solid #b4b4b4;
  margin-bottom: 15px;
  margin-left: 8px;
  margin-right: 8px;
  padding: 15px 12px;
  width: calc(100% / 3 - 17px);
}

@media screen and (max-width: 780px) {
  .event-item {
    margin-bottom: 10px;
    margin-left: 5px;
    margin-right: 5px;
    width: calc(50% - 10px);
  }
}

.event-item__tags {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
  margin-bottom: 15px;
}

.event-item__tag {
  border: 2px solid #ed777a;
  border-radius: 3px;
  color: #ed777a;
  display: block;
  font-size: 1.2rem;
  min-width: 60px;
  padding-bottom: 2px;
  padding-left: 5px;
  padding-right: 5px;
  padding-top: 2px;
  text-align: center;
}

.event-item__tag:hover {
  opacity: 0.7;
}

.event-item__date {
  display: block;
  font-size: 1.3rem;
  margin-bottom: 10px;
}

.event-item__text {
  font-weight: bold;
  line-height: 1.5;
}

.event-item__text:hover {
  text-decoration: underline;
}

.event__menu {
  background-color: #fdf6f6;
  border-radius: 5px;
  margin-bottom: 20px;
}

.event-list__menu-headline {
  border-bottom: 2px solid #ed777a;
  font-size: 1.8rem;
  font-weight: bold;
  padding: 20px;
  padding-bottom: 15px;
}

.event__menu-contents {
  padding: 15px;
}

.event__menu-name {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 15px;
}

.event__menu-item {
  border-bottom: 1px solid #dfdfdf;
  margin-bottom: 15px;
  padding-bottom: 10px;
}

.event__menu-item-link {
  display: inline-block;
  font-size: 1.4rem;
  padding-left: 15px;
  position: relative;
}

.event__menu-item-link:hover {
  text-decoration: underline;
}

.event__menu-item-link::before {
  border-bottom: 3px solid transparent;
  border-left: 3px solid transparent;
  border-right: 3px solid #000;
  border-top: 3px solid #000;
  content: "";
  height: 12px;
  left: -2px;
  position: absolute;
  top: calc(50% - 7px);
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

.sp-event__menu {
  background-color: #fdf6f6;
  margin-left: -12px;
  margin-right: -12px;
  margin-top: 40px;
}

.event__menu-button {
  border-bottom: 1px solid #ed777a;
  border-top: 1px solid #ed777a;
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  padding: 12px;
  position: relative;
  text-align: left;
  width: 100%;
}

.frame_RM .event__menu-button {
  background: #fdf6f6;
}

.event__menu-button-month {
  bottom: 1px;
}

.frame_RM .sp-event__menu-wrapper {
  background: #fdf6f6;
}

.sp-event__menu-name {
  border-bottom: 1px solid #dfdfdf;
  font-size: 1.6rem;
  font-weight: bold;
  padding: 12px;
}

.sp-event__menu-item {
  border-bottom: 1px solid #dfdfdf;
  padding-left: 12px;
  padding-right: 12px;
}

.sp-event__menu-item-link {
  display: block;
  font-size: 1.4rem;
  height: 100%;
  padding-bottom: 12px;
  padding-top: 12px;
}

.sp-event__menu-item-link:hover {
  text-decoration: none;
}

.event__menu-button.is-close .event__menu-button-text {
  display: block;
  position: relative;
}

.event__menu-button.is-close .event__menu-button-text::before {
  border-bottom: 3px solid #ed777a;
  border-left: 3px solid transparent;
  border-right: 3px solid #ed777a;
  border-top: 3px solid transparent;
  content: "";
  height: 16px;
  position: absolute;
  right: 0;
  top: calc(50% - 12px);
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 16px;
}

.event__menu-button.is-open .event__menu-button-text {
  display: block;
  position: relative;
}

.event__menu-button.is-open .event__menu-button-text::before {
  border-bottom: 3px solid transparent;
  border-left: 3px solid #ed777a;
  border-right: 3px solid transparent;
  border-top: 3px solid #ed777a;
  content: "";
  height: 16px;
  position: absolute;
  right: 0;
  top: calc(50% - 4px);
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 16px;
}

.sp-event__menu-wrapper {
  display: none;
}

@media screen and (min-width: 781px) {
  .event__menu-button {
    background: #fdf6f6;
    border-bottom: 2px solid #ed777a;
    border-radius: 5px 5px 0 0;
    border-top: none;
    cursor: default;
    font-size: 1.8rem;
    font-weight: bold;
    padding: 20px;
    padding-bottom: 15px;
  }
  .sp-event__menu-name {
    border-bottom: none;
    padding: 12px 0 0;
  }
  .sp-event__menu-item {
    padding-left: 0;
    padding-right: 0;
  }
  .sp-event__menu-wrapper {
    background: #fdf6f6;
    border-radius: 0 0 5px 5px;
    display: block !important;
    margin-bottom: 20px;
    padding: 0 15px 30px;
  }
  .event__menu-button.is-close .event__menu-button-text::before {
    display: none !important;
  }
  .event__menu-button.is-open .event__menu-button-text::before {
    display: none !important;
  }
}

/************************* article-common *************************/
.article {
  margin-bottom: 55px;
}

.article__header {
  margin-bottom: 20px;
}

.article__metadata {
  -webkit-align-items: flex-start;
  align-items: flex-start;
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.article__tags {
  margin-bottom: 10px;
  margin-right: auto;
}

.article__date {
  font-size: 1.2rem;
  line-height: 1.4;
  margin-left: 0.5em;
  padding-bottom: calc(0.2em + 2px);
  padding-top: calc(0.2em + 2px);
  text-align: right;
  word-break: keep-all;
}

.article__sns-buttons {
  -webkit-align-items: flex-start;
  align-items: flex-start;
  border: 2px solid #d8d8d8;
  display: flex;
  display: -webkit-flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 6px;
}

.article__sns-button {
  line-height: 1;
  margin: 2px;
}

.article__sns-buttons iframe,.article__sns-buttons div {
  vertical-align: bottom;
}

.related-infomation {
  margin-bottom: 55px;
}

.related-infomation__link-list {
  margin-bottom: 20px;
}

.related-infomation__video {
  margin-bottom: 10px;
  margin-left: auto;
  margin-right: auto;
  max-width: 640px;
}

.related-infomation__video-title {
  font-size: 1.6rem;
  font-weight: bold;
  padding-top: 10px;
}

.icon-copy-link {
  vertical-align: top;
  width: 20px;
}

.wysiwyg {
  margin-bottom: 20px;
}

.wysiwyg > *:first-child {
  margin-top: 0 !important;
}

.wysiwyg > *:last-child {
  margin-bottom: 0 !important;
}

.wysiwyg h2 {
  border-bottom: 3px solid #8e816f;
  clear: both;
  font-size: 2.3rem;
  margin-bottom: 20px;
  margin-top: 38px;
  padding-bottom: 10px;
  position: relative;
}

.wysiwyg h3 {
  border-bottom: 1px solid #8e816f;
  clear: both;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
  margin-top: 38px;
  padding-bottom: 10px;
}

.wysiwyg h3.no-border {
  border-bottom: none;
  clear: none;
  padding-bottom: 0;
}

.wysiwyg h4 {
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 10px;
  margin-top: 20px;
}

.wysiwyg p {
  margin-bottom: 1em;
  margin-top: 1em;
}

.wysiwyg img {
  max-width: 100%;
  vertical-align: bottom;
  width: auto;
}

.wysiwyg figure {
  display: table;
  margin: 0 auto;
  max-width: 100%;
  min-width: 150px;
  table-layout: fixed;
  text-align: center;
}

.wysiwyg figure img {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

.wysiwyg figcaption {
  display: block;
  font-size: 1.2rem;
  line-height: 1.4;
  margin-bottom: 0.5em;
  margin-top: 0.5em;
  text-align: left;
}

.wysiwyg .img-center {
  text-align: center;
}

.wysiwyg .img-right {
  text-align: right;
}

.wysiwyg .float-left {
  float: left;
  margin: 0 1em 1em 0;
  width: calc(50% - 1em);
}

.wysiwyg .float-right {
  float: right;
  margin: 0 0 1em 1em;
  width: calc(50% - 1em);
}

@media screen and (max-width: 780px) {
  .wysiwyg .float-left,.wysiwyg .float-right {
    float: none;
    margin: 0 auto 1em;
    width: auto;
  }
}

.wysiwyg hr {
  clear: both;
}

.wysiwyg .float-clear {
  clear: both;
}

.wysiwyg .caption {
  display: block;
  font-size: 1.2rem;
  margin-bottom: 0.5em;
  margin-top: 0.5em;
  text-align: left;
}

.wysiwyg .frame {
  border: 1px solid #d8d8d8;
  margin-bottom: 20px;
  margin-top: 20px;
  padding: 20px 12px;
}

.wysiwyg .frame > *:first-child {
  margin-top: 0 !important;
}

.wysiwyg .frame > *:last-child {
  margin-bottom: 0 !important;
}

.wysiwyg .frame-pink {
  border: 2px solid #ed777a;
  margin-bottom: 20px;
  margin-top: 20px;
  padding: 20px 12px;
}

.wysiwyg .frame-pink > *:first-child {
  margin-top: 0 !important;
}

.wysiwyg .frame-pink > *:last-child {
  margin-bottom: 0 !important;
}

.wysiwyg .headline-has-icon {
  -webkit-align-items: center;
  align-items: center;
  display: flex;
  display: -webkit-flex;
}

.wysiwyg .headline-has-icon__icon {
  -webkit-flex: 0 0 33px;
  flex: 0 0 33px;
  margin-right: 10px;
}

.wysiwyg .headline-has-icon__icon img {
  vertical-align: bottom;
}

.wysiwyg .headline-has-icon__text {
  -webkit-flex: 1 1 auto;
  flex: 1 1 auto;
}

.wysiwyg a.link {
  display: inline-block;
  font-weight: bold;
  line-height: 1;
  padding-left: 17px;
  position: relative;
  text-decoration: underline;
}

.wysiwyg a.link:hover {
  text-decoration: none;
}

.wysiwyg a.link::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 3px solid #ed777a;
  border-top: 3px solid #ed777a;
  content: "";
  height: 12px;
  left: -2px;
  margin-top: -5px;
  position: absolute;
  top: 7px;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
  width: 12px;
}

/* ==========================================================================
Print
========================================================================== */
/************************* print *************************/
@media print {
  #fwCms_wrapper {
    min-width: 1024px;
  }
  .mainArea {
    padding-bottom: 0;
  }
  .header-wrapper {
    min-height: unset;
  }
  .header {
    padding: 0 0 10px;
  }
  .header-wrapper--fixed {
    min-width: 1024px;
    position: relative !important;
  }
  .header__official-link-wrapper {
    display: none;
  }
  .header-contents__right {
    display: none;
  }
  .header__search-input {
    display: none;
  }
  .navigation {
    display: none;
  }
  #fwCms_wrapper,.fwCms_leftMenu {
    padding-top: 0 !important;
  }
  #contents {
    display: block;
    height: unset;
  }
  .fwCms_leftMenu .frame_MB {
    margin-left: auto;
    margin-right: auto;
  }
  .pc-pagetop-wrapper,.sp-page-top-button {
    display: none;
  }
  .fwCms_leftMenu .frame_LM {
    display: none;
  }
  .footer__after-menu-wrapper {
    margin-top: 0;
  }
  .footer__menu-wrapper {
    display: none;
  }
  .footer__after-menu {
    display: none;
  }
}

/* **CKEditor */
ul.CKEditorUL {
  margin-left: 1em;
}

ul.CKEditorUL li {
  padding-left: 1.5em;
	text-indent: -1.5em;
}

ul.CKEditorUL li::before {
  background: #d8d8d8;
	border-radius: 50%;
	content: "";
	display: inline-block;
	height: 1em;
	margin-right: 0.5em;
	vertical-align: middle;
	width: 1em;
}

ol.CKEditorOL {
  list-style: decimal;
  padding-left: 25px;
  margin-left: 1em;
}

span.catch-text {
  font-size: 1.8rem;
  font-weight: bold;
}

span.read-text {
  font-size: 1.7rem;
}

span.go-to-top a {
  display: inline-block;
  line-height: 1.2;
  padding-left: 20px;
  position: relative;
}

span.go-to-top a::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 3px solid #747474;
  border-top: 3px solid #747474;
  content: "";
  height: 12px;
  left: 2px;
  margin-top: 0;
  position: absolute;
  top: 0.43em;
  -webkit-transform: rotate(-45deg) scale(0.7);
  transform: rotate(-45deg) scale(0.7);
  width: 12px;
}

span.border-box {
  display: block;
  border: 1px solid #d8d8d8;
	margin-bottom: 20px;
	margin-top: 20px;
	padding: 20px 12px;
}

h1.CKEditorH1 {
  font-size: 2.4rem;
	margin-bottom: 20px;
/*  color: #ed777a;	*/
}

h2.CKEditorH2 {
  border-bottom: 3px solid #8e816f;
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 20px;
	padding-bottom: 10px;
	position: relative;
/*  color: #ed777a;	*/
}

h3.CKEditorH3 {
  border-bottom: 1px solid #8e816f;
	font-size: 1.8rem;
	font-weight: bold;
	margin-bottom: 20px;
	padding-bottom: 10px;
/*  color: #ed777a;	*/
}
/*
.CKEditor hr {
  border: 1px solid #d8d8d8;
	border-width: 1px 0 0 0;
}

.CKEditor a {
  text-decoration: underline;
}

.CKEditor a:hover {
  text-decoration: none;
}
*/
.internal-link, .external-link, .anchor-link, .download-link {
  line-height: 1.2;
  padding-left: 20px;
  display: inline-block;
  text-decoration: underline;
  position: relative;
}
.internal-link:hover, .external-link:hover, .anchor-link:hover, .download-link:hover {
  text-decoration: none;
}
.internal-link::before {
  border-bottom: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 2px solid #3c3c3c;
  border-top: 2px solid #3c3c3c;
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  top: 4px;
  left: 0;
  -webkit-transform: rotate(45deg) scale(0.7);
  transform: rotate(45deg) scale(0.7);
}
.external-link::before {
  content: "";
  width: 9px;
  height: 9px;
  position: absolute;
  top: 4px;
  left: 3px;
  background: url(/excludes/tokyo/img/blunk-link-icon.png) no-repeat;
  background-size: cover;
}
.anchor-link::before {
  border-top: 2px solid transparent;
  border-right: 2px solid transparent;
  border-left: 3px solid #747474;
  border-bottom: 3px solid #747474;
  content: "";
  width: 12px;
  height: 12px;
  top: 0;
  left: 2px;
  position: absolute;
  -webkit-transform: rotate(-45deg) scale(0.7);
  transform: rotate(-45deg) scale(0.7);
}
.download-link::before {
  content: "";
  width: 18px;
  height: 22px;
  position: absolute;
  top: -1px;
  left: -1px;
  background: url(/excludes/tokyo/img/pdf-icon.png) no-repeat;
  background-size: cover;
}

.CKEditor table {
  width: 100% !important;
}

.CKEditor table th,.CKEditor table td {
  border: 1px solid #ed777a;
  font-weight: normal;
  height: 50px;
  padding: 10px;
}

.CKEditor table th {
  background-color: #fdf6f6;
}

.CKEditor table th:first-child {
  width: 30%;
}
