@charset "UTF-8";
/*
Theme Name: 沖縄リピート
Description: 2018 リニューアル
Version: 1.0
Tags: html5 css3(scss) javascript php mysql FontAwesome4.7.0
*/
@media screen and (max-width: 600px) {
  .admin-bar {
    margin-top: 0; }

  #wpadminbar {
    position: fixed; } }
html {
  font-size: 62.5%; }
  html:focus {
    outline: none; }
  html * {
    box-sizing: border-box; }

body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  line-height: 1.6;
  font-size: 14px;
  color: #222;
  min-height: 100%; }

main {
  overflow: hidden; }

.container {
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-right: 15px;
  width: 100%; }
  @media print, screen and (min-width: 768px) {
    .container {
      width: 750px;
      transition: ease-in .1s; } }
  @media print, screen and (min-width: 992px) {
    .container {
      width: 970px;
      transition: ease-in .1s; } }
  @media print, screen and (min-width: 1200px) {
    .container {
      width: 1170px;
      transition: ease-in .1s; } }

.clearfix:before, .clearfix:after, .container:before, .container:after {
  content: " ";
  display: table; }

.clearfix:after, .container:after {
  clear: both; }

#wpadminbar {
  overflow: auto; }

/* ----------------------------------- */
/* フォント設定 */
/* ----------------------------------- */
.font_serif {
  font-family: Georgia, "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "HGS明朝E", serif; }

.mt0 {
  margin-top: 0	 !important; }

.mt5 {
  margin-top: 5px !important; }

.mt10 {
  margin-top: 10px !important; }

.mt15 {
  margin-top: 15px !important; }

.mt20 {
  margin-top: 20px !important; }

.mt30 {
  margin-top: 30px !important; }

.mt35 {
  margin-top: 35px !important; }

.mt40 {
  margin-top: 40px !important; }

.mt50 {
  margin-top: 50px !important; }

.mb0 {
  margin-bottom: 0 !important; }

.mb5 {
  margin-bottom: 5px !important; }

.mb10 {
  margin-bottom: 15px !important; }

.mb15 {
  margin-bottom: 15px !important; }

.mb20 {
  margin-bottom: 20px !important; }

.mb30 {
  margin-bottom: 30px !important; }

.mb35 {
  margin-bottom: 35px !important; }

.mb40 {
  margin-bottom: 40px !important; }

.mb50 {
  margin-bottom: 50px !important; }

.w10p {
  width: 10% !important; }

.w20p {
  width: 20% !important; }

.w30p {
  width: 30% !important; }

.w40p {
  width: 40% !important; }

.w50p {
  width: 50% !important; }

.w60p {
  width: 60% !important; }

.w70p {
  width: 70% !important; }

.w80p {
  width: 80% !important; }

.w90p {
  width: 90% !important; }

.w100p {
  width: 100% !important; }

.fs12 {
  font-size: 12px !important; }

.fs14 {
  font-size: 14px !important; }

.fs16 {
  font-size: 16px !important; }

.fs18 {
  font-size: 18px !important; }

.fs20 {
  font-size: 20px !important; }

.fs22 {
  font-size: 22px !important; }

.fs24 {
  font-size: 24px !important; }

/* ----------------------------------- */
/* リンク */
/* ----------------------------------- */
a {
  color: #222;
  text-decoration: underline;
  transition: all ease-in-out .3s;
  text-decoration: none; }
  a:hover, a:focus {
    color: #22B3DC;
    text-decoration: none;
    transition: all ease-in-out .3s; }
  a:focus, a:active, a:hover {
    outline: 0;
    text-decoration: none; }

/* ----------------------------------- */
/* リンク付き画像 */
/* ----------------------------------- */
a img:hover {
  -moz-opacity: 0.8 !important;
  opacity: 0.8 !important; }

a:active {
  text-decoration: none; }

.entry-meta .edit-link a,
.commentlist .edit-link a {
  background: #eee;
  -moz-border-radius: 3px;
  border-radius: 3px;
  color: #666;
  float: right;
  font-size: 12px;
  line-height: 1.5em;
  font-weight: 300;
  text-decoration: none;
  padding: 0 8px; }

.entry-content .edit-link {
  clear: both;
  display: block; }

/* ----------------------------------- */
/* 配置 */
/* ----------------------------------- */
.alignnone {
  max-width: 100%;
  margin-bottom: 10px; }

.alignleft {
  display: inline;
  float: left; }

.alignright {
  display: inline;
  float: right; }

.aligncenter {
  display: block;
  margin-right: auto;
  margin-left: auto; }

blockquote {
  font-size: 16px; }

blockquote.alignleft,
.wp-caption.alignleft,
img.alignleft {
  margin: 0 20px 20px 0; }

blockquote.alignright,
.wp-caption.alignright,
img.alignright {
  margin: 0 0 20px 20px; }

blockquote.aligncenter,
.wp-caption.aligncenter,
img.aligncenter {
  clear: both;
  display: block;
  margin: 0 auto; }

.wp-caption.alignleft,
.wp-caption.alignright,
.wp-caption.aligncenter {
  margin-bottom: 1.2em; }

/* ----------------------------------- */
/* イメージ */
/* ----------------------------------- */
img {
  vertical-align: bottom;
  max-width: 100%;
  flex-shrink: 0; }
  img[class*="align"], img[class*="wp-image-"], img[class*="attachment-"] {
    height: auto; }
  img.alignleft, img.alignright, img.aligncenter {
    margin-bottom: 30px; }
  img.alignleft {
    display: inline;
    float: left;
    margin-right: 20px; }
  img.alignright {
    display: inline;
    float: right;
    margin-left: 20px; }
  img.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px !important; }

.entry-content img.wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0; }

img#wpstats {
  display: block;
  margin: 0 auto 1em; }

/* ----------------------------------- */
/* ギャラリー */
/* ----------------------------------- */
.gallery {
  margin: 30px 0; }
  .gallery .gallery-item {
    display: inline-block;
    padding: 0 1.79104477%;
    text-align: center;
    vertical-align: top;
    width: 100%;
    margin: 0 0 15px; }
    .gallery .gallery-item .gallery-icon img {
      margin: 0 auto;
      width: 100%;
      height: auto;
      border: none !important; }
    .gallery .gallery-item .gallery-caption {
      color: #707070;
      display: block;
      text-align: left;
      font-size: 14px;
      line-height: 1.5;
      padding: 0.5em 0 0;
      margin: 0; }
  .gallery.gallery-columns-2 .gallery-item {
    max-width: 50%; }
  .gallery.gallery-columns-3 .gallery-item {
    max-width: 33.33%; }
  .gallery.gallery-columns-4 .gallery-item {
    max-width: 25%; }
  .gallery.gallery-columns-5 .gallery-item {
    max-width: 20%; }
  .gallery.gallery-columns-6 .gallery-item {
    max-width: 16.66%; }
  .gallery.gallery-columns-7 .gallery-item {
    max-width: 14.28%; }
  .gallery.gallery-columns-8 .gallery-item {
    max-width: 12.5%; }
  .gallery.gallery-columns-9 .gallery-item {
    max-width: 11.11%; }
  @media print, screen and (min-width: 768px) {
    .gallery.gallery-columns-2 .gallery-item {
      max-width: 50%; }
    .gallery.gallery-columns-3 .gallery-item {
      max-width: 33.33%; }
    .gallery.gallery-columns-4 .gallery-item {
      max-width: 25%; }
    .gallery.gallery-columns-5 .gallery-item {
      max-width: 20%; }
    .gallery.gallery-columns-6 .gallery-item {
      max-width: 16.66%; }
    .gallery.gallery-columns-7 .gallery-item {
      max-width: 14.28%; }
    .gallery.gallery-columns-8 .gallery-item {
      max-width: 12.5%; }
    .gallery.gallery-columns-9 .gallery-item {
      max-width: 11.11%; } }

/* キャプション */
/* ----------------------------------- */
.wp-caption {
  max-width: 100%;
  font-size: 14px;
  margin: 0; }
  .wp-caption img {
    border-color: #eee;
    max-width: 100%; }

/* ----------------------------------- */
/* Make sure videos and embeds fit their containers */
/* ----------------------------------- */
embed,
iframe,
object {
  max-width: 100%; }

/* ----------------------------------- */
/* ボタン */
/* ----------------------------------- */
.btnWrap {
  margin: 30px 0; }

.btn {
  clear: both;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 290px;
  height: 40px;
  margin: 0;
  padding: 8px 0 0 0;
  font-size: 16px;
  line-height: 1.5;
  font-weight: normal;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  text-decoration: none;
  transition: .3s ease-in;
  user-select: none;
  position: relative;
  border: 1px solid #E6E6E6;
  color: #222222;
  background: #fff;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none; }
  .btn:hover, .btn:focus {
    text-decoration: none;
    color: #fff;
    background: #22B3DC;
    border-color: #22B3DC; }
  .btn.arrow:after {
    position: absolute;
    align-items: center;
    border: none;
    content: "\f105";
    font-family: FontAwesome;
    transform: none;
    color: #222;
    right: 15px;
    font-size: 20px;
    border-radius: 0;
    top: 50%;
    margin-top: -15px;
    transition: .3s ease-in; }
  .btn.arrow:hover:after, .btn.arrow:focus:after {
    color: #fff; }
  .btn.arrowReverse:after {
    position: absolute;
    align-items: center;
    border: none;
    content: "\f0a9";
    font-family: FontAwesome;
    transform: none;
    color: #22B3DC;
    right: 15px;
    font-size: 20px;
    border-radius: 0;
    top: 50%;
    margin-top: -15px;
    transition: .3s ease-in; }
  .btn.arrowReverse:hover:after, .btn.arrowReverse:focus:after {
    color: #fff; }
  .btn.reverse {
    text-decoration: none !important;
    color: #fff !important;
    background: #22B3DC;
    border-color: #22B3DC; }
    .btn.reverse:hover, .btn.reverse:focus {
      background: #fff;
      color: #22B3DC !important; }
  .btn.btnLeft {
    margin: 0; }
  .btn.btnRight {
    margin: 0 auto 0 0; }
  .btn.btnCenter {
    margin-left: auto;
    margin-right: auto; }
  .btn.btnFull {
    max-width: none; }
  .btn.h60 {
    min-height: 60px;
    padding: 18px 0 0 0; }

/* ----------------------------------- */
/* カラム */
/* ----------------------------------- */
.column1Wrap {
  margin-bottom: 30px; }

.column2Wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 20px; }
  .column2Wrap .columnBox {
    flex-basis: 100%;
    margin-bottom: 20px; }

.column3Wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 15px; }
  .column3Wrap .columnBox {
    flex-basis: 100%;
    width: 100%;
    margin-bottom: 20px; }
    .column3Wrap .columnBox img {
      width: 100%; }
    .column3Wrap .columnBox p:last-child {
      margin-bottom: 0; }

.column4Wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 15px; }
  .column4Wrap .columnBox {
    flex-basis: 100%;
    margin-bottom: 20px; }
    .column4Wrap .columnBox img {
      width: 100%; }
    .column4Wrap .columnBox p:last-child {
      margin-bottom: 0; }

.columnBox {
  overflow: hidden; }
  .columnBox img {
    align-self: baseline;
    max-width: 100%; }
  .columnBox p:last-of-type {
    margin-bottom: 0; }

@media print, screen and (min-width: 768px) {
  .column2Wrap .columnBox {
    flex-basis: 48%;
    width: 48%; }
  .column2Wrap .column2Wrap .columnBox {
    flex-basis: 45%; }

  .column3Wrap .column_box {
    flex-basis: 48%;
    width: 48%; }

  .column4Wrap {
    position: relative; }
    .column4Wrap .columnBox {
      flex-basis: 48%;
      width: 48%; } }
@media print, screen and (min-width: 992px) {
  .column3Wrap:after {
    content: "";
    display: block;
    width: 31%; }
  .column3Wrap .columnBox {
    flex-basis: 31%;
    width: 31%; }

  .column4Wrap {
    position: relative; }
    .column4Wrap:before {
      content: "";
      display: block;
      width: 23%;
      order: 1; }
    .column4Wrap:after {
      content: "";
      width: 23%;
      display: block; }
    .column4Wrap .columnBox {
      flex-basis: 23%;
      width: 23%; } }
/* ----------------------------------- */
/* レイアウト */
/* ----------------------------------- */
.sideLayout {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  .sideLayout #mainColumn {
    flex-basis: 100%;
    width: 100%; }
  .sideLayout #sideColumn {
    flex-basis: 100%;
    width: 100%; }
  @media print, screen and (min-width: 992px) {
    .sideLayout {
      flex-wrap: nowrap; }
      .sideLayout #mainColumn {
        flex-basis: calc( 100% - 330px);
        width: calc( 100% - 330px); }
      .sideLayout #sideColumn {
        flex-basis: 300px;
        width: 300px; } }
  @media print, screen and (min-width: 1200px) {
    .sideLayout #mainColumn {
      flex-basis: calc( 100% - 360px);
      width: calc( 100% - 360px); } }

/* ---------------------------------------------------------------- */
/* ヘッダー */
/* ---------------------------------------------------------------- */
#header #headerCntWrap {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  min-height: 60px;
  padding: 0; }
  #header #headerCntWrap #logo {
    flex-basis: 250px;
    width: 250px; }
    #header #headerCntWrap #logo h1, #header #headerCntWrap #logo a {
      display: block;
      width: 100%;
      margin: 0;
      padding: 0;
      font-size: 100%;
      line-height: 1.2; }
      #header #headerCntWrap #logo h1 img, #header #headerCntWrap #logo a img {
        max-width: 100%;
        height: auto; }
  #header #headerCntWrap #headerRead {
    display: none; }
  #header #headerCntWrap #headerCnt {
    display: none; }
