/*
Theme Name:original
Author:SolabotSchool
Version:1.00-
*/

/*全体設定*/
/*ヘッダー*/
/*フッター*/
/*固定ページ全体*/
/*投稿一覧*/
/*緊急投稿一覧*/
/*自分の投稿一覧*/
/*上部広告スライダー*/
/*左サイドバー詳細検索*/
/*トップページ*/
/*マップ*/
/*緊急投稿フォーム*/
/*投稿詳細*/
/*メッセージ*/
/*投稿者個別の投稿一覧*/
/*会員登録*/
/*プロフィールページ*/
/*お気に入りリスト*/
/*翻訳*/

/*メディアクエリ・ブレイクポイント*/

/*-----------------------------------------------全体設定-----------------------------------------------*/
/* reset */
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
}

ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption,
th {
  text-align: left;
}

q:before,
q:after {
  content: '';
}

object,
embed {
  vertical-align: top;
}

legend {
  display: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
}

img,
abbr,
acronym,
fieldset {
  border: 0;
}

select {
  background: #fff;
  border: 1px solid #777;
  padding: 0.4vw 0.6vw;
  font-size: 1vw;
  font-weight: bold;
}

input,
textarea {
  font-size: 1vw;
}

body {
  overflow-x: hidden;
}

img {
  display: block;
  width: 100%;
  height: auto;
}

/*全体幅*/
*,
*:before,
*:after {
  box-sizing: border-box;
}

#content {
  min-height: 60vh;
}

/*フォント*/
@font-face {
  font-family: "NotoSansJP-Regular";
  src: url("/wp-content/themes/original/fonts/NotoSansJP-Regular.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "NotoSansJP-Regular";
  src: url("/wp-content/themes/original/fonts/NotoSansJP-Medium.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "NotoSansJP-Regular";
  src: url("/wp-content/themes/original/fonts/NotoSansJP-Bold.woff") format("woff");
  font-display: swap;
}

div,
a,
p,
span {
  font-family: "NotoSansJP-Regular";
}

h1,
h2,
h3,
h4,
h5 {
  font-family: "NotoSansJP-Bold";
}

/*カラー　色*/
.red {
  color: #d00;
}

/*hoverで表示*/
.hover_visible:hover {
  overflow: visible;
}

/*-----------------------------------------------ヘッダー-----------------------------------------------*/
#masthead {
  padding: 0.6vw 0;
  position: sticky;
  top: 0;
  z-index: 999;
  background: #fff;
}

.main-header {
  border: 3px solid #45688d;
  width: 96vw;
  margin: auto;
  padding: 0.2vw 0vw;
}

.main-header-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1vw;
}

.site-branding {
  max-width: 20vw;
  overflow: hidden;
}

.site-logo {
  width: 6vw;
}

.site-title {
  margin-left: 0;
}

.site-title a {
  font-size: 1.5vw;
  color: #000;
  text-decoration: none;
}

.site-description {
  font-size: 1vw;
  line-height: 1.2;
}
.site-description a {
  text-decoration: none;
}

/*天気予報*/
.tenki {
  width: 11vw;
  overflow: hidden;
  flex-grow: 1;
}


/*ヘッダー他メニュー*/
.header_nav {
  margin-left: auto;
  margin-right: 1vw;
  flex-shrink: 0;
}

.header_nav_container {
  display: flex;
  align-items: center;
}

.nav_item {
  margin-right: 1vw;
}

/*緊急投稿ボタン*/
.emergency_form_btn {
  background: #000;
  color: #f0e650;
  font-size: 0.9vw;
  text-align: center;
  border: 6px solid red;
  border-radius: 0.2vw;
  cursor: pointer;
}

.emergency_form_btn a {
  text-decoration: none;
  color: #f0e650;
  display: block;
  padding: 0 1vw;
}

.home .emergency_form_btn {
  padding: 0 1vw;
}

.emergency_form_btn .emphasis {
  font-size: 1.3vw;
}

.emergency_form_btn:hover {
  opacity: 0.8;
}

a.js_modal_open.emergency_form_close {
  position: static;
}

.emergency_list_btn a {
  text-decoration: none;
  font-size: 1.2vw;
  background: #000;
  color: #f0e650;
  display: block;
  padding: 0 0.6vw;
  border-radius: 0.3vw;
  border: 3px solid #f0e650;
}

/*ユーザー情報*/
.user_icon {
  width: 3vw;
  margin: auto;
  position: relative;
}

.user_icon img {
  border-radius: 50%;
}

.user_name {
  width: 6vw;
  margin: auto;
  font-size: 0.7vw;
  text-align: center;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.user_name a {
  text-decoration: none;
}

/*未読メッセージ*/
.main-header-content .bp-better-messages-unread {
  position: absolute;
  top: 0;
  right: -5px;
}

/*翻訳*/
.gt_switcher-popup img {
  width: auto;
}

.gtranslate_wrapper {
  display: flex;
  align-items: center;
  height: 100%;
}

/*qr*/
.nav_item.qr {
  width: 3vw;
}

/* Drawer Button */
.drawer-hamburger {
  background-color: transparent;
  box-sizing: content-box;
  display: block;
  margin-right: -5px;
  outline: 0;
  padding: 12px 5px;
  transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  width: 21px;
  min-width: 21px;
  z-index: 102;
  border: 0;
  cursor: pointer;
}

.drawer-hamburger:hover,
.drawer-hamburger:focus {
  background-color: transparent;
}

.drawer-hamburger-icon {
  position: relative;
  display: block;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  background-color: #111;
  height: 2px;
  transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  width: 100%;
}

.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
  position: absolute;
  left: 0;
  content: ' ';
}

.drawer-hamburger-icon:before {
  top: -6px;
}

.drawer-hamburger-icon:after {
  top: 6px;
}

.drawer-opened .drawer-hamburger-icon {
  background-color: transparent;
}

.drawer-opened .drawer-hamburger-icon:before,
.drawer-opened .drawer-hamburger-icon:after {
  top: 0;
}

.drawer-opened .drawer-hamburger-icon:before {
  transform: rotate(45deg);
}

