/*
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 {
  margin-right: 2vw;
}
.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;
}

/*天気予報*/
.weather_area br {
  display: none;
}
.weather_container {
  width: 10.5vw;
}
.weather_slider {
  flex-basis: 70%;
}
.weather_date {
  flex-basis: 30%;
}
.weather_flex-container {
  display: flex !important;
  align-items: center;
  justify-content: space-evenly;
}
.weather_area img {
  width: 35px;
  object-fit: contain;
}
.weather_area .max-temp {
  color: #f00;
}
.weather_area .min-temp {
  color: #0061ca;
}
.weather_area .prob-precip {
  font-size: 1vw;
  border:1px solid;
  border-radius: 3px;
  line-height: 1;
  padding:0.2vw 0.3vw;
  background-color: #555;
  color: #fff;
}

.weather_slider {
  display: none;
}

.header_nav {
  margin-left: auto;
  margin-right: 1vw;
  flex-shrink: 0;
}
.header_nav_container {
  display: flex;
  align-items: center;
}
.nav_item {
  margin-right: 1vw;
}

/*ユーザー情報*/
.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;
}
.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;
}


/*-----------------------------------------------固定ページ全体-----------------------------------------------*/
/*狭いコンテンツ*/
.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 {
  bottom: 0;
  left: 0;
}
.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.contents_status {
  top: 0;
  right: 0;
  display: flex;
}

.post_list_label.room_price, .post_list_label.item_price {
  bottom: 0;
  right: 0;
}

.post_list_title a {
  font-size: 1vw;
  text-decoration: none;
}


/*投稿がない場合*/
.no_post {
  font-size: 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%;
}
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: 18%;
}

/*-----------------------------------------------上部広告スライダー-----------------------------------------------*/
.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;
  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;
}

.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;
}

/*範囲検索*/
.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;
  display: flex;
  width: 96%;
  margin: auto;
  justify-content: space-between;
}
.search_container {
  width: 20%;
  transition: all 0.3s;
}
.sticky_wrap {
  position: sticky;
  top: 4.2vw;
}
.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;
}

/*-----------------------------------------------投稿フォーム-----------------------------------------------*/
.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;
}

/*カテゴリー*/
.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;
  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;
}

/*-----------------------------------------------投稿詳細-----------------------------------------------*/
.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;
}

/*-------------------------------------メディアクエリ750以下【SPのみ】-------------------------------------*/
@media only screen and (max-width: 750px) {
	.pc_only {
		display: none !important;
	}
	/*ヘッダー*/
	.header_nav {
		display: none;
	}
	.site-logo {
		width: 16vw;
	}
	.site-title {
		margin-left: 3vw;
	}
	.site-title a {
		font-size: 4vw;
	}
	.main-header-content {
		padding-right: 3vw;
	}
	/*トップページ*/
	.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;
	}
	/*フッター*/
	.footer_contents {
		font-size: 3vw;
	}
}
/*--------------------------------メディアクエリ750以上【タブレット以上】---------------------------------*/
@media only screen and (min-width: 751px) {
	.sp_only {
		display: none !important;
	}
	
}