@media print, screen and (min-width: 992px) {
  #header #headerCntWrap {
    min-height: 70px; }
    #header #headerCntWrap #headerRead {
      display: inline-flex;
      margin: 0 auto 0 0; }
      #header #headerCntWrap #headerRead p {
        font-size: 11px;
        color: #333;
        font-weight: normal;
        margin: 0 0 0 10px;
        padding: 0 10px 0 0; }
    #header #headerCntWrap #headerCnt {
      display: inline-flex;
      flex-basis: 370px; }
      #header #headerCntWrap #headerCnt .aboutLink {
        display: block;
        border: 1px solid #22B3DC;
        border-radius: 28px;
        min-width: 140px;
        height: 28px;
        color: #22B3DC;
        font-size: 12px;
        text-decoration: none;
        text-align: center;
        padding-top: 4px;
        margin: 5px 10px 0 0; }
        #header #headerCntWrap #headerCnt .aboutLink:hover {
          background: #22B3DC;
          color: #fff; }
      #header #headerCntWrap #headerCnt ul {
        margin: 0 10px 0 0;
        padding: 0;
        width: 90px;
        display: flex;
        align-items: center;
        justify-content: space-between; }
        #header #headerCntWrap #headerCnt ul li {
          list-style: none;
          flex-basis: 24px; }
          #header #headerCntWrap #headerCnt ul li a {
            display: block;
            width: 24px;
            height: 24px;
            height: auto; }
      #header #headerCntWrap #headerCnt .selectCustom {
        position: relative;
        border-radius: 2px;
        background: #ffffff;
        overflow: hidden;
        width: 120px;
        text-align: center; }
        #header #headerCntWrap #headerCnt .selectCustom:after {
          position: absolute;
          top: calc( 50% - 3px );
          right: 2px;
          width: 0;
          height: 0;
          padding: 0;
          content: '';
          border-left: 6px solid transparent;
          border-right: 6px solid transparent;
          border-top: 6px solid #22B3DC;
          pointer-events: none; }
        #header #headerCntWrap #headerCnt .selectCustom select {
          width: 100%;
          cursor: pointer;
          text-indent: 0.01px;
          text-overflow: ellipsis;
          border: none;
          outline: none;
          background: transparent;
          background-image: none;
          box-shadow: none;
          -webkit-appearance: none;
          appearance: none;
          padding: 8px 8px 8px 8px !important;
          color: #666666; }
          #header #headerCntWrap #headerCnt .selectCustom select::-ms-expand {
            display: none; } }
@media print, screen and (min-width: 1200px) {
  #header #headerCntWrap {
    height: 70px;
    overflow: hidden; }
    #header #headerCntWrap #headerRead p {
      font-size: 12px;
      margin: 0 0 0 15px;
      padding: 0 15px 0 0; } }

/* ---------------------------------------------------------------- */
/* フッターエリア */
/* ---------------------------------------------------------------- */
#footer {
  padding: 30px 0 0;
  border-top: 1px solid #E6E6E6; }
  #footer #footerLogo {
    margin-bottom: 30px;
    text-align: center; }
    #footer #footerLogo a {
      display: block;
      margin: 0 auto; }
  #footer #siteNaviArea {
    display: none; }
  #footer #underArea #footerNavi {
    display: none; }
  #footer #underArea .copyright {
    text-align: center;
    font-size: 12px;
    font-weight: normal; }
  @media print, screen and (min-width: 992px) {
    #footer #footerLogo {
      text-align: left; }
    #footer #siteNaviArea {
      display: block;
      margin-bottom: 40px; }
      #footer #siteNaviArea .siteNaviWrap {
        display: flex;
        flex: 1 2 auto;
        justify-content: space-between; }
      #footer #siteNaviArea .nolink {
        pointer-events: none; }
      #footer #siteNaviArea ul {
        margin: 0;
        padding: 0; }
        #footer #siteNaviArea ul li {
          list-style: none;
          margin-bottom: 5px;
          line-height: 1.8; }
          #footer #siteNaviArea ul li a {
            font-weight: bold;
            font-size: 16px; }
          #footer #siteNaviArea ul li .sub-menu {
            margin: 10px 0 15px 1em; }
            #footer #siteNaviArea ul li .sub-menu li {
              margin: 0 0; }
              #footer #siteNaviArea ul li .sub-menu li a {
                font-weight: normal;
                font-size: 14px; }
              #footer #siteNaviArea ul li .sub-menu li .sub-menu {
                margin: 0 0 0 1em; }
        #footer #siteNaviArea ul.lv2 {
          margin: 30px 0 0 0; }
    #footer #underArea {
      border-top: 1px solid #222;
      margin: 0 0 30px; }
      #footer #underArea .underWrap {
        display: flex;
        justify-content: space-between;
        align-items: center; }
      #footer #underArea #footerNavi {
        display: inline-flex; }
        #footer #underArea #footerNavi ul {
          display: flex;
          margin: 0;
          padding: 0; }
          #footer #underArea #footerNavi ul li {
            list-style: none;
            margin-right: 10px; }
            #footer #underArea #footerNavi ul li a {
              font-size: 12px;
              color: #222; }
              #footer #underArea #footerNavi ul li a:hover {
                color: #22B3DC; }
      #footer #underArea .copyright {
        text-align: center;
        font-size: 12px;
        font-weight: normal; } }

/* ---------------------------------------------------------------- */
/* メインナビ */
/* ---------------------------------------------------------------- */
/* SP */
/* ----------------------------------- */
#mainNaviArea {
  display: none; }

.drawer {
  position: relative; }
  .drawer #mainNaviSpArea {
    position: relative; }
    .drawer #mainNaviSpArea .drawer-hamburger {
      position: relative;
      width: 40px;
      height: 40px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: #22B3DC;
      padding: 0; }
    .drawer #mainNaviSpArea .drawer-hamburger-icon {
      margin-top: 0;
      width: 24px;
      height: 3px;
      background: #fff;
      border-radius: 3px; }
      .drawer #mainNaviSpArea .drawer-hamburger-icon:before {
        background: #fff;
        height: 3px;
        border-radius: 3px;
        top: -8px; }
      .drawer #mainNaviSpArea .drawer-hamburger-icon:after {
        background: #fff;
        height: 3px;
        border-radius: 3px;
        top: 8px; }
  .drawer .drawer-nav {
    background: #22B3DC; }
    .drawer .drawer-nav ul {
      margin: 0;
      padding: 0;
      width: 100%; }
      .drawer .drawer-nav ul li {
        list-style: none;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        border-bottom: 1px solid #fff;
        position: relative;
        background: #1aaca7; }
        .drawer .drawer-nav ul li a {
          width: 100%;
          color: #fff;
          min-height: 40px;
          padding: 9px 15px;
          background: #22B3DC; }
          .drawer .drawer-nav ul li a:hover {
            background: #4ac1e2; }
        .drawer .drawer-nav ul li.children {
          overflow: hidden; }
          .drawer .drawer-nav ul li.children > a {
            width: calc( 270px - 40px ); }
          .drawer .drawer-nav ul li.children i {
            position: relative;
            width: 40px;
            height: 40px;
            display: block;
            text-align: center;
            padding-top: 9px;
            margin: 0 0 0 auto;
            font-size: 20px;
            color: #fff;
            transition: .1s ease; }
            .drawer .drawer-nav ul li.children i.active, .drawer .drawer-nav ul li.children i:hover {
              transform: rotate(-180deg);
              cursor: pointer; }
          .drawer .drawer-nav ul li.children .sub-menu {
            display: none; }
            .drawer .drawer-nav ul li.children .sub-menu li a {
              min-height: inherit;
              display: block;
              padding: 8px 15px 8px 27px;
              background: #1a8cac; }
              .drawer .drawer-nav ul li.children .sub-menu li a:hover {
                background: #4ac1e2; }
            .drawer .drawer-nav ul li.children .sub-menu li.children .sub-menu {
              display: none;
              margin: 0;
              padding: 0; }
              .drawer .drawer-nav ul li.children .sub-menu li.children .sub-menu li a {
                padding: 6px 15px 6px 41px;
                background: #13687f; }
                .drawer .drawer-nav ul li.children .sub-menu li.children .sub-menu li a:hover {
                  background: #4ac1e2; }
              .drawer .drawer-nav ul li.children .sub-menu li.children .sub-menu li:last-child {
                border: none; }
            .drawer .drawer-nav ul li.children .sub-menu li:last-child {
              border: none; }
  .drawer.drawer-open #mainNaviSpArea {
    position: absolute;
    right: 120px; }
    .drawer.drawer-open #mainNaviSpArea .drawer-hamburger .drawer-hamburger-icon {
      background: none; }
      .drawer.drawer-open #mainNaviSpArea .drawer-hamburger .drawer-hamburger-icon:after {
        background: #fff;
        top: inherit; }
      .drawer.drawer-open #mainNaviSpArea .drawer-hamburger .drawer-hamburger-icon:before {
        background: #fff;
        top: inherit; }
    .drawer.drawer-open #mainNaviSpArea .drawer-nav {
      width: 270px; }

/* ----------------------------------- */
/* PCメニュー */
/* ----------------------------------- */
@media print, screen and (min-width: 992px) {
  #mainNaviSpArea {
    display: none; }

  #mainNaviArea {
    display: block;
    margin: 0 0 15px;
    padding: 0; }
    #mainNaviArea #mainNavi {
      padding: 0; }
      #mainNaviArea #mainNavi > ul {
        margin: 0;
        padding: 0;
        width: 100%;
        position: relative;
        height: 24px;
        display: flex;
        align-items: center;
        border-left: 1px solid #666;
        border-right: 1px solid #666;
        position: relative; }
        #mainNaviArea #mainNavi > ul > li {
          list-style: none;
          margin: 0;
          padding: 0;
          height: 100%;
          flex: 1 2 auto;
          text-align: center; }
          #mainNaviArea #mainNavi > ul > li a {
            text-align: center;
            height: 24px;
            color: #666666;
            margin: 0;
            padding: 0 10px;
            text-decoration: none;
            line-height: 1.2;
            font-size: 14px; }
            #mainNaviArea #mainNavi > ul > li a:hover, #mainNaviArea #mainNavi > ul > li a:focus, #mainNaviArea #mainNavi > ul > li a:active {
              cursor: pointer;
              color: #22B3DC; }
            #mainNaviArea #mainNavi > ul > li a span {
              flex-basis: 100%;
              font-size: 12px; }
          #mainNaviArea #mainNavi > ul > li + li {
            border-left: 1px solid #666; }
          #mainNaviArea #mainNavi > ul > li.current > a {
            color: #22B3DC !important; }
          #mainNaviArea #mainNavi > ul > li > .sub-menu {
            transition: .3s ease-in;
            position: absolute;
            left: 0;
            top: 100%;
            z-index: 5;
            width: 100%;
            background: #22B3DC;
            margin: 0;
            padding: 0 15px 0;
            display: flex;
            flex-wrap: wrap;
            justify-content: flex-start; }
            #mainNaviArea #mainNavi > ul > li > .sub-menu li {
              list-style: none;
              margin: 0;
              padding: 0;
              flex: 1 0 auto;
              text-align: left;
              height: 0;
              transition: .3s;
              overflow: hidden;
              line-height: 1.8; }
              #mainNaviArea #mainNavi > ul > li > .sub-menu li a {
                color: #fff;
                font-weight: bold; }
                #mainNaviArea #mainNavi > ul > li > .sub-menu li a:hover {
                  color: #22B3DC !important; }
              #mainNaviArea #mainNavi > ul > li > .sub-menu li > .sub-menu {
                margin: 0 0 15px 20px;
                padding: 0; }
                #mainNaviArea #mainNavi > ul > li > .sub-menu li > .sub-menu li {
                  list-style: none;
                  padding: 0; }
                  #mainNaviArea #mainNavi > ul > li > .sub-menu li > .sub-menu li a {
                    font-size: 13px;
                    margin-right: 1em;
                    font-weight: normal; }
          #mainNaviArea #mainNavi > ul > li:hover > .sub-menu, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu {
            transition: .3s ease;
            position: absolute;
            left: 0;
            top: 100%;
            z-index: 5;
            width: 100%;
            background: #22B3DC;
            margin: 0;
            padding: 30px 15px 15px;
            display: flex;
            flex-wrap: wrap;
            justify-content: flex-start; }
            #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li {
              list-style: none;
              margin: 0 0 15px;
              padding: 0;
              flex: 1 0 auto;
              text-align: left;
              overflow: visible;
              height: auto; }
              #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li a, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li a {
                color: #fff;
                font-weight: bold; }
                #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li a:hover, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li a:hover {
                  color: #ff977d !important; }
              #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li > .sub-menu, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li > .sub-menu {
                margin: 0 0 15px 20px;
                padding: 0; }
                #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li > .sub-menu li, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li > .sub-menu li {
                  list-style: none;
                  padding: 0;
                  margin: 0; }
                  #mainNaviArea #mainNavi > ul > li:hover > .sub-menu li > .sub-menu li a, #mainNaviArea #mainNavi > ul > li:focus > .sub-menu li > .sub-menu li a {
                    font-size: 13px;
                    margin-right: 1em;
                    font-weight: normal; }
          #mainNaviArea #mainNavi > ul > li.current-menu-item > a {
            color: #ff977d !important; }
            #mainNaviArea #mainNavi > ul > li.current-menu-item > a ul.sub-menu > a {
              color: #ff977d !important;
              background: #fff; }
              #mainNaviArea #mainNavi > ul > li.current-menu-item > a ul.sub-menu > a:hover, #mainNaviArea #mainNavi > ul > li.current-menu-item > a ul.sub-menu > a:focus {
                color: #accent_color2 !important; }
          #mainNaviArea #mainNavi > ul > li.current-menu-parent > ul li.current-menu-item a {
            color: #ff977d !important;
            background: #fff; } }