.drawer-opened .drawer-hamburger-icon:after {
  transform: rotate(-45deg);
}

.drawer-opened .drawer-hamburger {
  position: fixed;
  top: 7.4vw;
  right: 3.6vw;
}

/* Drawer Navigation */
.drawer-overlay {
  display: none;
  height: 100vh;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

.drawer-navigation {
  background: #fff;
  height: 100vh;
  overflow-y: auto;
  position: fixed;
  right: 0;
  top: 0;
  transform: translateX(100%);
  transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  width: 22vw;
  z-index: 101;
  -webkit-overflow-scrolling: touch;
  padding: 3vw;
}

.drawer-navigation-content {
  box-sizing: border-box;
  height: 100%;
  overflow-y: auto;
  padding: 60px 75px 60px 40px;
  width: 100%;
}

.drawer-opened .drawer-overlay {
  display: block;
}

.drawer-opened .drawer-navigation {
  box-shadow: 0 0 90px rgba(0, 0, 0, 0.2);
  transform: translateX(0);
}

.drawer-navigation .nav_item {
  margin-right: 1vw;
  margin-bottom: 0.4vw;
}

.drawer-navigation .nav_item a {
  font-size: 1vw;
  text-decoration: none;
}

.drawer-navigation .nav_item a:hover {
  text-decoration: underline;
}

/*ドロワーオープン時スクロール禁止*/
html.overflow_hidden {
  overflow: hidden;
}

.drawer_nav .header_nav_container {
  display: block;
}

/*モーダル関連*/
.modal {
  display: none;
  position: fixed;
  top: 0;
  height: 100vh;
  width: 100%;
  left: 0;
  z-index: 999;
}

.modal_bg {
  position: absolute;
  height: 100vh;
  width: 100%;
  background: rgba(0, 0, 0, 0.8);
}

/* モーダル本体 */
.modal_content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  overflow: scroll;
  /* はみ出た部分はスクロールさせる */
  height: 60%;
  /* これが無いと「overflow:scroll」が利かない */
  width: 60%;
  /* これが無いと「overflow:scroll」が利かない */
  background: white;
  padding: 40px;
}

/* モーダルウィンドウ表示中に記事本体を固定 */
body.fixed {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
}

a.js_modal_close {
  display: block;
  text-align: right;
}

/*-----------------------------------------------フッター-----------------------------------------------*/
/*追尾フッター*/
.fixed_footer {
  position: sticky;
  bottom: 0;
  z-index: 998;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.footer_nav_container {
  display: flex;
  justify-content: space-evenly;
  padding: 1vw;
}

.footer_nav_container .nav_item a {
  text-align: center;
  border: 2px solid #45688d;
  text-decoration: none;
  line-height: 1.2;
  padding: 0.2vw 0.2vw;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer_contents {
  background: #333;
  color: #fff;
  padding: 2vw 0;
  text-align: center;
}

.post_btns {
  display: flex;
  padding: 1vw;
}

.post_btn a {
  text-decoration: none;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 8vw;
  height: 3vw;
  border-radius: 0.3vw;
  box-shadow: 0 3px 1px 0 #999;
}

.post_btn.normal a {
  background: #45688d;
}

.post_btn.map a {
  background: #fff100;
  color: #000;
}

.post_btn a:active {
  transform: translateY(2px);
  box-shadow: 0 1px 1px 0 #999;
}

.post_btn.map {
  margin-right: 1vw;
}


/*-----------------------------------------------固定ページ全体-----------------------------------------------*/
/*狭いコンテンツ*/
.entry-content {
  width: 50vw;
  margin: auto;
  padding: 2vw 0;
}

.entry-title {
  font-size: 1.4vw;
  margin-bottom: 1vw;
}


/*-----------------------------------------------投稿一覧-----------------------------------------------*/
.post_items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.post_items::after {
  content: "";
  width: calc(100% / 3 - 1vw);
  display: block;
}

.post_list_item {
  width: calc(100% / 3 - 1vw);
  position: relative;
  margin-bottom: 2vw;
}

.post_list_item>a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
  display: block;
  height: 100%;
}

.post_list_thumbnail {
  border: 1px solid #ddd;
  position: relative;
}

.post_media_wrap {
  position: relative;
}

.post_media_wrap:before {
  content: "";
  display: block;
  padding-top: 56%;
}

.post_media_wrap img,
.post_media_wrap .wp-video {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*リストアイテムラベル*/
.post_list_label {
  position: absolute;
  z-index: 3;
  border: 2px solid #078ead;
  margin: 0.2vw;
  pointer-events: none;
  background: #fff;
}

.post_list_label a {
  text-decoration: none;
}

.post_list_label.cat a {
  text-decoration: none;
}

.post_list_label,
.post_list_label a {
  font-size: 1vw;
  line-height: 1;
  padding: 0.2vw;
  color: #078ead;
}

.post_list_label.area {
  top: 0;
  left: 0;
  display: flex;
}

.post_list_label.cat_bousai {
  bottom: 0;
  left: 0;
}

.post_list_label.report_date {
  top: 0;
  right: 0;
}

.post_list_label.resolved_status {
  bottom: 0;
  right: 0;
  display: flex;
}

.post_list_title a {
  font-size: 1vw;
  text-decoration: none;
}

.emergency_label {
  font-size: 1vw;
  position: relative;
  display: inline-block;
  text-align: center;
  border-radius: 50%;
  color: #f0e650;
  line-height: 1;
  margin-right: 0.2vw;
}

.emergency_label:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1.6vw;
  height: 1.6vw;
  border: 2px solid #f0e650;
  border-radius: 50%;
  background: #000;
  z-index: -1;
}

/*ページネーション*/
.post_list .page-numbers {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1vw;
}

.post_list a.page-numbers {
  font-size: 1vw;
  text-decoration: none;
  background: ;
}

/*投稿がない場合*/
.no_post {
  font-size: 1vw;
}

/*-----------------------------------------------緊急投稿一覧-----------------------------------------------*/
.page_emergencys_title {
  font-size: 1.6vw;
  border-left: 16px solid #f0e650;
  background: #000;
  color: #f0e650;
  padding: 0.2vw 1vw;
  margin-bottom: 1vw;
}

/*-----------------------------------------------自分の投稿一覧-----------------------------------------------*/
.mypost_table {
  width: 90vw;
  margin: auto;
  table-layout: fixed;
}

.mypost_table tbody tr:nth-child(2n+2) {
  background: #f8fcfe;
}

.mypost_table tbody tr:hover {
  background: #eee;
}

.mypost_table th,
.mypost_table td {
  border: 1px solid #000;
  padding: 1vw;
}

.mypost_table thead th {
  position: sticky;
  z-index: 5;
  top: 10.71vw;
  left: 0;
  border: 1px solid #000;
  border-top: 0;
  border-bottom: 0;
  background: #d1dde5;
  text-align: center;
}

.mypost_table thead th::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #000;
  z-index: 1;
  border-right: 0;
  border-left: 0;
}