/* ---------------------------------------------------------------- */
/* パンくず */
/* ---------------------------------------------------------------- */
.breadcrumbs {
  clear: both;
  padding: 0;
  margin: 0 0 30px;
  font-size: 12px;
  overflow: hidden;
  background: #22B3DC;
  color: #fff;
  min-height: 40px; }
  .breadcrumbs .breadcrumbsList {
    margin: 0;
    padding: 11px 0 5px 0; }
  .breadcrumbs a {
    font-size: 12px;
    text-decoration: none;
    padding: 0;
    color: #fff; }
    .breadcrumbs a:hover, .breadcrumbs a:focus {
      text-decoration: underline; }

/* ---------------------------------------------------------------- */
/* ページナビ */
/* ---------------------------------------------------------------- */
.wp-pagenavi {
  position: relative;
  text-align: center;
  padding: 0 0;
  margin: 30px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 40px; }
  .wp-pagenavi a, .wp-pagenavi span {
    color: #22B3DC;
    width: 32px;
    height: 32px;
    padding: 0 0 0 0;
    text-decoration: none;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 100%;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 5px; }
  .wp-pagenavi a:hover,
  .wp-pagenavi a:focus {
    color: #fff !important;
    background: #22B3DC;
    border: 1px solid #22B3DC; }
  .wp-pagenavi span.current {
    color: #fff;
    background: #22B3DC;
    font-weight: normal;
    border: 1px solid #22B3DC; }
  .wp-pagenavi .nextpostslink,
  .wp-pagenavi .previouspostslink {
    font-size: 20px;
    color: #22B3DC;
    background: none;
    border: none; }
    .wp-pagenavi .nextpostslink:hover, .wp-pagenavi .nextpostslink:focus,
    .wp-pagenavi .previouspostslink:hover,
    .wp-pagenavi .previouspostslink:focus {
      color: #ff977d !important;
      background: none;
      border: none; }

/* ---------------------------------------------------------------- */
/* ページトップ ボタン */
/* ---------------------------------------------------------------- */
#pagetopArea {
  position: fixed;
  right: 15px;
  bottom: 85px;
  display: none;
  z-index: 1; }
  #pagetopArea a {
    font-size: 28px;
    font-weight: 100;
    text-align: center;
    margin: 0;
    width: 36px;
    height: 36px;
    padding: 2px 0 0 0;
    display: block;
    color: #fff;
    background: #22B3DC;
    line-height: 1;
    border-radius: 100%;
    border: 1px solid #22B3DC; }
    #pagetopArea a:hover, #pagetopArea a:focus {
      cursor: pointer;
      background: #fff;
      color: #22B3DC; }
  @media print, screen and (min-width: 768px) {
    #pagetopArea {
      display: block; } }

/* ---------------------------------------------------------------- */
/* メインスライダー  */
/* ---------------------------------------------------------------- */
#sliderArea {
  width: 100%;
  overflow: hidden;
  background: #fff;
  margin: 0 0 30px; }
  #sliderArea .swiper-container {
    position: relative;
    background: #fff; }
  #sliderArea .swiper-slide {
    height: 100%;
    padding-bottom: 5px;
    margin-bottom: 15px;
    opacity: 0 !important;
    transition: .3s; }
    #sliderArea .swiper-slide.swiper-slide-active {
      opacity: 1 !important; }
    #sliderArea .swiper-slide .thumbnail {
      width: 100%; }
      #sliderArea .swiper-slide .thumbnail .thumbnailBox {
        position: relative;
        width: 100%;
        overflow: hidden; }
        #sliderArea .swiper-slide .thumbnail .thumbnailBox:before {
          content: "";
          display: block;
          padding-top: 60%; }
        #sliderArea .swiper-slide .thumbnail .thumbnailBox img {
          width: 100%;
          height: auto;
          position: absolute;
          top: 0;
          left: 0;
          bottom: 0;
          right: 0; }
    #sliderArea .swiper-slide .sliderCnt {
      padding: 15px; }
      #sliderArea .swiper-slide .sliderCnt .column {
        display: flex;
        align-items: center;
        margin-bottom: 15px; }
      #sliderArea .swiper-slide .sliderCnt time {
        display: block;
        font-size: 12px;
        color: #333;
        margin: 0 15px 0 0; }
      #sliderArea .swiper-slide .sliderCnt .catList {
        margin: 0;
        padding: 0; }
        #sliderArea .swiper-slide .sliderCnt .catList li {
          list-style: none;
          display: inline-block; }
          #sliderArea .swiper-slide .sliderCnt .catList li a {
            font-size: 10px;
            color: #22B3DC;
            text-decoration: none;
            display: block;
            height: 24px;
            padding: 0 15px;
            line-height: 24px;
            border: 1px solid #22B3DC;
            border-radius: 24px; }
            #sliderArea .swiper-slide .sliderCnt .catList li a:hover {
              color: #fff;
              background: #22B3DC; }
      #sliderArea .swiper-slide .sliderCnt .permaLinkWrap {
        margin: 0 0 15px; }
        #sliderArea .swiper-slide .sliderCnt .permaLinkWrap a {
          font-size: 16px;
          color: #333;
          text-decoration: none;
          margin: 0;
          display: block;
          font-weight: bold; }
          #sliderArea .swiper-slide .sliderCnt .permaLinkWrap a:hover {
            color: #22B3DC; }
      #sliderArea .swiper-slide .sliderCnt .excerpt {
        margin: 0 0 15px; }
        #sliderArea .swiper-slide .sliderCnt .excerpt p {
          font-size: 14px;
          margin: 0; }
      #sliderArea .swiper-slide .sliderCnt .postTag {
        margin: 0;
        padding: 0; }
        #sliderArea .swiper-slide .sliderCnt .postTag li {
          list-style: none;
          display: inline-block;
          margin: 0 10px 5px 0;
          border-radius: 25%;
          min-height: 24px;
          text-align: center; }
          #sliderArea .swiper-slide .sliderCnt .postTag li a {
            font-size: 10px;
            line-height: 1em;
            background: #F9F8F2;
            color: #222;
            display: inline-block;
            white-space: nowrap;
            padding: 7px 15px;
            border-radius: 26px;
            text-decoration: none; }
            #sliderArea .swiper-slide .sliderCnt .postTag li a:hover {
              background: #22B3DC;
              color: #fff; }
  #sliderArea .swiper-pagination {
    position: relative;
    text-align: center;
    margin: 0 0 30px; }
    #sliderArea .swiper-pagination .swiper-pagination-bullet {
      margin: 0 10px 0 0;
      text-align: center;
      width: 24px;
      height: 24px;
      display: inline-block;
      font-size: 12px;
      border-radius: 0;
      background: none;
      opacity: 1;
      padding: 2px 0 0 0;
      border: 1px solid #E6E6E6; }
    #sliderArea .swiper-pagination .swiper-pagination-bullet-active {
      border-color: #22B3DC;
      background: #22B3DC;
      color: #fff; }
  @media print, screen and (min-width: 768px) {
    #sliderArea .swiper-container {
      width: 750px;
      background: #fff; }
    #sliderArea .swiper-pagination {
      text-align: left !important;
      margin: 0 0 30px 15px; } }
  @media print, screen and (min-width: 992px) {
    #sliderArea {
      margin: 5px 0 30px; }
      #sliderArea .swiper-container {
        width: 940px; }
      #sliderArea .swiper-slide {
        width: 100%;
        display: flex;
        justify-content: space-between;
        margin: 0;
        padding: 0;
        border: 1px solid #E6E6E6; }
        #sliderArea .swiper-slide .thumbnail {
          max-width: 540px;
          max-height: 432px;
          overflow: hidden; }
          #sliderArea .swiper-slide .thumbnail img {
            width: 100%; }
        #sliderArea .swiper-slide .sliderCnt {
          flex-basis: calc(100% - 540px);
          width: calc(100% - 540px);
          padding: 0; }
          #sliderArea .swiper-slide .sliderCnt time {
            flex-basis: 70px;
            display: block;
            margin: 2px 0 0 0; }
          #sliderArea .swiper-slide .sliderCnt .catList {
            margin: 0; }
          #sliderArea .swiper-slide .sliderCnt .sliderInner {
            padding: 15px; }
          #sliderArea .swiper-slide .sliderCnt .excerpt {
            margin-bottom: 10px; }
      #sliderArea .swiper-pagination {
        position: absolute;
        left: 555px;
        bottom: 15px;
        width: auto;
        margin: 0;
        padding: 0; } }
  @media print, screen and (min-width: 1200px) {
    #sliderArea .swiper-container {
      width: 1140px; }
    #sliderArea .swiper-slide .thumbnail {
      max-width: 720px;
      max-height: 432px;
      overflow: hidden; }
      #sliderArea .swiper-slide .thumbnail img {
        width: 100%; }
    #sliderArea .swiper-slide .sliderCnt {
      flex-basis: calc(100% - 720px);
      width: calc(100% - 720px); }
      #sliderArea .swiper-slide .sliderCnt .column {
        margin-bottom: 20px; }
      #sliderArea .swiper-slide .sliderCnt time {
        margin-bottom: 0; }
      #sliderArea .swiper-slide .sliderCnt .catList {
        margin-bottom: 0; }
      #sliderArea .swiper-slide .sliderCnt .permalink {
        margin-bottom: 30px; }
      #sliderArea .swiper-slide .sliderCnt .excerpt {
        margin-bottom: 30px; }
      #sliderArea .swiper-slide .sliderCnt .sliderInner {
        padding: 30px; }
    #sliderArea .swiper-pagination {
      left: 750px;
      bottom: 30px; } }

/* ---------------------------------------------------------------- */
/* HOME */
/* ---------------------------------------------------------------- */
#indexPage h2 {
  background: url("images/common/footer-image.png") no-repeat;
  background-size: 40px auto;
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 30px;
  padding: 4px 0 0 50px;
  min-height: 35px;
  color: #22B3DC; }
#indexPage #asArea {
  margin-bottom: 15px; }
  #indexPage #asArea #asFlex {
    display: flex;
    flex-wrap: wrap; }
  #indexPage #asArea #aboutArea {
    flex-basis: 100%;
    align-items: center;
    margin-bottom: 15px; }
    #indexPage #asArea #aboutArea a {
      display: flex;
      flex-basis: 100%;
      align-items: center;
      justify-content: center;
      flex-direction: row;
      min-height: 60px;
      height: 100%;
      background: #6F91C0;
      border: 1px solid #6F91C0;
      color: #fff;
      font-weight: bold;
      font-size: 16px;
      text-decoration: none; }
      #indexPage #asArea #aboutArea a:hover {
        background: #fff;
        color: #6F91C0; }
  #indexPage #asArea #searchArea {
    flex-basis: 100%;
    padding: 15px;
    background: #22B3DC; }
    #indexPage #asArea #searchArea #searchForm {
      display: flex;
      flex-wrap: wrap; }
      #indexPage #asArea #searchArea #searchForm p {
        color: #fff;
        margin: 0 0 10px;
        font-size: 14px; }
      #indexPage #asArea #searchArea #searchForm form {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        margin: 0; }
        #indexPage #asArea #searchArea #searchForm form .selectCustom {
          flex-basis: 100%;
          position: relative;
          margin-bottom: 15px; }
          #indexPage #asArea #searchArea #searchForm form .selectCustom:after {
            position: absolute;
            top: calc( 50% - 3px );
            right: 4px;
            width: 0;
            height: 0;
            padding: 0;
            content: '';
            border-left: 6px solid transparent;
            border-right: 6px solid transparent;
            border-top: 6px solid #22B3DC;
            pointer-events: none; }
          #indexPage #asArea #searchArea #searchForm form .selectCustom select {
            width: 100%;
            cursor: pointer;
            text-indent: 0.01px;
            text-overflow: ellipsis;
            outline: none;
            background: transparent;
            background-image: none;
            box-shadow: none;
            -webkit-appearance: none;
            appearance: none;
            border-radius: 4px;
            padding-left: 15px;
            border: none;
            height: 60px;
            font-size: 14px;
            background: #fff; }
            #indexPage #asArea #searchArea #searchForm form .selectCustom select option {
              font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }
            #indexPage #asArea #searchArea #searchForm form .selectCustom select::-ms-expand {
              display: none; }
        #indexPage #asArea #searchArea #searchForm form input[type="text"] {
          padding-left: 15px;
          flex-basis: 100%;
          border: none;
          border-left: 1px solid #E6E6E6;
          font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
          border-radius: 4px;
          height: 60px;
          margin-bottom: 15px;
          font-size: 14px; }
        #indexPage #asArea #searchArea #searchForm form input[type="submit"] {
          flex-basis: 100%;
          font-family: FontAwesome;
          background: none;
          border: none;
          font-size: 32px;
          color: #fff;
          height: 60px;
          border-radius: 4px;
          border: 1px solid #22B3DC;
          transition: .3s ease; }
          #indexPage #asArea #searchArea #searchForm form input[type="submit"]:hover {
            cursor: pointer;
            background: #fff;
            color: #22B3DC; }
#indexPage #reserveArea {
  margin: 0 0 40px; }
  #indexPage #reserveArea ul {
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap; }
    #indexPage #reserveArea ul li {
      list-style: none;
      flex-basis: 50%;
      height: 60px; }
      #indexPage #reserveArea ul li a {
        display: block;
        width: 100%;
        height: 100%;
        padding-top: 10px;
        text-decoration: none;
        color: #fff;
        font-size: 18px;
        font-weight: bold;
        text-align: center;
        line-height: 1.2;
        border-width: 1px;
        border-style: solid; }
        #indexPage #reserveArea ul li a span {
          display: block;
          flex-basis: 100%;
          font-size: 14px;
          font-weight: normal; }
      #indexPage #reserveArea ul li:nth-of-type(1) a {
        background: #80AC67;
        border-color: #80AC67; }
        #indexPage #reserveArea ul li:nth-of-type(1) a:hover {
          color: #80AC67;
          background: #fff; }
      #indexPage #reserveArea ul li:nth-of-type(2) a {
        background: #D65A2F;
        border-color: #D65A2F; }
        #indexPage #reserveArea ul li:nth-of-type(2) a:hover {
          color: #D65A2F;
          background: #fff; }
      #indexPage #reserveArea ul li:nth-of-type(3) a {
        background: #F58058;
        border-color: #F58058; }
        #indexPage #reserveArea ul li:nth-of-type(3) a:hover {
          color: #F58058;
          background: #fff; }
      #indexPage #reserveArea ul li:nth-of-type(4) a {
        background: #EE83C3;
        border-color: #EE83C3; }
        #indexPage #reserveArea ul li:nth-of-type(4) a:hover {
          color: #EE83C3;
          background: #fff; }
#indexPage #eventArea {
  margin: 0 0 30px; }
  #indexPage #eventArea .swiper-container {
    padding: 0 0 50px; }
    #indexPage #eventArea .swiper-container .swiper-wrapper .thumbnail {
      overflow: hidden;
      max-height: 158px;
      margin-bottom: 15px; }
      #indexPage #eventArea .swiper-container .swiper-wrapper .thumbnail a {
        position: relative;
        width: 100%;
        display: block;
        overflow: hidden; }
        #indexPage #eventArea .swiper-container .swiper-wrapper .thumbnail a:before {
          content: "";
          display: block;
          padding-top: 60%; }
        #indexPage #eventArea .swiper-container .swiper-wrapper .thumbnail a img {
          width: 100%;
          height: auto;
          position: absolute;
          top: 0;
          left: 0;
          bottom: 0;
          right: 0; }
    #indexPage #eventArea .swiper-container .swiper-wrapper .period {
      margin-bottom: 10px; }
      #indexPage #eventArea .swiper-container .swiper-wrapper .period p {
        color: #222;
        font-size: 12px;
        margin: 0; }
    #indexPage #eventArea .swiper-container .swiper-wrapper .permalink a {
      font-size: 16px;
      font-weight: bold;
      color: #222;
      text-decoration: none;
      margin: 0; }
      #indexPage #eventArea .swiper-container .swiper-wrapper .permalink a:hover {
        color: #22B3DC; }
#indexPage #adsenseArea {
  margin: 0 0 30px; }
  #indexPage #adsenseArea .adsenseBoxWrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    #indexPage #adsenseArea .adsenseBoxWrap .adsenseBox {
      flex-basis: 100%;
      width: 100%;
      margin-bottom: 15px; }
      #indexPage #adsenseArea .adsenseBoxWrap .adsenseBox a img {
        display: inline; }
        #indexPage #adsenseArea .adsenseBoxWrap .adsenseBox a img:first-of-type {
          width: 100%; }
      #indexPage #adsenseArea .adsenseBoxWrap .adsenseBox img {
        display: inherit; }
#indexPage #bannerArea {
  margin-bottom: 50px; }
  #indexPage #bannerArea .bannerList {
    display: flex;
    flex-wrap: wrap; }
    #indexPage #bannerArea .bannerList .bannerBox {
      flex-basis: 100%;
      margin-bottom: 10px; }
      #indexPage #bannerArea .bannerList .bannerBox:last-of-type {
        margin-bottom: 0; }
      #indexPage #bannerArea .bannerList .bannerBox a {
        display: block;
        width: 100%; }
        #indexPage #bannerArea .bannerList .bannerBox a img {
          width: 100%;
          height: auto; }
#indexPage #frArea {
  margin-bottom: 30px; }
  #indexPage #frArea #frFlex {
    display: flex;
    flex-wrap: wrap; }
  #indexPage #frArea #featureArea {
    flex-basis: 100%;
    margin-bottom: 40px; }
  #indexPage #frArea #recommendArea {
    flex-basis: 100%;
    margin-bottom: 40px; }
    #indexPage #frArea #recommendArea h3 {
      border-left: 2px solid #22B3DC;
      min-height: 30px;
      color: #222;
      font-weight: bold;
      font-size: 16px;
      padding: 3px 0 0 15px;
      margin: 0 0 30px; }
    #indexPage #frArea #recommendArea .rcListWrap {
      display: flex;
      flex-wrap: wrap;
      align-items: flex-start;
      justify-content: space-between; }
    #indexPage #frArea #recommendArea .rcListBox {
      flex-basis: 48%;
      margin-bottom: 15px; }
      #indexPage #frArea #recommendArea .rcListBox .thumbnail {
        flex-basis: 100%;
        width: 100%;
        margin-bottom: 10px; }
        #indexPage #frArea #recommendArea .rcListBox .thumbnail a {
          position: relative;
          width: 100%;
          overflow: hidden;
          display: block; }
          #indexPage #frArea #recommendArea .rcListBox .thumbnail a:before {
            content: "";
            display: block;
            padding-top: 60%; }
          #indexPage #frArea #recommendArea .rcListBox .thumbnail a img {
            width: 100%;
            height: auto;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0; }
      #indexPage #frArea #recommendArea .rcListBox .rcListCnt {
        flex-basis: 100%; }
        #indexPage #frArea #recommendArea .rcListBox .rcListCnt time {
          font-size: 12px;
          color: #222;
          display: block;
          margin-bottom: 5px; }
        #indexPage #frArea #recommendArea .rcListBox .rcListCnt .permaLinkWrap {
          line-height: 1.2; }
          #indexPage #frArea #recommendArea .rcListBox .rcListCnt .permaLinkWrap a {
            font-size: 14px;
            font-weight: bold;
            color: #222;
            text-decoration: none;
            line-height: 1.2; }
            #indexPage #frArea #recommendArea .rcListBox .rcListCnt .permaLinkWrap a:hover {
              color: #22B3DC; }
      #indexPage #frArea #recommendArea .rcListBox:nth-of-type(5), #indexPage #frArea #recommendArea .rcListBox:nth-of-type(6) {
        display: none; }
#indexPage #areaNaviArea {
  margin-bottom: 30px; }
  #indexPage #areaNaviArea .areaNaviBg {
    background: url("images/home/areabg.jpg") no-repeat;
    background-position: center center;
    background-size: 100% auto;
    position: relative;
    width: 100%;
    display: block;
    overflow: hidden; }
    #indexPage #areaNaviArea .areaNaviBg:before {
      content: "";
      display: block;
      padding-top: 38%; }
  #indexPage #areaNaviArea .heading {
    background: #22B3DC; }
    #indexPage #areaNaviArea .heading .areaNaviHeadWrap {
      height: 100px;
      display: flex;
      align-items: center; }
      #indexPage #areaNaviArea .heading .areaNaviHeadWrap h2 {
        margin: 0;
        padding: 0;
        background: none;
        color: #fff;
        font-weight: bold;
        font-size: 18px;
        min-height: inherit; }
  #indexPage #areaNaviArea .areaNaviWrap {
    background: #22B3DC;
    padding-bottom: 30px;
    z-index: 1; }
  #indexPage #areaNaviArea .areaNavi {
    background: #fff; }
    #indexPage #areaNaviArea .areaNavi ul {
      margin: 0;
      padding: 0;
      display: flex;
      flex-wrap: wrap; }
      #indexPage #areaNaviArea .areaNavi ul > li {
        position: relative;
        flex-basis: 50%;
        height: 50px;
        list-style: none;
        border: none; }
        #indexPage #areaNaviArea .areaNavi ul > li:hover a {
          color: #fff;
          background: #22B3DC;
          cursor: pointer; }
        #indexPage #areaNaviArea .areaNavi ul > li > a {
          display: flex;
          align-items: center;
          justify-content: center;
          color: #222;
          text-decoration: none;
          font-size: 18px;
          font-weight: bold;
          line-height: 1.2;
          padding: 0 30px 0 10px;
          width: 100%;
          min-height: 50px;
          border-bottom: 1px solid #E6E6E6;
          border-right: 1px solid #E6E6E6; }
          #indexPage #areaNaviArea .areaNavi ul > li > a.active {
            background: #22B3DC;
            color: #fff;
            cursor: pointer; }
        #indexPage #areaNaviArea .areaNavi ul > li.children > a {
          position: relative;
          pointer-events: none; }
          #indexPage #areaNaviArea .areaNavi ul > li.children > a:before {
            position: absolute;
            font: 16px FontAwesome;
            font-weight: 100;
            content: '\f196';
            top: 0;
            right: 0;
            transition: .3s ease;
            display: flex;
            width: 30px;
            height: 50px;
            align-items: center;
            justify-content: center;
            color: #222; }
        #indexPage #areaNaviArea .areaNavi ul > li.children:nth-child(even) ul.sub-menu {
          left: -100%; }
        #indexPage #areaNaviArea .areaNavi ul > li.children ul.sub-menu {
          background: #fff;
          position: absolute;
          width: 200%;
          display: none;
          z-index: 1;
          border-left: 1px solid #E6E6E6; }
          #indexPage #areaNaviArea .areaNavi ul > li.children ul.sub-menu > li {
            display: flex;
            align-items: center; }
            #indexPage #areaNaviArea .areaNavi ul > li.children ul.sub-menu > li a {
              font-size: 16px;
              background: #22B3DC;
              font-weight: normal;
              position: relative;
              color: #fff; }
              #indexPage #areaNaviArea .areaNavi ul > li.children ul.sub-menu > li a:hover {
                color: #22B3DC;
                background: #fff; }
        #indexPage #areaNaviArea .areaNavi ul > li.children.active {
          cursor: pointer;
          z-index: 2; }
          #indexPage #areaNaviArea .areaNavi ul > li.children.active > a {
            background: #22B3DC;
            color: #fff; }
            #indexPage #areaNaviArea .areaNavi ul > li.children.active > a:before {
              color: #fff;
              font: 16px FontAwesome;
              content: '\f147'; }
        #indexPage #areaNaviArea .areaNavi ul > li.children:hover {
          cursor: pointer;
          z-index: 2; }
          #indexPage #areaNaviArea .areaNavi ul > li.children:hover > a:before {
            color: #fff;
            font: 16px FontAwesome; }
        #indexPage #areaNaviArea .areaNavi ul > li:last-child {
          flex-basis: 100%;
          border: none; }
          #indexPage #areaNaviArea .areaNavi ul > li:last-child ul.sub-menu {
            width: 100%; }
#indexPage #bottomBannerArea {
  margin-bottom: 40px; }
  #indexPage #bottomBannerArea .bannerBox {
    margin-bottom: 30px; }
    #indexPage #bottomBannerArea .bannerBox:last-of-type {
      margin-bottom: 0; }
    #indexPage #bottomBannerArea .bannerBox a {
      display: block; }
#indexPage #pageLinkArea {
  border-top: 1px solid #E6E6E6;
  padding: 30px 0 15px; }
  #indexPage #pageLinkArea .pageLinkList {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
  #indexPage #pageLinkArea .pageLinkBox {
    flex-basis: 100%;
    margin-bottom: 15px; }
    #indexPage #pageLinkArea .pageLinkBox a {
      align-self: center;
      display: flex;
      align-items: center;
      justify-content: center;
      height: 60px;
      background: #22B3DC;
      color: #fff;
      font-weight: bold;
      font-size: 18px;
      text-align: center;
      border: 1px solid #22B3DC; }
      #indexPage #pageLinkArea .pageLinkBox a:hover {
        color: #22B3DC;
        background: #fff; }
#indexPage #cBnrArea {
  border-top: 1px solid #E6E6E6;
  padding: 40px 0 10px; }
  #indexPage #cBnrArea .swiper-container {
    padding: 0 0 50px; }
    #indexPage #cBnrArea .swiper-container .swiper-wrapper .thumbnail {
      overflow: hidden;
      max-height: 100%;
      border: 1px solid #E6E6E6;
      margin-bottom: 0;
      position: relative; }
      #indexPage #cBnrArea .swiper-container .swiper-wrapper .thumbnail a {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 10px; }
        #indexPage #cBnrArea .swiper-container .swiper-wrapper .thumbnail a:before {
          content: "";
          display: block;
          padding-top: 60%; }
    #indexPage #cBnrArea .swiper-container .swiper-wrapper .swiper-pagination {
      bottom: 15px; }
@media print, screen and (min-width: 768px) {
  #indexPage #asArea {
    margin-bottom: 30px; }
    #indexPage #asArea #aboutArea {
      margin-bottom: 30px; }
    #indexPage #asArea #searchArea {
      padding: 5px 0 5px 15px; }
      #indexPage #asArea #searchArea #searchForm {
        flex-wrap: nowrap; }
        #indexPage #asArea #searchArea #searchForm p {
          margin: 18px 0 10px 0;
          flex-basis: 190px; }
        #indexPage #asArea #searchArea #searchForm form {
          flex-wrap: nowrap;
          justify-content: space-between; }
          #indexPage #asArea #searchArea #searchForm form .selectCustom {
            flex-basis: 30%;
            margin-bottom: 0; }
            #indexPage #asArea #searchArea #searchForm form .selectCustom select {
              border-radius: 4px 0 0 4px;
              margin: 3px 0 0 0;
              height: 54px; }
          #indexPage #asArea #searchArea #searchForm form input[type="text"] {
            flex-basis: auto;
            flex-grow: 2;
            border-radius: 0px 4px 4px 0px;
            margin: 3px 0 0 0;
            height: 54px; }
          #indexPage #asArea #searchArea #searchForm form input[type="submit"] {
            flex-basis: 60px;
            width: 60px; }
  #indexPage #reserveArea {
    margin: 0 0 50px; }
    #indexPage #reserveArea ul {
      flex-wrap: nowrap;
      overflow: hidden; }
      #indexPage #reserveArea ul li {
        list-style: none;
        flex-basis: 25%;
        height: 60px; }
        #indexPage #reserveArea ul li:nth-of-type(1) a {
          border-radius: 60px 0 0 60px; }
        #indexPage #reserveArea ul li:nth-of-type(4) a {
          border-radius: 0 60px 60px 0; }
  #indexPage #bannerArea .bannerList .bannerBox {
    margin-bottom: 20px; }
  #indexPage #frArea #recommendArea .rcListBox {
    flex-basis: 48%;
    margin-bottom: 20px;
    display: flex;
    justify-content: space-between; }
    #indexPage #frArea #recommendArea .rcListBox .thumbnail {
      flex-basis: 140px;
      width: auto;
      margin-bottom: 0; }
    #indexPage #frArea #recommendArea .rcListBox .rcListCnt {
      flex-basis: calc( 100% - 150px ); }
    #indexPage #frArea #recommendArea .rcListBox:nth-of-type(5), #indexPage #frArea #recommendArea .rcListBox:nth-of-type(6) {
      display: inline-flex; }
  #indexPage #areaNaviArea {
    margin-bottom: 60px; }
    #indexPage #areaNaviArea .areaNaviBg {
      height: 240px;
      background-position: center center;
      background-size: 992px; }
      #indexPage #areaNaviArea .areaNaviBg:before {
        display: none; }
    #indexPage #areaNaviArea .areaNavi ul > li {
      flex-basis: 25%; }
      #indexPage #areaNaviArea .areaNavi ul > li:last-of-type {
        flex-basis: 25%; }
      #indexPage #areaNaviArea .areaNavi ul > li.sub:nth-child(even) ul.sub-menu {
        left: 0; }
      #indexPage #areaNaviArea .areaNavi ul > li.sub ul.sub-menu {
        width: 100%;
        border-top: none; }
  #indexPage #pageLinkArea {
    padding: 40px 0 25px; }
    #indexPage #pageLinkArea .pageLinkList {
      flex-wrap: wrap; }
      #indexPage #pageLinkArea .pageLinkList:after {
        content: "";
        display: block;
        width: 31%; }
    #indexPage #pageLinkArea .pageLinkBox {
      flex-basis: 31%; } }