.mypost_table tbody tr:first-child td {
  border-top: 0;
}

td.thumbnail {
  width: 15%;
}

.mypost_list_thumbnail.no_image {
  background: #fff;
  border: 1px solid #ddd;
}

td.thumbnail .wp-video-shortcode {
  width: 100% !important;
  max-width: 100%;
  min-width: 100% !important;
  height: 100% !important;
  aspect-ratio: 16 / 12;
}

td.thumbnail .wp-video {
  width: 100% !important;
}

.edit_btns {
  display: flex;
  justify-content: center;
}

.edit_btns span:last-child {
  margin: 0;
}

.edit_btns span {
  margin-right: 1vw;
}

.view_post a:before {
  font-family: "dashicons";
  content: "\f105";
}

.edit_post a:before {
  font-family: "dashicons";
  content: "\f119";
}

.delete_post a:before {
  font-family: "dashicons";
  content: "\f182";
}

th.thumbnail {
  width: 15%;
}

th.date {
  width: 12%;
}

th.title {
  width: auto;
}

th.edit {
  width: 20%;
}

.mypost_table .status {
  width: 16%;
}

.mypost_table .status form {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
}

.mypost_table .status select {
  padding: 5px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.mypost_table .status .save-status-btn {
  padding: 5px 10px;
  background-color: #0073aa;
  color: white;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

.mypost_table .status .save-status-btn:hover {
  background-color: #005177;
}

.mypost_table .status .status-message {
  font-size: 0.8em;
  margin-top: 5px;
  width: 100%;
  position: absolute;
  top: 100%;
}

.mypost_table .status .status-message.success {
  color: green;
}

.mypost_table .status .status-message.error {
  color: red;
}

/*-----------------------------------------------上部広告スライダー-----------------------------------------------*/
.ad_post_slider {
  position: relative;
  width: 96%;
  padding-top: 0.3vw;
  margin: 0 auto 1vw;
}

.ad_post_slider_title {
  font-size: 1.2vw;
  padding-left: 1vw;
  margin-bottom: 0.2vw;
}

.ad_post_slider_hide {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  cursor: pointer;
  font-size: 1vw;
  display: flex;
  align-items: center;
  line-height: 1;
  background: #45688d;
  color: #fff;
  padding: 0.3vw 0.8vw 0.5vw;
}

.ad_post_slider_hide:hover {
  opacity: 0.8;
}

.ad_post_slider_hide svg {
  background: #fff;
  padding: 0.1vw;
  border-radius: 50%;
}

.ad_post_slider_hide span {
  margin-right: 0.3vw;
}

.slide_ad_post .swiper-slide a {
  border: 3px solid #45688d;
  text-decoration: none;
  padding: 0.1vw 0.3vw;
  width: 17.5vw;
  display: block;
  text-align: center;
}

.slide_ad_post .swiper-slide a.red {
  border: 3px solid #d00;
  color: #d00;
}

.ad_post_slider .post_list_item {
  width: 100%;
  margin-bottom: 1vw;
}

.slide_ad_post .swiper-pagination {
  bottom: 0 !important;
}

.slide_ad_post {
  padding: 1vw 2vw !important;
}

.slide_ad_post .swiper-button-prev {
  left: 0;
}

.slide_ad_post .swiper-button-next {
  right: 0;
}

.slide_ad_post .swiper-button-prev::after,
.slide_ad_post .swiper-button-next::after {
  font-size: 0.7vw;
  font-weight: bold;
  color: #fff;
  background: #555;
  border-radius: 50%;
  width: 1.6vw;
  height: 1.6vw;
  display: flex;
  align-items: center;
  justify-content: center;
}


/*-----------------------------------------------左サイドバー詳細検索-----------------------------------------------*/
.filter-title {
  font-size: 1.1vw;
  background: #ddd;
  padding: 0.2vw;
  position: sticky;
  top: 0;
}

.filter-field {
  padding: 0.8vw 0.4vw;
}

.filter-field label {
  display: flex;
  font-size: 1vw;
  margin-bottom: 0.6vw;
  line-height: 1;
}

.filter-field label input {
  margin-right: 0.2vw;
}

/*親子ターム関連*/
.child-terms {
  margin-left: 1vw;
}

.child-terms .child-terms {
  max-height: 50vh;
  overflow-y: auto;
  border: 1px solid #ddd;
  padding: 0.4vw 1vw;
  margin-bottom: 1vw;
}

/*表示・非表示*/
.serach_panel_toggle {
  position: absolute;
  top: 0.4vw;
  left: 0.4vw;
  z-index: 1;
  width: 2vw;
  background: #fff;
  border-radius: 0.2vw;
  cursor: pointer;
  padding: 0.1vw;
}

.serach_panel_toggle:hover {
  opacity: 0.8;
}


.main_container.search_hide {
  position: relative;
}

.main_container.search_hide .post_list {
  width: 100%;
}

.main_container.search_hide .search_container {
  width: 0;
}

.main_container.search_hide .serach_panel_toggle {
  opacity: 0;
}

.main_container.search_hide .serach_panel_toggle.open {
  position: absolute;
  top: 1vw;
  right: 100%;
  left: auto;
  opacity: 1;
  background: #45688d;
  padding: 1.6vw 0.2vw;
  border-radius: 0 0.2vw 0.2vw 0;
}


/*エリア部分*/
.advanced_search .tab_area {
  display: flex;
}

.advanced_search .tab_area>div {
  width: calc(100% /3);
}

.advanced_search .tab,
.advanced_search .tab_map {
  background: #1b334d;
  font-size: 1.1vw;
  padding: 0.2vw;
  color: #fff;
  text-align: center;
  border-bottom: 1px solid #fff;
  cursor: pointer;
}

.advanced_search .tab:last-child {
  border-bottom: 0;
}

.panel {
  display: none;
}

.panel.active {
  display: block;
}

.advanced_search .tab.active {
  background: #45688d;
}

.advanced_search .tab_map a {
  text-decoration: none;
  color: #fff;
}

.advanced_search .tab_map a::before {
  font-family: "dashicons";
  content: "\f105";
}

/*範囲検索*/
.filter-field.flex {
  display: flex;
  justify-content: space-between;
}

.filter-field.flex input {
  width: calc(100% / 2 - 1vw);
}

/*個数*/
.filter-item-quantity .flex input {
  width: 36%;
  text-align: right;
}

.filter-item-quantity .flex select {
  width: 28%;
  font-size: 0.8vw;
}

/*-----------------------------------------------トップページ-----------------------------------------------*/
.main_container {
  padding-top: 1vw;
  padding-bottom: 1vw;
  display: flex;
  width: 96%;
  margin: auto;
  justify-content: space-between;
}

.search_container {
  width: 20%;
  transition: all 0.3s;
}

.sticky_wrap {
  position: sticky;
  top: 13vw;
}

.search_title {
  font-size: 1.3vw;
  background: #45688d;
  color: #fff;
  text-align: center;
  padding: 0.4vw 0;
}

.search_container form {
  max-height: 54vh;
  overflow-y: auto;
}

.main_container .post_list {
  width: 78%;
  transition: all 0.3s;
}

.search_container select {
  width: 100%;
}

.search_container input[type="text"] {
  width: 100%;
  padding: 0.4vw;
}

.filter-submit {
  position: sticky;
  bottom: 0;
  background: #fff;
  border-top: 1px solid #ddd;
  padding-top: 5px !important;
  margin-bottom: 0 !important;
  z-index: 5;
}

.filter-submit button {
  width: 96%;
  background: #45688d;
  display: block;
  font-size: 1vw;
  margin: auto;
  margin-bottom: auto;
  border: 0;
  border-radius: 0.2vw;
  color: #fff;
  padding: 0.4vw 0 0.2vw;
  cursor: pointer;
}

.filter-submit .form_reset {
  margin-bottom: 0.3vw;
  background: #777;
}

.filter-submit button:hover {
  opacity: 0.8;
}

/*緊急投稿ピックアップ*/
.post_items.new_emergencys {
  position: relative;
  padding: 2vw 1vw 2vw;
  border: 3px solid #f0e650;
  margin-bottom: 1vw;
  box-shadow: 0 0 0 3px #000;
  max-height: 20vw;
  overflow-y: auto;
}

.emergencys_title {
  position: absolute;
  top: 0;
  font-size: 1.2vw;
  background: #000;
  color: #f0e650;
  padding: 0 1vw;
}

.new_emergencys .post_list_item {
  margin-bottom: 1vw;
}

.emergencys_more {
  position: absolute;
  bottom: 0.4vw;
  right: 0.4vw;
}

.emergencys_more a {
  text-decoration: none;
  font-size: 1vw;
  background: #000;
  color: #f0e650;
  display: block;
  padding: 0 0.6vw;
  border-radius: 0.3vw;
  border: 3px solid #f0e650;
}

/*非ログインでモザイク*/
.no_login .post_items.new_emergencys .post_list_item {
    filter: blur(3px);
    pointer-events: none;
}

/*リストでも非ログインはモザイク*/
.no_login .post_list_item.emergency_post {
    filter: blur(3px);
    pointer-events: none;
}
/*-----------------------------------------------緊急投稿フォーム-----------------------------------------------*/
.form_hide_contents {
  display: none;
}

#emergency_form {
  position: fixed;
  bottom: 100%;
  left: 0;
  z-index: 999;
  width: 100vw;
  height: 100vh;
  transition: all 0.5s;
}

.emergency_form_bg {
  background: #00000080;
  width: 100%;
  height: 100%;
}

#emergency_form.active {
  bottom: 0;
}