@media print, screen and (min-width: 992px) {
  #indexPage #asArea #asFlex {
    flex-wrap: nowrap;
    justify-content: space-between; }
  #indexPage #asArea #aboutArea {
    flex-basis: 240px;
    margin-bottom: 0; }
  #indexPage #asArea #searchArea {
    flex-basis: calc( 100% - 270px); }
  #indexPage #eventArea {
    margin: 0 0 50px; }
    #indexPage #eventArea .swiper-container {
      padding: 0 0 50px; }
    #indexPage #eventArea .swiper-pagination {
      bottom: 0; }
  #indexPage #adsenseArea .adsenseBoxWrap .adsenseBox {
    flex-basis: 48%;
    width: 48%; }
  #indexPage #bannerArea .bannerList {
    justify-content: space-between; }
    #indexPage #bannerArea .bannerList .bannerBox {
      flex-basis: calc( 50% - 15px ); }
  #indexPage #frArea #frFlex {
    flex-wrap: nowrap;
    justify-content: space-between; }
  #indexPage #frArea #featureArea {
    flex-basis: calc( 100% - 330px); }
  #indexPage #frArea #recommendArea {
    flex-basis: 300px; }
    #indexPage #frArea #recommendArea .rcListBox {
      flex-basis: 100%;
      margin-bottom: 25px; }
      #indexPage #frArea #recommendArea .rcListBox .rcListCnt {
        flex-basis: calc( 100% - 150px ); }
  #indexPage #areaNaviArea .areaNaviBg {
    height: 260px;
    background-position: center center;
    background-size: 1200px;
    z-index: -1; }
  #indexPage #areaNaviArea .areaNaviWrap {
    background: #22B3DC;
    width: 100%;
    position: relative;
    padding-bottom: 0; }
  #indexPage #areaNaviArea .areaNavi {
    border: none;
    width: 940px;
    margin: 0 auto;
    transform: translateY(-30px); }
    #indexPage #areaNaviArea .areaNavi ul > li {
      flex-grow: 1; }
  #indexPage #pageLinkArea {
    padding: 60px 0 45px; } }
@media print, screen and (min-width: 1200px) {
  #indexPage #asArea #aboutArea {
    flex-basis: 390px;
    margin-bottom: 0; }
  #indexPage #asArea #searchArea {
    flex-basis: calc( 100% - 420px); }
  #indexPage #frArea #featureArea {
    flex-basis: calc( 100% - 360px); }
  #indexPage #areaNaviArea .areaNaviBg {
    height: 380px;
    background-size: cover; }
  #indexPage #areaNaviArea .areaNaviWrap {
    background: #22B3DC;
    width: 100%;
    position: relative;
    padding-bottom: 0;
    height: 120px; }
  #indexPage #areaNaviArea .areaNavi {
    width: 1140px;
    transform: translateY(-40px); }
    #indexPage #areaNaviArea .areaNavi ul {
      flex-wrap: nowrap; }
      #indexPage #areaNaviArea .areaNavi ul > li {
        flex-basis: calc( 100% / 7) !important;
        position: inherit;
        height: 80px; }
        #indexPage #areaNaviArea .areaNavi ul > li a {
          border: none;
          text-align: center;
          height: 80px;
          padding: 26px 0; }
        #indexPage #areaNaviArea .areaNavi ul > li.sub > a:before {
          height: 80px; }
        #indexPage #areaNaviArea .areaNavi ul > li.sub ul.sub-menu {
          width: 100%;
          height: 50px;
          border: none;
          border-top: 1px solid #e7e7e7;
          left: 0;
          top: 80px;
          background: #fff;
          overflow: hidden; }
          #indexPage #areaNaviArea .areaNavi ul > li.sub ul.sub-menu li {
            position: relative;
            flex-basis: auto;
            height: 50px;
            display: inline-block;
            border: none; }
            #indexPage #areaNaviArea .areaNavi ul > li.sub ul.sub-menu li a {
              height: 50px;
              color: #222;
              text-align: left;
              padding: 13px 15px 9px 15px;
              max-height: 50px;
              min-height: inherit;
              background: none;
              color: #222; } }
#indexPage .catListArea .listWrap {
  margin-bottom: 40px; }
#indexPage .postListWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0 0 30px; }
  #indexPage .postListWrap .postListBox {
    flex-basis: 48%;
    display: flex;
    flex-wrap: wrap; }
    #indexPage .postListWrap .postListBox .postListL {
      flex-basis: 100%;
      width: 100%;
      margin-bottom: 10px; }
      #indexPage .postListWrap .postListBox .postListL .thumbnail {
        margin-bottom: 10px; }
        #indexPage .postListWrap .postListBox .postListL .thumbnail a {
          position: relative;
          width: 100%;
          overflow: hidden;
          display: block; }
          #indexPage .postListWrap .postListBox .postListL .thumbnail a:before {
            content: "";
            display: block;
            padding-top: 60%; }
          #indexPage .postListWrap .postListBox .postListL .thumbnail a img {
            width: 100%;
            height: auto;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0; }
      #indexPage .postListWrap .postListBox .postListL .catList {
        margin: 0;
        padding: 0; }
        #indexPage .postListWrap .postListBox .postListL .catList li {
          list-style: none;
          display: inline-block;
          margin-bottom: 5px; }
          #indexPage .postListWrap .postListBox .postListL .catList li a {
            font-size: 10px;
            color: #22B3DC;
            text-decoration: none;
            display: block;
            height: 24px;
            padding: 0 15px;
            line-height: 24px;
            border: 1px solid #22B3DC;
            border-radius: 24px; }
            #indexPage .postListWrap .postListBox .postListL .catList li a:hover {
              color: #fff;
              background: #22B3DC; }
    #indexPage .postListWrap .postListBox .postListR .permaLinkWrap {
      margin: 0 0 15px; }
      #indexPage .postListWrap .postListBox .postListR .permaLinkWrap a {
        font-size: 14px;
        color: #333;
        text-decoration: none;
        margin: 0;
        display: block;
        font-weight: bold; }
        #indexPage .postListWrap .postListBox .postListR .permaLinkWrap a:hover {
          color: #22B3DC; }
    #indexPage .postListWrap .postListBox .postListR .excerpt {
      margin: 0 0 15px;
      display: none; }
      #indexPage .postListWrap .postListBox .postListR .excerpt p {
        font-size: 14px;
        margin: 0; }
    #indexPage .postListWrap .postListBox .postListR .tags .postTag {
      margin: 0;
      padding: 0; }
      #indexPage .postListWrap .postListBox .postListR .tags .postTag li {
        list-style: none;
        display: inline-block;
        margin: 0 15px 0 0;
        border-radius: 25%;
        min-height: 24px;
        text-align: center; }
        #indexPage .postListWrap .postListBox .postListR .tags .postTag li a {
          display: block;
          width: 100%;
          height: auto;
          font-size: 10px;
          color: #333;
          background: #F9F8F2;
          border-radius: 24px;
          padding: 2px 15px;
          text-decoration: none; }
          #indexPage .postListWrap .postListBox .postListR .tags .postTag li a:hover {
            background: #22B3DC;
            color: #fff; }
    #indexPage .postListWrap .postListBox:first-of-type {
      flex-basis: 100%;
      margin-bottom: 30px; }
      #indexPage .postListWrap .postListBox:first-of-type .postListR .permaLinkWrap a {
        font-size: 16px; }
      #indexPage .postListWrap .postListBox:first-of-type .postListR .excerpt {
        display: inherit; }
    #indexPage .postListWrap .postListBox:nth-of-type(4) {
      display: none; }
  @media print, screen and (min-width: 768px) {
    #indexPage .postListWrap:after {
      content: "";
      display: block;
      width: 30%; }
    #indexPage .postListWrap .postListBox {
      flex-basis: 31%;
      display: flex;
      flex-wrap: wrap;
      align-items: flex-start; }
      #indexPage .postListWrap .postListBox:after {
        content: "";
        display: block;
        width: 30%; }
      #indexPage .postListWrap .postListBox:first-of-type {
        flex-basis: 100%;
        justify-content: space-between; }
        #indexPage .postListWrap .postListBox:first-of-type .postListL {
          flex-basis: 480px;
          margin-bottom: 0; }
          #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail {
            width: 100%; }
            #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a {
              position: relative;
              width: 100%;
              overflow: hidden; }
              #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a:before {
                content: "";
                display: block;
                padding-top: 60%; }
              #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a img {
                width: 100%;
                height: auto;
                position: absolute;
                top: 0;
                left: 0;
                bottom: 0;
                right: 0; }
        #indexPage .postListWrap .postListBox:first-of-type .postListR {
          flex-basis: calc( 100% - 510px); }
      #indexPage .postListWrap .postListBox:nth-of-type(4) {
        display: inline-flex; } }
  @media print, screen and (min-width: 992px) {
    #indexPage .postListWrap .postListBox:first-of-type {
      flex-basis: 100%;
      justify-content: space-between; }
      #indexPage .postListWrap .postListBox:first-of-type .postListL {
        flex-basis: 400px; }
        #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a {
          position: relative;
          width: 100%;
          overflow: hidden; }
          #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a:before {
            content: "";
            display: block;
            padding-top: 60%; }
          #indexPage .postListWrap .postListBox:first-of-type .postListL .thumbnail a img {
            width: 100%;
            height: auto;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0; }
      #indexPage .postListWrap .postListBox:first-of-type .postListR {
        flex-basis: calc( 100% - 420px); } }
  @media print, screen and (min-width: 1200px) {
    #indexPage .postListWrap .postListBox:first-of-type .postListL {
      flex-basis: 510px; }
    #indexPage .postListWrap .postListBox:first-of-type .postListR {
      flex-basis: calc( 100% - 540px); } }

/* ---------------------------------------------------------------- */
/* カテゴリ一覧共通 */
/* ---------------------------------------------------------------- */
#cntsCatList {
  margin-bottom: 50px; }

.catListPage h1 {
  font-size: 20px;
  font-weight: bold;
  color: #222;
  margin: 0 0 30px;
  padding: 0; }
.catListPage .postListWrap {
  margin: 0 0 30px; }
  .catListPage .postListWrap .postListBox {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: solid 1px #E6E6E6; }
    .catListPage .postListWrap .postListBox .postListL {
      flex-basis: 100%;
      width: 100%;
      margin-bottom: 10px; }
      .catListPage .postListWrap .postListBox .postListL .thumbnail {
        margin-bottom: 10px; }
        .catListPage .postListWrap .postListBox .postListL .thumbnail a {
          position: relative;
          width: 100%;
          overflow: hidden;
          display: block; }
          .catListPage .postListWrap .postListBox .postListL .thumbnail a:before {
            content: "";
            display: block;
            padding-top: 60%; }
          .catListPage .postListWrap .postListBox .postListL .thumbnail a img {
            width: 100%;
            height: auto;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0; }
    .catListPage .postListWrap .postListBox .postListR {
      flex-basis: 100%; }
      .catListPage .postListWrap .postListBox .postListR .postMeta {
        display: flex;
        flex-basis: auto;
        align-items: center; }
        .catListPage .postListWrap .postListBox .postListR .postMeta time {
          margin-right: 15px; }
        .catListPage .postListWrap .postListBox .postListR .postMeta .catList {
          margin: 0;
          padding: 0; }
          .catListPage .postListWrap .postListBox .postListR .postMeta .catList li {
            list-style: none;
            display: inline-block; }
            .catListPage .postListWrap .postListBox .postListR .postMeta .catList li a {
              font-size: 10px;
              color: #22B3DC;
              text-decoration: none;
              display: block;
              height: 24px;
              padding: 0 15px;
              line-height: 24px;
              border: 1px solid #22B3DC;
              border-radius: 24px; }
              .catListPage .postListWrap .postListBox .postListR .postMeta .catList li a:hover {
                color: #fff;
                background: #22B3DC; }
      .catListPage .postListWrap .postListBox .postListR .permaLinkWrap {
        margin: 0 0 15px; }
        .catListPage .postListWrap .postListBox .postListR .permaLinkWrap h2 {
          background: none; }
          .catListPage .postListWrap .postListBox .postListR .permaLinkWrap h2 a {
            font-size: 14px;
            color: #333;
            text-decoration: none;
            margin: 0;
            display: block;
            font-weight: bold; }
            .catListPage .postListWrap .postListBox .postListR .permaLinkWrap h2 a:hover {
              color: #22B3DC; }
      .catListPage .postListWrap .postListBox .postListR .excerpt {
        margin: 0 0 15px;
        display: none; }
        .catListPage .postListWrap .postListBox .postListR .excerpt p {
          font-size: 14px;
          margin: 0; }
      .catListPage .postListWrap .postListBox .postListR .tags .postTag {
        margin: 0;
        padding: 0; }
        .catListPage .postListWrap .postListBox .postListR .tags .postTag li {
          list-style: none;
          display: inline-block;
          margin: 0 15px 0 0;
          border-radius: 25%;
          min-height: 24px;
          text-align: center; }
          .catListPage .postListWrap .postListBox .postListR .tags .postTag li a {
            display: block;
            width: 100%;
            height: auto;
            font-size: 10px;
            color: #333;
            background: #F9F8F2;
            border-radius: 24px;
            padding: 2px 15px;
            text-decoration: none; }
            .catListPage .postListWrap .postListBox .postListR .tags .postTag li a:hover {
              background: #22B3DC;
              color: #fff; }
  @media print, screen and (min-width: 768px) {
    .catListPage .postListWrap .postListBox {
      flex-wrap: nowrap;
      justify-content: space-between;
      margin-bottom: 15px;
      padding-bottom: 15px;
      border-bottom: solid 1px #E6E6E6; }
      .catListPage .postListWrap .postListBox .postListL {
        flex-basis: 270px;
        width: 270px;
        margin-bottom: 10px; }
        .catListPage .postListWrap .postListBox .postListL .thumbnail {
          margin-bottom: 0;
          width: 240px; }
      .catListPage .postListWrap .postListBox .postListR {
        width: auto;
        flex-basis: auto;
        flex: 1 10 auto; } }
.catListPage .catListPage .btnWrap {
  margin: 50px 0 0; }

/* ---------------------------------------------------------------- */
/* サイドバー  */
/* ---------------------------------------------------------------- */
#sideArea .widget-area {
  display: none; }
#sideArea .widget {
  margin-bottom: 40px; }
  #sideArea .widget img {
    max-width: 100%; }
#sideArea .widgetTitle {
  border-left: 2px solid #22B3DC;
  min-height: 30px;
  color: #222;
  font-weight: bold;
  font-size: 16px;
  padding: 3px 0 0 15px;
  margin: 0 0 15px; }
#sideArea .widget_categories .screen-reader-text {
  display: none; }
#sideArea .widget_categories form {
  width: 100%;
  position: relative; }
  #sideArea .widget_categories form::after {
    position: absolute;
    top: calc( 50% - 3px );
    right: 4px;
    width: 0;
    height: 0;
    padding: 0;
    content: '';
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #22B3DC;
    pointer-events: none; }
  #sideArea .widget_categories form select {
    width: 100%;
    cursor: pointer;
    text-indent: 0.01px;
    text-overflow: ellipsis;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    padding-left: 15px;
    height: 30px;
    font-size: 12px;
    border-color: #E6E6E6; }
    #sideArea .widget_categories form select option {
      font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }
    #sideArea .widget_categories form select::-ms-expand {
      display: none; }
#sideArea .widget_tag_cloud {
  background: #fff;
  margin-bottom: 30px; }
  #sideArea .widget_tag_cloud a {
    font-size: 12px !important;
    line-height: 1em;
    background: #F9F8F2;
    color: #222;
    display: inline-block;
    white-space: nowrap;
    padding: 7px 15px;
    border-radius: 26px;
    text-decoration: none;
    margin-bottom: 10px; }
    #sideArea .widget_tag_cloud a:hover {
      background: #22B3DC;
      color: #fff; }
#sideArea .popular-posts {
  background: #fff;
  padding: 0; }
  #sideArea .popular-posts .wpp-list {
    margin: 0;
    padding: 0; }
    #sideArea .popular-posts .wpp-list .sideRankBox {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      min-height: 60px;
      margin-bottom: 10px;
      counter-increment: number; }
      #sideArea .popular-posts .wpp-list .sideRankBox:last-of-type {
        margin-bottom: 0; }
      #sideArea .popular-posts .wpp-list .sideRankBox .sideRankThumb {
        flex-basis: 115px;
        position: relative; }
        #sideArea .popular-posts .wpp-list .sideRankBox .sideRankThumb a {
          display: block; }
          #sideArea .popular-posts .wpp-list .sideRankBox .sideRankThumb a img {
            max-width: 96px;
            height: 64px;
            width: auto;
            margin: 0 0 0 18px; }
        #sideArea .popular-posts .wpp-list .sideRankBox .sideRankThumb:before {
          width: 18px;
          height: 64px;
          position: absolute;
          top: 0;
          left: 0;
          z-index: 1;
          background: #22B3DC;
          display: flex;
          align-items: center;
          justify-content: center;
          font-size: 14px;
          color: #fff;
          content: counter(number); }
      #sideArea .popular-posts .wpp-list .sideRankBox .sideRankCnt {
        flex-basis: calc( 100% - 125px);
        position: relative; }
        #sideArea .popular-posts .wpp-list .sideRankBox .sideRankCnt .sideRankTitle a {
          text-decoration: none;
          color: #222;
          font-size: 14px;
          font-weight: bold;
          text-decoration: none;
          display: block;
          line-height: 1.4; }
          #sideArea .popular-posts .wpp-list .sideRankBox .sideRankCnt .sideRankTitle a:hover {
            color: #22B3DC; }
        #sideArea .popular-posts .wpp-list .sideRankBox .sideRankCnt .view {
          display: block;
          position: absolute;
          bottom: 0;
          right: 0;
          text-align: right;
          font-size: 12px; }
#sideArea .instagram-feed {
  margin-bottom: 40px; }
  #sideArea .instagram-feed .widgetTitle {
    margin-bottom: 25px; }
#sideArea .side-news .newsListBox {
  margin-bottom: 30px; }
  #sideArea .side-news .newsListBox:last-of-type {
    margin-bottom: 0; }
  #sideArea .side-news .newsListBox .newsListMeta {
    display: flex;
    align-items: center;
    margin-bottom: 10px; }
    #sideArea .side-news .newsListBox .newsListMeta time {
      font-size: 12px;
      color: #222;
      margin-right: 30px; }
    #sideArea .side-news .newsListBox .newsListMeta .catName {
      font-size: 10px;
      display: block;
      height: 24px;
      padding: 4px 0 0 0;
      min-width: 86px;
      border: 1px solid #E6E6E6;
      margin: 0;
      text-align: center; }
  #sideArea .side-news .newsListBox a.permaLink {
    font-weight: bold; }
#sideArea .widget_media_image img {
  width: 100%;
  height: auto; }

/* ---------------------------------------------------------------- */
/* ページ・シングル */
/* ---------------------------------------------------------------- */
#cnts {
  margin-bottom: 50px;
  width: 100%;
  /* 赤ボタン単品 */ }
  #cnts #mainColumn {
    margin: 20px 0;
    min-height: 300px; }
  #cnts h1 {
    font-size: 20px;
    font-weight: bold;
    color: #222;
    margin: 0 0 20px;
    padding: 0; }
  #cnts h2 {
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    margin: 15px 0 35px;
    padding: 10px 15px 10px 15px;
    background: #22B3DC;
    position: relative;
    min-height: 50px; }
    #cnts h2:before {
      content: "";
      position: absolute;
      top: 100%;
      left: 15px;
      border: 10px solid transparent;
      border-top: 15px solid #22B3DC; }
    #cnts h2:first-of-type {
      margin: 0 0 30px; }
  #cnts h3 {
    font-size: 20px;
    font-weight: bold;
    margin: 15px 0 20px;
    color: #222222;
    padding: 0 0 5px;
    border-bottom: 1px solid #22B3DC; }
  #cnts h4 {
    font-size: 18px;
    font-weight: bold;
    margin: 15px 0 20px;
    color: #222;
    padding: 8px 15px 5px;
    min-height: 36px;
    background: #F0F2F2;
    display: block; }
  #cnts h5 {
    font-size: 16px;
    font-weight: normal;
    margin: 15px 0 20px;
    color: #222;
    padding: 5px 0 4px 15px;
    min-height: 30px;
    border-left: 2px solid #22B3DC; }
  #cnts h6 {
    font-size: 14px;
    font-weight: bold;
    margin: 15px 0 20px;
    color: #222;
    padding: 7px 0 6px 0;
    border-bottom: 1px solid #333; }
  #cnts h1, #cnts h2, #cnts h3, #cnts h4, #cnts h5, #cnts h6 {
    line-height: 1.2; }
  #cnts img {
    max-width: 100%;
    margin-bottom: 10px; }
  #cnts p {
    margin: 0 0 20px;
    text-align: justify;
    text-align: inter-ideograph; }
    #cnts p:last-of-type {
      margin-bottom: 30px; }
    #cnts p.tableAtt {
      margin: -20px 0 20px; }
    #cnts p img {
      margin-bottom: 0; }
  #cnts .bold {
    font-weight: bold; }
  #cnts .coming {
    text-align: center;
    margin: 50px 0;
    font-size: 16px; }
  #cnts .small {
    font-size: 14px; }
  #cnts .box {
    margin-bottom: 50px; }
  #cnts .textLeft {
    text-align: left; }
  #cnts .textCenter {
    text-align: center; }
  #cnts .textRight {
    text-align: right; }
  #cnts pre {
    overflow: auto;
    background: #eee;
    padding: 5px;
    border-radius: 8px; }
  #cnts a {
    position: relative;
    text-decoration: underline;
    color: #22B3DC; }
    #cnts a:hover, #cnts a:focus {
      text-decoration: none;
      color: #22B3DC; }
    #cnts a.textBlank {
      position: relative;
      margin-right: 30px;
      display: inline-block; }
      #cnts a.textBlank:before {
        content: '\f08e';
        position: absolute;
        display: block;
        font: 14px/1 FontAwesome;
        right: -25px;
        top: 5px; }
    #cnts a.textArrow {
      text-decoration: none;
      color: #22B3DC; }
      #cnts a.textArrow:hover {
        color: #ff977d;
        text-decoration: underline; }
      #cnts a.textArrow:after {
        display: inline-block;
        content: '\f0a9';
        font: 16px/1 FontAwesome;
        margin-left: 10px;
        text-decoration: none; }
    #cnts a.textArrowR {
      text-decoration: none;
      color: #ff977d; }
      #cnts a.textArrowR:hover, #cnts a.textArrowR:focus {
        color: #22B3DC;
        text-decoration: underline; }
      #cnts a.textArrowR:after {
        display: inline-block;
        content: '\f0a9';
        font: 16px/1 FontAwesome;
        margin-left: 10px;
        text-decoration: none; }
    #cnts a.btn {
      text-decoration: none; }
  #cnts .returnBtn {
    text-decoration: none;
    background: #22B3DC;
    color: #fff; }
    #cnts .returnBtn:hover {
      color: #22B3DC;
      background: #fff; }
    #cnts .returnBtn.arrow:after {
      color: #fff; }
    #cnts .returnBtn.arrow:hover:after {
      color: #22B3DC; }
  #cnts .textBlue {
    color: #22B3DC; }
  #cnts table {
    margin: 0 0 30px;
    width: 100%;
    border-collapse: collapse; }
    #cnts table caption {
      font-size: 18px;
      color: #22B3DC;
      font-weight: bold;
      text-align: left;
      margin: 0; }
    #cnts table tr th, #cnts table tr td {
      display: block;
      min-height: 30px;
      padding: .5em .8em;
      width: auto;
      line-height: 1.4; }
    #cnts table tr th {
      font-weight: normal;
      text-align: left;
      vertical-align: top;
      background-color: #EFEFEF; }
  #cnts blockquote {
    background: #ddd;
    width: 100%;
    border-radius: 8px;
    padding: 30px;
    margin: 0 0 60px;
    position: relative; }
    #cnts blockquote:before {
      content: '\f10d';
      position: absolute;
      display: block;
      font: 20px/1 FontAwesome;
      color: #22B3DC;
      left: 10px;
      top: 10px; }
    #cnts blockquote:after {
      content: '\f10e';
      position: absolute;
      display: block;
      font: 20px/1 FontAwesome;
      color: #22B3DC;
      right: 10px; }
    #cnts blockquote p {
      margin: 0 0 15px; }
      #cnts blockquote p:last-child {
        margin-bottom: 0; }
  #cnts dl {
    margin: 0 0 30px; }
    #cnts dl dt {
      font-weight: bold; }
    #cnts dl dd {
      margin: 0;
      margin-bottom: 15px; }
  #cnts ul {
    margin: 0 0 20px 5px;
    padding: 0; }
    #cnts ul li {
      list-style: none;
      position: relative;
      padding: 0 0 0 20px; }
      #cnts ul li:before {
        position: absolute;
        left: 0;
        top: 8px;
        content: '';
        width: 10px;
        height: 10px;
        background: #222;
        border-radius: 50%;
        margin-right: 8px; }
      #cnts ul li ul {
        padding: 0; }
    #cnts ul.numList {
      margin: 0 0 30px;
      padding: 0; }
      #cnts ul.numList li {
        list-style: none;
        position: relative;
        padding: 0;
        display: flex;
        margin-bottom: 15px; }
        #cnts ul.numList li .num {
          line-height: 1;
          display: flex;
          align-items: center;
          justify-content: center;
          flex-basis: 40px;
          width: 40px;
          height: 40px;
          font-size: 18px;
          margin-right: 15px;
          color: #fff;
          background: #009C6F;
          border-radius: 100%; }
        #cnts ul.numList li span:nth-of-type(2) {
          flex-basis: calc( 100% - 55px );
          align-self: center; }
        #cnts ul.numList li:before {
          display: none; }
  #cnts ol {
    margin: 0 0 20px;
    padding: 0 0 0 25px; }
    #cnts ol li {
      margin: 0;
      padding: 0; }
      #cnts ol li:last-child {
        margin: 0 0 10px; }
      #cnts ol li ol {
        margin: 10px 0;
        padding: 0 0 0 20px; }
  #cnts address {
    font-style: normal; }
  #cnts hr.red {
    border-bottom: 1px solid #C65871 !important;
    margin-bottom: 50px; }
  #cnts #toc_container {
    color: #22B3DC;
    border-color: #22B3DC;
    margin: 0 0 30px; }
    #cnts #toc_container .toc_title {
      font-size: 16px;
      margin-bottom: 0; }
    #cnts #toc_container a {
      text-decoration: none; }
      #cnts #toc_container a:hover {
        color: #ff977d; }
    #cnts #toc_container ul li {
      list-style: none;
      font-size: 14px;
      margin-bottom: 5px; }
      #cnts #toc_container ul li:before {
        display: none;
        font-size: 14px; }
  #cnts .gmapWrap {
    position: relative;
    width: 100%; }
    #cnts .gmapWrap iframe {
      width: 100%;
      height: 300px; }
  #cnts .adsbygoogle {
    max-width: 100%;
    width: 100%; }
  #cnts .red-btn {
    box-shadow: 2px 2px 2px #555;
    font-size: 16px;
    text-align: center;
    /*ボタンの中央配置 */
    margin: 0px auto 0px auto;
    /*ボタンの上右下左の余白 */
    max-width: 300px;
    /*ボタンの横幅 */
    text-align: center;
    /*ボタン内の文字中央寄せ */
    padding: 0;
    /*ボタン内文字の余白 */
    background-color: #ed254e;
    margin-right: auto;
    margin-left: auto;
    border-radius: 5px;
    /*ボタンの角を少し丸く */
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    font-weight: bold;
    /*ボタン内文字は太字 */
    color: #fff !important;
    /*ボタン内の文字色 */
    height: 30px;
    line-height: 30px; }
    #cnts .red-btn a {
      text-decoration: none !important;
      /*ボタン内テキストリンク下線無し */
      color: #fff !important;
      /*ボタン内の文字色 */
      display: block; }
  #cnts .box28 {
    position: relative;
    margin: 2em 0;
    padding: 25px 4px 7px;
    border: solid 2px #00B3E3; }
    #cnts .box28 .box-title {
      position: absolute;
      display: inline-block;
      top: -2px;
      left: -2px;
      padding: 0 9px;
      height: 25px;
      line-height: 25px;
      vertical-align: middle;
      font-size: 12px;
      background: #00B3E3;
      color: #ffffff;
      font-weight: bold; }
    #cnts .box28 p {
      margin: 0;
      padding: 0; }
    #cnts .box28 .red-btn a {
      font-size: 14px; }
  @media print, screen and (min-width: 768px) {
    #cnts .adsbygoogle {
      max-width: 720px; } }
  @media print, screen and (min-width: 992px) {
    #cnts table {
      border-top: 1px solid #E6E6E6; }
      #cnts table tr th, #cnts table tr td {
        display: table-cell;
        min-height: 30px;
        padding: .8em .8em;
        width: auto;
        border-bottom: 1px solid #E6E6E6; }
      #cnts table tr th {
        font-weight: normal;
        text-align: left;
        vertical-align: top;
        background: none; }
    #cnts .adsbygoogle {
      max-width: 610px; } }
  @media print, screen and (min-width: 1200px) {
    #cnts .adsbygoogle {
      max-width: 780px; } }