.emergency_form_inner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 60%;
  max-height: 80vh;
  margin: auto;
  background: #fff;
  overflow-y: auto;
  transform: translate(-50%, -50%);
  padding: 2vw 3vw;
}

.emergency_form_bg {
  background: #00000080;
  width: 100%;
  height: 100%;
}

.emergency_form_close {
  position: absolute;
  top: 0.5vw;
  right: 0.5vw;
  cursor: pointer;
}

.emergency_form_close .dashicons {
  width: 2vw;
  height: 2vw;
  font-size: 2vw;
}

.emergency_form_title {
  font-size: 1.6vw;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-bottom: 1vw;
}

.emergency_form_title {
  font-size: 1.6vw;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-bottom: 1vw;
}

.terms_and_conditions label {
  display: flex;
  align-items: center;
}

.terms_and_conditions label input {
  width: auto;
  margin-right: 0.4vw;
}


/*-----------------------------------------------マップ-----------------------------------------------*/
.map_container {
  display: flex;
  justify-content: space-between;
  width: 96vw;
  margin: 0 auto 1vw;
}

.map_main {
  width: 78%;
}

.map_sub {
  width: 20%;
}

.gm-visible-list li {
  display: flex;
  align-items: center;
  font-size: 1vw;
}

.gm-visible-list li img {
  width: 30px;
  margin-right: 0.4vw;
}

.map_contents {
  width: 96vw;
  margin: auto;
}

.gm-visible-list {
  max-height: 31vw;
  overflow: auto;
  border: 1px solid #ddd;
  padding: 1vw;
}

.gm-visible-list li {
  margin-bottom: 0.3vw;
}

.map_selector {
  width: 96vw;
  margin: auto;
}