/* シングル */
.single #cnts .postHeader .MetaList {
  display: flex;
  margin: 0 0 15px; }
  .single #cnts .postHeader .MetaList time {
    margin-right: 10px; }
    .single #cnts .postHeader .MetaList time i {
      margin-right: 10px; }
  .single #cnts .postHeader .MetaList .author {
    margin-left: 10px; }
    .single #cnts .postHeader .MetaList .author i {
      margin-right: 10px; }
.single #cnts .postHeader .catList {
  margin: 0 0 10px; }
  .single #cnts .postHeader .catList ul {
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap; }
    .single #cnts .postHeader .catList ul li {
      list-style: none;
      padding: 0;
      margin: 0 10px 5px 0;
      display: inline-flex; }
      .single #cnts .postHeader .catList ul li:before {
        display: none; }
      .single #cnts .postHeader .catList ul li a {
        font-size: 10px;
        color: #22B3DC;
        text-decoration: none;
        display: block;
        height: 24px;
        padding: 0 15px;
        line-height: 24px;
        border: 1px solid #22B3DC;
        border-radius: 24px; }
        .single #cnts .postHeader .catList ul li a:hover {
          color: #fff;
          background: #22B3DC; }
.single #cnts .postHeader .tags {
  margin-bottom: 10px; }
  .single #cnts .postHeader .tags .postTag {
    margin: 0;
    padding: 0; }
    .single #cnts .postHeader .tags .postTag li {
      list-style: none;
      display: inline-block;
      margin: 0 15px 5px 0;
      padding: 0;
      border-radius: 25%;
      min-height: 24px;
      text-align: center; }
      .single #cnts .postHeader .tags .postTag li:before {
        display: none; }
      .single #cnts .postHeader .tags .postTag li a {
        display: block;
        width: 100%;
        height: auto;
        font-size: 10px;
        color: #333;
        background: #F9F8F2;
        border-radius: 24px;
        padding: 2px 15px;
        text-decoration: none; }
        .single #cnts .postHeader .tags .postTag li a:hover {
          background: #22B3DC;
          color: #fff; }
.single #cnts #postCnt .thumbnail {
  display: block;
  margin: 10px 0 20px; }
  .single #cnts #postCnt .thumbnail a {
    position: relative;
    width: 100%;
    overflow: hidden; }
    .single #cnts #postCnt .thumbnail a:before {
      content: "";
      display: block;
      padding-top: 60%; }
    .single #cnts #postCnt .thumbnail a img {
      width: 100%;
      height: auto;
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0; }
.single #cnts #adsenseArea {
  margin: 15px 0 15px; }
  .single #cnts #adsenseArea .adsenseBoxWrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    .single #cnts #adsenseArea .adsenseBoxWrap .adsenseBox {
      flex-basis: 100%;
      width: 100%;
      margin-bottom: 15px; }
      .single #cnts #adsenseArea .adsenseBoxWrap .adsenseBox a {
        display: block; }
      .single #cnts #adsenseArea .adsenseBoxWrap .adsenseBox img {
        display: inherit !important;
        margin: 0 !important; }
.single #cnts .cTitle {
  background: none;
  height: auto;
  color: #222;
  font-size: 20px;
  margin: 0; }
  .single #cnts .cTitle:before {
    display: none; }
  .single #cnts .cTitle i {
    font-size: 28px;
    margin-right: 20px;
    color: #22B3DC; }
.single #cnts .companyInfo {
  margin: 30px 0; }
  .single #cnts .companyInfo table {
    margin-bottom: 0; }
.single #cnts #relatedArticle {
  background: #EFEFEF;
  padding: 30px 15px 15px;
  margin: 30px -15px 30px -15px; }
  .single #cnts #relatedArticle h2 {
    background: none;
    color: #222;
    border-bottom: 1px solid #22B3DC;
    font-size: 18px;
    height: auto;
    min-height: inherit;
    padding: 0 0 5px;
    margin-bottom: 15px; }
    .single #cnts #relatedArticle h2:before {
      display: none; }
  .single #cnts #relatedArticle .relatedBoxWrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    .single #cnts #relatedArticle .relatedBoxWrap .relatedBox {
      flex-basis: 48%;
      width: 48%;
      margin-bottom: 15px; }
      .single #cnts #relatedArticle .relatedBoxWrap .relatedBox .thumbnail a {
        position: relative;
        width: 100%;
        display: block;
        overflow: hidden; }
        .single #cnts #relatedArticle .relatedBoxWrap .relatedBox .thumbnail a:before {
          content: "";
          display: block;
          padding-top: 60%; }
        .single #cnts #relatedArticle .relatedBoxWrap .relatedBox .thumbnail a img {
          width: 100%;
          height: auto;
          display: block;
          position: absolute;
          top: 0;
          left: 0;
          bottom: 0;
          right: 0; }
      .single #cnts #relatedArticle .relatedBoxWrap .relatedBox .relatedCnt .permaLinkWrap a {
        font-weight: bold;
        text-decoration: none;
        color: inherit; }
        .single #cnts #relatedArticle .relatedBoxWrap .relatedBox .relatedCnt .permaLinkWrap a:hover {
          color: #22B3DC; }
.single #cnts #authorArea {
  border: 1px solid #E6E6E6;
  display: flex;
  flex-wrap: wrap;
  padding: 25px 20px;
  margin: 0 0 20px;
  clear: both; }
  .single #cnts #authorArea .authorThumbnail {
    flex-basis: 100%;
    margin-bottom: 15px; }
    .single #cnts #authorArea .authorThumbnail img {
      width: 160px;
      height: 160px;
      display: block;
      margin: 0 auto; }
  .single #cnts #authorArea .authorCnt .authorName {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 15px; }
    .single #cnts #authorArea .authorCnt .authorName a {
      text-decoration: none;
      color: inherit; }
      .single #cnts #authorArea .authorCnt .authorName a:hover {
        color: #22B3DC; }
  .single #cnts #authorArea .authorCnt p {
    margin-bottom: 0; }
.single #cnts .footerAdsenseBox {
  margin-bottom: 15px; }
@media print, screen and (min-width: 768px) {
  .single #cnts #relatedArticle {
    margin-left: 0;
    margin-right: 0; }
    .single #cnts #relatedArticle .relatedBoxWrap:before {
      content: "";
      display: block;
      width: 23%;
      order: 1; }
    .single #cnts #relatedArticle .relatedBoxWrap:after {
      content: "";
      display: block;
      width: 23%; }
    .single #cnts #relatedArticle .relatedBoxWrap .relatedBox {
      flex-basis: 23%;
      width: 23%; }
  .single #cnts #authorArea {
    flex-wrap: nowrap;
    margin: 40px 0 20px; }
    .single #cnts #authorArea .authorThumbnail {
      margin: 0;
      flex: 1 0 180px;
      width: 180px; }
      .single #cnts #authorArea .authorThumbnail img {
        margin: 0; }
    .single #cnts #authorArea .authorCnt {
      flex-basis: 100%; }
      .single #cnts #authorArea .authorCnt .authorName {
        text-align: left; } }
@media print, screen and (min-width: 992px) {
  .single #cnts #relatedArticle .relatedBoxWrap:before {
    display: none; }
  .single #cnts #relatedArticle .relatedBoxWrap:after {
    content: "";
    display: block;
    width: 23%; }
  .single #cnts #relatedArticle .relatedBoxWrap .relatedBox {
    flex-basis: 31%;
    width: 31%; }
  .single #cnts #adsenseArea .adsenseBoxWrap .adsenseBox {
    flex-basis: 48%;
    width: 48%; } }
@media print, screen and (min-width: 1200px) {
  .single #cnts #relatedArticle .relatedBoxWrap:before {
    content: "";
    display: block;
    width: 23%;
    order: 1; }
  .single #cnts #relatedArticle .relatedBoxWrap:after {
    content: "";
    display: block;
    width: 23%; }
  .single #cnts #relatedArticle .relatedBoxWrap .relatedBox {
    flex-basis: 23%;
    width: 23%; } }

/*ページ */
.page #cnts > h1 {
  margin-bottom: 30px; }

/* ---------------------------------------------------------------- */
/* コメント */
/* ---------------------------------------------------------------- */
#comments {
  margin-top: 50px; }
  #comments .fb-comments {
    width: 100%; }
    #comments .fb-comments span,
    #comments .fb-comments iframe,
    #comments .fb-comments #u_0_0 {
      width: 100% !important; }
    #comments .fb-comments ._pup {
      color: #4b4f56;
      font-size: 14px; }
    #comments .fb-comments ._491z ._33ki {
      font-size: 14px; }

/* ---------------------------------------------------------------- */
/* 検索 */
/* ---------------------------------------------------------------- */
#searchPage #searchArea {
  margin-top: 30px;
  flex-basis: 100%;
  padding: 15px;
  background: #22B3DC; }
  #searchPage #searchArea #searchForm {
    display: flex;
    flex-wrap: wrap; }
    #searchPage #searchArea #searchForm p {
      color: #fff;
      margin: 0 0 10px;
      font-size: 14px; }
    #searchPage #searchArea #searchForm form {
      display: flex;
      flex-wrap: wrap;
      width: 100%;
      margin: 0; }
      #searchPage #searchArea #searchForm form .selectCustom {
        flex-basis: 100%;
        position: relative;
        margin-bottom: 15px; }
        #searchPage #searchArea #searchForm form .selectCustom:after {
          position: absolute;
          top: calc( 50% - 3px );
          right: 4px;
          width: 0;
          height: 0;
          padding: 0;
          content: '';
          border-left: 6px solid transparent;
          border-right: 6px solid transparent;
          border-top: 6px solid #22B3DC;
          pointer-events: none; }
        #searchPage #searchArea #searchForm form .selectCustom select {
          width: 100%;
          cursor: pointer;
          text-indent: 0.01px;
          text-overflow: ellipsis;
          outline: none;
          background: transparent;
          background-image: none;
          box-shadow: none;
          -webkit-appearance: none;
          appearance: none;
          border-radius: 4px;
          padding-left: 15px;
          border: none;
          height: 60px;
          font-size: 14px;
          background: #fff; }
          #searchPage #searchArea #searchForm form .selectCustom select option {
            font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }
          #searchPage #searchArea #searchForm form .selectCustom select::-ms-expand {
            display: none; }
      #searchPage #searchArea #searchForm form input[type="text"] {
        padding-left: 15px;
        flex-basis: 100%;
        border: none;
        border-left: 1px solid #E6E6E6;
        font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
        border-radius: 4px;
        height: 60px;
        margin-bottom: 15px;
        font-size: 14px; }
      #searchPage #searchArea #searchForm form input[type="submit"] {
        flex-basis: 100%;
        font-family: FontAwesome;
        background: none;
        border: none;
        font-size: 32px;
        color: #fff;
        height: 60px;
        border-radius: 4px;
        border: 1px solid #22B3DC;
        transition: .3s ease; }
        #searchPage #searchArea #searchForm form input[type="submit"]:hover {
          cursor: pointer;
          background: #fff;
          color: #22B3DC; }
@media print, screen and (min-width: 768px) {
  #searchPage #searchArea {
    padding: 5px 0 5px 15px; }
    #searchPage #searchArea #searchForm {
      flex-wrap: nowrap; }
      #searchPage #searchArea #searchForm p {
        margin: 18px 0 10px 0;
        flex-basis: 190px; }
      #searchPage #searchArea #searchForm form {
        flex-wrap: nowrap;
        justify-content: space-between; }
        #searchPage #searchArea #searchForm form .selectCustom {
          flex-basis: 30%;
          margin-bottom: 0; }
          #searchPage #searchArea #searchForm form .selectCustom select {
            border-radius: 4px 0 0 4px;
            margin: 3px 0 0 0;
            height: 54px; }
        #searchPage #searchArea #searchForm form input[type="text"] {
          flex-basis: auto;
          flex-grow: 2;
          border-radius: 0px 4px 4px 0px;
          margin: 3px 0 0 0;
          height: 54px; }
        #searchPage #searchArea #searchForm form input[type="submit"] {
          flex-basis: 60px; } }

/* ---------------------------------------------------------------- */
/* 投稿者ページ */
/* ---------------------------------------------------------------- */
#authorPage #authorArea {
  border: 1px solid #E6E6E6;
  display: flex;
  flex-wrap: wrap;
  padding: 25px 20px;
  margin: 0 0 50px; }
  #authorPage #authorArea .authorThumbnail {
    flex-basis: 100%;
    margin-bottom: 15px; }
    #authorPage #authorArea .authorThumbnail img {
      width: 160px;
      height: 160px;
      display: block;
      margin: 0 auto; }
  #authorPage #authorArea .authorCnt .authorName {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 15px; }
    #authorPage #authorArea .authorCnt .authorName a {
      pointer-events: none;
      text-decoration: none;
      color: #222; }
  #authorPage #authorArea .authorCnt p {
    margin-bottom: 0; }
    #authorPage #authorArea .authorCnt p a {
      text-decoration: underline;
      color: #22B3DC; }
      #authorPage #authorArea .authorCnt p a:hover {
        text-decoration: none; }