.map_selector ul {
  display: flex;
  align-items: center;
  gap: 0.6vw;
  border: 2px solid #ddd;
  margin-bottom: 0.6vw;
  padding: 0.3vw 1vw;
}

.map_selector ul li {
  display: flex;
  align-items: center;
  justify-content: center;
}


/*-----------------------------------------------投稿フォーム-----------------------------------------------*/
/*フォーム共通　メインカテゴリー非表示*/
.wpuf-el.main_cat {
  display: none;
}

.wpuf-label {
  font-size: 1vw;
}

.wpuf-fields select {
  background: #fff;
  border: 1px solid #777;
  padding: 0.4vw 0.6vw;
  font-size: 1vw;
}

.wpuf-fields input,
.wpuf-fields textarea {
  font-size: 1vw;
  padding: 0.4vw 0.6vw;
  width: 100%;
}

.wpuf-submit-button {
  font-size: 1.2vw;
  padding: 0.8vw 5vw;
  font-weight: bold;
  background: #222;
  color: #fff;
  border: 0;
  border-radius: 0.4vw;
  line-height: 1;
  cursor: pointer;
  transition: all 0.3s;
}

.wpuf-submit-button:hover {
  opacity: 0.8;
}

body ul.wpuf-form li .wpuf-fields .wpuf-help {
  font-style: normal;
  color: #d00;
  font-weight: bold;
}

body ul.wpuf-form li .wpuf-fields .wpuf-help {
  font-size: 100% !important;
  font-style: normal !important;
}

/*カテゴリー*/
.selectit {
  display: flex;
  align-items: center;
}

.selectit input {
  width: auto;
  margin-right: 0.4vw;
}

/*第一階層*/
.cat_life .wpuf-fields>ul.wpuf-category-checklist,
.contents_type .wpuf-fields>ul.wpuf-category-checklist,
.area .wpuf-fields>ul.wpuf-category-checklist {
  border: 1px solid #ddd;
  max-height: 20vw;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0.5vw 0.8vw !important;
}

/*第二階層*/
.cat_life .wpuf-fields>ul>li>.children,
.contents_type .wpuf-fields>ul>li>.children,
.area .wpuf-fields>ul>li>.children {
  border: 1px solid #ddd;
  max-height: 20vw;
  overflow-y: auto;
  padding: 0.5vw 0.8vw;
}

/*第三階層*/
.cat_life .wpuf-fields>ul>li>.children .children,
.contents_type .wpuf-fields>ul>li>.children .children,
.area .wpuf-fields>ul>li>.children .children {
  border: 1px solid #ddd;
  max-height: 20vw;
  overflow-y: auto;
  padding: 0.5vw 0.8vw;
}

/*空室カレンダー*/
.wpuf-el.vacancy .children .children {
  display: flex;
  width: 100%;
  overflow-x: auto;
}

.wpuf-el.vacancy .children .children li {
  width: 53px;
  display: block;
  flex-shrink: 0;
  border: 1px solid #bbb;
  border-right: 0;
  text-align: center;
}

.wpuf-el.vacancy .children .children li:last-child {
  border-right: 1px solid #bbb;
}

.wpuf-el.vacancy .wpuf-fields>ul>li>label {
  display: flex;
  align-items: center;
  justify-content: start;
}

.wpuf-el.vacancy .wpuf-fields>ul>li>label input,
.wpuf-el.vacancy .wpuf-fields>ul>li>ul>li>label input {
  width: auto;
  margin-right: 1rem;
}

.wpuf-el.vacancy .children {
  max-height: 550px;
  overflow-y: auto;
  border: 1px solid #ddd;
  padding: 1rem;
}

body ul.wpuf-form li .wpuf-fields .wpuf-checkbox-inline {
  width: calc(100% / 2 - 50px);
}

body ul.wpuf-form li.area .wpuf-fields .wpuf-checkbox-inline {
  width: 100%;
}

body ul.wpuf-form li .wpuf-fields .wpuf-checkbox-inline input {
  width: auto;
  margin-right: 0.2rem;
}

/* 初期状態で子リストを非表示にする */
.wpuf-category-checklist ul.children {
  display: none;
}

/*緯度経度エラー*/
.address_error {
  position: absolute;
  bottom: 100%;
  color: #d00;
}

.address_input .wpuf-fields {
  position: relative;
}

.wpuf-el.address {
  display: none;
}

/* ローダーコンテナ */
.address-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  /* 入力欄との間隔 */
  vertical-align: middle;
  height: 20px;
  /* スピナーの高さに合わせる */
  width: 20px;
  position: absolute;
  top: 10px;
  right: 5px;
  z-index: 1;
}