@media print, screen and (min-width: 768px) {
  #authorPage #authorArea {
    flex-wrap: nowrap;
    margin: 40px 0 50px; }
    #authorPage #authorArea .authorThumbnail {
      margin: 0;
      flex: 1 0 180px; }
      #authorPage #authorArea .authorThumbnail img {
        margin: 0; }
    #authorPage #authorArea .authorCnt {
      flex-basis: 100%; }
      #authorPage #authorArea .authorCnt .authorName {
        text-align: left; } }

/* ---------------------------------------------------------------- */
/* 沖縄REPEATとは? */
/* ---------------------------------------------------------------- */
#whatPage #cnts .read img {
  max-width: 390px;
  height: auto;
  margin: 0 auto 15px;
  display: block; }
#whatPage #cnts .read .readText {
  color: #22B3DC;
  font-size: 22px;
  font-weight: bold;
  background: none;
  text-align: center;
  margin: 0 0 30px;
  padding: 0;
  line-height: 1.6; }
  #whatPage #cnts .read .readText:before {
    display: none; }

/* ---------------------------------------------------------------- */
/* 予約一覧 */
/* ---------------------------------------------------------------- */
#reservePage #cnts .reserveCatArea .reserveBox {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 15px; }
  #reservePage #cnts .reserveCatArea .reserveBox .reserveName {
    font-size: 20px;
    font-weight: bold;
    flex-basis: 100%;
    width: 100%; }
    #reservePage #cnts .reserveCatArea .reserveBox .reserveName p {
      margin: 0; }
  #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap {
    flex-basis: 100%;
    width: 100%;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    text-align: center; }
    #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .articleLink {
      flex-basis: 50%;
      width: 50%;
      height: 50px; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .articleLink .noLink {
        margin: 0;
        padding: 14px 0 0 0;
        text-align: center;
        color: #EFEFEF;
        border: 1px solid #EFEFEF;
        width: 100%;
        height: 100%;
        background: none; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .articleLink a {
        width: 100%;
        height: 100%;
        padding: 14px 0 0 0;
        display: block;
        text-decoration: none;
        color: #fff;
        position: relative;
        background: #6F91C0;
        border: 1px solid #6F91C0; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .articleLink a:after {
          position: absolute;
          align-items: center;
          border: none;
          content: "\f105";
          font-family: FontAwesome;
          transform: none;
          right: 15px;
          font-size: 20px;
          border-radius: 0;
          top: 50%;
          margin-top: -16px; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .articleLink a:hover {
          background: #fff;
          color: #6F91C0; }
    #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink {
      flex-basis: 50%;
      width: 50%;
      height: 50px; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink .noLink {
        margin: 0;
        padding: 14px 0 0 0;
        text-align: center;
        color: #EFEFEF;
        border: 1px solid #EFEFEF;
        width: 100%;
        height: 100%;
        background: none; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink a {
        width: 100%;
        height: 100%;
        padding: 14px 0 0 0;
        display: block;
        text-decoration: none;
        color: #fff;
        position: relative;
        background: #F58058;
        border: 1px solid #F58058; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink a:after {
          position: absolute;
          align-items: center;
          border: none;
          content: "\f105";
          font-family: FontAwesome;
          transform: none;
          right: 15px;
          font-size: 20px;
          border-radius: 0;
          top: 50%;
          margin-top: -16px; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink a:before {
          content: '\f08e';
          position: absolute;
          display: block;
          font: 14px/1 FontAwesome;
          left: 10px;
          top: 19px; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap .reserveLink a:hover {
          background: #fff;
          color: #F58058; }
@media print, screen and (min-width: 768px) {
  #reservePage #cnts .reserveCatArea {
    margin-bottom: 30px; }
    #reservePage #cnts .reserveCatArea .reserveBox {
      display: flex;
      flex-wrap: nowrap;
      justify-content: center;
      align-items: center;
      margin-bottom: 15px; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveName {
        font-size: 20px;
        font-weight: bold;
        flex-basis: 100%;
        width: 100%; }
        #reservePage #cnts .reserveCatArea .reserveBox .reserveName p {
          margin: 0; }
      #reservePage #cnts .reserveCatArea .reserveBox .reserveLinkWrap {
        flex-basis: 480px;
        width: 480px; } }

/* ---------------------------------------------------------------- */
/* フォーム設定 */
/* ---------------------------------------------------------------- */
/* フォームナビ */
/* ---------------------------- */
#cnts ul.formFlow {
  display: flex;
  height: 40px;
  align-items: center;
  justify-content: center;
  margin: 0 0 30px;
  padding: 0; }
  #cnts ul.formFlow li {
    display: inline-flex;
    justify-content: center;
    flex-basis: 33.333%;
    background: #EEEEEE;
    color: #22B3DC;
    list-style: none;
    padding: 0;
    margin: 0 !important;
    height: 100%;
    font-size: 14px;
    align-items: center;
    position: relative; }
    #cnts ul.formFlow li:before {
      display: none; }
    #cnts ul.formFlow li.active {
      background: #22B3DC;
      color: #fff;
      position: relative; }
      #cnts ul.formFlow li.active:after {
        position: absolute;
        content: '';
        right: -40px;
        top: 0;
        z-index: 1;
        width: 0;
        height: 0;
        border: 20px solid transparent;
        border-left: 20px solid #22B3DC; }
    #cnts ul.formFlow li.second.active:before {
      position: absolute;
      content: '';
      left: 0;
      top: 0;
      z-index: 3;
      width: 0;
      height: 0;
      border: 20px solid transparent;
      border-left: 20px solid #22B3DC; }
    #cnts ul.formFlow li.third.active {
      background: #22B3DC !important;
      color: #fff;
      position: relative; }
      #cnts ul.formFlow li.third.active:after {
        display: none; }
      #cnts ul.formFlow li.third.active:before {
        background: none;
        display: inline;
        position: absolute;
        content: '';
        left: 0;
        top: 0;
        z-index: 2;
        width: 0;
        height: 0;
        border-radius: 0;
        border: 20px solid transparent;
        border-left: 20px solid #EEEEEE; }

/* ---------------------------------------------------------------- */
/* メールマガジン */
/* ---------------------------------------------------------------- */
#mail-magazinePage #cnts form label {
  display: none; }
#mail-magazinePage #cnts form input[type="text"] {
  padding: 8px .5em 8px 10px;
  margin: 0 0 20px;
  background: #EEEEEE;
  width: 100%;
  max-width: 100%;
  min-height: 40px;
  overflow: hidden;
  margin-bottom: 0;
  border: 1px solid #EEEEEE; }
  #mail-magazinePage #cnts form input[type="text"]:focus {
    background: #fff; }
  #mail-magazinePage #cnts form input[type="text"]:hover {
    background: #fff; }
#mail-magazinePage #cnts form input[type="submit"] {
  clear: both;
  display: block;
  text-align: center;
  width: 100%;
  max-width: 290px;
  height: 40px;
  margin: 0 auto;
  padding: 4px 0 0 0;
  font-size: 16px;
  line-height: 1.5;
  font-weight: normal;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  text-decoration: none;
  transition: .3s ease-in;
  user-select: none;
  position: relative;
  border: 1px solid #E6E6E6;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  text-decoration: none !important;
  color: #fff;
  background: #22B3DC;
  border-color: #22B3DC; }
  #mail-magazinePage #cnts form input[type="submit"]:hover, #mail-magazinePage #cnts form input[type="submit"]:focus {
    background: #fff;
    color: #22B3DC !important; }

/* ---------------------------- */
/* フォームエレメント */
/* ---------------------------- */
#formArea dl {
  display: flex;
  flex-wrap: wrap; }
  #formArea dl dt {
    flex-basis: 100%;
    padding: 5px 0 0 0;
    margin-bottom: 15px; }
  #formArea dl dd {
    flex-basis: 100%;
    margin-bottom: 15px;
    align-self: center; }
    #formArea dl dd.fb100 {
      flex-basis: 100%; }
#formArea .att {
  color: crimson;
  font-size: 12px; }
#formArea .error {
  margin: 0; }
#formArea .radio_wrap {
  margin-top: 10px; }
#formArea .vertical-item {
  display: block !important; }
#formArea input[type="text"],
#formArea input[type="email"],
#formArea input[type="number"],
#formArea textarea {
  padding: 8px .5em 8px 10px;
  margin: 0;
  background: #EEEEEE;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  margin-bottom: 0;
  border: 1px solid #EEEEEE; }
  #formArea input[type="text"]:focus,
  #formArea input[type="email"]:focus,
  #formArea input[type="number"]:focus,
  #formArea textarea:focus {
    background: #fff; }
  #formArea input[type="text"]:hover,
  #formArea input[type="email"]:hover,
  #formArea input[type="number"]:hover,
  #formArea textarea:hover {
    background: #fff; }
  #formArea input[type="text"] + input,
  #formArea input[type="email"] + input,
  #formArea input[type="number"] + input,
  #formArea textarea + input {
    margin-top: 10px; }
#formArea input[type="number"].short {
  width: 60px; }
#formArea input[type="text"],
#formArea input[type="email"] {
  width: 100%; }
  #formArea input[type="text"] .short,
  #formArea input[type="email"] .short {
    max-width: 150px; }
#formArea input[type="file"] {
  margin-bottom: 10px; }
#formArea .mwform-tel-field input[type="text"] {
  width: auto; }
#formArea select {
  padding: .4em 0 .3em .5em;
  margin-bottom: 5px;
  display: block;
  border-color: #e7e7e7; }
  #formArea select option {
    word-wrap: normal; }
#formArea input[type="text"].short {
  width: 200px;
  text-align: left;
  margin-bottom: 0; }
#formArea input[type="text"].hasDatepicker {
  margin: 5px 0;
  background: #EEEEEE; }
  #formArea input[type="text"].hasDatepicker:hover, #formArea input[type="text"].hasDatepicker:focus {
    background: #fff; }
#formArea .mwform-radio-field input {
  margin-left: 15px; }
#formArea .mwform-checkbox-field {
  display: block;
  width: 100%;
  margin: 5px 5px;
  font-size: 14px; }
#formArea .mwform-zip-field input {
  width: inherit; }
#formArea input[type="checkbox"] {
  border: 1px solid #aaaaaa;
  vertical-align: -8px;
  -webkit-appearance: none;
  position: relative;
  margin-right: 5px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
  -webkit-box-sizing: border-box;
  width: 26px;
  height: 26px;
  /*Other Browser*/
  background: #e2e2e2;
  /*For Old WebKit*/
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #ffffff), color-stop(1, #e2e2e2));
  /*For Modern Browser*/
  background: linear-gradient(to bottom, #ffffff 0%, #e2e2e2 100%); }
#formArea input[type="checkbox"]:checked {
  /*Other Browser*/
  background: #22B3DC;
  /*For Old WebKit*/
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, #22B3DC), color-stop(1, #22B3DC));
  /*For Modern Browser*/
  background: linear-gradient(to bottom, #22B3DC 0%, #22B3DC 100%);
  border: 1px solid #22B3DC; }
#formArea input[type="checkbox"]:checked:before {
  position: absolute;
  left: 1px;
  top: 16px;
  display: block;
  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
  content: "";
  width: 10px;
  height: 4px;
  background: #ffffff;
  -webkit-transform: rotate(45deg);
  -webkit-transform-origin: right center; }
#formArea input[type="checkbox"]:checked:after {
  display: block;
  position: absolute;
  left: 9px;
  top: 16px;
  content: "";
  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
  width: 16px;
  height: 4px;
  background: #ffffff;
  -webkit-transform: rotate(-53deg);
  -webkit-transform-origin: left center; }
#formArea .mwform-radio-field {
  display: block;
  margin: 5px 0 10px; }
  #formArea .mwform-radio-field input {
    margin: 0; }
#formArea .mwform-radio-field-text {
  margin-left: 10px; }
#formArea .mwform-tel-field input {
  margin: 0 !important; }
#formArea input[type="radio"] {
  position: relative;
  -webkit-appearance: button;
  appearance: button;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  content: "";
  background-color: #FFFFFF;
  border: 1px solid #999999;
  -webkit-border-radius: 24px;
  border-radius: 24px;
  -webkit-box-shadow: inset 4px 4px 10px rgba(0, 0, 0, 0.2);
  box-shadow: inset 4px 4px 10px rgba(0, 0, 0, 0.2);
  vertical-align: middle;
  cursor: pointer; }
#formArea input[type="radio"]:checked:after {
  display: block;
  position: absolute;
  top: 5px;
  left: 5px;
  content: "";
  width: 12px;
  height: 12px;
  background: #00A0E9;
  -webkit-border-radius: 12px;
  border-radius: 12px; }
#formArea .return {
  width: 200px;
  margin: 0 0 15px;
  display: block;
  text-align: center;
  background: #fff;
  border: 1px solid #22B3DC;
  color: #22B3DC;
  padding: .4em 0;
  transition: .3s;
  font-size: 14px; }
  #formArea .return:hover, #formArea .return:focus {
    color: #fff;
    background: #22B3DC;
    transition: .3s; }
#formArea .submit {
  width: 270px;
  margin: 0 auto;
  padding: 4px 0 0 0; }
#formArea .inline_wrap select {
  display: inline-block; }
@media print, screen and (min-width: 768px) {
  #formArea dl {
    justify-content: space-between; }
    #formArea dl dt {
      flex-basis: 250px;
      text-align: right; }
    #formArea dl dd {
      flex-basis: calc(100% - 280px); }
      #formArea dl dd.fb100 {
        flex-basis: 100%; }
  #formArea input[type="text"],
  #formArea input[type="email"],
  #formArea input[type="number"],
  #formArea textarea {
    margin: 0; }
  #formArea select {
    margin-bottom: 0; }
  #formArea .mwform-checkbox-field {
    display: inline-block;
    width: auto; }
  #formArea .mwform-radio-field {
    display: inline-block;
    margin: 0 15px 5px 0; }
    #formArea .mwform-radio-field .mwform-radio-field-text {
      margin-right: 15px; }
    #formArea .mwform-radio-field input {
      margin: 0; }
  #formArea .mwform-radio-field-text {
    margin-left: 10px; } }