/* スピナー自体 */
.address-loader .spinner {
  border: 3px solid rgba(0, 0, 0, 0.1);
  border-left-color: #333;
  /* またはあなたのブランドカラー */
  border-radius: 50%;
  width: 20px;
  height: 20px;
  animation: spin 1s linear infinite;
  /* アニメーション */
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*利用規約部分*/
body ul.wpuf-form li.wpuf-el._____html_1 .wpuf-fields {
  width: 100%;
  border: 3px solid #777;
  padding: 1vw;
}

/*-----------------------------------------------投稿詳細-----------------------------------------------*/
.entry-header {
  width: 50vw;
  margin: auto;
}

.single .entry-title {
  margin-bottom: 0;
}

/*投稿内詳細*/
.post_h2 {
  font-size: 2vw;
  border-left: 10px solid #45688d;
  margin-bottom: 2vw;
  background: #e6edf4;
  line-height: 1;
  padding: 0.8vw 0 0.4vw 1vw;
}

.single .wp-video {
  margin: auto;
}

.post-thumbnail {
  margin-bottom: 2vw;
}

.entry-title {
  font-size: 1.8vw;
}

.post_images {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.post_images_item {
  width: calc(100% / 2 - 1vw);
  margin-bottom: 2vw;
  position: relative;
}

.post_images_item:before {
  content: "";
  display: block;
  padding-top: 56%;
}

.post_images_item img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.post_detailed_item {
  display: flex;
  border: 1px solid #000;
  border-bottom: 0;
}

.post_detailed_label {
  border-right: 1px solid #000;
  padding: 1.2vw;
  font-size: 1vw;
  background: #eee;
  width: 17vw;
  text-align: center;
}

.post_detailed_field {
  padding: 1.2vw;
  font-size: 1vw;
}

.post_detailed_item:last-child {
  border-bottom: 1px solid #000;
}

.post_detailed {
  margin-bottom: 2vw;
}

.post_main_contents {
  margin-bottom: 8vw;
}

/*投稿者プロフィール*/
.author_info {
  display: flex;
  border: 3px solid #45688d;
  padding: 1vw;
  background: #f7f9fb;
}

.author_profile {
  width: 10vw;
  margin-right: 3vw;
}

.author_icon img {
  border-radius: 50%;
}

.author_name {
  font-size: 1vw;
  text-align: center;
}

.author_name a {
  text-decoration: none;
  color: #45688d;
}

.author_contents {
  flex-grow: 1;
}

.author_icon {
  width: 6vw;
  margin: auto;
}

.author_posts {
  display: flex;
  align-items: center;
  border-bottom: 3px dashed #45688d;
  padding-bottom: 0.4vw;
  margin-bottom: 1vw;
  justify-content: space-between;
}

.author_posts_count {
  margin-right: 1vw;
}

.author_posts_countspan.label {
  font-size: 1vw;
}

.author_posts_count span.label {
  font-size: 1.2vw;
}

span.post_count {
  font-size: 1.8vw;
  margin: 0 0.2vw;
}

.count_suffix {
  font-size: 1.2vw;
}

.send_message {
  width: auto;
  margin-left: auto;
  text-align: right;
  display: flex;
  justify-content: center;
  align-items: center;
}

.send_message .dashicons {
  color: #4a688e;
  font-size: 1.4vw;
}

a.bpbm-pm-button.send_message_link {
  background: transparent !important;
  color: #45688d !important;
  font-size: 1.2vw;
  text-decoration: none;
}

.author_posts_list a {
  background: #45688d;
  border: 0;
  font-size: 1vw;
  font-weight: bold;
  color: #fff;
  padding: 0.4vw 1vw;
  border-radius: 0.3vw;
  cursor: pointer;
  text-decoration: none;
}

.author_posts_list a:hover {
  opacity: 0.8;
}

.need_login {
  text-align: center;
}

.need_login a {
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #4a688e;
}

.need_login span.dashicons {
  margin-right: 0.2vw;
  font-size: 1.2vw;
  display: block;
  width: auto;
  height: auto;
}


/*-----------------------------------------------メッセージ-----------------------------------------------*/
.message_container {
  width: 96vw;
  margin: 0 auto 1vw;
}

/*未ログイン時*/
.message_no_login {
  display: flex;
  justify-content: center;
  align-items: center;
}

/*-----------------------------------------------投稿者個別の投稿一覧-----------------------------------------------*/
.author_post_list {
  width: 50vw;
  margin: auto;
  padding: 2vw 0;
}

.author_post_list h2 {
  font-size: 1.8vw;
  margin-bottom: 1vw;
}

/*ページネーション*/
.pagination {
  display: flex;
  gap: 0.5vw;
  justify-content: center;
}

.pagination li a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  width: 2.2vw;
  height: 2vw;
  line-height: 1;
  color: #fff;
  background: #45688d;
  font-size: 1vw;
  padding-bottom: 0.2vw;
}

.page-numbers.current {
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  width: 2.2vw;
  height: 2vw;
  line-height: 1;
  color: #fff;
  background: #bdc4cd;
  font-size: 1vw;
  padding-bottom: 0.2vw;
}

.pagination li a:hover {
  opacity: 0.8;
}

.page-numbers.dots {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}


/*-----------------------------------------------会員登録-----------------------------------------------*/
/*全体*/
.um-page-register .entry-content {
  width: 90vw;
}

.um-row.private,
.um-row.public {
  width: 45%;
  display: inline-block;
  vertical-align: top;
}

.um-row.register_form_sepalate {
  width: 5%;
  display: inline-block;
}

/*公開非公開範囲*/
span.um-req:before {
  content: "必須";
  color: #d00;
}

.profile_edit_label {
  font-size: 1.6vw;
  color: #fff;
  text-align: center;
}

.um-row.private .profile_edit_label {
  background: #d00;
}

.um-row.public .profile_edit_label {
  background: #81d742;
}

.um-row.private .profile_edit_caption {
  color: #d00;
}

.um-row.public .profile_edit_caption {
  color: #81d742;
}


/*プライバシー関連*/
.um-field-type_terms_conditions {
  text-align: center;
}

.um-field-type_terms_conditions .um-field-checkbox {
  display: flex !important;
  justify-content: center;
}

.um-field-type_terms_conditions .um-field-checkbox-state {
  position: static;
}

.um-field-type_terms_conditions .um-field-checkbox-option {
  margin: 0;
}


.um-field-type_terms_conditions .um-field-area:first-child .um-gdpr-content {
  border: 1px solid #ddd;
  padding: 1vw;
  max-width: 50%;
  margin: auto;
  max-height: 500px;
  overflow-y: auto;
}

.um-field-type_terms_conditions p {
  text-align: left;
  margin-bottom: 1.6rem;
}

.um-field-type_terms_conditions h2 {
  text-align: left;
  font-size: 1.2vw;
  margin-bottom: 5px;
}

/*-----------------------------------------------プロフィールページ-----------------------------------------------*/
.user a.bpbm-pm-button.send_message_link {
  background: #45688d !important;
  color:   #fff !important;
  font-size: 1vw;
  text-decoration: none;
  border-radius: 0.4vw;
  display: flex !important;
  justify-content: center;
  margin-top: 2vw;
  box-shadow: 0 3px 1px 0 #333;
}

/*-----------------------------------------------お気に入りリスト-----------------------------------------------*/
.favorites_ul {
  margin: 2vw 0;
}
.favorites_li * {
  display: inline-block;
  vertical-align: middle;
}
.favorites_li a:first-child {
  width: 10vw;
  margin-right: 2vw;
}
.favorites_li a:nth-child(2) {
  width: 30vw;
  margin-right: auto;
}
.favorites_li button {
  width: auto;
  margin-left: auto;
}

/*-----------------------------------------------翻訳-----------------------------------------------*/
.gt_white_content a img {
  width: auto;
}

/*-------------------------------------メディアクエリ750以下【SPのみ】-------------------------------------*/
@media only screen and (max-width: 750px) {
  .pc_only {
    display: none !important;
  }
  /*全体*/
  #content {
    min-height: 80vh;
  }
  select {
    font-size: 4vw;
  }
  /*ヘッダー*/
  .header_nav {
    display: none;
  }

  .site-branding {
    max-width: 100%;
  }

  .site-title a {
    font-size: 5vw;
  }
  .site-description {
    font-size: 4vw;
  }

  .main-header-content {
    padding-right: 3vw;
  }

  /*翻訳*/
  a.glink.gt_switcher-popup span {
    font-size: 10px !important;
  }

  /*ドロワーメニュー*/
  .drawer-navigation {
		width: 50vw;
		padding: 16vw 6vw;
	}
	.drawer-navigation .nav_item a {
		font-size: 4.2vw;
	}
	.drawer-navigation .nav_item {
		margin-bottom: 3vw;
	}

  /*上部広告*/
  .slide_ad_post .swiper-slide a {
    width: auto;
    font-size: 4.2vw;
  }
  .slide_ad_post .swiper-wrapper {
    height: 100% !important;
  }

  .slide_ad_post {
    padding-top: 6vw !important;
  }

  .slide_ad_post .swiper-button-prev,
  .slide_ad_post .swiper-button-next {
    display: none;
  }

  .slide_ad_post .swiper-pagination {
    bottom: auto !important;
    top: -4px;
  }

  .ad_post_slider_hide {
    font-size: 4vw;
    padding: 0.5vw 1.2vw 0.7vw;
  }

  .ad_post_slider_hide svg {
    width: 4vw !important;
    height: 4vw !important;
  }

  .ad_post_slider_hide span {
    margin-right: 1vw;
  }

  /*検索*/
	.search_container {
		position: absolute;
		top: 0;
		left: -100%;
		z-index: 999;
		width: 85%;
		height: 100%;
		background: #fffffff0;
		border-right: 2px solid #ddd;
    position: fixed;
	}
  .search_container.opened {
    left: 0;
  }
	.serach_panel_toggle.open {
		display: none;
	}
  .search_container form {
		max-height: 94dvh;
	}
	.serach_panel_toggle.close {
		display: none;
	}
	.search_title {
		font-size: 4.2vw;
		padding: 2vw;
	}
	.filter-title {
		font-size: 3.4vw;
		text-align: center;
	}
	.filter-field {
		padding: 3vw;
	}
	.filter-field label {
		font-size: 3.4vw;
		margin-bottom: 2vw;
	}
	.advanced_search .tab, .advanced_search .tab_map {
		font-size: 4vw;
		padding: 1vw 0.2vw;
	}
	.filter-field label input {
		margin-right: 1vw;
	}
	input, textarea {
		font-size: 4vw;
		padding: 1vw;
	}
	.contents_date .filter-field {
		display: flex;
		justify-content: space-around;
	}
	.filter-submit button {
		font-size: 4vw;
		padding: 1vw;
	}
	.filter-submit .form_reset {
		margin-bottom: 2vw;
	}
  /*緊急投稿ボタン*/
  .emergency_form_btns {
		display: flex;
		margin: 1vw;
	}
	.emergency_list_btn {
		flex-grow: 1;
	}
	.emergency_list_btn a {
		font-size: 3.4vw;
		text-align: center;
		height: 100%;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.emergency_form_btn .emphasis {
		font-size: 4vw;
	}
	.emergency_form_btn {
		font-size: 3vw;
	}
  .new_emergencys .post_list_item {
    margin-bottom: 3vw;
  }
  /*緊急投稿フォーム*/
  .emergency_form_inner {
		width: 85%;
		max-height: 80dvh;
	}
	.emergency_form_title {
		font-size: 5vw;
	}
	.wpuf-label {
		font-size: 4vw;
		margin-bottom: 2vw;
	}
	.wpuf-fields input, .wpuf-fields textarea {
		font-size: 4vw;
	}
	.wpuf-fields select {
		font-size: 4vw;
	}
	.cat_life .wpuf-fields>ul.wpuf-category-checklist, .contents_type .wpuf-fields>ul.wpuf-category-checklist, .area .wpuf-fields>ul.wpuf-category-checklist {
		max-height: 50vw;
	}
	.cat_life .wpuf-fields>ul>li>.children, .contents_type .wpuf-fields>ul>li>.children, .area .wpuf-fields>ul>li>.children {
		max-height: 50vw;
	}
	.cat_life .wpuf-fields>ul>li>.children .children, .contents_type .wpuf-fields>ul>li>.children .children, .area .wpuf-fields>ul>li>.children .children {
		max-height: 50vw;
	}
	.terms_and_conditions label {
		font-size: 3.4vw;
	}
	.wpuf-el._____html, .wpuf-el._____html_2 {
		width: 0;
		height: 0;
		padding: 0;
		margin: 0;
	}
	.terms_and_conditions .wpuf-label, .wpuf-submit .wpuf-label {
		display: none;
	}
	.wpuf-submit-button {
		font-size: 4vw;
		width: 100%;
		padding: 3vw;
		border-radius: 1vw;
	}
	/*緊急投稿リスト*/
	.main_container .post_list {
		width: 100%;
	}
	.emergencys_title {
		font-size: 4vw;
		z-index: 9;
	}
	.post_items.new_emergencys {
		padding: 7vw 2vw 3vw;
		margin-bottom: 4vw;
    max-height: 230px;
    overflow-y: auto;
	}
  .emergencys_more a {
    font-size: 4vw;
  }
  .emergencys_more {
    display: none;
  }
  /*検索トグル*/
  .serach_toggle_sp {
		position: fixed;
		top: calc(50% + 0vw);
		right: 0;
		z-index: 998;
		transform: translateY(-50%);
		width: 10vw;
		background: #d00;
		color: #fff;
		padding: 2vw;
		border-radius: 2vw 0 0 2vw;
		cursor: pointer;
		writing-mode: rl;
		line-height: 1.1;
		font-size: 4.2vw;
		text-align: center;
	}
	/*投稿リスト*/
	.post_list_item {
		width: calc(100% / 2 - 1vw);
    margin-bottom: 4vw;
	}
	.post_list_label, .post_list_label a {
		font-size: 3.5vw;
	}
	.post_list_date {
		font-size: 3.5vw;
	}
	.emergency_label {
		font-size: 4vw;
		margin-right: 1vw;
	}
	.emergency_label::before {
		width: 7vw;
		height: 7vw;
	}
	.post_list_title a {
		font-size: 4vw;
	}

  /*トップページ*/
  .slide_fv .slide_image_wrap::before {
    padding-top: 100%;
  }

  .about_container {
    padding: 12vw 6vw;
  }

  .home_h2 {
    font-size: 6vw;
  }

  .about_contents {
    flex-direction: column-reverse;
  }

  .about_text {
    width: 100%;
    font-size: 4vw;
  }

  .about_image {
    width: 100%;
    margin-bottom: 3vw;
  }
  /*投稿詳細*/
  .entry-content {
		width: 95vw;
	}
	.entry-title {
		font-size: 5vw;
	}
  /*フッター*/
  .footer_contents {
    font-size: 3vw;
  }
  /*フッター追尾メニュー*/
	.footer_nav_container .nav_item {
		width: auto;
		flex-shrink: 0;
	}
	.footer_nav_container {
		max-width: 79vw;
		overflow: auto;
	}
	.footer_nav {
		position: relative;
	}
	.footer_nav:before {
		content: "←　→";
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
		width: auto;
		height: 5vw;
		background: #333;
		border-radius: 1vw;
		display: flex;
		justify-content: center;
		align-items: center;
		color: #fff;
		font-weight: bold;
		padding-bottom: 3px;
		padding: 0 1.2vw 3px;
		opacity: 0.8;
    pointer-events: none;
    animation-name: anim_h;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
    animation-duration: 1.5s;
	}
  @keyframes anim_h {
    0% {
      transform: translate(0px, -50%);
    }
    100% {
      transform: translate(10px,  -50%);
    }
  }
	.footer_nav.arrow_hide:before {
		display: none;
	}
  .fixed_footer {
		padding: 0 2vw;
	}
	.post_btns {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		justify-content: space-between;
		transition: all 0.3s;
		z-index: -1;
		opacity: 0;
    background: #ffffffc9;
	}
	.post_btn {
		width: calc(100% / 2 - 1vw);
	}
	.post_btn a {
		width: 100%;
		height: auto;
		padding: 2vw 0;
		border-radius: 1vw;
	}
	.post_btn_sp {
		font-size: 4.6vw;
		background: #45688d;
		color: #fff;
		padding: 2vw;
		border-radius: 1vw;
    cursor: pointer;
	}
	.post_btns.active {
		bottom: 100%;
		z-index: 1;
		opacity: 1;
	}
  /*投稿詳細*/
	.entry-header {
		width: 95vw;
		margin: auto;
	}
	.simplefavorite-button {
		margin-bottom: 5vw;
	}
	.post_detailed {
		margin-bottom: 5vw;
	}
	.post_h2 {
		font-size: 5vw;
		padding: 3vw;
	}
	.post_detailed_label {
		font-size: 3.8vw;
		width: 38vw;
	}
	.post_detailed_field {
		font-size: 3.8vw;
	}
	.author_info {
		display: block;
		padding: 5vw;
	}
	.author_profile {
		width: 100%;
		margin: 0;
	}
	.author_icon {
		width: 40%;
	}
	.author_name {
		font-size: 4vw;
	}
	.author_posts_count span.label {
		font-size: 4vw;
	}
	span.post_count {
		font-size: 6vw;
	}
	.count_suffix {
		font-size: 4vw;
	}
	.author_posts_list a {
		font-size: 4vw;
		border-radius: 1vw;
		padding: 2vw;
	}
	.author_posts {
		display: block;
		margin-bottom: 3vw;
		padding-bottom: 4vw;
	}
	.need_login {
		text-align: left;
	}
	.need_login span.dashicons {
		font-size: 8vw;
		margin-right: 3vw;
	}
	.need_login a {
		font-size: 4vw;
	}
	.author_posts_list {
		text-align: center;
	}
	.author_posts_count {
		margin: 0 0 2vw;
		text-align: center;
	}
  .user a.bpbm-pm-button.send_message_link {
    font-size: 4vw;
    border-radius: 1.8vw;
  }
  /*自分の投稿*/
  .mypost_table {
		width: 96vw;
		width: 100%;
		table-layout: auto;
		border-collapse: separate;
	}
	.table_wrap {
		overflow: auto;
		display: block;
		width: 96vw;
		margin: auto;
	}
	.mypost_table th, .mypost_table td {
		white-space: nowrap;
	}
	.mypost_table thead th {
		top: 0vw;
	}
	.mypost_table thead th.thumbnail, .mypost_table tbody td.thumbnail {
		z-index: 6;
		position: sticky;
		left: 0;
		top: 0;
	}
	.mypost_table tbody td.thumbnail {
		background: #fff;
	}
	.mypost_table thead th.thumbnail::before, .mypost_table tbody td.thumbnail::before {
		content: "";
		display: block;
		/*! border: 1px solid #000; */
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
  /*お気に入りリスト*/
	.favorites_li a:first-child {
		width: 30vw;
		margin-bottom: 2vw;
	}
	.simplefavorite-button.preset {
		width: 100%;
	}
	.fav_list_button {
		width: 100%;
	}
  /*マップページ*/
    .gm-visible-list li {
        font-size: 4vw;
    }
    .map_container {
        display: block;
    }
    .map_main {
        width: 100%;
    }
    .gm-map {
        height: 50vh !important;
    }
    .map_sub {
        width: 100%;
        margin-top: 2vw;
    }
}

/*--------------------------------メディアクエリ750以上【タブレット以上】---------------------------------*/
@media only screen and (min-width: 751px) {
  .sp_only {
    display: none !important;
  }

}